@charset "UTF-8";
/* ==========================================================================
  FORM
========================================================================== */
/* 入力画面 */
@media all and (width >= 48rem) {
  input,
  textarea,
  select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: 0;
    border: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    resize: none;
  }
  .page-hero::before {
    background-image: url(/assets/img/contact/bg_page-hero.png);
    background-image: url(/assets/img/contact/bg_page-hero.webp);
    background-image: url(/assets/img/contact/bg_page-hero.avif);
  }
  .l-section__in {
    max-width: calc(864 / var(--font-size) * 1rem);
    margin-inline: auto;
  }
  .l-section__head {
    text-align: center;
    margin-bottom: calc(64 / var(--font-size) * 1rem);
  }
  .l-section__head .c-txt {
    --txt-letter-spacing: 0.1em;
    font-weight: 500;
  }
  .l-block__head {
    margin-bottom: calc(12 / var(--font-size) * 1rem);
  }
  .contact-form-item + .contact-form-item {
    margin-top: calc(24 / var(--font-size) * 1rem);
  }
  .contact-form-item + .contact-form-item:has(.contact-form-item-checkbox) {
    margin-top: calc(36 / var(--font-size) * 1rem);
  }
  .contact-form-block__in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: calc(64 / var(--font-size) * 1rem);
  }
  .contact-form-icon {
    color: #ee1000;
  }
  .contact-form-block__head {
    width: calc(150 / var(--font-size) * 1rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: calc(12 / var(--font-size) * 1rem);
  }
  .contact-form-block__body {
    width: 100%;
  }
  .contact-form-block-text {
    font-size: calc(16 / var(--font-size) * 1rem);
    line-height: 1.5625;
    color: #0c2543;
  }
  .contact-form-block__head .contact-form-block-text {
    font-weight: 500;
  }

  .contact-form-block-input {
    width: 100%;
    position: relative;
  }
  .contact-form-block-input:not(:has(.contact-form-block-input-radio))::after {
    display: block;
    position: absolute;
    z-index: -1;
    left: 0;
    top: 0;
    content: '';
    width: 100%;
    height: 100%;
    border-radius: calc(7 / var(--font-size) * 1rem);
    background: rgba(228, 239, 246, 0.7);
    mix-blend-mode: multiply;
  }
  .contact-form-block-input-radio-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: calc(32 / var(--font-size) * 1rem);
  }
  .contact-form-block-input input,
  .contact-form-block-input select,
  .contact-form-block-input textarea {
    position: relative;
    width: 100%;
    background: var(--primary-color-10);
    mix-blend-mode: multiply;
    padding-block: calc(16 / var(--font-size) * 1rem);
    padding-inline: calc(20 / var(--font-size) * 1rem);
    border-radius: calc(7 / var(--font-size) * 1rem);
  }
  .contact-form-block-input.is-error input,
  .contact-form-block-input.is-error select,
  .contact-form-block-input.is-error textarea,
  .contact-form-item-checkbox.is-error input {
    border: 1px solid #d81718;
  }
  .contact-form-block-input.is-error .error-txt,
  .contact-form-item-checkbox.is-error .error-txt{
    display: block;
    color: #d81718;
    font-size: 14px;
  }
  .contact-form-errormes{
    padding: .8em;
    border: 1px solid #d81718;
    color: #d81718;
    font-size: 16px;
    text-align: center;
    margin: 20px 0;
    line-height: 1.5;
  }
  .contact-form-block-input:has(.contact-form-block-input-select) {
    max-width: calc(250 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-select {
    position: relative;
  }
  .contact-form-block-input-select::before {
    position: absolute;
    content: '';
    right: calc(26 / var(--font-size) * 1rem);
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: calc(12 / var(--font-size) * 1rem);
    height: calc(7 / var(--font-size) * 1rem);
    background: var(--black-color);
    -webkit-mask-image: url(/assets/img/common/ico_down.svg);
            mask-image: url(/assets/img/common/ico_down.svg);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
  }
  .contact-form-block-input-select select {
    cursor: pointer;
  }
  .contact-form-block-input-radio * {
    cursor: pointer;
  }
  .contact-form-block-input-radio label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(12 / var(--font-size) * 1rem);
    line-height: calc(34 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-radio input {
    margin-top: calc(2 / var(--font-size) * 1rem);
    position: relative;
    background: #eaf0f3;
    padding: 0;
    width: calc(20.25 / var(--font-size) * 1rem);
    height: calc(20.25 / var(--font-size) * 1rem);
    aspect-ratio: 1/1;
    border-radius: 9999px;
    border: #a1a1a1 calc(1 / var(--font-size) * 1rem) solid;
    line-height: calc(34 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-radio input:checked::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: calc(10.72 / var(--font-size) * 1rem);
    height: calc(10.72 / var(--font-size) * 1rem);
    border-radius: 9999px;
    background: var(--primary-color-500);
  }

  .contact-form-block-input input::-webkit-input-placeholder, .contact-form-block-input textarea::-webkit-input-placeholder {
    color: #929292;
  }

  .contact-form-block-input input::-moz-placeholder, .contact-form-block-input textarea::-moz-placeholder {
    color: #929292;
  }

  .contact-form-block-input input:-ms-input-placeholder, .contact-form-block-input textarea:-ms-input-placeholder {
    color: #929292;
  }

  .contact-form-block-input input::-ms-input-placeholder, .contact-form-block-input textarea::-ms-input-placeholder {
    color: #929292;
  }

  .contact-form-block-input input::placeholder,
  .contact-form-block-input textarea::placeholder {
    color: #929292;
  }
  .contact-form-item-checkbox {
    text-align: center;
  }
  .contact-form-item-checkbox a {
    color: #339cd5;
    text-decoration: underline;
  }
  .contact-form-item-checkbox a:hover {
    text-decoration: none;
  }
  .contact-form-item-checkbox label {
    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;
    color: #0c2543;
  }
  .contact-form-item-checkbox input {
    cursor: pointer;
    position: relative;
    width: calc(22 / var(--font-size) * 1rem);
    height: calc(22 / var(--font-size) * 1rem);
    background: #f6f8f8;
    border: #bdbfc1 calc(1 / var(--font-size) * 1rem) solid;
    margin-right: calc(8 / var(--font-size) * 1rem);
  }
  .contact-form-item-checkbox input:checked::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: calc(18 / var(--font-size) * 1rem);
    height: calc(16 / var(--font-size) * 1rem);
    background: #339cd5;
    -webkit-mask-image: url(/assets/img/common/ico_check.svg);
            mask-image: url(/assets/img/common/ico_check.svg);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
  }
  .contact-form-btn {
    cursor: pointer;
    margin-inline: auto;
    margin-top: calc(48 / var(--font-size) * 1rem);
    max-width: calc(250 / var(--font-size) * 1rem);
    --btn-font-size: 16;
    --btn-ico-size-x: 47;
    --btn-bg-color: linear-gradient(-90deg, var(--primary-color-200), var(--primary-color-500) 50%, var(--primary-color-200));
    --btn-txt-color: var(--white-color);
    --btn-min-height: 70;
    --btn-border-radius: 9999;
    --btn-px: 24;
    width: 100%;
    -webkit-transition: background 0.25s;
    transition: background 0.25s;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    position: relative;
    height: 100%;
    overflow: hidden;
    border-radius: 9999px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    min-height: calc(var(--btn-min-height) / var(--btn-font-size) * 1rem);
    padding: calc(8 / var(--btn-font-size) * 1rem) calc(var(--btn-px) / var(--btn-font-size) * 1rem);
  }
  .contact-form-btn::before {
    content: '';
    position: absolute;
    left: 0;
    width: 200%;
    height: 100%;
    background: var(--btn-bg-color);
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    z-index: -1;
  }
  .contact-form-btn:hover::before {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .contact-form-btn input {
    cursor: pointer;
    background: none;
    color: var(--white-color);
    margin-right: calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .contact-form-footer {
  }
  .contact-form-footer .l-contact-footer__in {
    max-width: calc(860 / var(--font-size) * 1rem);
    margin-inline: auto;
  }
  .l-contact-footer__head {
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  .contact-form-footer .c-heading {
    --heading-font-size: 26;
  }
  .l-contact-footer__body::before {
    background: -webkit-gradient(linear, left top, right top, color-stop(10%, transparent), color-stop(30%, #fff), color-stop(70%, #fff), to(transparent)), -webkit-gradient(linear, left top, right top, from(#22429d), to(#73bde1));
    background: linear-gradient(to right, transparent 10%, #fff 30%, #fff 70%, transparent), linear-gradient(to right, #22429d, #73bde1);
  }
  .contact-tel {
    margin-left: 0;
    padding-left: 0;
    border: none;
    background: -webkit-gradient(linear, left top, right top, from(#76c1e4), to(#203e9b));
    background: linear-gradient(to right, #76c1e4, #203e9b);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .contact-tel .number {
  }
  .contact-tel-num {
    font-size: calc(36.45 / var(--font-size) * 1rem);
    letter-spacing: 0.1em;
    background: -webkit-gradient(linear, left top, right top, from(#76c1e4), to(#203e9b));
    background: linear-gradient(to right, #76c1e4, #203e9b);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .contact-tel-num::before {
    width: calc(40 / var(--font-size) * 1rem);
    height: calc(40 / var(--font-size) * 1rem);
    vertical-align: bottom;
    margin-right: calc(18 / var(--font-size) * 1rem);
  }
  .contact-tel-hour {
    margin-top: calc(4 / var(--font-size) * 1rem);
    font-size: calc(16.38 / var(--font-size) * 1rem);
  }

  /* エラー */
  .error-txt {
    display: none;
    color: #ee1000;
    margin-top: calc(8 / var(--font-size) * 1rem);
  }
  .contact-form-item.is-error .error-txt {
    display: block;
  }
  .contact-form-item.is-error input,
  .contact-form-item.is-error select,
  .contact-form-item.is-error textarea {
    outline: calc(1 / var(--font-size) * 1rem) #ee1000 solid;
  }
  .contact-form-item.is-error .contact-form-block-input-radio input {
    outline: none;
    border-color: #ee1000;
  }
}
@media all and (width < 64rem) {
  .l-contact-footer__body::before {
    background: -webkit-gradient(linear, left top, right top, color-stop(10%, transparent), color-stop(30%, #fff), color-stop(70%, #fff), color-stop(90%, transparent)), -webkit-gradient(linear, left top, right top, from(#22429d), to(#73bde1));
    background: linear-gradient(to right, transparent 10%, #fff 30%, #fff 70%, transparent 90%), linear-gradient(to right, #22429d, #73bde1);
  }
}
@media all and (width < 48rem) {
  input,
  textarea,
  select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    outline: 0;
    border: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    resize: none;
  }
  .page-hero::before {
    background-image: url(/assets/img/contact/bg_page-hero.png);
    background-image: url(/assets/img/contact/bg_page-hero.webp);
    background-image: url(/assets/img/contact/bg_page-hero.avif);
  }
  .l-section__in {
    max-width: calc(864 / var(--font-size) * 1rem);
    margin-inline: auto;
  }
  .l-section__head {
    text-align: left;
    margin-bottom: calc(40 / var(--font-size) * 1rem);
  }
  .l-section__head .c-txt {
    font-weight: 500;
    --txt-letter-spacing: 0.08em;
    --txt-line-height: 2;
  }
  .l-block__head {
    margin-bottom: calc(12 / var(--font-size) * 1rem);
  }
  .contact-form-item + .contact-form-item {
    margin-top: calc(24 / var(--font-size) * 1rem);
  }
  .contact-form-item + .contact-form-item:has(.contact-form-item-checkbox) {
    margin-top: calc(36 / var(--font-size) * 1rem);
  }
  .contact-form-block__in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: calc(16 / var(--font-size) * 1rem);
  }
  .contact-form-icon {
    color: #ee1000;
  }
  .contact-form-block__head {
  }
  .contact-form-block__body {
    width: 100%;
  }
  .contact-form-block-text {
    font-size: calc(13 / var(--font-size) * 1rem);
    line-height: 1.5;
    color: #0c2543;
  }
  .contact-form-block__head .contact-form-block-text {
    letter-spacing: 0.08em;
    font-weight: 600;
  }
  .contact-form-block-input {
    width: 100%;
    position: relative;
  }
  .contact-form-block-input:not(:has(.contact-form-block-input-radio))::after {
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    content: '';
    width: 100%;
    height: 100%;
    border-radius: calc(7 / var(--font-size) * 1rem);
    background: #e4eff6;
    mix-blend-mode: multiply;
    pointer-events: none;
  }
  .contact-form-block-input-radio-wrap {
  }
  .contact-form-block-input input,
  .contact-form-block-input select,
  .contact-form-block-input textarea {
    width: 100%;
    background: var(--primary-color-10);
    padding-block: calc(16 / var(--font-size) * 1rem);
    padding-inline: calc(20 / var(--font-size) * 1rem);
    border-radius: calc(7 / var(--font-size) * 1rem);
    font-size: calc(13 / var(--font-size) * 1rem);
    letter-spacing: 0.08em;
  }
  .contact-form-block-input textarea {
    line-height: 2;
  }
  .contact-form-block-input:has(.contact-form-block-input-select) {
    max-width: calc(250 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-select {
    position: relative;
  }
  .contact-form-block-input-select::before {
    position: absolute;
    content: '';
    right: calc(26 / var(--font-size) * 1rem);
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    width: calc(12 / var(--font-size) * 1rem);
    height: calc(7 / var(--font-size) * 1rem);
    background: var(--black-color);
    -webkit-mask-image: url(/assets/img/common/ico_down.svg);
            mask-image: url(/assets/img/common/ico_down.svg);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
  }
  .contact-form-block-input-select select {
    cursor: pointer;
  }
  .contact-form-block-input-radio * {
    cursor: pointer;
  }
  .contact-form-block-input-radio label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(12 / var(--font-size) * 1rem);
    line-height: calc(34 / var(--font-size) * 1rem);
    font-size: calc(13 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-radio input {
    margin-top: calc(2 / var(--font-size) * 1rem);
    position: relative;
    background: #eaf0f3;
    padding: 0;
    width: calc(16 / var(--font-size) * 1rem);
    height: calc(16 / var(--font-size) * 1rem);
    aspect-ratio: 1/1;
    border-radius: 9999px;
    border: #a1a1a1 calc(1 / var(--font-size) * 1rem) solid;
    line-height: calc(19 / var(--font-size) * 1rem);
  }
  .contact-form-block-input-radio input:checked::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: calc(8 / var(--font-size) * 1rem);
    height: calc(8 / var(--font-size) * 1rem);
    border-radius: 9999px;
    background: var(--primary-color-500);
  }

  .contact-form-block-input input::-webkit-input-placeholder, .contact-form-block-input textarea::-webkit-input-placeholder {
    color: #929292;
    letter-spacing: 0.08em;
  }

  .contact-form-block-input input::-moz-placeholder, .contact-form-block-input textarea::-moz-placeholder {
    color: #929292;
    letter-spacing: 0.08em;
  }

  .contact-form-block-input input:-ms-input-placeholder, .contact-form-block-input textarea:-ms-input-placeholder {
    color: #929292;
    letter-spacing: 0.08em;
  }

  .contact-form-block-input input::-ms-input-placeholder, .contact-form-block-input textarea::-ms-input-placeholder {
    color: #929292;
    letter-spacing: 0.08em;
  }

  .contact-form-block-input input::placeholder,
  .contact-form-block-input textarea::placeholder {
    color: #929292;
    letter-spacing: 0.08em;
  }
  .contact-form-block-input textarea::-webkit-input-placeholder {
    line-height: 2;
  }
  .contact-form-block-input textarea::-moz-placeholder {
    line-height: 2;
  }
  .contact-form-block-input textarea:-ms-input-placeholder {
    line-height: 2;
  }
  .contact-form-block-input textarea::-ms-input-placeholder {
    line-height: 2;
  }
  .contact-form-block-input textarea::placeholder {
    line-height: 2;
  }
  .contact-form-item-checkbox {
    text-align: center;
  }
  .contact-form-item-checkbox a {
    color: #339cd5;
    text-decoration: underline;
  }
  .contact-form-item-checkbox label {
    font-size: calc(13 / var(--font-size) * 1rem);
    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;
    color: #0c2543;
  }
  .contact-form-item-checkbox input {
    cursor: pointer;
    position: relative;
    width: calc(18 / var(--font-size) * 1rem);
    height: calc(18 / var(--font-size) * 1rem);
    background: #f6f8f8;
    border: #bdbfc1 calc(1 / var(--font-size) * 1rem) solid;
    margin-right: calc(8 / var(--font-size) * 1rem);
  }
  .contact-form-item-checkbox input:checked::before {
    position: absolute;
    content: '';
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    width: calc(15 / var(--font-size) * 1rem);
    height: calc(14 / var(--font-size) * 1rem);
    background: #339cd5;
    -webkit-mask-image: url(/assets/img/common/ico_check.svg);
            mask-image: url(/assets/img/common/ico_check.svg);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
  }
  .contact-form-btn {
    cursor: pointer;
    margin-inline: auto;
    margin-top: calc(40 / var(--font-size) * 1rem);
    max-width: calc(220 / var(--font-size) * 1rem);
    --btn-font-size: 13;
    --btn-ico-size-x: 38;
    --btn-bg-color: linear-gradient(-90deg, var(--primary-color-200), var(--primary-color-500) 50%, var(--primary-color-200));
    --btn-txt-color: var(--white-color);
    --btn-min-height: 46;
    --btn-border-radius: 9999;
    --btn-px: 18;
    width: 100%;
    -webkit-transition: background 0.25s;
    transition: background 0.25s;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    position: relative;
    overflow: hidden;
    color: var(--white-color);
    border-radius: 9999px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--btn-font-size) * 1rem);
    padding: calc(8 / var(--btn-font-size) * 1rem) calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    padding-right: calc(32 / var(--font-size) * 1rem);
    font-size: calc(var(--btn-font-size) / var(--font-size) * 1rem);
  }
  .contact-form-btn::before {
    content: '';
    position: absolute;
    left: 0;
    width: 200%;
    height: 100%;
    background: var(--btn-bg-color);
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    z-index: -1;
  }
  .contact-form-btn input {
    cursor: pointer;
    background: none;
    color: var(--white-color);
    margin-right: calc(var(--btn-px) / var(--font-size) * 1rem);
  }
  .contact-form-footer {
  }
  .contact-form-footer .l-contact-footer__in {
  }
  .l-contact-footer__head {
    max-width: calc(275 / var(--font-size) * 1rem);
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  .l-contact-footer__head::before {
    width: 100%;
    height: 50%;
  }
  .contact-form-footer .c-heading {
    --heading-font-size: 20;
    text-align: center;
  }
  .l-contact-footer__body::before {
    background: -webkit-gradient(linear, left top, right top, color-stop(10%, transparent), color-stop(30%, #fff), color-stop(70%, #fff), to(transparent)), -webkit-gradient(linear, left top, right top, from(#22429d), to(#73bde1));
    background: linear-gradient(to right, transparent 10%, #fff 30%, #fff 70%, transparent), linear-gradient(to right, #22429d, #73bde1);
  }
  .contact-tel {
    margin-left: 0;
    padding-left: 0;
    border: none;
    background: -webkit-gradient(linear, left top, right top, from(#76c1e4), to(#203e9b));
    background: linear-gradient(to right, #76c1e4, #203e9b);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .contact-tel .number {
  }
  .contact-tel-num {
    font-size: calc(26 / var(--font-size) * 1rem);
    letter-spacing: 0.1em;
    background: -webkit-gradient(linear, left top, right top, from(#76c1e4), to(#203e9b));
    background: linear-gradient(to right, #76c1e4, #203e9b);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .contact-tel-num::before {
    width: calc(28 / var(--font-size) * 1rem);
    height: calc(28 / var(--font-size) * 1rem);
    vertical-align: bottom;
    margin-right: calc(8 / var(--font-size) * 1rem);
  }
  .contact-tel-hour {
    margin-top: calc(4 / var(--font-size) * 1rem);
    font-size: calc(12 / var(--font-size) * 1rem);
  }

  /* エラー */
  .error-txt {
    display: none;
    color: #ee1000;
    font-size: calc(12 / var(--font-size) * 1rem);
    margin-top: calc(8 / var(--font-size) * 1rem);
  }
  .contact-form-item.is-error .error-txt {
    display: block;
  }
  .contact-form-item.is-error input,
  .contact-form-item.is-error select,
  .contact-form-item.is-error textarea {
    outline: calc(1 / var(--font-size) * 1rem) #ee1000 solid;
  }
  .contact-form-item.is-error .contact-form-block-input,
  .contact-form-item.is-error .contact-form-block-input-radio input {
    outline: none;
    border-color: #ee1000;
  }
}
/* 確認画面 */
@media all and (width >= 48rem) {
  .confirm-contact-form .get-txt {
    line-height: 1.5625;
  }
  .confirm-contact-form-item + .confirm-contact-form-item {
    margin-top: calc(58 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-block__in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: calc(64 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-block__head {
    width: calc(150 / var(--font-size) * 1rem);
    -ms-flex-negative: 0;
        flex-shrink: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .confirm-contact-form-block__body {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .confirm-contact-form-block-text {
    font-size: calc(16 / var(--font-size) * 1rem);
    line-height: 1.5625;
    color: #0c2543;
  }
  .confirm-contact-form-block__head .confirm-contact-form-block-text {
    font-weight: 500;
  }
  .confirm-contact-form-block-input .get-txt {
    color: #090b1b;
    line-height: 1.5625;
  }
  .confirm-contact-form-item.--message .confirm-contact-form-block__head {
    margin-top: calc(6 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-item.--message .get-txt {
    line-height: 2.125;
  }
  .confirm-contact-form-btn-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: calc(40 / var(--font-size) * 1rem);
    margin-top: calc(80 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn {
    --btn-font-size: 16;
    --btn-ico-size-x: 47;
    --btn-bg-color: linear-gradient(-90deg, var(--primary-color-200), var(--primary-color-500) 50%, var(--primary-color-200));
    --btn-txt-color: var(--white-color);
    --btn-min-height: 70;
    --btn-border-radius: 9999;
    --btn-px: 24;
    width: calc(250 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn.back {
    --btn-bg-color: #cccccc;
    .c-btn-ico {
      right: auto;
      left: 0;
      -webkit-transform: translateY(-50%) rotate(180deg);
              transform: translateY(-50%) rotate(180deg);
      margin-right: 0;
      margin-left: calc(var(--btn-px) / var(--font-size) * 1rem);
    }
    a {
      padding-left: calc(32 / var(--font-size) * 1rem);
      padding-right: calc(18 / var(--font-size) * 1rem);
    }
  }
  .confirm-contact-form-btn a {
    width: 100%;
    -webkit-transition: background 0.25s;
    transition: background 0.25s;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    position: relative;
    height: 100%;
    overflow: hidden;
    color: var(--white-color);
    border-radius: 9999px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    min-height: calc(var(--btn-min-height) / var(--btn-font-size) * 1rem);
    padding: calc(8 / var(--btn-font-size) * 1rem) calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    padding-right: calc(32 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn a::before {
    content: '';
    position: absolute;
    left: 0;
    width: 200%;
    height: 100%;
    background: var(--btn-bg-color);
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
    z-index: -1;
  }
  .confirm-contact-form-btn a:hover::before {
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .confirm-contact-form-btn.back a:hover {
    opacity: 0.7;
  }
}
@media all and (width < 48rem) {
  .confirm-contact-form .get-txt {
    line-height: 1.5625;
  }
  .confirm-contact-form-item + .confirm-contact-form-item {
    padding-top: calc(16 / var(--font-size) * 1rem);
    margin-top: calc(16 / var(--font-size) * 1rem);
    border-top: rgba(10, 20, 47, 0.2) calc(1 / var(--font-size) * 1rem) solid;
  }
  .confirm-contact-form-block__in {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: calc(8 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-block__head {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .confirm-contact-form-block__body {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .confirm-contact-form-block-text {
    font-size: calc(13 / var(--font-size) * 1rem);
    line-height: 1.5;
    color: #0c2543;
  }
  .confirm-contact-form-block__head .confirm-contact-form-block-text {
    letter-spacing: 0.08em;
    font-weight: 600;
  }
  .confirm-contact-form-block-input .get-txt {
    font-size: calc(13 / var(--font-size) * 1rem);
    color: #090b1b;
    line-height: 2;
    letter-spacing: 0.08em;
  }
  .confirm-contact-form-item.--message .confirm-contact-form-block__head {
    margin-top: calc(6 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-item.--message .get-txt {
    line-height: 2;
  }
  .confirm-contact-form-btn-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(16 / var(--font-size) * 1rem);
    margin-top: calc(40 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn {
    --btn-font-size: 15.8;
    --btn-ico-size-x: 40;
    --btn-bg-color: linear-gradient(-90deg, var(--primary-color-200), var(--primary-color-500) 50%, var(--primary-color-200));
    --btn-txt-color: var(--white-color);
    --btn-min-height: 60;
    --btn-border-radius: 9999;
    --btn-px: 18;
    width: calc(220 / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn.back {
    --btn-bg-color: #cccccc;
    .c-btn-ico {
      right: auto;
      left: 0;
      -webkit-transform: translateY(-50%) rotate(180deg);
              transform: translateY(-50%) rotate(180deg);
      margin-right: 0;
      margin-left: calc(var(--btn-px) / var(--font-size) * 1rem);
    }
    a {
      padding-left: calc(32 / var(--font-size) * 1rem);
      padding-right: calc(18 / var(--font-size) * 1rem);
    }
  }
  .confirm-contact-form-btn a {
    width: 100%;
    position: relative;
    overflow: hidden;
    color: var(--white-color);
    border-radius: 9999px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    height: calc(var(--btn-min-height) / var(--btn-font-size) * 1rem);
    padding: calc(8 / var(--btn-font-size) * 1rem) calc(var(--btn-px) / var(--btn-font-size) * 1rem);
    padding-right: calc(32 / var(--font-size) * 1rem);
    font-size: calc(var(--btn-font-size) / var(--font-size) * 1rem);
  }
  .confirm-contact-form-btn a::before {
    content: '';
    position: absolute;
    left: 0;
    width: 200%;
    height: 100%;
    background: var(--btn-bg-color);
    z-index: -1;
  }
}
/* 完了画面 */
@media all and (width >= 48rem) {
  .contact-complete .c-heading {
    --heading-font-size: 26;
    margin-inline: auto;
  }
  .contact-complete .c-txt {
    text-align: center;
    font-weight: 500;
    --txt-letter-spacing: 0.1em;
  }
  .contact-complete .c-btn-wrapper {
    margin-top: calc(58 / var(--font-size) * 1rem);
    max-width: calc(309 / var(--font-size) * 1rem);
    margin-inline: auto;
  }
  .contact-complete .c-btn {
    --btn-min-height: 70;
  }
  .contact-complete .c-btn-wrapper .c-btn .c-btn-ico {
    -webkit-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }
}
@media all and (width < 48rem) {
  .contact-complete .c-heading {
    --heading-font-size: 20;
    margin-inline: auto;
  }
  .contact-complete .c-txt {
    font-weight: 500;
    --txt-letter-spacing: 0.08em;
    --txt-line-height: 2;
  }
  .contact-complete .c-btn-wrapper {
    margin-top: calc(40 / var(--font-size) * 1rem);
    max-width: calc(240 / var(--font-size) * 1rem);
    margin-inline: auto;
  }
  .contact-complete .c-btn-wrapper .c-btn {
    --btn-min-height: 60;
    --btn-px: 20;
  }
  .contact-complete .c-btn-wrapper .c-btn .c-btn-ico {
    -webkit-transform: translateY(-50%) rotate(180deg);
            transform: translateY(-50%) rotate(180deg);
  }
}
