@charset "UTF-8";
/**
 * おためし購入フォーム Phase3用 Styles
 * @author ISHII Shunsuke
 */
.otameshi-form div,
.otameshi-form span,
.otameshi-form object,
.otameshi-form iframe,
.otameshi-form h1,
.otameshi-form h2,
.otameshi-form h3,
.otameshi-form h4,
.otameshi-form h5,
.otameshi-form h6,
.otameshi-form p,
.otameshi-form blockquote,
.otameshi-form pre,
.otameshi-form abbr,
.otameshi-form address,
.otameshi-form cite,
.otameshi-form code,
.otameshi-form del,
.otameshi-form dfn,
.otameshi-form em,
.otameshi-form img,
.otameshi-form ins,
.otameshi-form kbd,
.otameshi-form q,
.otameshi-form samp,
.otameshi-form small,
.otameshi-form strong,
.otameshi-form sub,
.otameshi-form sup,
.otameshi-form var,
.otameshi-form b,
.otameshi-form i,
.otameshi-form dl,
.otameshi-form dt,
.otameshi-form dd,
.otameshi-form ol,
.otameshi-form ul,
.otameshi-form li,
.otameshi-form fieldset,
.otameshi-form form,
.otameshi-form label,
.otameshi-form legend,
.otameshi-form table,
.otameshi-form caption,
.otameshi-form tbody,
.otameshi-form tfoot,
.otameshi-form thead,
.otameshi-form tr,
.otameshi-form th,
.otameshi-form td,
.otameshi-form article,
.otameshi-form aside,
.otameshi-form canvas,
.otameshi-form details,
.otameshi-form figcaption,
.otameshi-form figure,
.otameshi-form footer,
.otameshi-form header,
.otameshi-form hgroup,
.otameshi-form menu,
.otameshi-form nav,
.otameshi-form section,
.otameshi-form summary,
.otameshi-form time,
.otameshi-form mark,
.otameshi-form audio,
.otameshi-form video {
  font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,
    "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo,
    "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.otameshi-form {
  overflow: hidden;
  -webkit-font-smoothing: antialiased;
}

.otameshi-form input,
.otameshi-form select {
  font-size: 16px !important;
}

.otameshi-form #accept_button {
  font-weight: bold;
}

.otameshi-form__header__logo {
  margin-right: 15px;
}

.otameshi-form__header__logo img {
  width: 70px;
}

.otameshi-form__header__title {
  font-size: 16px;
  font-weight: bold;
}

.otameshi-form__header__box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 20px 20px;
}

.otameshi-form__header__progress {
  position: relative;
}

.otameshi-form__header__progress:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 5px;
  background-color: #dddddd;
}

.otameshi-form__header__progress__box {
  display: inline-block;
  transition: width 0.35s cubic-bezier(0.05, 0.72, 0.26, 0.97);
  min-width: 20%;
  max-width: calc(100% - 16px);
  position: relative;
  font-weight: bold;
}

.otameshi-form__header__progress__box__bar {
  height: 5px;
  position: relative;
  z-index: 2;
  overflow: hidden;
}

.otameshi-form__header__progress__box__bar:after {
  content: "";
  display: block;
  position: absolute;
  right: 0px;
  top: -10px;
  width: 100%;
  border: 5px solid #76952f;
  border-left: 10px solid transparent;
  border-top: 10px solid transparent;
  border-right: 10px solid transparent;
}

.otameshi-form__header__progress__box__step {
  text-align: right;
  color: #76952f;
  margin-top: 5px;
  padding-right: 4px;
  font-size: 10px;
}

.otameshi-form__header__progress__box__nextstep {
  text-align: left;
  color: #dddddd;
  margin-top: 5px;
  font-size: 10px;
  position: absolute;
  left: calc(100% + 4px);
  top: 5px;
  width: 1000px;
}

.otameshi-form__footer {
  width: 100%;
  padding: 14px 16px 24px;
  box-sizing: border-box;
  position: fixed;
  bottom: 0;
  left: 0;
  background-color: rgba(255, 255, 255, 0.7);
  z-index: 5;
}

.otameshi-form__footer__ui {
  width: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
}

.otameshi-form__footer__ui button {
  border: 1px solid #666;
  border-radius: 4px;
  margin-bottom: 0 !important;
}

.otameshi-form__stage {
  padding-top: 24px;
  padding-bottom: 88px;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-flex-align: start;
  align-items: flex-start;
  min-width: 100%;
  overflow: hidden;
  position: relative;
  transition: left 0.35s cubic-bezier(0.26, 0.02, 0.14, 1);
  display: none;
}

.otameshi-form__stage.is-ready {
  display: -ms-flexbox;
  display: flex;
}

.otameshi-form__stage[data-step="1"] {
  left: 0vw;
}

.otameshi-form__stage[data-step="2"] {
  left: -100vw;
}

.otameshi-form__stage[data-step="3"] {
  left: -200vw;
}

.otameshi-form__stage[data-step="4"] {
  left: -300vw;
}

.otameshi-form__stage[data-step="5"] {
  left: -400vw;
}

.otameshi-form__stage[data-step="6"] {
  left: -500vw;
}

.otameshi-form__stage[data-step="7"] {
  left: -600vw;
}

.otameshi-form__stage[data-step="8"] {
  left: -700vw;
}

.otameshi-form__stage[data-step="9"] {
  left: -800vw;
}

.otameshi-form__stage[data-step="10"] {
  left: -900vw;
}

.otameshi-form__stage[data-step="11"] {
  left: -1000vw;
}

.otameshi-form__stage[data-step="12"] {
  left: -1100vw;
}

.otameshi-form__stage[data-step="13"] {
  left: -1200vw;
}

.otameshi-form__stage[data-step="14"] {
  left: -1300vw;
}

.otameshi-form__stage[data-step="15"] {
  left: -1400vw;
}

.otameshi-form__stage[data-step="16"] {
  left: -1500vw;
}

.otameshi-form__stage[data-step="17"] {
  left: -1600vw;
}

.otameshi-form__stage[data-step="18"] {
  left: -1700vw;
}

.otameshi-form__stage[data-step="19"] {
  left: -1800vw;
}

.otameshi-form__stage[data-step="20"] {
  left: -1900vw;
}

.otameshi-form__stage__step {
  max-width: 640px;
  width: 100vw;
  min-height: calc(100vh - 70px);
  box-sizing: border-box;
  padding: 0 16px;
  margin: 0 auto;
}
@media screen and (max-width: 376px) {
  #js-x-form-input-step1 {
    padding-bottom: 100px;
  }
}

.otameshi-form__stage__step .otameshi-form__input {
  display: none;
}

.otameshi-form__stage__step.is-active .otameshi-form__input {
  display: block;
}

.otameshi-form__item {
  display: flex;
  margin-bottom: 20px;
  align-items: center;
  margin: 0 auto 24px;
  max-width: 640px;
}

.otameshi-form__item__img {
  padding-right: 8px;
}

.otameshi-form__item__text__title {
  font-size: 15px;
  line-height: 1.5;
  margin-bottom: 5px;
}

.otameshi-form__item__text__price {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  color: #db4f43;
  font-size: 15px;
  font-weight: bold;
}
.otameshi-form__item__text__price span {
  font-size: inherit;
  color: inherit;
}
.otameshi-form__item__text__price .before {
  color: #333;
  text-decoration: line-through;
}
.otameshi-form__item__text__price .after {
  margin: 0 4px;
}

.otameshi-form__item__text__price small {
  color: #db4f43;
  font-size: 13px;
  font-weight: bold;
  padding-top: 2px;
}

.otameshi-form__item__text__price:after {
  content: "";
  display: block;
  display: inline-block;
  padding: 4px 6px;
  border-radius: 4px;
  border: 1px solid #db4f43;
  color: #db4f43;
  content: "送料無料";
  font-weight: normal;
  font-size: 11px;
  margin-left: 8px;
}

.otameshi-form__input {
  position: relative;
}

.otameshi-form__input__help {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 10px;
  line-height: 22px;
  color: #666;
}

.otameshi-form__input__paymentlist {
  border-bottom: 1px solid #ebebeb;
  margin: 0 -16px;
}

.otameshi-form__input__paymentlist__item {
  border-top: 1px solid #ebebeb;
  padding: 0 16px;
}

.otameshi-form__input__paymentlist__item input[type="radio"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  width: 32px;
  height: 32px;
  border-radius: 100%;
  border: 1px solid #c7c7c7;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  outline: none;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto 0;
  background-color: #fff;
  z-index: 2;
}

.otameshi-form__input__paymentlist__item input[type="radio"]:after {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background-color: #76952f;
  border-radius: 100%;
  opacity: 0;
  transform: scale(0);
  transition: transform 0.35s cubic-bezier(0, 1.54, 0.44, 0.98),
    opacity 0.35s cubic-bezier(0, 1.54, 0.44, 0.98);
}

.otameshi-form__input__paymentlist__item input[type="radio"]:checked:after {
  opacity: 1;
  transform: scale(1);
}

.otameshi-form__input__paymentlist__item
  input[type="radio"]:checked
  + div:after {
  opacity: 0;
  transform: scaleY(1);
  transition: all 0.35s cubic-bezier(0, 0.5, 0.39, 0.99);
}

.otameshi-form__input__paymentlist__item label {
  display: -ms-flexbox;
  display: flex;
  padding: 16px 0;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

.otameshi-form__input__paymentlist__item__detail {
  margin-left: 10px;
  padding-left: 32px;
}

.otameshi-form__input__paymentlist__item__detail:after {
  content: "";
  display: block;
  z-index: 1;
  opacity: 0;
  transform: scaleY(0);
  background-color: #76952f;
  position: absolute;
  transition: all 0s ease;
  width: calc(100% + 32px);
  height: 100%;
  margin: 0 -16px;
  top: 0;
  left: 0;
}

.otameshi-form__input__paymentlist__item__title {
  font-size: 15px;
  font-weight: bold;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 4px;
  position: relative;
  z-index: 2;
}

.otameshi-form__input__paymentlist__item__title img {
  display: block;
  margin: -4px 6px -4px 0;
}

.otameshi-form__input__paymentlist__item__notes {
  position: relative;
  font-size: 11px;
  line-height: 1.63;
  z-index: 2;
}

.otameshi-form__input__paymentlist__item__notes img {
  display: block;
  margin-top: 5px;
}

.otameshi-form__input__paymentlist__item__bnr {
  margin: -9px -7px -9px 11px;
  position: relative;
  z-index: 2;
}

.otameshi-form__input--delivery_radio_btns {
  position: relative;
  z-index: 2;
  min-height: 110px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.otameshi-form__input--delivery_radio_btns--dummy {
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 110px;
  z-index: 1;
}

.otameshi-form__input--delivery_radio_btns--dummy label p {
  color: white !important;
  pointer-events: none;
}

.otameshi-form__input--delivery_radio_btns--dummy input[type="radio"] {
  background-color: #ebebeb !important;
}

.otameshi-form__input--delivery_radio_btns:after {
  content: "";
  display: block;
  width: calc(33.3% - 7px);
  height: 0;
}

.otameshi-form__input--delivery_radio_btns label {
  display: block;
  position: relative;
  width: calc(33.3% - 7px);
  height: 48px;
  margin-bottom: 7px;
}

.otameshi-form__input--delivery_radio_btns label p {
  position: absolute;
  font-size: 15px;
  font-weight: bold;
  color: #6f6f6f;
  width: 100%;
  height: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 2;
  top: 0;
  left: 0;
  transition: all 0.35s ease;
}

.otameshi-form__input--delivery_radio_btns input[type="radio"] {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  margin: 0;
  width: 100%;
  height: 48px;
  border-radius: 4px;
  background-color: #dddddd;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  z-index: 2;
  outline: none;
  transition: all 0.35s ease;
  border: none;
}

.otameshi-form__input--delivery_radio_btns input[type="radio"]:checked {
  background-color: #76952f;
  transition: all 0s ease;
}

.otameshi-form__input--delivery_radio_btns input[type="radio"]:checked + p {
  color: white;
  transition: all 0s ease;
}

.otameshi-form__btn {
  width: 100%;
  box-sizing: border-box;
}

.otameshi-form__btn__notes {
  margin: 0 0 20px;
  font-size: 13px;
  text-align: center;
}

.otameshi-form__btn__notes a {
  color: #76952f;
}

.otameshi-form__btn--confirm {
  padding-top: 24px;
}

.otameshi-form__btn--confirm.is-creditcard-inner {
  padding: 32px 16px 22px;
}

.otameshi-form__btn--confirm.is-creditcard-inner button {
  margin-bottom: 0;
  width: 100%;
}

.otameshi-form__btn button {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  cursor: pointer;
  display: block;
  box-sizing: border-box;
  margin-bottom: 48px;
  font-size: 15px;
  line-height: 48px;
  text-align: center;
  color: #fff;
  background-color: #76952f;
  border: 0;
  border-radius: 4px;
  font-weight: bold;
  width: 263px;
  margin: 0 auto;
}

.otameshi-form__btn button:disabled {
  background-color: #c8d4ab;
  pointer-events: none;
}

.form--renewal__form__content__radio__wrapper {
  position: relative;
}

.form--renewal__form__title {
  margin: 0 0 14px;
}

.form--renewal__form__title:after {
  background-color: #db4f43;
  border-radius: 3px;
}

.form--renewal__form__content {
  padding-bottom: 0;
  border: none !important;
}

.form--renewal__content--flat--confirm {
  margin: 32px -16px 0;
}

.form--renewal__form__content__addition {
  margin-top: 10px;
  padding-top: 16px;
}

.form--renewal__form__content__addition__title {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  align-items: center;
}

.form--renewal__form__content__addition__title.is-required:after {
  content: "必須";
  display: inline-block;
  margin-left: 8px;
  padding-right: 5px;
  padding-left: 5px;
  font-size: 11px;
  font-weight: normal;
  text-align: center;
  vertical-align: top;
  line-height: 20px;
  color: #fff;
  background-color: #db4f43;
  border-radius: 3px;
}

footer.footer {
  padding-bottom: 120px;
}

.form--renewal__content__confirm__data__caption--flat {
  font-size: 17px;
}

.form--renewal__content__confirm__data__category__title {
  font-size: 13px;
}

.form--renewal__content__confirm__data__category__data {
  word-break: break-all;
}

.form--renewal__content__confirm__data__inner.is-prices {
  margin: 0 16px;
  padding: 16px;
  background-color: #fefce8;
}

.form--renewal__content__confirm__data.is-lo2020 {
  position: relative;
  margin-bottom: 0;
  padding: 13px 0;
}

.form--renewal__content__confirm__data.is-lo2020 button {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: 19px 16px 18px 0;
}

.form--renewal__content--flat {
  border-bottom: 4px solid #eee;
}

@keyframes otameshiRadioFadeIn {
  0% {
    transform: scale(0.875);
    opacity: 0;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}

@keyframes otameshiRadioTapAction {
  0% {
    transform: scale(1);
  }
  85% {
    transform: scale(1.1);
  }
  100% {
    transform: scale(1);
  }
}

.form--renewal__content--error__list:not(:empty) {
  padding-top: 16px;
  padding-right: 16px;
  padding-bottom: 16px;
  padding-left: 16px;
  max-width: 640px;
  margin: 0 auto;
}

.form--renewal__form__content label.error {
  margin-top: 8px;
  font-size: 15px;
  line-height: 17px;
  color: #e80519;
  display: block;
  padding: 0;
}
.x-input-error {
  margin-top: 5px;
  font-size: 15px;
  line-height: 17px;
  color: #e80519;
}

.otameshi-form__couponBanner {
  text-align: center;
  margin-bottom: 4px;
  -webkit-transform: scaleY(0) rotate(0.0001deg);;
      -ms-transform: scaleY(0) rotate(0.0001deg);;
          transform: scaleY(0) rotate(0.0001deg);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  -o-transition: transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  color: #fff;
  font-size: 13px;
  font-weight: bold;
}
.otameshi-form__couponBanner.--active {
  background: #558D5C;
  -webkit-transform: scaleY(1) rotate(0.0001deg);;
      -ms-transform: scaleY(1) rotate(0.0001deg);;
          transform: scaleY(1) rotate(0.0001deg);;
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  -o-transition: transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  position: relative;
  line-height: 1.5;
  padding: 10px 8px;
}
.otameshi-form__couponBanner.--active::before {
  content: '';
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: -100%;
  background-image: -o-linear-gradient(320deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 75%);
  background-image: linear-gradient(130deg, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0.5) 50%, rgba(255, 255, 255, 0) 75%);
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}
.otameshi-form__couponBanner.--active.--on::before {
  left: 100%;
}
.otameshi-form__couponBanner.--fail {
  background: #E3904A;
  -webkit-transform: scaleY(1) rotate(0.0001deg);;
      -ms-transform: scaleY(1) rotate(0.0001deg);;
          transform: scaleY(1) rotate(0.0001deg);;
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  -o-transition: transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
  -webkit-transform-origin: 0 0;
      -ms-transform-origin: 0 0;
          transform-origin: 0 0;
  position: relative;
  line-height: 1.5;
  padding: 10px 8px;
}
.x-input-trialDiscountCode .form--renewal__form__title::after {
  display: none;
}

.form--renewal__content__confirm__service__price__description--total.--trial-coupon {
  width: 100%;
  text-align: right;
  font-weight: bold;
  font-size: 13px;
}

@media only screen and (max-width: 374px) {
  .otameshi-form__input--delivery_radio_btns label p {
    font-size: 13px;
  }
  .form--renewal__form__content__birthday {
    font-size: 12px;
  }
  .otameshi-form__couponBanner.--fail,
  .otameshi-form__couponBanner.--active {
    font-size: 11px;
  }
}

.form--renewal__form__content__trialDiscountCode {
  display: flex;
  align-items: center;
}
.form--renewal__form__content__trialDiscountCode button {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
  display: block;
  padding: 0;
  text-align: center;
  line-height: 48px;
  border-radius: 4px;
  width: 100px;
  font-size: 14px;
  font-weight: bold;
  border: none;
  background-color: #76952f;
  color: #fff;
  margin: 13px 0 0 16px;
}
@media only screen and (max-width: 374px) {
  .form--renewal__form__content__trialDiscountCode button {
    width: 80px;
    font-size: 11px;
  }
}

.form--renewal__form__content__trialDiscountCode button:disabled {
  background-color: #c8d4ab;
  pointer-events: none;
}