body {
  font-family: "Noto Sans JP", sans-serif;
  color: #212121;
  font-weight: 400;
}

img {
  width: 100%;
}

.header .header-text {
  background-color: #00a0e9;
  font-style: normal;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.5;
  text-align: center;
  padding: 22px 0;
  color: #fff;
}

/* 共通パーツ */
.common-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 320px;
  margin: 0 auto;
  background: linear-gradient(180deg, #ffce33 0%, #ffb42e 100%);
  border-radius: 8px;
  line-height: 2;
  padding: 17px 0;
  font-weight: 700;
  font-size: 18px;
  text-align: center;
  color: #fff;
  border: none;
  cursor: pointer;
  text-decoration: none;
}

.common-btn .text {
  margin-right: 14px;
}

.common-btn > img {
  width: 6px;
}

.main-content {
  margin: 34px auto 29px;
  padding: 0 28px 0 27px;
}

.main-content .main-title {
  margin-bottom: 37px;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 2;
}

.main-form .main-form-row {
  margin-bottom: 27px;
}

.main-form .main-form-row .main-form-label {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
  font-size: 16px;
  font-weight: 700;
  line-height: 2.25;
}

.main-form .main-form-row .main-form-label .required {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 14px;
  background: #fa4040;
  border-radius: 6px;
  width: 46px;
  height: 24px;
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 1;
}

.main-form .main-form-row .main-form-text {
  margin-bottom: 13px;
  color: #757575;
  font-size: 13px;
  line-height: 1.6923;
}

.main-form .main-form-row .main-form-select {
  position: relative;
}

.main-form .main-form-row .main-form-select::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8px 8px 0 8px;
  border-color: #fa4040 transparent transparent transparent;
}

.main-form .main-form-row .main-form-select > select {
  width: 100%;
  border: 2px solid #dddddd;
  border-radius: 8px;
  padding: 7px 0 7px 22px;
  box-sizing: border-box;
  line-height: 2.25;
  -webkit-appearance: none;
  appearance: none;
  color: #212121;
}

.main-form .main-form-row .main-form-radio-label {
  margin-right: 38px;
  font-size: 15px;
}

.main-form .main-form-row .main-form-radio-label > input {
  margin: 0 13px 0 0;
  width: 23px;
  height: 23px;
}

.main-form-error {
  display: none;
  margin-top: 21px;
  color: #fa4040;
  font-size: 16px;
  line-height: 1.375;
}

.main-form-error.active {
  display: block;
}

/* 結果画面 */
.main-result-content {
  margin: 18px auto;
  padding: 0 18px 0 17px;
}

.main-result-title {
  width: 140px;
  margin: 0 auto 32px;
  text-align: center;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.8;
  background: linear-gradient(transparent 65%, #ffedbb 35%);
}

.main-result-content .main-result-pack {
  margin-bottom: 34.5px;
  padding: 20px 30px 14px;
  background: #fffbef;
  border: 3px solid #ffb82f;
  border-radius: 10px;
  box-sizing: border-box;
}

.main-result-content .main-result-pack .main-result-maintenancePack {
  margin-bottom: 17px;
  text-align: center;
  line-height: 1.7;
  font-size: 14px;
  font-weight: 700;
}

.main-result-content .main-result-pack .main-result-maintenancePack > span {
  display: block;
  font-size: 24px;
}

.main-result-content .main-result-pack .main-result-perYear {
  margin-bottom: 25.5px;
  background: #fa4040;
  border-radius: 6px;
  font-size: 18px;
  line-height: 2;
  text-align: center;
  padding: 3.5px 0;
  color: #fff;
  font-weight: 700;
  position: relative;
}

.main-result-content .main-result-pack .main-result-perYear::before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 8.5px 12.99px 0 12.99px;
  border-color: #fa4040 transparent transparent transparent;
}

.main-result-content .main-result-pack .main-result-estimated {
  margin-bottom: 17px;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
}

.main-result-content .main-result-pack .main-result-estimated > span {
  color: #ffb000;
  font-size: 34px;
  font-weight: 700;
}

.main-result-content .main-result-pack .main-result-image {
  margin-bottom: 17px;
}

.main-result-content .main-result-pack .main-result-text {
  font-size: 13px;
  line-height: 1.76923;
}

.main-result-content .main-maintenance {
  margin-bottom: 39px;
}

.main-result-content .main-maintenance .main-title {
  margin-bottom: 28px;
}

.main-result-content .main-maintenance .main-maintenance-contents {
  margin-bottom: 39px;
}

.main-result-content .main-maintenance .main-maintenance-content {
  margin-bottom: 25px;
  padding: 20px 27px;
  border: 3px solid #e4e4e4;
  border-radius: 10px;
  box-sizing: border-box;
}

.main-result-content .main-maintenance .main-maintenance-content:last-child {
  margin-bottom: 0;
}

.main-result-content .main-maintenance .main-maintenance-title {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 700;
}

.main-result-content .main-maintenance .main-maintenance-title > img {
  width: 66px;
  margin-right: 14px;
}

.main-result-content .main-maintenance .main-maintenance-average {
  margin-bottom: 12px;
  background: #ffb000;
  border-radius: 4px;
  font-weight: 700;
  font-size: 15px;
  line-height: 33px;
  text-align: center;
  color: #fff;
}

.main-result-content .main-maintenance .main-maintenance-average > span {
  font-size: 19px;
}

.main-result-content .main-maintenance .main-maintenance-text {
  margin-bottom: 12px;
  font-size: 14px;
  line-height: 1.7142;
}

.main-result-content .main-maintenance .main-maintenance-text > span {
  color: #00a0e9;
}

.main-result-content .main-maintenance .main-maintenance-text:last-child {
  margin-bottom: 0;
}

.main-result-content .main-maintenance-estimated {
  margin-bottom: 23px;
  text-align: center;
}

.main-result-content .main-maintenance-estimated .total-money {
  font-size: 21px;
  line-height: 1.95;
  background: linear-gradient(transparent 70%, #ffedbb 30%);
  width: 290px;
  margin: 0 auto;
  line-height: 46px;
}

.main-result-content .main-maintenance-estimated .average-money {
  font-weight: 700;
  font-size: 21px;
}

.main-result-content .main-maintenance-estimated .average-money > span {
  font-size: 35px;
}

.main-result-content .main-maintenance-estimated .estimated-money {
  background: linear-gradient(transparent 65%, #ffedbb 35%);
  font-size: 18px;
  line-height: 36px;
}

.main-result-content .main-maintenance-estimated .estimated-money > span {
  font-weight: 700;
}

.main-result-content .main-maintenance-image {
  margin-bottom: 42px;
}

.main-result-content .main-maintenance-asterisk {
  padding: 0 10px 42px 10px;
  margin-bottom: 42px;
  border-bottom: 1px solid #f2f2f2;
  font-size: 14px;
  line-height: 1.714;
}

.main-result-content .main-maintenance-asterisk p > a {
  color: #00a0e9;
}

.main-result-content .main-maintenance-asterisk > p:first-child {
  margin-bottom: 25px;
}

.main-result-content .main-maintenance-detail {
  padding: 0 10px;
}

.main-result-content .main-maintenance-detail .detail-title {
  padding-left: 10px;
  margin-bottom: 17px;
  font-size: 15px;
  line-height: 1.53333;
  font-weight: 700;
}

.main-result-content .main-maintenance-detail .detail-text {
  padding: 0 10px;
  margin-bottom: 30px;
  font-size: 14px;
  line-height: 1.71428;
}

.main-result-content .main-maintenance-detail .detail-text > a {
  color: #00a0e9;
}

/* PC */
@media screen and (min-width: 767px) {
  .header .header-text {
    padding: 27px 0;
    font-size: 26px;
  }

  /* 結果画面 */
  .main-content {
    margin: 46px auto 85px;
    max-width: 715px;
    width: 100%;
    padding: 0;
  }

  .main-content .main-title {
    font-size: 22px;
  }

  .main-result-title {
    margin-bottom: 36px;
    font-size: 22px;
    line-height: 1.636363;
  }

  .main-result-content .main-result-pack {
    margin-bottom: 57.5px;
    padding-bottom: 22px;
  }

  .main-result-content .main-result-pack .main-result-perYear {
    width: 350px;
    margin: 0 auto 25.5px;
  }

  .main-result-content .main-result-pack .main-result-image {
    width: 560px;
    margin: 0 auto 17px;
  }

  .main-result-content .main-result-pack .main-result-text {
    text-align: center;
  }

  .main-result-content .main-maintenance .main-title {
    margin-bottom: 57px;
  }

  .main-result-content .main-maintenance .main-maintenance-contents {
    display: flex;
    flex-wrap: wrap;
    gap: 30px 35px;
    margin-bottom: 72px;
  }

  .main-result-content .main-maintenance .main-maintenance-content {
    width: 340px;
    margin-bottom: 0;
  }

  .main-result-content .main-maintenance-estimated {
    display: flex;
    justify-content: space-between;
    width: 593px;
    padding: 0 3.5px;
    margin: 0 auto 84px;
    background: linear-gradient(transparent 65%, #ffedbb 35%);
  }

  .main-result-content .main-maintenance-estimated .total-money {
    width: auto;
    margin: 0;
    background: none;
    line-height: 46px;
  }

  .main-result-content .main-maintenance-estimated .estimated-money {
    margin-left: 20px;
  }

  .main-result-content .main-maintenance-estimated .estimated-money > span {
    font-size: 32px;
  }

  .main-result-content .main-maintenance-detail .detail-text {
    margin-bottom: 71px;
  }

  .common-btn {
    width: 400px;
    margin: 0 auto;
  }
}
