.catetop.reservation #m-header::before {
  background-image: url(/assets/images/personal/reservation/img_reservation.webp);
  background-position: left top;
}

.reservation .m-hdr__ttl {
  padding-left: 0;
}
.reservation .login-box {
  padding: 30px 0;
  margin-bottom: 30px;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .reservation .login-box {
    padding: 20px 10px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.reservation .login-box div {
  width: 50%;
  padding: 0 10px;
}
@media print, screen and (max-width: 1024px) {
  .reservation .login-box div {
    width: 50%;
    padding: 0 10px;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .reservation .login-box div {
    width: 100%;
  }
}
.reservation .login-box .service_pickup button {
  font-size: 2rem;
  width: 18em;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .reservation .login-box .service_pickup button {
    font-size: 1.5rem;
    width: 100%;
  }
}
.reservation_btn {
  background-color: #4FBA5A;
  border: 1px solid #4FBA5A;
  color: #fff;
}
.reservation_btn:hover, .reservation_btn:focus {
  background-color: #fff;
  border-color: #4FBA5A;
  color: #4FBA5A;
}
.reservation_btn .btn-ico__blank {
  background-color: #fff;
}
.reservation_btn:hover .btn-ico__blank {
  background-color: #4FBA5A;
}
.reservation .m-cont__wrap {
  background-color: #fff;
  border-radius: 4px;
  padding: 70px 90px 80px;
}
@media print, screen and (max-width: 1024px) {
  .reservation .m-cont__wrap {
    padding: 50px;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .reservation .m-cont__wrap {
    background-color: transparent;
    padding: 0;
  }
}
.reservation .g-bk {
  background-color: #F6F6F6;
  padding: 40px;
}
@media print, screen and (max-width: 1024px) {
  .reservation .g-bk {
    padding: 15px;
  }
}

.flow_box {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 35px 4.59% 0 4.59%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
@media print, screen and (max-width: 1024px) {
  .flow_box {
    padding: 35px 0 0 0;
  }
}
.flow_box dl {
  width: 28.333%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -ms-flex-line-pack: stretch;
      align-content: stretch;
  text-align: center;
  background: url(/assets/images/personal/reservation/bk6px.svg) #DAF0FF;
  padding: 0 25px 30px 25px;
  margin-right: 5%;
  border-radius: 6px;
  position: relative;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box dl {
    width: 300px;
    margin-right: 0;
    margin-bottom: 80px;
  }
}
.flow_box dl::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -45%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 38.46%;
  height: 13.3%;
  background: url(/assets/images/personal/reservation/ico_res04.svg) no-repeat 0 0;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box dl::after {
    top: auto;
    right: auto;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    bottom: -45px;
    width: 40px;
    height: 20px;
    background: url(/assets/images/personal/reservation/ico_res04_sp.svg) no-repeat 0 0;
  }
}
.flow_box dl:last-child {
  margin-right: 0;
}
.flow_box dl:last-child::after {
  display: none;
}
.flow_box dl dt {
  width: 70px;
  height: 70px;
  border-radius: 50%;
  border: 3px solid #156DA7;
  background-color: #fff;
  line-height: 70px;
  font-size: 3rem;
  font-weight: 900;
  color: #156DA7;
  text-align: center;
  margin: -35px auto 0 auto;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box dl dt {
    width: 50px;
    height: 50px;
    line-height: 50px;
    font-size: 2rem;
    margin: -25px auto 0 auto;
  }
}
.flow_box dl dd {
  width: 100%;
  padding: 204px 0 0 0;
  font-size: 2rem;
}
@media print, screen and (max-width: 1024px) {
  .flow_box dl dd {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box dl dd {
    font-size: 1.8rem;
    padding: 150px 0 0 0;
  }
}
.flow_box .flow01 dd {
  background: url(/assets/images/personal/reservation/ico_res01.svg) no-repeat 50% 30%;
}
@media print, screen and (max-width: 1024px) {
  .flow_box .flow01 dd {
    background-size: 80%;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box .flow01 dd {
    background: url(/assets/images/personal/reservation/ico_res01.svg) no-repeat 50% 30px;
  }
}
.flow_box .flow02 dd {
  background: url(/assets/images/personal/reservation/ico_res02.svg) no-repeat 50% 30%;
}
@media print, screen and (max-width: 1024px) {
  .flow_box .flow02 dd {
    background-size: 50%;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box .flow02 dd {
    background: url(/assets/images/personal/reservation/ico_res02.svg) no-repeat 50% 30px;
  }
}
.flow_box .flow03 dd {
  background: url(/assets/images/personal/reservation/ico_res03.svg) no-repeat 50% 30%;
}
@media print, screen and (max-width: 1024px) {
  .flow_box .flow03 dd {
    background-size: 80%;
  }
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  .flow_box .flow03 dd {
    background: url(/assets/images/personal/reservation/ico_res03.svg) no-repeat 50% 30px;
  }
}
/*# sourceMappingURL=reservation.css.map */