@charset "UTF-8";
/*
 * 幅定義
 *
 */
/*
 * 色定義
 *
 */
.contents-box h2 {
  font-size: 36px;
  font-weight: bold;
  position: relative;
  margin-bottom: 10px;
}
.contents-box h2::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: -5px;
  width: 60px;
  height: 4px;
  background-color: #e50012;
}
.contents-box img {
  max-width: 100%;
}

.msg {
  font-size: 17px;
  margin-bottom: 30px;
}

.box1 {
  display: flex;
}
.box1 h2 {
  margin-bottom: 30px;
  background-color: #ff5764;
  color: white;
  font-size: 20px;
  font-weight: bold;
  padding: 15px 0 15px 20px;
}
.box1 h2::after {
  width: 0;
  height: 0;
}
.box1 .buttons-pc a {
  text-decoration: none;
  color: #000;
}
.box1 .buttons-pc div {
  position: relative;
  width: 250px;
  padding: 20px 0 20px 20px;
  background-color: #f9f9f9;
  border: 1px solid #fff;
  margin-right: 50px;
}
.box1 .buttons-pc div::after {
  content: "";
  width: 6px;
  height: 6px;
  border: 0px;
  border-top: solid 2px #d1d1d1;
  border-right: solid 2px #d1d1d1;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 20px;
  margin-top: -4px;
}
.box1 .buttons-pc .active {
  font-weight: bold;
  background-color: #fff2f3;
}
.box1 .buttons-pc .active::after {
  content: "";
  width: 6px;
  height: 6px;
  border: 0px;
  border-top: solid 2px #ffced1;
  border-right: solid 2px #ffced1;
  -ms-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  right: 20px;
  margin-top: -4px;
}
.box1 .step > div {
  display: flex;
}
.box1 .step > div > div:nth-child(1) {
  font-size: 15px;
  font-weight: bold;
  color: #e50012;
}
.box1 .step > div > div:nth-child(2) {
  position: relative;
  padding-left: 19px;
  color: white;
  font-size: 14px;
  font-weight: bold;
}
.box1 .step > div > div:nth-child(2)::before {
  border-right: 1px solid #e50012;
  right: 4px;
  content: "　";
  font-size: 2.2em;
  position: absolute;
  z-index: -1;
  height: 100%;
}
.box1 .step > div > div:nth-child(2)::after {
  content: "●";
  font-size: 2.2em;
  top: -0.44em;
  color: #e50012;
  position: absolute;
  left: 9px;
  z-index: -1;
}
.box1 .step > div > div:nth-child(3) {
  margin-left: 50px;
  margin-bottom: 50px;
  font-size: 14px;
}
.box1 .step ul li {
  position: relative;
}
.box1 .step ul li div {
  color: #e50012;
  font-size: 17px;
  font-weight: bold;
  margin-bottom: 5px;
}
.box1 .step ul li::before {
  position: absolute;
  left: -30px;
  content: "－";
  color: #e6e6e6;
}
.box1 .step .first > div:nth-child(2)::before {
  border-right: 1px solid #e50012;
  top: 4px;
  right: 4px;
  content: "　";
  font-size: 2.2em;
  position: absolute;
  z-index: -2;
  height: 100%;
}
.box1 .step .last > div:nth-child(2)::before {
  border-right: 1px solid #e50012;
  right: 4px;
  content: "　";
  font-size: 2.2em;
  position: absolute;
  z-index: -2;
  height: 10px;
}

.buttons-sp {
  display: none;
  width: 100%;
}
.buttons-sp a {
  text-decoration: none;
  color: #000;
}
.buttons-sp a {
  flex-grow: 1;
  display: table-cell;
  text-align: center;
  vertical-align: middle;
  padding-top: 50px;
  padding-bottom: 50px;
  height: 3em;
  position: relative;
}
.buttons-sp a::after {
  content: "";
  width: 6px;
  height: 6px;
  border: 0px;
  border-top: solid 2px #d1d1d1;
  border-right: solid 2px #d1d1d1;
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position: absolute;
  top: 25%;
  left: 48%;
}
.buttons-sp a:not(:first-child) {
  border-left: 1px solid #d1d1d1;
}
.buttons-sp .active {
  background-color: #fff2f3;
}
.buttons-sp .active div {
  font-weight: bold;
}
.buttons-sp .active::after {
  content: "";
  width: 6px;
  height: 6px;
  border: 0px;
  border-top: solid 2px #ffced1;
  border-right: solid 2px #ffced1;
  -ms-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  position: absolute;
  top: 30%;
  left: 48%;
}

/**
 * スマホレスポンシブ対応
 */
@media screen and (max-width: 750px) {
  .buttons-pc {
    display: none;
  }

  .buttons-sp {
    display: table;
  }
}
@media screen and (max-width: 400px) {
  .box1 .step > div > div:nth-child(3) {
    margin-left: 30px;
  }
  .box1 .step ul li::before {
    position: absolute;
    left: -20px;
    content: "－";
    color: #E6E6E6;
  }
}

/*# sourceMappingURL=top.css.map */
