/* New Hoken CSS */
@charset "UTF-8";

/* セクションタイトル */
.section-title {
  text-align: center;
  margin-bottom: 20px;
}

.section-title .page-ttl {
  font-size: 20px;
  font-weight: 600;
}

.section-step {
  text-align: center;
  margin-bottom: 30px;
}

.section-step .steps {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

.steps:after {
  content: "";
  display: block;
  width: 75%;
  height: 2px;
  background-color: var(--color-primary);
  position: absolute;
  top: 24px;
  left: 12.5%;
  z-index: -1;
}

.section-step .step {
  text-align: center;
  font-size: 14px;
  width: 25%;
  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-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 12px;
}

.section-step .step .number {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-primary);
  background-color: #fff;
  border: 2px solid var(--color-primary);
  width: 48px;
  height: 48px;
  border-radius: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.section-step .step .data {
  font-size: 12px;
  color: var(--color-primary);
  font-weight: 600;
}

.section-step .step.active .number {
  background-color: var(--color-primary);
  color: #fff;
}

/* プラン選択 */
.section-plan .ttl {
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 20px;
}

.section-plan .plans {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  row-gap: 20px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.section-plan .plan {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 calc(33.333% - 6.667px);
  flex: 1 1 calc(33.333% - 6.667px);
  max-width: calc(33.333% - 6.667px);
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  position: relative;
  min-height: 206px;
}

.section-plan .plan.plan-standard.plan-checked {
  background-color: var(--color-primary);
  color: #fff;
}

.section-plan .plan.plan-upgrade.plan-checked {
  background-color: var(--color-secondary);
  color: #fff;
}

.section-plan .plan:last-of-type {
  margin-right: 0;
}

.section-plan .plan.plan-standard {
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.section-plan .plan .label:nth-last-of-type(2) {
  letter-spacing: 1.5px;
  font-weight: 800;
  margin-top: 3px;
}

.section-plan .plan.plan-upgrade .label:nth-last-of-type(2) {
  font-size: 10px;
}

.section-plan .plan .plan-box {
  padding: 20px 0 10px;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  border-width: 2px;
  border-style: solid;
  border-color: var(--color-primary);
  background-color: #fff;
  text-align: center;
}

.section-plan .plan.plan-upgrade .plan-box {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
}

.section-plan .plan.plan-light .plan-box {
  border-color: var(--color-text-dark);
  color: var(--color-text-dark);
}

.section-plan .plan .plan-name {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 10px;
}

.section-plan .plan .fee {
  font-size: 10px;
  font-weight: 600;
  padding-bottom: 20px;
}

.section-plan .plan .fee .strong {
  font-size: 25px;
  letter-spacing: -2px;
  font-weight: 700;
  margin-right: 2px;
}

.section-plan .plan .description {
  font-size: 10px;
  font-weight: 500;
  line-height: 1.2;
}

.section-plan .plan .description:first-of-type {
  margin-top: 30px;
  margin-bottom: 5px;
}

.section-plan .plan .label {
  font-size: 15px;
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
}

.section-plan .label .repletion {
  display: inline-block;
  background-color: var(--color-secondary);
  color: #fff;
  font-size: 10px;
  width: 50px;
  height: 16px;
  padding-left: 2px;
  margin-right: 3px;
}

.section-plan .label .repletion-txt {
  display: inline-block;
  font-size: 11px;
}

.choose-btn {
  display: none;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: absolute;
  top: -10px;
  left: calc(50% - 30px);
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  width: 60px;
  height: 20px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
  border: 1px solid #fff;
}

.section-plan .plan.plan-standard .choose-btn {
  background-color: var(--color-primary);
}

.section-plan .plan.plan-upgrade .choose-btn {
  background-color: var(--color-secondary);
}

.section-plan .plan.plan-light .choose-btn {
  background-color: var(--color-text-dark);
}

.radio-input:checked ~ label .choose-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.plan .radio-input:checked ~ label .plan-box {
  color: #fff;
}

.plan.plan-standard .radio-input:checked ~ label .plan-box {
  background-color: var(--color-primary);
}

.plan.plan-upgrade .radio-input:checked ~ label .plan-box {
  background-color: var(--color-secondary);
}

.plan.plan-upgrade .radio-input:checked ~ label .plan-box .repletion {
  background-color: #fff;
  color: var(--color-secondary);
}

.plan.plan-light .radio-input:checked ~ label .plan-box {
  background-color: var(--color-text-dark);
}

.section-plan.confirm-plan .plans {
  -webkit-column-gap: 0px;
  -moz-column-gap: 0px;
  column-gap: 0px;
  row-gap: 0px;
}

.section-plan.confirm-plan .plan {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 0px;
  flex: 1 1 0;
  max-width: 0;
  width: 0;
}

.section-plan.confirm-plan .plan label .plan-box {
  display: none;
}

.section-plan.confirm-plan .plan .radio-input:checked ~ label .plan-box {
  display: block;
  width: calc(33.3333vw - 13.3333px - 6.6667px);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media screen and (min-width: 768px) {
  .section-plan.confirm-plan .plan .radio-input:checked ~ label .plan-box {
    width: calc(208.3333px - 6.6667px);
  }
}

/* フォーム */
.section-form {
  padding: 40px 0 0;
}

.section-form .ttl {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 20px;
}

.section-form .form-item {
  margin-bottom: 20px;
}

.section-form .label {
  font-size: var(--font-size-normal);
  font-weight: 600;
  margin-bottom: 5px;
  white-space: nowrap;
}

.section-form .label span.small {
  font-weight: 500;
}

.section-form .about {
  padding-top: 20px;
  padding-bottom: 10px;
  font-size: 20px;
  font-weight: 600;
  text-align: center;
}

.section-form .form-item .info {
  font-size: 10px;
  color: var(--color-text-dark);
}

.section-form .form-item label.info {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-dark);
}

.section-form .form-item .input,
.section-form .form-item .select {
  width: 100%;
  padding: 12px 10px;
  background: #ebebeb;
  border-radius: 2px;
  font-size: 16px;
  position: relative;
  color: var(--color-text-dark)
}

.section-form .form-item .select {
  padding-left: 26px;
}

.section-form .form-item .input::-webkit-input-placeholder {
  color: #6a6969;
}

.section-form .form-item .input::-moz-placeholder {
  color: #6a6969;
}

.section-form .form-item .input:-ms-input-placeholder {
  color: #6a6969;
}

.section-form .form-item .input::-ms-input-placeholder {
  color: #6a6969;
}

.section-form .form-item .input::placeholder {
  color: #6a6969;
}

.section-form .form-item .alert {
  font-size: 12px;
  color: #e20011;
  margin-top: 4px;
}

.section-form .form .search-result {
  margin-top: 10px;
}

.section-form .form .form-item .choose {
  width: 100%;
  max-height: 185px;
  padding: 5px 10px 5px 12px;
  border: 1px solid #ddd;
  overflow-x: hidden;
  overflow-y: scroll;
}

.section-form .form .form-item .choose .shikijyo {
  position: relative;
  display: block;
  padding: 3px 0;
}

.section-form .form .form-item .choose .shikijyo .info {
  display: block;
  padding-left: 24px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
}

.section-form .form .form-item .choose .shikijyo .info:before {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #da2772;
  border-radius: 50%;
}

.section-form
  .form
  .form-item
  .choose
  .shikijyo
  .radio-input:checked
  + .info:after {
  content: "";
  display: block;
  position: absolute;
  top: 9px;
  left: 4px;
  width: 8px;
  height: 8px;
  background-color: #da2772;
  border-radius: 50%;
}

.section-form.confirm-form .datas.radios .data {
  display: none;
}

.section-form.confirm-form .datas.radios .none.radio:checked + .data {
  display: block;
}

.data-loading-group {
  position: relative;
  margin-right: 5px;
}

.loading {
  display: none;
  position: absolute;
  top: 50%;
  right: 5px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
}

.loading.active {
  display: block;
}

.form-item .link {
  margin-top: 10px;
}

.inputs {
  gap: 14px;
}

.inputs .item {
  position: relative;
}

.address .prefecture.item.left {
  width: 40%;
}

.inputs .item .arrow {
  display: block;
  position: absolute;
  border-width: 6px;
  border-color: transparent;
  border-top-color: var(--color-primary);
  border-style: solid;
  width: 8px;
  top: calc(50% - 4px);
  right: 8px;
  pointer-events: none;
}

.inputs .prefecture.item .arrow {
  top: calc(50% - -4px);
}

.inputs.prefectures .item .arrow {
  top: calc(50% - 4px);
}

.inputs.kaisaibi .item {
  width: 30%;
}

.inputs.kaisaibi .item:first-of-type {
  width: 40%;
}

.inputs.day .item {
  width: 30%;
}

.inputs.day .item:first-of-type {
  width: 40%;
}

.inputs.prefectures .item {
  width: 40%;
}

label.info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  line-height: 1;
  cursor: pointer;
  margin: 4px 0 0 -10px;
}

.radio-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  width: 24px;
  height: 24px;
  border: 2px solid var(--color-primary);
  border-radius: 9999px;
  cursor: pointer;
}

.radio-input:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 14px;
  height: 14px;
  margin: auto;
  border-radius: 9999px;
  background-color: var(--color-primary);
}

.link-search {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: var(--color-primary);
  color: #fff;
  width: 100%;
  font-size: 15px;
  font-weight: 700;
  height: 43px;
  width: 87px;
  border-radius: 2px;
  text-decoration: none;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

.link-search:hover {
  background-color: var(--color-primary);
}

/* 共通エラー表示 */
.section-form .alert.error:before {
  content: "";
  display: block;
  position: absolute;
  font-size: 11px;
  color: #e20011;
}

.section-form .form-item .item .select.error,
.section-form .form-item .input.error {
  border: 1px solid #e20011;
  background-color: #ffe3e3;
}

/* 各種エラーメッセージ */
.alert.alert-zenkaku.error:before {
  content: "全角で入力してください";
}

.alert.alert-tel.error:before {
  content: "半角数字・携帯番号を入力してください";
}

.alert.alert-email.error:before {
  content: "メールアドレス形式で入力してください";
}

.alert.alert-date.error:before {
  content: "無効な日付です";
}

.alert.alert-date.error ~ .error:before {
  content: none !important;
}

.alert.alert-kaisaibi.error:before {
  content: "お申し込み日から45日より先の日付を指定してください";
}

.alert.alert-zip-no.error:before {
  content: "入力した郵便番号に該当する住所がありません";
}

.alert.alert-banchi.error:before {
  content: "丁目番地以下は次の欄にご記入ください";
}

.alert.alert-hankaku-kana.error:before {
  content: "半角カナで入力してください";
}

.alert.alert-zip.error:before {
  content: "半角数字で入力してください";
}

.alert.alert-length.error:before {
  content: "50文字以内で入力してください";
}

.alert.alert-over.error:before {
  content: "検索結果が200件以上存在しています。検索条件をご確認ください。";
}

.alert.alert-over.not-exist:before {
  content: "式場情報を取得できませんでした。\Aお手数ですが、上記「式場名称」に結婚式会場の名称を、下記「所在地」に結婚式会場の住所を入力してください。";
}

/* ボタン */
.btn {
  text-align: center;
  margin-top: 40px;
}

.btn .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: var(--color-primary);
  color: #fff;
  width: 100%;
  font-size: 20px;
  font-weight: 700;
  height: 65px;
  border-radius: 4px;
  text-decoration: none;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

.btn .link:hover {
  background-color: var(--color-primary);
}

/* 住所をコピーボタン */
button.btn-address-copy {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: #3e3a39;
  color: #fff;
  width: 102px;
  height: 43px;
  margin: 0px 0 0 8px;
  font-size: 10px;
  font-weight: 600;
  line-height: 120%;
  border-radius: 2px;
  text-decoration: none;
  white-space: nowrap;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
  -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

/* ボタン(修正する) */
.btn-correction {
  text-align: center;
  margin-top: 40px;
}

.btn-correction .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  border: solid 2px var(--color-text-dark);
  color: var(--color-text-dark);
  width: 100%;
  font-size: 20px;
  font-weight: 600;
  height: 65px;
  text-decoration: none;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}

/* 確認画面 */
.check-item {
  border-bottom: solid 1px #ebebeb;
  padding: 15px 0 10px 0;
}

.check-list .label {
  font-size: 15px;
  font-weight: 400;
}

.check-list .data {
  font-size: 15px;
  font-weight: 600;
}

.check-list .datas-name .data {
  margin-right: 5px;
}

.check-list input {
  display: none;
}

.check-list select {
  display: none;
}

.check-border-box {
  padding: 5px 0px 10px 0px;
  margin-top: 37px;
  margin-bottom: -10px;
  border: solid 1px var(--color-primary);
}

.check-border-box .text {
  font-size: 15px;
  font-weight: 400;
}

a.check-link-box {
  display: block;
  padding: 10px;
  margin-bottom: 15px;
  border: solid 2px var(--color-primary);
  font-size: 15px;
  font-weight: 600;
  text-align: center;
  text-decoration: underline;
  color: var(--color-text-dark);
}

.checkbox-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 12px 18px 12px 10px;
  margin-bottom: 15px;
  border: solid 2px var(--color-primary);
  font-size: 10px;
  font-weight: 600;
}

.checkbox-box .left {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-right: 15px;
  padding-right: 10px;
  border-right: solid 1px var(--color-text-dark);
}

.notice {
  font-size: 10px;
  font-weight: 400;
}

.check-text {
  margin-top: 50px;
  font-size: 15px;
  font-weight: 400;
}

.check-input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  width: 18px;
  height: 18px;
  border: 2px solid var(--color-primary);
  cursor: pointer;
}

.check-input:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 1px;
  width: 12px;
  height: 6px;
  border-bottom: 2px solid var(--color-primary);
  border-left: 2px solid var(--color-primary);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.pay-method .btn .link:disabled {
  opacity: 0.4;
  pointer-events: none;
}

/* 完了 */

.section-thanks .ttl {
  text-align: center;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 20px;
}

.section-thanks .text {
  text-align: center;
  font-size: 10px;
  font-weight: 400;
  width: 316px;
  margin: 0 auto;
}

.section-thanks .strong {
  font-weight: 600;
}

.section-thanks .line-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 320px;
  padding: 20px 0px 25px 0px;
  margin: 37px auto 0px auto;
}

.section-thanks .line-box img {
  width: 55px;
}

.section-thanks .line-box .txt-area {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin: 0 0 0 26px;
}

.section-thanks .line-box .read {
  font-size: 10px;
  font-weight: 600;
  text-align: left;
}

.section-thanks .line-box .txt {
  margin: 2px 0 0 0px;
  font-size: 10px;
  font-weight: 400;
  line-height: 15px;
}

.section-thanks .line-border-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 20px 0px 25px 0px;
  width: 320px;
  margin: 0px auto 30px auto;
  border: solid 1px var(--color-primary);
}

.section-thanks .line-border-box .qr {
  margin: 0 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.section-thanks .line-border-box .qr img {
  width: 75px;
}

.section-thanks .line-border-box .or {
  font-size: 10px;
  font-weight: 800;
  color: var(--color-primary);
}

.section-thanks .line-border-box .btn {
  margin: 0 15px;
}

.section-thanks .line-border-box .btn img {
  width: 135px;
  margin: 12px 0 10px 0;
}

.section-thanks .line-border-box .txt {
  font-size: 10px;
  font-weight: 400;
  line-height: 15px;
}

.ttl-thanks-media {
  font-size: 16px;
  font-weight: 600;
  text-align: center;
}

.thanks-media {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 25px;
  margin-bottom: 60px;
}

.thanks-media .left {
  width: 48%;
}

.thanks-media .right {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.thanks-media img {
  width: 100%;
}

.thanks-media .txt {
  padding: 0 0 0 15px;
  font-size: 10px;
  font-weight: 400;
  line-height: 15px;
}

.popup {
  display: none;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  height: calc(100vh - 30px - 380px);
}

.popup.active {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.popup .loading.active {
  position: relative;
  -webkit-transform: none;
  transform: none;
  top: 0;
  margin-top: 40px;
}

@media screen and (min-width: 768px) {
  .section {
    max-width: 730px;
    margin: auto;
    padding: 0;
  }

  /* セクションタイトル */
  .section-title {
    margin-bottom: 70px;
  }

  .section-title .page-ttl {
    font-size: 30px;
  }

  .section-step {
    max-width: 825px;
    margin-bottom: 80px;
  }

  .steps:after {
    width: 75%;
    height: 4px;
    top: 54px;
  }

  .section-step .step {
    font-size: 36px;
  }

  .section-step .step .number {
    font-size: 36px;
    border: 4px solid var(--color-primary);
    width: 96px;
    height: 96px;
  }

  .section-step .step .data {
    font-size: var(--font-size-normal);
  }

  /* プラン選択 */
  .section-plan {
    max-width: 665px;
  }

  .section-plan .ttl {
    font-size: 30px;
    margin-bottom: 60px;
  }

  .section-plan .plans {
    -webkit-column-gap: 15px;
    -moz-column-gap: 15px;
    column-gap: 15px;
    row-gap: 40px;
  }

  .section-plan .plan {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 calc(33.333% - 10px);
    flex: 1 1 calc(33.333% - 10px);
    max-width: calc(33.333% - 10px);
    min-height: 206px;
  }

  .section-plan .plan .label:nth-last-of-type(2) {
    letter-spacing: 1.5px;
    font-weight: 800;
    margin-top: 3px;
  }

  .section-plan .plan.plan-upgrade .label:nth-last-of-type(2) {
    font-size: 10px;
  }

  .section-plan .plan .plan-box {
    padding: 50px 0 50px;
    width: 100%;
    height: 100%;
    -webkit-box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    border-width: 4px;
  }

  .section-plan .plan .plan-name {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 10px;
  }

  .section-plan .plan .fee {
    font-size: 20px;
    padding-bottom: 20px;
  }

  .section-plan .plan .fee .strong {
    font-size: 40px;
    letter-spacing: -2px;
    margin-right: 2px;
  }

  .section-plan .plan .description {
    margin-top: 50px;
    font-size: var(--font-size-normal);
    line-height: 1.2;
  }

  .section-plan .plan .description:first-of-type {
    margin-top: 30px;
    margin-bottom: 5px;
  }

  .section-plan .plan .label {
    font-size: 20px;
  }

  .section-plan .label .repletion {
    font-size: 20px;
    width: 105px;
    height: 32px;
    padding-left: 2px;
    margin-left: 10px;
  }

  .section-plan .label .repletion-txt {
    font-size: 20px;
  }

  .choose-btn {
    top: -22px;
    left: calc(50% - 60px);
    font-size: 20px;
    width: 120px;
    height: 44px;
    border: 2px solid #fff;
  }

  /* フォーム */
  .section-form {
    padding: 170px 0 100px 0;
  }

  .section-form .ttl {
    font-size: 30px;
    margin-top: 60px;
    margin-bottom: 20px;
  }

  .section-form .form {
    margin: 0 auto 80px auto;
  }

  .confirm-form.section-form .form {
    max-width: 415px;
    margin: 0 auto 45px auto;
  }

  .section-form .form .container {
    max-width: 420px;
    padding-left: 0;
    padding-right: 0;
  }

  .section-form .form-item {
    margin-bottom: 20px;
  }

  .section-form .label {
    font-size: 20px;
    margin-top: 35px;
    margin-bottom: 5px;
  }

  .section-form .label span.small {
    font-weight: 500;
    font-size: 20px;
  }

  .section-form .about {
    padding-top: 50px;
    padding-bottom: 10px;
    font-size: 30px;
  }

  .section-form .form-item .info {
    font-size: var(--font-size-pc-small);
  }

  .section-form .form-item label.info {
    font-size: var(--font-size-pc-large);
    margin-left: 0px;
    margin-right: 35px;
  }

  .section-form .form-item .input,
  .section-form .form-item .select {
    padding: 15px;
    font-size: var(--font-size-pc-large);
  }

  .section-form .form-item .select {
    padding-left: 26px;
  }

  .section-form .form-item .alert {
    font-size: 12px;
    margin-top: 4px;
  }

  .data-loading-group {
    margin-right: 5px;
  }

  .form-item .link {
    margin-top: 10px;
  }

  .inputs {
    gap: 14px;
  }

  .inputs .item .arrow {
    border-width: 6px;
    width: 8px;
    top: calc(50% - 4px);
    right: 8px;
  }

  .inputs .prefecture.item .arrow {
    top: calc(50% - -10px);
  }

  .inputs.prefectures .item .arrow {
    top: calc(50% - 4px);
  }

  label.info {
    margin: 4px 0 0 -10px;
  }

  .radio-input {
    margin: 20px 0;
    width: 32px;
    height: 32px;
    border: 4px solid var(--color-primary);
  }

  .radio-input:checked::after {
    width: 16px;
    height: 16px;
  }

  .inputs.prefectures .item {
    width: 40%;
  }

  .link-search {
    font-size: var(--font-size-pc-large);
    height: 52px;
    width: 120px;
    margin: 0px 0 0 15px;
  }

  /* ボタン */
  .btn {
    margin: 100px auto 0 auto;
    max-width: 420px;
  }

  .btn .link {
    font-size: var(--font-size-pc-large);
    height: 76px;
    border-radius: 10px;
  }

  /* 住所をコピーボタン */
  button.btn-address-copy {
    width: 160px;
    height: 52px;
    margin: 0px 0 0 15px;
    font-size: var(--font-size-pc-small);
  }

  .data-loading-group {
    width: 200px;
  }

  .address .prefecture.left {
    width: 40%;
  }

  /* ボタン(修正する) */
  .btn-correction {
    margin: 40px auto 75px;
    max-width: 415px;
  }

  .btn-correction .link {
    border: solid 3px var(--color-text-dark);
    font-size: var(--font-size-pc-large);
    height: 76px;
  }

  /* 確認画面 */
  .check-item {
    padding: 0px 0 20px 0;
  }

  .check-list .label {
    font-size: var(--font-size-pc-large);
  }

  .check-list .data {
    font-size: var(--font-size-pc-large);
  }

  .check-list .datas-name .data {
    margin-right: 5px;
    max-width: 415px;
  }

  .check-border-box {
    padding: 5px 20px 10px 20px;
    margin-top: 37px;
    margin-bottom: -10px;
    border: solid 2px var(--color-primary);
  }

  .check-border-box .about {
    padding: 20px 0 15px;
    font-size: var(--font-size-pc-large);
  }

  .check-border-box .text {
    font-size: var(--font-size-pc-small);
  }

  .check-border-box .right {
    margin: 0;
  }

  .check-border-box .inputs .right {
    margin: 20px 0 30px;
  }

  .check-border-box .radio-input {
    margin: -5px 5px 0 0;
  }

  .check-border-box .radio-input + label {
    margin-right: 20px;
  }

  a.check-link-box {
    padding: 15px;
    margin-bottom: 40px;
    border: solid 2px var(--color-primary);
    font-size: var(--font-size-pc-small);
  }

  .checkbox-box {
    padding: 10px 20px 10px 10px;
    margin-bottom: 20px;
    border: solid 2px var(--color-primary);
    font-size: var(--font-size-pc-small);
  }

  .checkbox-box .left {
    margin-right: 15px;
    padding-right: 15px;
    border-right: solid 1px var(--color-text-dark);
    line-height: 1.2;
  }

  .notice {
    margin: 20px auto 0;
    font-size: var(--font-size-pc-small);
    max-width: 415px;
  }

  .check-text {
    margin-top: 60px;
    font-size: var(--font-size-pc-large);
    font-weight: 400;
  }

  .check-input {
    margin-top: -10px;
    width: 18px;
    height: 18px;
    border: 2px solid var(--color-primary);
  }

  .check-input:checked::after {
    width: 12px;
    height: 7px;
    border-bottom: 2px solid var(--color-primary);
    border-left: 2px solid var(--color-primary);
  }
  .pay-method {
    padding-top: 20px;
  }

  .pay-method .btn {
    margin-top: 20px;
  }

  .popup {
    height: calc(100vh - 270px - 450px);
  }

  /* 完了 */

  .section-thanks .ttl {
    font-size: 36px;
    margin-top: 120px;
    margin-bottom: 70px;
  }

  .section-thanks .text {
    font-size: var(--font-size-normal);
    width: 420px;
    margin: auto;
  }

  .section-thanks .strong {
    display: block;
    font-size: var(--font-size-pc-large);
    padding-top: 20px;
  }

  .section-thanks .line-box {
    width: 420px;
    padding: 20px 0px 25px 0px;
    margin: 30px auto 0px auto;
  }

  .section-thanks .line-box img {
    width: 70px;
  }

  .section-thanks .line-box .txt-area {
    margin: 0 0 0 37px;
  }

  .section-thanks .line-box .read {
    font-size: var(--font-size-pc-small);
  }

  .section-thanks .line-box .txt {
    margin: 2px 0 0 0px;
    font-size: var(--font-size-pc-small);
    line-height: 130%;
  }

  .section-thanks .line-border-box {
    padding: 40px 0px 35px 0px;
    width: 415px;
    margin: 10px auto 80px auto;
    border: solid 2px var(--color-primary);
  }

  .section-thanks .line-border-box .qr {
    margin: 0 5px 0 0;
    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: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .section-thanks .line-border-box .qr img {
    width: 88px;
    margin-bottom: 10px;
  }

  .section-thanks .line-border-box .or {
    font-size: var(--font-size-pc-small);
  }

  .section-thanks .line-border-box .btn {
    margin: 0 0 0 25px;
  }

  .section-thanks .line-border-box .btn img {
    width: 170px;
    margin: 12px 0 27px 0;
  }

  .section-thanks .line-border-box .txt {
    font-size: var(--font-size-pc-small);
    line-height: 130%;
  }

  .ttl-thanks-media {
    margin-top: 70px;
    font-size: 32px;
  }

  .thanks-media {
    margin: 35px auto 60px;
    width: 415px;
  }

  .thanks-media .left {
    width: 190px;
  }

  .thanks-media .txt {
    padding: 0 0 0 20px;
    width: 235px;
    font-size: var(--font-size-pc-small);
    line-height: 190%;
  }

  .container-media .btn {
    margin: 140px auto 180px;
  }
  .container-media .line {
    border-width: 2px 0 0;
  }
}

@media screen and (max-width: 767px) and (orientation: landscape) {
  .section-step .container{
    max-width: 500px;
  }
  .section-plan .container {
    max-width: 420px;
  }
  .section-form .form .container {
    max-width: 420px;
    padding-left: 0;
    padding-right: 0;
  }
  .inputs.flex:not(.day) .item {
    width: 50%;
  }
  .btn {
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }
  .section-plan.confirm-plan .plan .radio-input:checked ~ label .plan-box {
      width: calc(140px - 6.6667px - 13.3333px);
  }
  .confirm-form.section-form .form {
    max-width: 415px;
    padding: 5px 20px 10px 20px;
    margin: 0 auto 45px auto;
  }
  .btn-correction {
    margin: 40px auto 75px;
    max-width: 415px;
  }
  .notice {
    margin: 20px auto 0;
    font-size: var(--font-size-pc-small);
    max-width: 415px;
  }
}

@media screen and (max-width: 375px) {
  .section-step .step .data {
    font-size: clamp(10px, 2.5vw, 12px);
  }
}