@import url("https://fonts.googleapis.com/css?family=Poppins");

@keyframes jelly {
    0%,
    100% {
        transform: scale(1, 1);
    }
    25% {
        transform: scale(0.9, 1.1);
    }
    50% {
        transform: scale(1.1, 0.9);
    }
    75% {
        transform: scale(0.95, 1.05);
    }
}

#contact {
    position: relative;
    padding-left: 245px;
}

#eForm1 {
    width: 75%;
    background: #FFF;
}

#contact .contact_us {
    position: relative;
    width: 100%;
    height: 100vh;
    color: white;
    min-height: 620px;
}

#contact .contact_us .title {
    position: absolute;
    font-size: 100px;
    left: 80px;
    top: 15%;
    line-height: 100px;
    display: flex;
    flex-wrap: wrap;
    width: 50%;
}

#contact .contact_us .title span {
    display: inline-block;
}

#contact .contact_us .slogan {
    position: absolute;
    font-size: 16px;
    top: 16%;
    line-height: 22px;
    z-index: 3;
    width: 240px;
    right: 40%;
    transform: translateX(100%) translateY(50px);
    margin-right: -2px;
    opacity: 0;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .contact_us .slogan.show {
    opacity: 1;
    transform: translateX(100%) translateY(0);
}

#contact .contact_us .company_name {
    position: absolute;
    font-size: 16px;
    width: 240px;
    right: 40%;
    transform: translateX(100%) translateY(50px);
    margin-right: -2px;
    top: 16%;
    line-height: 22px;
    z-index: 3;
    margin-top: 245px;
    opacity: 0;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .contact_us .company_name.show {
    opacity: 1;
    transform: translateX(100%) translateY(0);
}

#contact .contact_us .copyright {
    position: absolute;
    font-size: 12px;
    width: 240px;
    right: 40%;
    transform: translateX(100%) translateY(50px);
    margin-right: -2px;
    top: 16%;
    line-height: 17px;
    z-index: 3;
    margin-top: 305px;
    color: #727272;
    opacity: 0;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .contact_us .copyright.show {
    opacity: 1;
    transform: translateX(100%) translateY(0);
}

#contact .contact_us .info {
    position: absolute;
    font-size: 13px;
    width: calc((100vw - 245px) * 0.4 - 100px);
    right: 40%;
    transform: translateX(100%) translateY(50px);
    margin-right: -2px;
    bottom: 65px;
    line-height: 20px;
    z-index: 3;
    color: white;
    opacity: 0;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .contact_us .info.show {
    opacity: 1;
    transform: translateX(100%) translateY(0);
}

#contact .contact_us .info a {
    color: white;
}

#contact .contact_us .info .location {
    position: absolute;
    font-size: 18px;
    font-weight: bold;
    transform: rotate(-90deg);
    transform-origin: left bottom;
    bottom: 5px;
    left: -36px;
}

#contact .contact_us .info .box {
    position: relative;
    margin-top: 38px;
}

#contact .contact_us .info .t1 {
    width: 120px;
    margin-left: calc((100vw - 245px) * 0.2);
}

#contact .contact_us .info .t2 {
    width: auto;
    margin-left: calc((100vw - 245px) * 0.2);
}

#contact .contact_us .info .t3 {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 240px;
}

#contact .contact_us .info .name {
    position: relative;
    opacity: 0.5;
    margin-bottom: 9px;
    display: block;
}

#contact .contact_us .info .field {
    position: relative;
}

#contact .contact_us .cloud {
    position: absolute;
    z-index: 3;
    left: 80px;
    bottom: 65px;
    display: flex;
    opacity: 0;
    transform: translateY(50px);
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .contact_us .cloud.show {
    opacity: 1;
    transform: translateX(0) translateY(0);
}

#contact .contact_us .cloud .name {
    position: absolute;
    top: -50px;
    font-size: 16px;
    font-weight: bold;
    left: 5px;
}

#contact .contact_us .cloud .link {
    position: relative;
    margin-right: 61px;
    width: 22px;
}

#contact .form_area {
    display: flex;
    position: relative;
    width: 80%;
    margin: 0 auto 0 0;
    /*padding-top: 310px;*/
    z-index: 3;
    padding-bottom: 130px;
    /*overflow: hidden;*/
    opacity: 0;
    transform: translateY(0);
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
    /*background: #FFF;*/
}

#contact .form_area .type {
    position: absolute;
    left: calc((100vw - 245px) * 0.6 - 55px);
    top: 53px;
    display: flex;
    opacity: 0;
    transform: translateY(20px);
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

#contact .form_area .type .type_name {
    position: relative;
    font-size: 18px;
    font-weight: bold;
    margin-right: 48px;
    padding: 6px 10px;
    width: 100px;
    display: block;
    -webkit-transition: all 0.6s ease;
    -moz-transition: all 0.6s ease;
    -o-transition: all 0.6s ease;
    -ms-transition: all 0.6s ease;
    transition: all 0.6s ease;
    cursor: pointer;
}

#contact .form_area .type .type_name.active {
    color: white;
    background-color: #151f17;
}

#contact .form_area .type.show {
    opacity: 1;
    transform: translateY(0);
}

#contact .form_area .service_box {
    background: url("../images/contact_bg.jpg") no-repeat center;
    background-size: cover;
    padding: 57px 90px 95px 47px;
    width: auto;
    opacity: 1;
    color: #7c7c7c;
    box-shadow: 5px 5px 10px rgb(0 0 0 / 50%);
    position: absolute;
    height: auto;
    left: 75%;
    z-index: 1;
}

#contact .form_area .service_box .field {
    color: #FFF;
}

#contact .form_area.show {
    margin-top: -25vh;
    /*background: #fff;*/
    opacity: 1;
    transform: translateY(0);
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .form_area .service_box.show {
    opacity: 1;
    transform: translateY(0);
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .form_area .service_box .title {
    position: relative;
    color: #FFF;
    font-size: 50px;
    font-weight: bold;
    display: inline-block;
    margin-bottom: 45px;
}

#contact .form_area .service_box .title span {
    display: block;
}

#contact .form_area .service_box .name {
    position: relative;
    font-size: 16px;
    font-weight: bold;
    margin-top: 45px;
    margin-bottom: 20px;
}

#contact .form_area .service_box .service {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    width: 265px;
}

#contact .form_area .service_box .service .item {
    position: relative;
    font-size: 14px;
    width: 50%;
    margin-bottom: 22px;
}

#contact .form_area .form_box {
    padding: 60px;
    position: relative;
    width: 100%;
    display: block;
    right: 0;
    opacity: 1;
}

#contact .form_area .form_box.show {
    opacity: 1;
    transform: translateY(0);
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .form_area .form_box .contact_title {
    position: relative;
    margin-bottom: 80px;
    display: inline-block;
    width: 50%;
    padding: 0 20px;
    cursor: pointer;
}

#contact .form_area .form_box .contact_title select {
    position: relative;
}

#contact .form_area .form_list {
    position: relative;
    display: table;
}

#contact .form_area .form_list .line {
    position: relative;
    margin-bottom: 35px;
    display: inline-block;
    width: 50%;
    padding: 0 20px;
}

#contact .form_area .form_list .line.code {
    margin-top: 25px;
}

#contact .form_area .form_list .line label {
    position: relative;
    display: block;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 8px;
}

#contact .form_area .form_list .line .tip {
    position: absolute;
    font-size: 12px;
    left: 86px;
    top: 2px;
    color: #242c51;
}

#contact .form_area .form_list .line .inputbox {
    position: relative;
    width: 100%;
    border: 0;
    background-color: #f5f5f5;
    height: 66px;
    outline: 0;
    padding: 0 12px;
    font-size: 16px;
}

#contact .form_area .form_list .line .textarea {
    position: relative;
    width: 100%;
    border: 0;
    background-color: #f5f5f5;
    height: 160px;
    outline: 0;
    padding: 10px 12px;
    font-size: 16px;
    resize: none;
}

#contact .form_list .input .codeimg {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    width: 132px;
}

#contact .form_area .sendmail {
    z-index: 1;
    margin: 1em;
    top: 50px;
    position: relative;
    width: 202px;
    height: 62px;
    border: 0;
    background-color: #2f2d54;
    color: white;
    text-align: center;
    line-height: 62px;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
    overflow: hidden;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#contact .form_area .sendmail:after {
    content: '';
    background-image: url(../images/logobg.jpg);
    position: absolute;
    width: 100%;
    height: 100%;
    background-position: center;
    left: 0;
    z-index: -1;
    transform: scale(1.2);
    opacity: 0;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#footer {
    display: none;
}

#thanks {
    display: none;
    position: fixed;
    z-index: 999;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    background-color: rgba(0, 0, 0, 0.8);
    cursor: pointer;
}

#thanks .close {
    width: 55px;
    height: 55px;
    right: 10px;
    position: absolute;
    top: 4px;
    z-index: 5;
    -webkit-transition: all 0.8s ease;
    -moz-transition: all 0.8s ease;
    -o-transition: all 0.8s ease;
    -ms-transition: all 0.8s ease;
    transition: all 0.8s ease;
}

#thanks .close::after {
    content: '';
    width: 35px;
    height: 1px;
    background-color: rgba(0, 0, 0, 0.74);
    position: absolute;
    right: 50%;
    top: 50%;
    transform: rotate(-45deg) translateX(50%) translateY(-50%);
    transform-origin: right;
}

#thanks .close::before {
    content: '';
    width: 35px;
    height: 1px;
    background-color: rgba(0, 0, 0, 0.74);
    position: absolute;
    left: 50%;
    top: 50%;
    transform: rotate(45deg) translateX(-50%) translateY(-50%);
    transform-origin: left;
}

#thanks .thanks_box {
    width: 770px;
    height: 538px;
    background-color: white;
    display: block;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    padding: 33px;
}

#thanks .thanks_box .box {
    position: relative;
    border: 9px solid black;
    display: block;
    height: 100%;
    padding: 35px 45px;
}

#thanks .maintitle span:after {
    background-color: rgba(0, 0, 0, 0.73);
}

#thanks .title {
    color: black;
    position: absolute;
    font-size: 75px;
    left: 45px;
    top: 30px;
    line-height: 75px;
    display: flex;
    flex-wrap: wrap;
    width: 50%;
}

#thanks .title span {

}

#thanks .memo {
    font-size: 14px;
    position: absolute;
    bottom: 40px;
    left: 45px;
    font-weight: bold;
}

#thanks .img {
    position: absolute;
    right: 47px;
    bottom: 26px;
}

#thanks .img img {
    margin: 0 auto;
    display: block;
}

.video-bg {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
}

.topbg {
    overflow: hidden;
}

/* 110/10/14 */
.form_list input[type="radio"] {
    display: none;
}

.form_list input[type="radio"] + label {
    color: #000;
}

.form_list input[type="radio"] + label span {
    display: inline-block;
    width: 19px;
    height: 19px;
    margin: -2px 10px 0 0;
    vertical-align: middle;
    background: url(../images/check_radio_sheet.png) 1px top no-repeat;
    cursor: pointer;
}

.form_list input[type="radio"]:checked + label span {
    background: url(../images/check_radio_sheet.png) -19px top no-repeat;
}

#howknow, #budget {
    display: flex;
    align-items: center;
    position: inherit;
    min-height: 66px;
}

.form_list #budget input[type="radio"] + label {
    margin-right: 20px;
}

#howknow {
    justify-content: space-evenly;
}

#howknow .radioOption {
    width: 117px;
    height: 117px;
    margin: 35px 0;
    border-radius: 50%;
    background-color: #FFF;
    position: relative;
    /*transition: background-color .5s ease,color .5s ease;*/
    opacity: 0;
    transform: translateY(100px);
    z-index: 1;
    outline: none;
    border: none;
}
#howknow .radioOption:before {
    content: '';
    z-index: -1;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    border-radius: 50%;
    border: 4px solid rgba(46, 45, 82, 0.2);
    transform-origin: center;
    transform: scale(1);
}

#howknow .radioOption.animated {
    opacity: 1;
    transform: translateY(0);
    transition: opacity .5s ease, transform .5s ease;
}
#howknow input[type="checkbox"]:checked + label .radioOption {
    animation: jelly .5s;
    box-shadow: 5px 5px 10px rgb(0 0 0 / 50%);
    background-color: #2f2d54;
}
#howknow input[type="checkbox"]:checked + label .radioOption p {
    color: #FFF;
}

#howknow .radioOption img, #howknow .radioOption p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 18px;
    color: #2f2d54;
    font-weight: bold;
    height: auto;
    max-height: 50%;
}

.form_list .input {
    position: relative;
    z-index: 1;
    display: inline-block;
    margin: 1em;
    max-width: 50%;
    width: calc(50% - 2em);
    vertical-align: top;
}

.form_list .input.w-100 {
    max-width: 100%;
    width: calc(100% - 2em);
}

.form_list .input.h-100 {
    height: 100%;
}

.form_list .input .tip {
    display: none;
    font-size: 50%;
    position: absolute;
    bottom: -20px;
    right: 10px;
    color: #242c51;
}

.form_list .input__field {
    position: absolute;
    display: block;
    float: right;
    padding: 0.8em 0;
    width: 60%;
    height: 100%;
    border: none;
    border-radius: 0;
    background: #f0f0f0;
    color: #aaa;
    -webkit-appearance: none;
    /* for box shadows to show on iOS */
}

.form_list select.input__field::-ms-expand {
    display: none;
}

.form_list select.input__field {
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") no-repeat transparent;
    background-position: right 0.75rem center;
    background-size: 20px 16px;
}

.form_list .input__field:focus {
    outline: none;
}

.form_list .input__label {
    border-bottom: 1px solid #c7c7c7;
    display: inline-block;
    float: right;
    width: 40%;
    color: #7c7c7c;
    font-size: 70.25%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

.form_list .input__field--madoka:focus + .input__label {
    border-bottom: 2px solid #2e2d52;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
}

.form_list .input__label:before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    width: 0%;
    height: 100%;
    border-top: 2px solid #2e2d52;
    -webkit-transition: width 0.2s;
    transition: width 0.2s;
}

.form_list .input__field--madoka:focus + .input__label:before {
    width: calc(50% - 1.5em);
    transition-delay: 0.4s;
}

.form_list .input__label:after {
    content: '';
    border-right: 2px solid #2e2d52;
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 0%;
    -webkit-transition: height 0.2s;
    transition: height 0.2s;
}

.form_list .input__field--madoka:focus + .input__label:after {
    height: 100%;
    transition-delay: 0.2s;
}

.form_list .input__label-content {
    position: relative;
    display: block;
    padding: 1.6em 0;
    width: 100%;
    height: 100%;
    font-size: initial;
}

.form_list .graphic {
    position: absolute;
    top: 0;
    left: 0;
    fill: none;
}

.form_list .input--madoka {
    min-height: 66px;
    height: 100%;
}

.form_list .input__field--madoka {
    width: 100%;
    background: transparent;
    color: #000;
    font-size: initial;
    font-weight: bold;
}

.form_list .input__label--madoka {
    position: absolute;
    width: 100%;
    height: 100%;
    color: #7c7c7c;
    text-align: left;
    cursor: text;
}

.form_list .input__label-content--madoka {
    -webkit-transform-origin: 0% 50%;
    transform-origin: 0% 50%;
    -webkit-transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
}

.form_list .graphic--madoka {
    -webkit-transform: scale3d(1, -1, 1);
    transform: scale3d(1, -1, 1);
    pointer-events: none;
}

.form_list .input__field--madoka:focus + .input__label--madoka, .form_list .input--filled .input__label--madoka {
    cursor: default;
    pointer-events: none;
}

.form_list .input__field--madoka:focus + .input__label--madoka .input__label-content--madoka, .form_list .input--filled .input__label-content--madoka {
    -webkit-transform: scale3d(1, 1, 1) translate3d(0, -2em, 0);
    transform: scale3d(1, 1, 1) translate3d(0, -2em, 0);
}

.form_list #memo {
    position: relative;
    resize: none;
}

.color_box {
    width: 100%;
    height: calc(50% + 102px);
    position: absolute;
    bottom: 0;
    background: #f7f7f7;
}

/* start the code here */

@media only screen and (max-width: 1400px) {
    #eForm1 {
        width: 100%;
        background: unset;
    }

    #contact .form_area .form_box {
        padding: 60px 0;
    }

    #contact .form_area .service_box .name {
        margin-top: 20px;
    }

    #contact .form_area .service_box {
        width: 100%;
        left: 0;
        display: flex;
        justify-content: space-between;
        padding: 60px;
        position: unset;
    }

    #contact .form_area {
        max-width: 890px;
        width: 90%;
        margin: 0 auto;
        flex-wrap: wrap-reverse;
        background: #FFF;
    }

    #contact .contact_us .company_name, #contact .contact_us .copyright, #contact .contact_us .slogan {
        right: 40%;
        left: auto;
        width: 225px;
    }

    #contact .contact_us .cloud .link {
        margin-right: 30px;
    }

    .color_box {
        height: calc(50% - 80px);
        z-index: -1;
    }
}

@media only screen and (max-width: 1300px) {
    #contact .contact_us .title {
        font-size: 70px;
        left: 5%;
        line-height: 74px;
    }

    #contact .contact_us .cloud {
        left: 5%;
    }


    #contact .form_area .service_box .title {
        font-size: 55px;
        line-height: 55px;
    }

    #contact .contact_us .info .t3 {
        width: 60%;
    }
}

@media only screen and (min-width: 1025px) {
    #contact .contact_us .info {
        right: 20%;
        bottom: unset;
        top: 16%;
        margin-top: 245px;
        width: calc((100vw - 245px) * 0.2 - 100px);
    }

    #contact .contact_us .info .t3 {
        top: 0;
        width: calc((100vw - 245px) * 0.2 - 100px);
    }

    #contact .contact_us .info .box {
        margin-top: unset;
    }

    #contact .form_area .type .type_name:hover {
        background-color: black;
        color: white;
    }

    #contact .form_area .sendmail:hover {
        background-color: transparent;
    }

    #contact .form_area .sendmail:hover:after {
        transform: scale(1);
        opacity: 1;
        transition: all 1.2s cubic-bezier(0.4, 0, 0, 1);
    }

    #thanks .close:hover {
        transform: rotate(180deg);
    }
}

@media only screen and (max-width: 1024px) {
    #thanks .thanks_box {
        transform: translateX(-50%) translateY(-50%) scale(.8);
    }

    #footer {
        display: block;
    }

    #contact {
        position: relative;
        padding-left: 0;
        width: 100%;
    }

    #contact .contact_us .title {
        font-size: 60px;
        left: 5%;
        line-height: 68px;
        top: 50px;
    }

    #contact .contact_us {
        height: 615px;
        min-height: 400px;
    }

    #contact .contact_us .cloud, #contact .contact_us .cloud.show, #contact .form_area .service_box .service {
        display: none;
    }

    #contact .contact_us .slogan, #contact .contact_us .slogan.show {
        right: auto;
        left: 5%;
        margin-right: 0;
        transform: translateX(0%);
        margin-top: 250px;
        top: 0;
    }

    #contact .contact_us .company_name, #contact .contact_us .company_name.show {
        right: 5%;
        transform: translateX(0%);
        top: 0;
        margin-top: 250px;
        width: 240px;
        margin-right: 0;
    }

    #contact .contact_us .copyright, #contact .contact_us .copyright.show {
        right: 5%;
        transform: translateX(0%);
        top: 0;
        margin-top: 310px;
        width: 240px;
        margin-right: 0;
    }

    #contact .contact_us .info, #contact .contact_us .info.show {
        right: auto;
        margin-right: auto;
        top: 50px;
        left: 5%;
        width: 90%;
        display: flex;
        justify-content: end;
        transform: translateX(0%) translateY(0);
    }

    #contact .contact_us .info .t1 {
        width: 120px;
        margin-right: 0;
        margin-left: 0;
        padding-left: 35px;
    }

    #contact .contact_us .info .location {
        left: 18px;
    }

    #contact .contact_us .info .t2 {
        width: 120px;
        margin-right: 0;
        margin-left: 0;
    }

    #contact .contact_us .info .t3 {
        position: relative;
        bottom: 0;
        left: 0;
        width: 240px;
    }

    #contact .form_area .form_box {
        width: 100%;
    }

    #contact .form_area .form_box .contact_title select {
        position: relative;
        width: 100%;
        height: 100%;
        border: 0;
        color: white;
        background-color: transparent;
        font-size: 16px;
        font-weight: bold;
        outline: 0;
        box-shadow: none;
    }

    #contact .form_area .form_box .contact_title {
        display: block;
        overflow: hidden;
        text-overflow: ellipsis;
        padding: 0;
        margin-right: 0;
        outline: none;
        font-size: 18px;
        letter-spacing: 1px;
        border: 2px solid black;
        padding-left: 18px;
        background-color: black;
        color: white;
        font-weight: bold;
        width: 100%;
        height: 66px;
        line-height: 66px;
        padding-right: 60px;
    }

    #contact .form_area .form_box .contact_title:before {
        content: '';
        background-color: white;
        position: absolute;
        right: 28px;
        width: 10px;
        height: 10px;
        top: 50%;
        transform: rotate(45deg);
        margin-top: -6px;
    }

    #contact .form_area .form_box .contact_title:after {
        content: '';
        background-color: black;
        position: absolute;
        right: 23px;
        width: 20px;
        height: 10px;
        top: 50%;
        z-index: 2;
        margin-top: -11px;
    }

    #contact .form_area .type {
        position: absolute;
        right: 0;
        top: 53px;
        display: flex;
        width: 100%;
        justify-content: center;
        left: auto;
    }

    #contact .form_area .type .type_name {
        text-align: center;
        margin-right: 20px;
        margin-left: 20px;
    }

    #contact .form_area .service_box .title {
        font-size: 50px;
        line-height: 50px;
    }
}

@media only screen and (max-width: 600px) {
    .color_box {
        height: calc(50% - 50px);
    }

    #howknow .radioOption p {
        font-size: 14px;
    }

    #howknow .radioOption {
        width: 66px;
        height: 66px;
    }

    #howknow, #budget {
        flex-wrap: wrap;
        height: 150px;
    }

    .form_list .input.w-mobile-100 {
        max-width: 100%;
        width: calc(100% - 2em);
    }

    #contact .contact_us .bg {
        background-color: #181b17;
    }

    #contact .contact_us .title {
        font-size: 35px;
        left: 8%;
        line-height: 40px;
        top: 50px;
    }

    #contact .contact_us {
        height: 660px;
    }

    #contact .contact_us .left_info {
        left: 8%;
        bottom: auto;
        margin-top: 160px;
    }

    #contact .contact_us .left_info .slogan, #contact .contact_us .left_info .slogan.show {
        font-size: 16px;
        display: block;
        line-height: 22px;
        font-weight: bold;
        margin-bottom: 85px;
    }

    #contact .contact_us .right_info, #contact .contact_us .right_info.show {
        right: auto;
        width: 84%;
        font-size: 12px;
        line-height: 18px;
        padding-top: 18px;
        bottom: 30px;
        left: 8%;
    }

    #contact .contact_us .slogan, #contact .contact_us .slogan.show {
        font-size: 12px;
        line-height: 18px;
        margin-top: 180px;
        left: 8%;
    }

    #contact .contact_us .company_name, #contact .contact_us .company_name.show {
        right: auto;
        transform: translateX(0%);
        top: 0;
        padding-top: 340px;
        width: 240px;
        margin-right: 0;
        left: 8%;
        position: relative;
        margin-top: 0;
    }

    #contact .contact_us .copyright, #contact .contact_us .copyright.show {
        right: auto;
        transform: translateX(0%);
        top: 0;
        margin-right: 0;
        left: 8%;
        position: relative;
        margin-top: 12px;
        width: 80%;
    }

    #contact .contact_us .info, #contact .contact_us .info.show {
        left: 8%;
        height: 100px;
        top: unset;
    }

    #contact .contact_us .info .field {
        position: absolute;
        bottom: 0;
        width: 100%;
        word-break: break-word;
        padding-right: 35px;
    }

    #contact .contact_us .info .field:before {
        content: 'Open';
        position: relative;
        opacity: 0.5;
        margin-bottom: 9px;
        display: block;
    }

    #contact .contact_us .info .field.tel:before {
        content: 'Tel';
    }

    #contact .contact_us .info .field.fax:before {
        content: 'Fax';
    }

    #contact .contact_us .info .field.email:before {
        content: 'email';
    }

    #contact .contact_us .info .name {
        display: none;
    }

    #contact .contact_us .info a {
        color: black;
    }

    #contact .contact_us .info .t1 {
        width: 45%;
        margin-right: 0;
        position: absolute;
        top: 185px;
        color: black;
        left: 5%;
        padding-left: 20px;
    }

    #contact .contact_us .info .t2 {
        width: 45%;
        margin-right: 0;
        position: absolute;
        top: 185px;
        color: black;
        left: 50%;
        padding-left: 0;
        right: auto;
    }

    #contact .contact_us .info .location {
        left: 5%;
    }

    #contact .contact_us .info .t3 {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 240px;
        /*margin-left: 20px;*/
        height: 70px;
    }

    #contact .contact_us .info .location {
        letter-spacing: 1px;
    }

    #contact .form_area .type .type_name {
        text-align: center;
        margin-right: 0;
        margin-left: 0;
        width: 50%;
        height: 34px;
        line-height: 33px;
        font-size: 12px;
        padding: 0;
    }

    #contact .form_area .type .type_name.active:after {
        display: none;
    }

    #contact .form_area .type .type_name:after {
        content: '';
        background-color: #dcdedc;
        position: absolute;
        bottom: 0;
        width: 94%;
        height: 1px;
        left: 3%;
    }

    #contact .form_area .service_box.show {
        display: none;
    }

    #contact .form_area .form_box {
        padding: 34px;
    }

    #contact .form_area.show {
        margin-top: unset;
        width: 100%;
    }

    #contact .form_area {
        max-width: 890px;
        width: 84%;
        padding-bottom: 55px;
    }

    #contact .form_area .type {
        top: 45px;
    }

    #contact .form_area .service_box .title {
        position: absolute;
        font-size: 30px;
        display: inline-block;
        left: 0;
        line-height: 35px;
        top: -108px;
    }

    #contact .form_area .form_box .contact_title select {
        font-size: 18px;
    }

    #contact .form_area .form_list .line.code {
        margin-bottom: 50px;
    }

    #contact .form_area .form_list .line label {
        font-size: 16px;
        margin-bottom: 15px;
    }

    #contact .form_area .sendmail {
        width: 80%;
        margin: 0 auto;
        display: block;
    }

    #contact .form_area .form_list .line .tip {
        position: absolute;
        font-size: 14px;
        left: 83px;
        top: 0;
    }

    #contact .form_list .input .codeimg {
        width: 110px;
    }

    #thanks .thanks_box {
        transform: none;
        width: 100%;
        height: 100%;
        left: 0;
        top: 0;
    }

    #thanks .thanks_box .box {
        padding: 0;
    }

    #thanks .thanks_box {
        padding: 20px;
        min-height: 570px;
    }

    #thanks .title {
        font-size: 11vw;
        line-height: 11vw;
        left: 7%;
        top: 0;
        position: relative;
        margin-top: 70px;
    }

    #thanks {
        overflow: scroll;
    }

    #thanks .img {
        position: absolute;
        right: auto;
        bottom: 26px;
        transform: translateX(-50%);
        left: 50%;
        width: 260px;
    }

    #thanks .memo {
        position: relative;
        bottom: auto;
        left: 7%;
        margin-top: 32px;
    }

}

@media (any-hover: hover) {
    #howknow .radioOption:hover:before {
        transform-origin: center;
        transform: scale(1.75);
        opacity: 0;
        transition: transform 0.5s ease-in-out, opacity 0.5s ease-in-out;
    }
    #howknow .radioOption:hover {
        cursor: pointer;
        background-color: #2f2d54;
        color: #FFF;
    }
    #howknow .radioOption:hover p {
        color: inherit;
    }
}
/* contact大標題 */
#contact .big-title {
    z-index: 1;
}

#contact .big-title .title-item {
    overflow: hidden;
}

#contact .big-title span {
    transition: initial;
    transform: translateY(0) skewY(0);
}

#contact .big-title>div {
    position: relative;
}

#contact .big-title>div:after {
    content: '';
    background-color: rgba(255, 255, 255, 0.73);
    width: 0;
    height: 2px;
    position: absolute;
    bottom: -2px;
    left: 0;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

#contact .big-title>div:nth-child(2):after {
    transition: all 1.5s ease;
}

#contact .big-title.show>div:after {
    width: 100%;
}

#contact .contact_us .title {
    width: 30%;
}