@charset "UTF-8";

.step-tbl th,
.step-tbl td > .hdg,
.step-list-order-01 .ms-alert-01,
.step-end > p {
  font-family: "Clarimo UD PE DemiBold", "UD Shin Go Conde90 DB", sans-serif;
  font-weight: bold;
}

/* =========================
 * ステップ用テーブル
 * ========================= */
.step-table-wrapper {
  width: 880px;
  margin: 0 auto;
}

.step-tbl {
  width: 100%;
  border-collapse: collapse;
}

.step-tbl th,
.step-tbl td {
  letter-spacing: -1px;
  text-align: center;
  vertical-align: middle;
  border-collapse: collapse;
  border: 2px solid #dcdcdc;
}

.step-tbl th {
  font-size: 18px;
  color: #333;
  background-color: #f6f6f6;
  padding: 10px;
}

.step-tbl td {
  position: relative;
  padding: 20px 14px;
}

.step-tbl td > .hdg {
  font-size: 16px;
  letter-spacing: 1px;
}

.step-tbl td > .hdg + .image {
  margin-top: 10px;
}

.step-tbl td:last-child {
  padding: 20px 20px 0;
  border-top: 0;
  border-bottom: 0;
}

.step-tbl tr:first-child td:last-child {
  border-top: 2px solid #dcdcdc;
}

.step-tbl tr:last-child td:last-child {
  border-bottom: 2px solid #dcdcdc;
}

.bg-tbl-01 td:last-child {
  background-color: #fff5d3;
}

.bg-tbl-02 td:last-child {
  background: linear-gradient(to bottom, #fff5d3 0%, #fff5d3 50%, #e9f4f1 50%, #e9f4f1 100%);
}

.bg-tbl-02 td:last-child::after {
  background-color: #dcdcdc;
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  content: "";
}

.bg-tbl-03 td:last-child {
  background-color: #e9f4f1;
}

.step-list-order-01 {
  max-width: 540px;
  margin: 0 auto;
  padding-bottom: 45px;
  counter-reset: num;
}

.step-list-order-01 > li {
  text-align: left;
  background-color: #fff;
  position: relative;
  width: 100%;
  padding: 15px;
  counter-increment: none;
}

.step-list-order-01 > li > .content {
  width: 100%;
  margin-top: 10px;
}

.step-list-order-01 > li > .num {
  font-size: 14px;
  line-height: 22px;
  text-align: center;
  white-space: nowrap;
  word-break: keep-all;
  color: #fff;
  background-color: #0b6297;
  position: relative;
  display: inline-block;
  width: 22px;
  height: 22px;
}

.step-list-order-01 > li > .num.icon-pc::after {
  position: absolute;
  bottom: 2px;
  left: 35px;
  display: inline-block;
  content: url("/contents/m-address-change/images/icon_step_num_01.png");
}

.step-list-order-01 > li > .num.icon-mail::after {
  position: absolute;
  bottom: 2px;
  left: 35px;
  display: inline-block;
  content: url("/contents/m-address-change/images/icon_step_num_02.png");
}

.step-list-order-01 > li > .num + .num {
  margin-left: 10px;
}

.step-list-order-01 li + li {
  margin-top: 55px;
}

.step-list-order-01 li + .ms-alert-wrap {
  margin-top: 70px;
}

.step-list-order-01:not(.type-em) > li::after {
  position: absolute;
  right: 0;
  bottom: -40px;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 40px;
  margin: 0 auto;
  content: "";
  border-width: 40px 270px 0 270px;
  border-style: solid;
  border-color: #fff transparent transparent transparent;
}

.step-list-order-01.type-em > li {
  text-align: left;
  background-color: #ffefeb;
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 15px;
  counter-increment: none;
  border: 2px solid #fd7f8f;
}

.step-list-order-01.type-em > li::after {
  position: absolute;
  bottom: -45px;
  left: 1px;
  display: inline-block;
  width: 100%;
  height: 45px;
  content: "";
  border-width: 45px 269px 0 269px;
  border-style: solid;
  border-color: #ffefeb transparent transparent transparent;
}

.step-list-order-01.type-em > li::before {
  position: absolute;
  right: 0;
  bottom: -47px;
  left: 0;
  display: inline-block;
  width: 100%;
  height: 45px;
  margin: 0 auto;
  content: "";
  border-width: 45px 270px 0 270px;
  border-style: solid;
  border-color: #fd7f8f transparent transparent transparent;
}

.step-list-order-01.type-em > li > .content {
  margin: 0;
}

.step-list-order-01 .ms-alert-01 {
  text-align: center;
  color: #fb0020;
  background-color: #ffefeb;
  margin-left: 10px;
  padding: 4px 16px;
  border: 2px solid #fd7f8f;
  border-radius: 20px;
}

.step-end {
  text-align: center;
  background-color: #fff;
  margin-top: 10px;
  margin-bottom: 20px;
  padding: 5px 15px;
  border: 2px solid #01916d;
}

.step-end > p {
  font-size: 24px;
  color: #01916d;
}

/* =========================
 * その他
 * ========================= */
.w-90px {
  width: 90px;
  min-width: 90px;
}

.w-200px {
  width: 200px;
  min-width: 200px;
}

.w-590px {
  width: 590px;
  min-width: 590px;
}
