@charset "UTF-8";
@media screen and (min-width: 768px) {
  .form_outer {
    border-top: 1px solid #d9d4ce;
    position: relative;
    margin: 0 120px 0 120px;
  }
  .form_outer::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    position: absolute;
    inset: 0 0 0 auto;
  }
  .form_outer .form_outer_wrapper {
    display: flex;
    justify-content: space-between;
    padding-top: 100px;
    width: 980px;
    margin: 0 auto;
  }
  .form_outer .step {
    padding: 40px 40px 45px 40px;
    margin: 0 !important;
    width: 240px;
    background: #fff;
    position: sticky;
    top: 100px;
    height: max-content;
    border-radius: 8px;
    box-sizing: border-box;
  }
  .form_outer .step p {
    font-size: 16px;
    font-weight: 700;
    letter-spacing: 0.08em;
    display: flex;
    align-items: center;
    color: #b7ada0;
    gap: 18px;
    margin: 0 0 26px;
    line-height: 1;
  }
  .form_outer .step p .number {
    width: 40px;
    height: 20px;
    border-radius: 100vh;
    padding-top: 1px;
    background: #f5f3f1;
    font-weight: 500;
    color: #b7ada0;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    font-size: 14px;
    letter-spacing: 0.04em;
  }
  .form_outer .step p .number::after {
    content: "";
    width: 1px;
    height: 27px;
    background: #d9d4ce;
    position: absolute;
    inset: auto 0 0 0;
    margin: 0 auto;
    transform: translateY(100%);
    font-size: 500px;
  }
  .form_outer .step p.input {
    color: #1b434d;
  }
  .form_outer .step p.input .number {
    background: #1b434d;
    color: #ffffff;
  }
  .form_outer .step p:nth-last-of-type(1) {
    margin: 0;
  }
  .form_outer .step p:nth-last-of-type(1) .number {
    margin: 0;
  }
  .form_outer .step p:nth-last-of-type(1) .number::after {
    display: none;
  }
  .form_outer:has(form[data-screen="confirm"]) .mid {
    color: #1b434d;
  }
  .form_outer:has(form[data-screen="confirm"]) .mid .number {
    background: #1b434d;
    color: #ffffff;
  }
  .form_outer:has(form[data-screen="complete"]) .mid {
    color: #1b434d;
  }
  .form_outer:has(form[data-screen="complete"]) .mid .number {
    background: #1b434d;
    color: #ffffff;
  }
  .form_outer:has(form[data-screen="complete"]) .complete {
    color: #1b434d;
  }
  .form_outer:has(form[data-screen="complete"]) .complete .number {
    background: #1b434d;
    color: #ffffff;
  }
  .form_outer:has(form[data-screen="complete"]) .disappear {
    display: none;
  }
  .form_outer .form_wrap {
    width: 600px;
    margin: 0 !important;
    padding: 33px 0 0;
  }
  .form_outer .form_wrap .form_about {
    margin-bottom: 44px;
  }
  .form_outer .form_wrap .form_about h2 {
    font-size: 32px;
    font-weight: 600;
    margin: 0 0 14px;
    letter-spacing: 0.06em;
  }
  .form_outer .form_wrap .form_about h2 + .sub {
    font-size: 20px;
    font-weight: 600;
    color: #d46a0d;
    letter-spacing: 0.04em;
    margin: 0 0 43px;
  }
  .form_outer .form_wrap .form_about .text {
    font-size: 15px;
    line-height: 2;
    margin: 0 0 15px;
    letter-spacing: 0.06em;
  }
  .form_outer .form_wrap .form_about .tel {
    display: flex;
    font-size: 24px;
    letter-spacing: 0.04em;
    text-decoration: none;
    font-weight: 500;
    gap: 17px;
    pointer-events: none;
  }
  .form_outer .form_wrap .form_about .tel::before {
    content: url("../../img/common/pc/tel-grn.png");
    width: 22px;
    height: auto;
  }
  .form_outer .form_wrap .form_about .tel:hover {
    text-decoration: none !important;
  }
  .form_outer .form_wrap form {
    border-top: 1px solid #d9d4ce;
    position: relative;
    padding: 48px 0 0;
  }
  .form_outer .form_wrap form:has(.smf-complete-content) {
    border: none;
    padding: 0 !important;
  }
  .form_outer .form_wrap form:has(.smf-complete-content)::before {
    display: none;
  }
  .form_outer .form_wrap form::before {
    content: "";
    width: 100%;
    height: 1px;
    background: #ffffff;
    position: absolute;
    inset: 0 0 auto 0;
  }
  .form_outer .form_wrap form .smf-item {
    margin: 0 0 47px;
  }
  .form_outer .form_wrap form .smf-item .smf-item__label__text {
    font-family: "Noto Serif JP", serif;
    font-size: 18px;
    font-weight: 700;
    position: relative;
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 13px;
    line-height: 1;
  }
  .form_outer .form_wrap form .smf-item input[type="text"] {
    width: 600px;
    height: 64px;
    box-sizing: border-box;
    border-radius: 4px;
    padding: 24px 30px;
    line-height: 1;
    border: none;
    font-size: 15px;
    color: #1b434d;
  }
  .form_outer .form_wrap form .smf-item input[type="text"]::placeholder {
    color: #b7ada0;
  }
  .form_outer .form_wrap form .smf-item input[type="text"].address {
    width: 236px;
    padding-left: 60px;
    position: relative;
  }
  .form_outer .form_wrap form .smf-item .smf-text-control:has(.address) {
    position: relative;
    margin-bottom: 8px;
  }
  .form_outer .form_wrap form .smf-item .smf-text-control:has(.address)::before {
    content: "〒";
    font-size: 15px;
    position: absolute;
    inset: 50% auto auto 32px;
    z-index: 10;
    color: #1b434d;
    transform: translateY(-50%);
  }
  .form_outer .form_wrap form .smf-item input[type="email"] {
    width: 600px;
    height: 64px;
    box-sizing: border-box;
    border-radius: 4px;
    padding: 24px 30px;
    line-height: 1;
    border: none;
    font-size: 15px;
    color: #1b434d;
  }
  .form_outer .form_wrap form .smf-item input[type="email"]::placeholder {
    color: #b7ada0;
  }
  .form_outer .form_wrap form .smf-item input[type="tel"] {
    width: 600px;
    height: 64px;
    box-sizing: border-box;
    border-radius: 4px;
    padding: 24px 30px;
    line-height: 1;
    border: none;
    font-size: 15px;
    color: #1b434d;
  }
  .form_outer .form_wrap form .smf-item input[type="tel"]::placeholder {
    color: #b7ada0;
  }
  .form_outer .form_wrap form .smf-item textarea {
    width: 600px;
    height: 162px;
    box-sizing: border-box;
    border-radius: 4px;
    padding: 24px 30px;
    line-height: 1;
    border: none;
    font-size: 15px;
    resize: none;
    color: #1b434d;
  }
  .form_outer .form_wrap form .smf-item textarea::placeholder {
    color: #b7ada0;
  }
  .form_outer .form_wrap form .smf-item .smf-radio-buttons-control__control .smf-radio-button-control {
    display: flex;
    align-items: center;
    column-gap: 14px;
    margin-bottom: 11px;
    letter-spacing: 0;
    font-size: 15px;
  }
  .form_outer .form_wrap form .smf-item .smf-radio-buttons-control__control .smf-radio-button-control input[type="radio"] {
    width: 28px;
    height: 28px;
    border-radius: none;
    box-sizing: border-box;
  }
  .form_outer .form_wrap form .smf-item .smf-radio-buttons-control__control .smf-radio-button-control input[type="radio"]:checked {
    border-color: #1b434d;
    background: #ffffff;
  }
  .form_outer .form_wrap form .smf-item .smf-radio-buttons-control__control .smf-radio-button-control input[type="radio"]:checked::before {
    width: 10px;
    height: 10px;
    background: #1b434d;
    inset: calc(50% - 5px) auto auto calc(50% - 5px);
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control {
    position: relative;
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control .smf-checkbox-control {
    display: flex;
    align-items: center;
    column-gap: 25px;
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control .smf-checkbox-control input[type="checkbox"] {
    border-radius: 4px;
    border: #d9d4ce 1px solid;
    width: 32px;
    height: 32px;
    margin: 0;
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control .smf-checkbox-control input[type="checkbox"]::before {
    content: "";
    position: absolute;
    border-color: #d9d4ce;
    border-style: solid;
    border-width: 0 2px 2px 0;
    height: 12px;
    left: calc(50% - 3px);
    margin: 0 !important;
    top: calc(50% - 8px);
    transform: rotate(45deg);
    width: 8px;
    visibility: visible;
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control .smf-checkbox-control input[type="checkbox"]:checked {
    background: #1b434d;
  }
  .form_outer .form_wrap form .smf-item .smf-checkboxes-control .smf-checkbox-control input[type="checkbox"]:checked::before {
    width: 8px;
    height: 12px;
    top: calc(50% - 8px);
  }
  .form_outer .form_wrap form .smf-item:has([data-validations="email required"]) .smf-item__label__text::after, .form_outer .form_wrap form .smf-item:has([data-validations="required"]) .smf-item__label__text::after {
    content: "必須";
    transform: translateY(2px);
    font-size: 11px;
    background: #d46a0d;
    color: #ffffff;
    border-radius: 2px;
    width: 37px;
    height: 19px;
    padding-left: 1px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }
  .form_outer .form_wrap form .smf-item.zip_area .smf-item__label__text::after {
    content: "任意";
    transform: translateY(2px);
    font-size: 11px;
    background: #b7ada0;
    color: #ffffff;
    border-radius: 2px;
    width: 36px;
    height: 19px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }
  .form_outer .form_wrap form .smf-item:has(.smf-error-messages) input {
    box-sizing: border-box;
    border: solid 1px #d46a0d;
  }
  .form_outer .form_wrap form .smf-item:has(.smf-error-messages) textarea {
    box-sizing: border-box;
    border: solid 1px #d46a0d;
  }
  .form_outer .form_wrap form .smf-item:has(.smf-error-messages) .smf-error-messages {
    color: #d46a0d;
    margin-top: 15px;
    margin-bottom: 10px;
    font-size: 13px;
  }
  .form_outer .form_wrap form .smf-button-control button[type="submit"] {
    width: 180px;
    height: 54px;
    border-radius: 100vh;
    letter-spacing: 0.08em;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: start;
    padding: 0 0 1px 39px;
    background: #1b434d;
    color: #ffffff;
    font-size: 15px;
    font-weight: 400;
    position: relative;
    text-decoration: none;
    transition: opacity 0.5s cubic-bezier(0.4, 0, 1, 1);
  }
  .form_outer .form_wrap form .smf-button-control button[type="submit"]::after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border-right: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    transform: rotate(-45deg) translateY(-50%);
    position: absolute;
    inset: 50% 18px auto auto;
  }
  .form_outer .form_wrap form .smf-button-control button[type="submit"]:hover {
    opacity: 0.8;
    text-decoration: none !important;
  }
  .form_outer .form_wrap form .contact_kind .smf-item__label__text {
    margin-bottom: 30px;
  }
  .form_outer .form_wrap form .agreement {
    border-top: 1px solid #d9d4ce;
    padding-top: 37px;
  }
  .form_outer .form_wrap form .agreement .smf-item__controls {
    position: relative;
  }
  .form_outer .form_wrap form .agreement .smf-item__controls .privacy_link_txt {
    margin: 0 !important;
    letter-spacing: 0.03em;
    position: absolute;
    top: 3px;
    left: 55px;
  }
  .form_outer .form_wrap form .agreement .smf-item__controls .privacy_link_txt a {
    letter-spacing: 0.03em;
    font-size: 15px;
  }
  .form_outer .form_wrap form .agreement .smf-item__controls a {
    text-decoration: underline;
  }
  .form_outer .form_wrap form .agreement .smf-checkbox-control__label {
    display: none;
  }
  .smf-complete-content {
    margin-top: -23px;
  }
  .smf-complete-content h2.contact_thanks {
    font-size: 32px;
    font-weight: 600;
    margin: 0 0 14px;
    letter-spacing: 0.09em;
    font-family: "Noto Serif JP", serif;
  }
  .smf-complete-content h2.contact_thanks + .sub {
    font-size: 20px;
    font-weight: 600;
    color: #d46a0d;
    letter-spacing: 0.04em;
    margin: 0 0 43px;
    font-family: "Cormorant Infant", serif;
  }
  .smf-complete-content .txt {
    margin-top: 50px;
    font-size: 15px;
    line-height: 2;
    letter-spacing: 0.07em;
  }
  .smf-complete-content .txt2 {
    margin-top: 25px;
    margin-bottom: 70px;
    font-size: 15px;
    line-height: 2;
    letter-spacing: 0.07em;
  }
  .smf-complete-content #to_top_btn a {
    display: block;
    text-decoration: none;
    width: 180px;
    height: 54px;
    border-radius: 100vh;
    letter-spacing: 0.12em;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: start;
    padding: 0 0 1px 39px;
    background: #1b434d;
    color: #ffffff;
    font-size: 15px;
    font-weight: 400;
    position: relative;
    text-decoration: none;
    transition: opacity 0.5s cubic-bezier(0.4, 0, 1, 1);
  }
  .smf-complete-content #to_top_btn a::after {
    content: "";
    display: block;
    width: 8px;
    height: 8px;
    border-right: 2px solid #ffffff;
    border-bottom: 2px solid #ffffff;
    transform: rotate(-45deg) translateY(-50%);
    position: absolute;
    inset: 50% 19px auto auto;
  }
}
