@charset "utf-8";

section:not(.main-visual) {padding: 65px 0;}

.img-wrap img {width: 100%; height: 100%; object-fit: cover;}

.btn-area {width: 100%; display: flex; justify-content: center;}
.btn-submit {width: 127px; height: 45px; border-radius: 30px; color: #fff; line-height: 45px; background-color: #1673E2; margin-top: -20px; font-size: 18px; font-weight: 500; text-align: center; box-shadow: 0px 4px 20px 1px rgba(222, 222, 222, 0.6);}

.checkbox-item input[type="checkbox"] {display:none;}
.checkbox-item input[type="checkbox"] + label{position: relative; flex-shrink: 0; cursor:pointer; color: var(--text1) !important; font-size: 20px; font-weight: 500; padding-left: 30px !important;}
.checkbox-item input[type="checkbox"] + label:hover {color: var(--text2) !important; transition: all 0.3s;}
.checkbox-item input[type="checkbox"] + label:before{position:absolute; content:""; display:inline-block; box-sizing: border-box; background-color: #D9D9D9; width:22px; height:22px; left:0; top: 53%; transform: translate(0, -50%); border-radius: 50%;}
.checkbox-item input[type="checkbox"]:checked + label:before{ content:"";  background-color: #D9D9D9; width:22px; height:22px; border: 6px solid #3C65ED;}

.radio-item input[type="radio"] {display:none;}
.radio-item input[type="radio"] + label{position: relative; flex-shrink: 0; cursor:pointer; color: var(--text1) !important; font-size: 18px; font-weight: 500; padding-left: 30px !important;}
.radio-item input[type="radio"] + label:hover {color: var(--text2) !important; transition: all 0.3s;}
.radio-item input[type="radio"] + label:before{position:absolute; content:""; display:inline-block; box-sizing: border-box; background-color: #D9D9D9; width:22px; height:22px; left:0; top: 53%; transform: translate(0, -50%); border-radius: 50%;}
.radio-item input[type="radio"]:checked + label:before{ content:"";  background-color: #D9D9D9; width:22px; height:22px; border: 6px solid #3C65ED;}
.radio-item.etc input[type="text"] {width: 282px; margin-left: 20px;}

.form-card > form {display: flex; flex-direction: column; row-gap: 72px;}
.form-card .input-group {display: flex; flex-direction: column; row-gap: 30px;}
.form-card .input-group .tit-area {border-bottom: 1px solid #8C8C8C;}
.form-card .input-group .tit-area h4 {position:relative; display: inline-block; font-size: 24px; font-weight: 600; padding-bottom: 16px;}
.form-card .input-group .tit-area.must h4::after {position: absolute; top: -2px; right: -11px; font-size: 18px; content: '*'; color: #1673E2;}

.input-area .input_multi,
.input-area .input_triple {width: 100%; display: flex; align-items: center; column-gap: 30px;}
.input-area .input_multi.flex-start,
.input-area .input_triple.flex-start {align-items: flex-start;}
.input-area .input_multi > div {width: calc(100% / 2);}
.input-area .input_triple > div {width: calc(100% / 3);}
.input-area .input-item {width: 100%;}
.input-area .input-item > span {position: relative; display: inline-block; font-size: 20px; font-weight: 500; padding-bottom: 16px;}
.input-area .input-item.must > span::after {position: absolute; top: -2px; right: -11px; font-size: 18px; content: '*'; color: #1673E2;}
.input-area .input-item .input-item-area {display: flex; column-gap: 10px;}
.input-area .input-item .input-item-area input,
.input-area .input-item .input-item-area select,
.input-area .input-item .input-item-area.textarea-area textarea,
.input-area .input-item .input-item-area.fileupload-item .span-upload {width: 100%; height: 44px; background-color: #EEE; border: 1px solid #EEE; padding: 12px 16px; color: #656565; font-size: 16px; font-weight: 500; outline: none; border-radius: 3px;}
.input-area .input-item .input-item-area input:focus,
.input-area .input-item .input-item-area select:focus,
.input-area .input-item .input-item-area.link-item-area input:focus,
.input-area .input-item .input-item-area.textarea-area textarea:focus {border: 1px solid #000; background-color: #fff; transition: all 0.3s;}
.input-area .input-item .input-item-area select {padding:0 42px 0 20px; white-space: nowrap;overflow: hidden;text-overflow: ellipsis; outline: none;appearance: none;}
.input-area .input-item .input-item-area.textarea-area textarea {height: 240px; resize: none;}
.input-area .input-item .input-item-area.textarea-area .wr_content {width: 100%;}
.input-area .input-item .input-item-area.fileupload-item {flex-wrap: wrap; row-gap: 20px;}
.input-area .input-item .input-item-area.radio-area {display: flex; flex-direction: column; row-gap: 20px; align-items: flex-start;}
.input-area .input-item .input-item-area.radio-area .radio-item {display: flex; align-items: center;}
.input-area .input-item .input-item-area.link-item-area {position: relative;}
.input-area .input-item .input-item-area.link-item-area label {position: absolute; top: 50%; left: 20px; transform: translate(0, -50%); width: 30px; height: 30px; background-color: #656565; border-radius: 50%; display: flex; align-items: center; justify-content: center;}
.input-area .input-item .input-item-area.link-item-area input {border: 1px solid #E9E9E9; background-color: #fff; padding: 16px 20px 16px 62px;}
.input-area .input-item .input-item-area.input-item-multi {flex-direction: column; row-gap: 16px;}
.input-area .input-item .input-item-area.num {align-items: center;}
.input-area .select-item {position: relative; cursor: pointer;}
.input-area .select-item svg {position: absolute; top: 50%; right: 20px; transform: translate(0, -50%) rotate(0deg); transition: transform 0.3s ease; pointer-events: none;}
.input-area .select-item:focus-within svg {transform: translate(0, -50%) rotate(180deg);}

.main-tit {width:100%; margin-bottom: 50px; display: flex; flex-direction: column; justify-content: center; align-items: center; row-gap: 10px;}
.main-tit span {font-size: 28px; font-weight: 700;}

.main-visual {position: relative; background-image: url(../img/main/main-visual.jpg); background-repeat: no-repeat; background-size: cover; margin-bottom: 35px;}
.main-visual::after {position: absolute; width: 100%; height: 100%; background-color: #000; opacity: 0.4; left: 0; top: 0; display: block; content: "";}
.main-visual .inner {position: relative; z-index: 1; display: flex; align-items: center; padding: 180px 0 140px 0;}
.main-visual .inner .left .icon-area {display: flex;  flex-direction: column; row-gap: 10px;}
.main-visual .inner .left .icon-area a {display: flex; align-items: center; column-gap: 16px;}
.main-visual .inner .left .icon-area a .icon {width: 37px; height: 37px; display: flex; align-items: center; justify-content: center; background-color: #fff; border-radius: 12px;}
.main-visual .inner .left .icon-area a span {color: #fff; font-weight: 500;}
.main-visual .inner .left {width: 60%; display: flex; flex-direction: column; row-gap: 24px;}
.main-visual .inner .left .img-wrap {position: relative; width: 100%; height: 636px; background-color: #fff; border-radius: 30px; overflow: hidden; }
.main-visual .inner .left .img-wrap img {position: absolute; top: 0; right: 0; width: auto; height: 96%; }
.main-visual .inner .right {width: 40%; display: flex; flex-direction: column; align-items: center; justify-content: space-around; row-gap: 74px;}
.main-visual .inner .right .logo {display: flex; flex-direction: column; align-items: center; justify-content: center; row-gap: 20px;}
.main-visual .inner .right .logo p {color: #fff; font-size: 20px; font-weight: 500; text-align: center;}
.main-visual .inner .right .logo p b {font-size: 24px; font-weight: 600;}
.main-visual .inner .right ul {display: flex; column-gap: 100px;}
.main-visual .inner .right ul li {display: flex; flex-direction: column; align-items: center; justify-content: center; row-gap: 22px;}
.main-visual .inner .right ul li .img {width: 210px; height: 210px; background-color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center;}
.main-visual .inner .right ul li span {color: #fff; font-size: 18px; font-weight: 600; text-align: center; line-height: 23px;}

.main-service .cont {display: flex; justify-content: center; align-items: center; flex-wrap: wrap; column-gap: 24px; row-gap: 53px;}
.main-service .cont li {width: calc(100% / 3 - 16px); padding: 60px 38px 50px 38px; border-radius: 20px; box-shadow: 0px 4px 20px 1px rgba(222, 222, 222, 0.6);}
.main-service .cont li h4 {font-size: 20px; font-weight: 700;}
.main-service .cont li p {font-size: 18px; color: #555; font-weight: 500; padding-top: 10px; padding-bottom: 55px;}
.main-service .cont li img {width: 100%;border-radius: 20px;}

.main-review .cont {display: flex; flex-direction: column; row-gap: 60px;}
.main-review .cont .card .more {position: relative; z-index: 1; width: 100%; height: 50px; background-color: #1673E2; display: flex; justify-content: center; align-items: center; column-gap: 4px; border: 1px solid #1673E2; border-radius: 0 0 20px 20px;}
.main-review .cont .card .more span {font-size: 20px; color: #fff; font-weight: 500;}
.main-review .cont .card .more svg {transform: rotate(180deg); transition: 0.3s;}
.main-review .cont .card .card-info {height: 350px; padding: 30px 105px; border-radius: 20px 20px 0 0; border: 1px solid #C0C0C0;}
.main-review .cont .card .card-info p {font-weight: 500; font-size: 18px; color: #555; word-break: keep-all;}
.main-review .cont .card .card-info span {display: block; font-size: 20px; font-weight: 500; color: #000;}
.main-review .cont .card .card-info .card-t {position: relative; z-index: 1; display: flex; column-gap: 50px; align-items: center; padding: 22px 24px;}
.main-review .cont .card .card-info .card-t .img-wrap {width: 400px; height: 250px; flex-shrink: 0; border-radius: 20px; overflow: hidden;}
.main-review .cont .card .card-info .card-t .info {width: 100%;}
.main-review .cont .card .card-info .card-t .info span {padding-bottom: 20px;}
.main-review .cont .card .card-info .list {display: flex; flex-direction: column; row-gap: 32px; opacity: 0; transition: opacity .2s;}
.main-review .cont .card .card-info .list li {display: flex; align-items: center; justify-content: space-between; column-gap: 40px; padding: 25px 24px; border-bottom: 1px solid #DDDDDD;}
.main-review .cont .card .card-info .list li p {width: 100%; line-height: 30px;}
.main-review .cont .card .card-info .list li .img-wrap {width: 234px; height: 164px; border-radius: 10px; overflow: hidden; flex-shrink: 0;;}
.main-review .cont .card .card-info .list li:nth-of-type(1) {margin-top: 20px;}
.main-review .cont .card .card-info .list li.btn-area {justify-content: center; border-bottom: 0; padding: 0 0 0 30px;}
.main-review .cont .card .card-info .list li.btn-area .more-btn {position: relative; z-index: 1; display: flex; padding: 6px 20px; border-radius: 20px; align-items: center; column-gap: 10px;box-shadow: 0px 4px 20px 1px rgba(222, 222, 222, 0.6);}
.main-review .cont .card .card-info .list li.btn-area .more-btn span {font-size: 18px; font-weight: 500;}
.main-review .cont .card .card-info .list li.btn-area .more-btn .icon {width: 37px; height: 37px; display: flex; align-items: center; justify-content: center; border-radius: 12px; box-shadow: 0px 4px 20px 1px rgba(222, 222, 222, 0.6);}

.main-review .cont .card.open .more svg {transform: rotate(0deg);}
.main-review .cont .card.open .card-info {height: auto;}
.main-review .cont .card.open .card-info .list {opacity: 1;}

.main-contact {position: relative; z-index: 1; padding: 50px 130px !important; border-radius: 20px; box-shadow: 0px 4px 20px 1px rgba(222, 222, 222, 0.6); margin: 100px auto 100px auto}
.main-contact .main-tit {margin-bottom: 65px;}
.main-contact .form-card .input-group .info {width: 100%; height: 210px; padding: 20px 24px; overflow-y: scroll; border: 1px solid #eee; border-radius: 3px; font-weight: 500; color: #262626;}
.main-contact .form-card .input-group.user .input-area .input_multi {column-gap: 150px;}

/* 반응형 */
@media screen and (max-width: 1520px) {
    .main-visual .inner {padding: 180px 32px 140px 32px; column-gap: 40px;}
    .main-visual .inner .right ul {column-gap: 60px;}
    .main-visual .inner .right ul li .img {width: 180px; height: 180px;}
    .main-visual .inner .right ul li .img img {width: 150px; height: auto;}
    .main-visual .inner .right ul li:nth-of-type(2) .img img {width: 125px; height: auto;}
    .main-visual .inner .right ul li span {font-size: 16px;}

    .main-contact {width: calc(100% - 64px); margin: 65px 32px;}
}

@media screen and (max-width: 1350px) {

    .main-review .cont .card .card-info {height: 320px; padding: 30px;}
    .main-review .cont .card .card-info .card-t {padding: 0;}
}

@media screen and (max-width: 1200px) {

    .main-visual .inner {column-gap: 30px; padding: 120px 32px 70px 32px;}
    .main-visual .inner .left {width: 100%;}
    .main-visual .inner .right {width: auto; flex-shrink: 0;}
    .main-visual .inner .left .img-wrap {height: 57vw;}
    .main-visual .inner .right .logo {display: none;}
    .main-visual .inner .right ul {flex-direction: column; row-gap: 40px;}

    .main-service .cont {justify-content: flex-start;}
    .main-service .cont li {width: calc(100% / 2 - 12px);}

    .main-contact {padding: 30px 18px !important;}
}

@media screen and (max-width: 1024px) {

    section:not(.main-visual) {padding: 50px 0;}

    .main-visual {margin-bottom: 50px;}
    .main-visual .inner {flex-direction: column; row-gap: 40px;}
    .main-visual .inner .left .img-wrap {height: 67vw;}
    .main-visual .inner .right ul {flex-direction: row; justify-content: center; align-items: flex-start;}

    .main-service .cont {column-gap: 16px; align-items: flex-start;}
    .main-service .cont li {width: calc(100% / 2 - 8px); padding: 40px 28px;}
    .main-service .cont li h4 {font-size: 18px; word-break: keep-all;}
    .main-service .cont li p {padding-bottom: 40px; font-size: 16px;}
    
    .main-review .cont .card .card-info {height: 300px;}
    .main-review .cont .card .card-info span,
    .main-review .cont .card .card-info p {font-size: 16px; line-height: normal;}
    .main-review .cont .card .card-info .card-t {column-gap: 30px;}
    .main-review .cont .card .card-info .card-t .img-wrap {width: 300px; height: 187px;}
    .main-review .cont .card .card-info .card-t .info span {font-size: 18px; padding-bottom: 10px;}
    .main-review .cont .card .more span {font-size: 18px;}
    .main-review .cont .card .more svg {width: 28px; height: 28px; flex-shrink: 0;}
    .main-review .cont .card .card-info .list li {padding: 15px 0; column-gap: 16px;}
    .main-review .cont .card .card-info .list li .img-wrap {width: 200px; height: 150px;}

    .main-tit {row-gap: 20px; margin-bottom: 60px;}
    .main-tit img {width: 80px; height: auto;}
    .main-tit span {font-size: 24px;}

    .form-card .input-group .tit-area h4 {font-size: 18px;}
    .input-area .input-item > span {font-size: 16px;}
    .input-area .input_multi,
    .input-area .input_triple {flex-direction: column; row-gap: 30px;}
    .input-area .input_multi > div {width: 100%;}
    .input-area .input-item .input-item-area.num {width: 50%;}

    .radio-item input[type="radio"] + label,
    .checkbox-item input[type="checkbox"] + label {font-size: 16px;}


}

@media screen and (max-width: 768px) {

    .main-visual .inner {padding: 120px 20px 36px 20px;}

    .main-service .cont li {width: 100%; padding: 30px 20px;}
    .main-service .cont li p {padding-bottom: 30px;}

    .main-contact {width: calc(100% - 40px); margin: 50px 20px;}

    .input-area .input-item .input-item-area.num,
    .input-area .input-item .input-item-area.radio-area .radio-item {width: 100%;}

    .main-review .cont .card .card-info {height: auto;}
    .main-review .cont .card .card-info .card-t {flex-direction: column; row-gap: 20px;}
    .main-review .cont .card .card-info .card-t .img-wrap,
    .main-review .cont .card .card-info .list li .img-wrap {width: 100%; height: 46vw;}
    .main-review .cont .card .card-info .list li:nth-of-type(1) {padding-top: 40px;}
    .main-review .cont .card .card-info .list li {flex-direction: column-reverse; row-gap: 20px; padding: 40px 0;}
    .main-review .cont .card .card-info .list {display: none;}
    .main-review .cont .card.open .card-info .list {display: block;}
    .main-review .cont .card .card-info .list li.btn-area {padding: 40px 0 0 0;}

}

@media screen and (max-width: 500px) {

    .main-tit {row-gap: 16px; margin-bottom: 30px;}
    .main-tit img {width: 60px; height: auto;}
    .main-tit span {font-size: 20px;}

    .main-visual .inner .right ul {flex-direction: column;align-items: center;}
}

@media screen and (max-width: 410px) {

}

/* 24시간 출장비 0원 스타일 */
.main-service .main-tit span {
    font-size: 2.5em;
    font-weight: bold;
}

.main-service .main-tit span .price-zero {
    color: #ff6600;
    font-size: 1.2em;
}

/* 서비스 항목의 가격(4만원) 빨강색 처리 */
.main-service .cont li h4 .price {
    color: #ff0000;
    font-weight: bold;
    font-size: 1.1em;
}

/* 반응형 - 태블릿 */
@media screen and (max-width: 1024px) {
    .main-service .main-tit span {
        font-size: 2em;
    }
}

/* 반응형 - 모바일 */
@media screen and (max-width: 768px) {
    .main-service .main-tit span {
        font-size: 1.8em;
    }
    
    .main-service .main-tit span .price-zero {
        font-size: 1.1em;
    }
}

@media screen and (max-width: 500px) {
    .main-service .main-tit span {
        font-size: 1.5em;
    }
}