.contact__heading {
    margin-bottom: 120px;
    padding: 42px;
    color: #fff;
    font-size: clamp(20px, 4.2vw, 80px);
    text-align: center;
    background-image: -moz-linear-gradient( -30deg, rgb(0,79,30) 10%, rgb(0,171,105) 65%, rgb(0,79,30) 100%);
    background-image: -webkit-linear-gradient( -30deg, rgb(0,79,30) 10%, rgb(0,171,105) 65%, rgb(0,79,30) 100%);
    background-image: -ms-linear-gradient( -30deg, rgb(0,79,30) 10%, rgb(0,171,105) 65%, rgb(0,79,30) 100%);
}

/* ======================
フォームデフォルトのデザイン
======================*/
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form textarea {
    display: block;
    height: 60px;
    line-height: 60px;
    width: 100%;
    padding: 0 20px;
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    letter-spacing: .06em;
    border: 2px solid #b2b2b2;
    border-radius: 4px;
}

.contact-form__select-wrapper {
    position: relative;
    max-width: 300px;
}

.contact-form__select-wrapper::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 30px;
    height: 60px;
    background: #b2b2b2;
    border-radius: 0 4px 4px 0;
    pointer-events: none;
}

.contact-form select {
    display: block;
    height: 60px;
    line-height: 56px;
    width: 100%;
    border-radius: 4px;
    border: 2px solid #b2b2b2;
    width: 100%;
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    padding: 0 20px;
}

.contact-form select.is-empty {
    color: #b2b2b2;
}

.contact-form select option {
   color: #111111;
}

.contact-form__select-wrapper {
    width: 100%;
    position: relative;
}

.contact-form__select-wrapper::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translateY(-50%);
    border-color: #fff transparent transparent transparent;
    border-width: 8px 6px 0px 6px;
    border-style: solid;
    pointer-events: none;
}

.contact-form textarea {
    height: 300px;
    line-height: 1.83;
    padding: 18px 20px;
}

.contact-form__ruby {
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    letter-spacing: .06em;
}

.contact-form__ruby--smal {
    font-size: clamp(18px, 1.3vw, 22px);
}

.contact-form tr {
    border-bottom: 4px solid #fff;
}

.contact-form th {
    background-image: -moz-linear-gradient( -10deg, rgb(0,171,105) 0%, rgb(0,112,69) 100%);
    background-image: -webkit-linear-gradient( -10deg, rgb(0,171,105) 0%, rgb(0,112,69) 100%);
    background-image: -ms-linear-gradient( -10deg, rgb(0,171,105) 0%, rgb(0,112,69) 100%);
    color: #fff;
    vertical-align: middle;
    letter-spacing: .1em;
    font-weight: 900;
    padding: 26px;
    width: 420px;
    /* font-size: 30px; */
    font-size: clamp(18px, 1.6vw, 30px);
}

.contact-form td {
    padding: 20px 58px;
    /* padding: 20px 4.6%; */
}

.contact-form th.th-txt-top {
    vertical-align: top;
}

/* ======================
placeholder
======================*/
::placeholder {
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    color: #b2b2b2;
    line-height: 1.2;
    letter-spacing: .06em;
}

/* 旧Edge対応 */
::-ms-input-placeholder {
    color: #b2b2b2;
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    line-height: 1.2;
    letter-spacing: .06em;
}

/* ======================
必須
======================*/
.contact-form__required {
    color: #f43b3b;
    background: #fff;
    display: inline-block;

    /* font-size: 20px; */
    font-size: clamp(14px, 1.1vw, 20px);

    font-weight: 500;
    letter-spacing: .1em;
    line-height: 1;
    padding: 7px 20px;

    white-space: nowrap;
}

.contact-form__head {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* ======================
お名前
======================*/
.contact-form__name {
    display: flex;
    justify-content: space-between;
}

.contact-form__name-col {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-right: 35px;
    width: 100%;
}

.contact-form__name-col:last-of-type {
    margin-right: 0;
}

.contact-form__ruby {
    width: 70px;
}

.contact-form__ruby-sm {
    font-size: .8em;
}

.contact-form__ruby-sm-required {
    background: #dcdddd;
    display: inline-block;
    padding: 10px;
    margin-right: 10px;
    font-weight: 500;
    font-size: clamp(14px, 1.1vw, 20px);
    line-height: 1;
}

.contact-form__name input[type="text"] {
    width: calc(100% - 70px);
}

/* ======================
部署名・ご役職
======================*/
.contact-form__posi-row + .contact-form__posi-row{
    margin-top: 18px;
}

.contact-form__posi-row {
    display: flex;
    align-items: center;
}

.contact-form__posi .contact-form__ruby {
    width: 135px;
}

.contact-form__posi input[type="text"] {
    width: calc(100% - 135px);
}

/* ======================
ご住所
======================*/
.contact-form__post {
    display: flex;
    max-width: 300px;
}

.contact-form__post input[type="text"] {
    text-align: center;
}

.contact-form__post-bar {
    margin: 0 16px;
    font-size: 24px;
    height: 60px;
    display: inline-flex;
    align-items: center;
}

.contact-form__addr-flex {
    display: flex;
    align-items: center;
}

.contact-form__addr-flex .contact-form__ruby {
    width: 140px;
}

.contact-form__addr-flex .contact-form__post,
.contact-form__addr-flex .contact-form__select-wrapper,
.contact-form__addr-flex .contact-form__city {
    width: calc(100% - 140px);
}

.contact-form__addr-flex {
    margin-bottom: 17px;
}

.contact-form__bill {
    margin-top: 0.5em;
}

/* ======================
お電話番号
======================*/
.contact-form__tel-field-group {
    display: flex;
    max-width: 470px;
    width: 100%;
}

.contact-form__tel-field-group input[type="text"] {
    text-align: center;
}

.contact-form__tel-bar {
    display: inline-flex;
    align-items: center;
    height: 60px;
    margin: 0 12px;
}

.contact-form__mail-txt {
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    font-weight: 400;
    line-height: 1;
    margin-bottom: 13px;
}

.contact-form__mail-wrapper + .contact-form__mail-wrapper {
    margin-top: 17px;
}

/* ======================
お問い合わせ項目
======================*/
.contact-form__check-wrapper {
    display: inline-block;
    margin-bottom: 22px;
}

.contact-form__check-wrapper:last-of-type {
    margin-bottom: 0;
}

.contact-form__note {
    font-weight: 700;
    font-size: 24px;
    font-size: clamp(18px, 1.3vw, 24px);
}

.contact-form__check-wrapper input[type="checkbox"] {
    display: none;
}

.contact-form__check-txt {
    /* font-size: 24px; */
    font-size: clamp(18px, 1.3vw, 24px);
    font-weight: 400;
    letter-spacing: .06em;
    position: relative;
    padding-left: 2.3em;
    display: inline-block;
}

.contact-form__check-txt::before {
    content: "";
    width: 1.2em;
    height: 1.2em;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    border: 2px solid #b2b2b2;
}

.contact-form__check-txt::after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1.2em;
    height: 1.2em;
    background: #1da96f url(../img/check.png)no-repeat;
    background-position: center;
    background-size: 80%;
    opacity: 0;
    border: 2px solid #1da96f;
}

.contact-form__check-wrapper input[type="checkbox"]:checked + .contact-form__check-txt::after {
    opacity: 1;
}

/* ======================
送信内容を確認する
======================*/
.contact-form__btn-unit {
    margin-top: 110px;
}

.contact-form__btn {
    display: block;
    background: #f43b3b;
    color: #fff;
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
    padding: 35px 17px 35px;
    border-bottom: 6px solid #c90000;
    font-size: 30px;
    text-align: center;
    letter-spacing: .2em;
    font-weight: 900;
    border-radius: 4px;
    line-height: 1;
}

/* ======================
バリデーション
======================*/
.contact-form__check-group {
    position: relative;
}

.contact-form__check-group .parsley-errors-list {
    position: absolute;
    bottom: -25px;
}

.parsley-errors-list {
    color: #f43b3b;
    font-weight: 500;
}

.contact-form__name-col .parsley-errors-list {
    width: 100%;
    padding-left: 70px;
}

@media (max-width:1279px) {
    .contact-form td {
        padding: 20px 29px;
    }

    .contact-form th {
        width: 294px;
    }
}

@media (max-width:1024px) {

    .contact-form input[type="text"],
    .contact-form input[type="email"],
    .contact-form textarea {
        padding: 0 15px;
    }

    .contact-form textarea {
        padding: 15px;
    }

    .contact-form__ruby {
        width: 50px;
    }

    .contact-form__name input[type="text"] {
        width: calc(100% - 50px);
    }

    .contact-form__name-col .parsley-errors-list {
        padding-left: 50px;
    }

    .contact-form__btn-unit {
        margin-top: 80px;
    }

    .contact-form__btn {
        font-size: 24px;
    }
}

@media (max-width:850px) {
    .contact-form__check-group {
        padding-bottom: 10px;
    }

    .contact-form__check-group .parsley-errors-list {
        bottom: -20px;
    }

    .contact__heading {
        margin-bottom: 80px;
        padding: 30px;
    }

    .contact-form tbody,
    .contact-form table,
    .contact-form tr,
    .contact-form th,
    .contact-form td {
        display: block;
        width: 100%;
    }

    .contact-form th {
        padding: 20px 26px;
    }

    .contact-form td {
        padding: 20px;
    }

    .contact-form__btn-unit {
        margin-top: 40px;
    }
}

@media (max-width:599px) {
    .parsley-errors-list {
        font-size: 12px;
    }

    .contact-form__check-group .parsley-errors-list {
        bottom: -15px;
    }

    .contact-form__name-col .parsley-errors-list {
        padding-left: 35px;
    }

    .contact-form__check-txt {
        font-size: clamp(16px, 1.3vw, 24px);
    }

    .contact-form__note {
        font-size: clamp(13px, 1.3vw, 24px);
    }

    .contact__heading {
        margin-bottom: 40px;
    }

    ::placeholder {
        font-size: clamp(16px, 1.3vw, 24px);
    }

    /* 旧Edge対応 */
    ::-ms-input-placeholder {
        font-size: clamp(16px, 1.3vw, 24px);
    }

    .contact-form select,
    .contact-form input[type="text"],
    .contact-form input[type="email"],
    .contact-form textarea {
        height: 50px;
        line-height: 50px;
        font-size: clamp(16px, 1.3vw, 24px);
    }

    .contact-form select {
        line-height: 46px;
        padding: 0 8px;
    }

    .contact-form textarea {
        height: 180px;
        line-height: 1.83;
    }

    .contact-form input[type="text"],
    .contact-form input[type="email"] {
        padding: 0 8px;
    }

    .contact-form td {
        padding: 15px 0;
    }

    .contact-form th {
        padding: 13px;
        font-size: clamp(16px, 1.6vw, 30px);
    }

    .contact-form__select-wrapper::before {
        height: 50px;
    }

    .contact-form__ruby {
        width: 35px;
    }

   .contact-form__ruby {
    font-size: clamp(14px, 1.3vw, 24px);
   }

   .contact-form__name input[type="text"] {
    width: calc(100% - 35px);
   }

   .contact-form__name-col {
    margin-right: 17px;
   }

   .contact-form__posi .contact-form__ruby {
    width: 75px;
   }

   .contact-form__posi input[type="text"] {
    width: calc(100% - 75px);
   }

   .contact-form__addr-flex .contact-form__ruby {
    width: 70px;
   }

   .contact-form__addr-flex .contact-form__post,
   .contact-form__addr-flex .contact-form__select-wrapper,
   .contact-form__addr-flex .contact-form__city {
    width: calc(100% - 70px);
   }

   .contact-form__post-bar {
    height:50px;
   }

   .contact-form__tel-bar {
    height: 50px;
   }

   .contact-form__btn {
    font-size: 18px;
    padding: 25px 12px;
   }

    .contact-form__post,
    .contact-form__select-wrapper {
        max-width: 230px;
    }
}

/* 確認画面 */
/* ================================================*/
#formWrap table th {
    border-bottom: 2px solid #fff;
}

#formWrap table th,
#formWrap table td {
    padding: 20px;
    line-height: 1.83;
    background: #fff;
    font-size: 18px;
    font-size: clamp(18px, 1.3vw, 24px);
    letter-spacing: .06em;
}

#formWrap table th {
    width: 400px;
    background-image: -webkit-linear-gradient( -10deg, rgb(0,171,105) 0%, rgb(0,112,69) 100%);
    background-image: -ms-linear-gradient( -10deg, rgb(0,171,105) 0%, rgb(0,112,69) 100%);
    color: #fff;
}

#formWrap h3 {
    font-size: 50px;
    font-weight: 900;
    margin-bottom: 60px;
    letter-spacing: .06em;
}

#formWrap table {
    width: 100%;
    margin: 0 auto 80px;
}

#formWrap p {
    margin-bottom: 2em;
}

#formWrap input[type="submit"],
#formWrap input[type="button"] {
    display: block;
    background: #f43b3b;
    color: #fff;
    max-width: 500px;
    width: 100%;
    margin: 12px 0 auto;
    padding: 35px 17px 35px;
    border-bottom: 6px solid #c90000;
    font-size: 30px;
    text-align: center;
    letter-spacing: .2em;
    font-weight: 900;
    border-radius: 4px;
    line-height: 1;
}

#formWrap input[type="button"] {
    background: #979797;
    border-bottom-color: #727171;
}

@media (max-width:1279px) {
    #formWrap table th {
        width: 294px;
    }
}

@media (max-width:1024px) {
    #formWrap table th {
        width: 294px;
    }

    #formWrap input[type="submit"],
    #formWrap input[type="button"] {
        font-size: 24px;
    }
}

@media (max-width:750px) {
    #formWrap table,
     #formWrap tbody,
     #formWrap table tr,
     #formWrap table th,
     #formWrap table td {
        display: block;
        width: 100%;
     }

     #formWrap table th,
     #formWrap table td {
        padding: 15px;
        font-size: 14px;
     }

     #formWrap table {
        margin: 0 auto 30px;
     }

     #formWrap input[type="submit"],
     #formWrap input[type="button"] {
        font-size: 18px;
        padding: 25px 12px;
    }

    #formWrap h3 {
        font-size: 32px;
        margin-bottom: 30px;
    }

    #formWrap p {
        font-size: 14px;
    }
}

/* 完了画面 */
/* ================================================*/
.post-cont h1 {
    font-size: 50px;
    font-weight: 900;
    margin-bottom: 60px;
    letter-spacing: .06em;
}

.post-cont p {
    margin-bottom: 2em;
    font-size: 22px;
}

@media (max-width:850px) {
    .post-cont p {
        font-size: 18px;
    }

    .post-cont + .contact-form__btn-unit {
       margin-top: 60px;
    }
}

@media (max-width:750px) {
    .post-cont h1 {
        font-size: 32px;
        margin-bottom: 30px;
    }

    .post-cont p {
        font-size: 15px;
    }

    .post-cont + .contact-form__btn-unit {
       margin-top: 40px;
    }
}


/* 枠線　確認画面 */
/* ================================== */
#formWrap table td {
    border: 1px solid #727171;
}

@media (max-width:750px) {
    #formWrap table td {
        border: none;
    }
    
}