@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@100;300;400;500;700;900&display=swap');



* {padding: 0; margin: 0; border: 0; box-sizing: border-box;}
li {list-style: none;}
a {text-decoration: none; color: inherit;}
img {vertical-align: top; max-width: 100%; filter: none;}
button {background-color: inherit; cursor: pointer; color: #333;}
html, body, section {font-family: 'Noto Sans KR', sans-serif; color: #333; overflow-x: hidden;}
li, input, select, button, textarea {font-family: 'Noto Sans KR', sans-serif;}




/* index */
.index_top {max-width: 720px; width: 100%; margin: 0 auto; padding: 200px 0 120px; color: #961db9;}

.index_top > h2 {font-size: 48px; text-align: center; margin-bottom: 100px;}
.index_top > h2 br.top_none {display: none;}

.index_top .index_check {width: 100%;}
.index_top .index_check label {width: 100%; display: flex; align-items: center; gap: 20px; margin-bottom: 20px; cursor: pointer;}
.index_top .index_check label input[type="checkbox"] {appearance: none; outline: none; cursor: pointer; width: 30px; height: 30px; border: 1px solid #961db9; cursor: pointer; position: relative; top: 3px;}
.index_top .index_check label input[type="checkbox"]:checked {background-color: #961db9;}
.index_top .index_check label p {font-size: 36px;}

.index_top .index_correct {position: relative; width: 680px; height: 100px; border-radius: 100px; background-color: #961db9; margin: 100px auto 0; cursor: pointer;}
.index_top .index_correct p {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 48px; font-weight: 700; color: #fff;}


.index_after {width: 100%; text-align: center; color: #961db9; padding: 0 0 120px; display: none; opacity: 0; position: relative; top: 120px;}
/* .index_after {width: 100%; text-align: center; color: #961db9; padding: 0 0 120px; display: block; opacity: 1; position: relative; top: 0px;} */

.index_after h2 {font-size: 60px; line-height: 60px;}

.index_after h3 {font-size: 48px; line-height: 48px; margin: 30px auto 80px;}

.index_after .circle {display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 25px;}
.index_after .circle p {width: 10px; height: 10px; border-radius: 50%; background-color: #961db9;}


.index_but {max-width: 1120px; width: 100%; margin: 0 auto; padding: 0 0 280px; display: none; opacity: 0; position: relative; top: 180px;}
/* .index_but {max-width: 1120px; width: 100%; margin: 0 auto; padding: 0 0 280px; display: block; opacity: 1; position: relative; top: 0px;} */

.index_but h2 {font-size: 150px; line-height: 150px; text-align: center; color: #961db9; margin-bottom: 120px;}

.index_but .contents_box {width: 100%;}
.index_but .contents_box.web .contents {position: relative; width: 866px; height: 200px; margin-bottom: 80px; display: none; opacity: 0;}
.index_but .contents_box.web .contents div {position: absolute; top: 0; left: 0; width: 855px; height: 200px;}
.index_but .contents_box.web .contents div p {position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex;justify-content: center; align-items: center; font-size: 40px; line-height: 60px; color: #fff;}

.index_but .contents_box.web .contents:last-child {margin-bottom: 0;}
.index_but .contents_box.web .contents:nth-child(even) {margin-left: auto;}
.index_but .contents_box.web .contents:nth-child(even) div p {text-align: right;}

.index_but .contents_box.web .contents:nth-child(1) {left: -866px;}
.index_but .contents_box.web .contents:nth-child(2) {right: -866px;}
.index_but .contents_box.web .contents:nth-child(3) {left: -866px;}
.index_but .contents_box.web .contents:nth-child(4) {right: -866px;}


.index_but .contents_box.web1200 .contents {position: relative; width: 650px; height: 150px; margin-bottom: 60px; display: none; opacity: 0;}
.index_but .contents_box.web1200 .contents div {position: absolute; top: 0; left: 0; width: 650px; height: 150px;}
.index_but .contents_box.web1200 .contents div p {position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex;justify-content: center; align-items: center; font-size: 24px; line-height: 36px; color: #fff;}

.index_but .contents_box.web1200 .contents:last-child {margin-bottom: 0;}
.index_but .contents_box.web1200 .contents:nth-child(even) {margin-left: auto;}
.index_but .contents_box.web1200 .contents:nth-child(even) div p {text-align: right;}

.index_but .contents_box.web1200 .contents:nth-child(1) {left: -650px;}
.index_but .contents_box.web1200 .contents:nth-child(2) {right: -650px;}
.index_but .contents_box.web1200 .contents:nth-child(3) {left: -650px;}
.index_but .contents_box.web1200 .contents:nth-child(4) {right: -650px;}


.index_but .contents_box.mob768 .contents {position: relative; width: 433px; height: 100px; margin-bottom: 60px; display: none; opacity: 0;}
.index_but .contents_box.mob768 .contents div {position: absolute; top: 0; left: 0; width: 433px; height: 100px;}
.index_but .contents_box.mob768 .contents div p {position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex;justify-content: center; align-items: center; font-size: 16px; line-height: 24px; color: #fff;}

.index_but .contents_box.mob768 .contents:last-child {margin-bottom: 0;}
.index_but .contents_box.mob768 .contents:nth-child(even) {margin-left: auto;}
.index_but .contents_box.mob768 .contents:nth-child(even) div p {text-align: right;}

.index_but .contents_box.mob768 .contents:nth-child(1) {left: -433px;}
.index_but .contents_box.mob768 .contents:nth-child(2) {right: -433px;}
.index_but .contents_box.mob768 .contents:nth-child(3) {left: -433px;}
.index_but .contents_box.mob768 .contents:nth-child(4) {right: -433px;}


.index_but .contents_box.mob540 .contents {position: relative; width: 324px; height: 75px; margin-bottom: 40px; display: none; opacity: 0;}
.index_but .contents_box.mob540 .contents div {position: absolute; top: 0; left: 0; width: 320px; height: 75px;}
.index_but .contents_box.mob540 .contents div p {position: absolute; top: 0; left: 0; width: 100%; height: 100%; display: flex;justify-content: center; align-items: center; font-size: 14px; line-height: 21px; color: #fff;}

.index_but .contents_box.mob540 .contents:last-child {margin-bottom: 0;}
.index_but .contents_box.mob540 .contents:nth-child(even) {margin-left: auto;}
.index_but .contents_box.mob540 .contents:nth-child(even) div p {text-align: right;}

.index_but .contents_box.mob540 .contents:nth-child(1) {left: -324px;}
.index_but .contents_box.mob540 .contents:nth-child(2) {right: -324px;}
.index_but .contents_box.mob540 .contents:nth-child(3) {left: -324px;}
.index_but .contents_box.mob540 .contents:nth-child(4) {right: -324px;}








.index_go.web {width: 100%; padding: 0 0 310px; text-align: center; color: #961db9; display: none; opacity: 0; position: relative; top: 300px;}

.index_go.web .top h2 {font-size: 150px; line-height: 150px; margin-bottom: 60px;}
.index_go.web .top img {display: block; width: 300px; margin: 0 auto;}

.index_go.web > p {font-size: 120px; line-height: 120px; font-weight: 300; margin: 180px auto 210px;}

.index_go.web > a {position: relative; display: block; width: 680px; height: 100px; border-radius: 100px; background-color: #961db9; margin: 100px auto 0; cursor: pointer;}
.index_go.web > a span {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 48px; font-weight: 700; color: #fff;}


.index_go.web1200 {width: 100%; padding: 0 0 310px; text-align: center; color: #961db9; display: none; opacity: 0; position: relative; top: 300px;}

.index_go.web1200 .top h2 {font-size: 120px; line-height: 120px; margin-bottom: 60px;}
.index_go.web1200 .top img {display: block; width: 240px; margin: 0 auto;}

.index_go.web1200 > p {font-size: 90px; line-height: 90px; font-weight: 300; margin: 130px auto 150px;}

.index_go.web1200 > a {position: relative; display: block; width: 480px; height: 80px; border-radius: 100px; background-color: #961db9; margin: 60px auto 0; cursor: pointer;}
.index_go.web1200 > a span {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 36px; font-weight: 700; color: #fff;}


.index_go.mob768 {width: 100%; padding: 0 0 310px; text-align: center; color: #961db9; display: none; opacity: 0; position: relative; top: 300px;}

.index_go.mob768 .top h2 {font-size: 90px; line-height: 90px; margin-bottom: 40px;}
.index_go.mob768 .top img {display: block; width: 160px; margin: 0 auto;}

.index_go.mob768 > p {font-size: 50px; line-height: 50px; font-weight: 300; margin: 80px auto 110px;}

.index_go.mob768 > a {position: relative; display: block; width: 240px; height: 60px; border-radius: 100px; background-color: #961db9; margin: 60px auto 0; cursor: pointer;}
.index_go.mob768 > a span {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 24px; font-weight: 700; color: #fff;}


.index_go.mob540 {width: 100%; padding: 0 0 160px; text-align: center; color: #961db9; display: none; opacity: 0; position: relative; top: 300px;}

.index_go.mob540 .top h2 {font-size: 90px; line-height: 90px; margin-bottom: 40px;}
.index_go.mob540 .top img {display: block; width: 160px; margin: 0 auto;}

.index_go.mob540 > p {font-size: 40px; line-height: 40px; font-weight: 300; margin: 80px auto 110px;}

.index_go.mob540 > a {position: relative; display: block; width: 240px; height: 60px; border-radius: 100px; background-color: #961db9; margin: 60px auto 0; cursor: pointer;}
.index_go.mob540 > a span {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 24px; font-weight: 700; color: #fff;}
















footer {width: 100%; background-color: #961db9; color: #fff; padding: 30px 0 50px;}

footer .inner {max-width: 1280px; width: 100%; display: flex; justify-content: space-between; margin: 0 auto;}

footer .inner .left img {width: 147px;}
footer .inner .left .box {margin-top: 30px;}
footer .inner .left .box .contents {display: flex; margin-bottom: 5px;}
footer .inner .left .box .contents:last-child {margin-bottom: 0;}
footer .inner .left .box .contents h2 {font-size: 14px; width: 110px;}
footer .inner .left .box .contents p {font-size: 14px; word-break: keep-all;}

footer .inner .right {position: relative; top: 15px;}

footer .inner .right .pri {display: flex; justify-content: right; gap: 23px;}
footer .inner .right .pri a {position: relative; font-size: 12px; font-weight: 300; color: #fff;}
footer .inner .right .pri a::before {content: ''; position: absolute; top: 4px; right: -11px; width: 1px; height: 12px; background-color: #fff;}
footer .inner .right .pri a:last-child::before {display: none;}

footer .inner .right .sns {display: flex; justify-content: right; gap: 10px; margin: 30px 0 40px;}
footer .inner .right .sns a {display: flex; justify-content: center; align-items: center; width: 40px; height: 40px;}
footer .inner .right .sns a img {width: 100%; height: 100%; object-fit: cover;}

footer .inner .right .copy {font-size: 21px; text-align: right;}





/******************* main 시작 *******************/
/* common */
.title_radius {position: relative; width: 160px; height: 35px; border-radius: 35px; background-color: #961db9; margin: 0 auto;}
.title_radius h2 {position: absolute; top: 44%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 24px; font-weight: 900; color: #fff;}

.title_radius.white {background-color: #fff;}
.title_radius.white h2 {color: #961db9;}

.title_p {font-size: 36px; color: #961db9; font-weight: 300; text-align: center;}





/* header */
header {position: fixed; top: 0; left: 0; width: 100%; height: 90px; background-color: #fff;  box-shadow: 0px 10px 15px rgba(0,0,0,0.1); z-index: 1000;}

header .inner {display: flex; justify-content: space-between; align-items: center; max-width: 1280px; width: 100%; height: 100%; margin: 0 auto;}
header .inner h1 a img {width: 147px;}
header .inner .gnb {display: flex;}
header .inner .gnb li {width: 140px; height: 50px;}
header .inner .gnb li a {display: block; width: 100%; height: 100%; text-align: center; color: #808080; line-height: 48px; font-size: 14px;}
header .inner .gnb li.active {background-color: #961db9;}
header .inner .gnb li.active a {color: #fff;}
header .inner .gnb li:hover {background-color: #961db9;}
header .inner .gnb li:hover a {color: #fff;}

.ham {position: absolute; top: 50%; right: 16px; transform: translateY(-50%); width: 40px; cursor: pointer; display: none;}





/* aside */
.aside_bg {position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: #000; opacity: 0.6; z-index: 1000; cursor: pointer; display: none;}

aside {position: fixed; top: 0; right: -240px; width: 240px; height: 100%; background-color: #fff; z-index: 1001;}

aside .top {position: relative; width: 100%; height: 100px; display: flex; justify-content: space-between; align-items: center; padding: 0 40px 0 30px;}
aside .top img {width: 100px;}
aside .top a:last-child {font-size: 18px; font-weight: 700; color: #961db9;}

aside .close {position: absolute; top: 50%; right: 10px; transform: translateY(-50%); width: 40px; height: 40px; border-radius: 50%; background-color: #961db9; cursor: pointer;}
aside .close span:first-child {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(45deg); width: 22px; height: 3px; background-color: #fff; border-radius: 2px;}
aside .close span:last-child {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(-45deg); width: 22px; height: 3px; background-color: #fff; border-radius: 2px;}

aside .gnb li {width: 100%; height: 40px; border-top: 1px dashed #ccc;}
aside .gnb li a {display: flex; justify-content: space-between; align-items: center; width: 100%; height: 100%; padding: 0 30px; font-size: 12px; color: #961db9;}
aside .gnb li a span {display: block; width: 10px; height: 10px; background-color: #fff; border-radius: 50%;}

aside .gnb li.active {background-color: #961db9; border-top: none;}
aside .gnb li.active a {color: #fff; font-weight: 700;}
aside .gnb li:hover {background-color: #961db9; border-top: none;}
aside .gnb li:hover a {color: #fff; font-weight: 700;}





/* right_wing */
.right_wing {position: fixed; top: 50%; right: -150px; transform: translateY(-50%); width: 150px; z-index: 50;}

.right_wing .contents li {width: 100%; height: 150px;}
.right_wing .contents li a {display: flex; flex-direction: column; gap: 20px; width: 100%; height: 100%; background-color: #333; padding-top: 25px; padding-left: 28px;}
.right_wing .contents li a h2 {font-size: 14px; line-height: 15px; color: #fff;}
.right_wing .contents li a img {width: 50px; height: 50px;}

.right_wing .contents li:nth-child(1) a {border-radius: 20px 0 0 0;}
.right_wing .contents li:last-child a {background-color: #fce400; border-radius: 0 0 0 20px;}
.right_wing .contents li:last-child a h2 {color: #333;}

.right_wing .close {position: absolute; bottom: -50px; right: 0; width: 50px; height: 50px; background-color: #961db9; border-radius: 0 0 0 20px; cursor: pointer; box-shadow: -1px 1px 5px rgba(0,0,0,0.5);}
.right_wing .close span:first-child {position: absolute; top: 16px; left: 16px; width: 21px; height: 3px; background-color: #fff; border-radius: 3px; transform: rotate(35deg);}
.right_wing .close span:last-child {position: absolute; top: 27px; left: 16px; width: 21px; height: 3px; background-color: #fff; border-radius: 3px; transform: rotate(-35deg);}

.wing_open {position: fixed; top: 50%; right: -50px; width: 40px; height: 50px; background-color: #961db9; border-radius: 20px 0 0 20px; cursor: pointer; z-index: 50; box-shadow: 0px 0px 5px rgba(0,0,0,0.5);}
.wing_open span:first-child {position: absolute; top: 17px; left: 11px; width: 21px; height: 3px; background-color: #fff; border-radius: 3px; transform: rotate(-35deg);}
.wing_open span:last-child {position: absolute; top: 28px; left: 11px; width: 21px; height: 3px; background-color: #fff; border-radius: 3px; transform: rotate(35deg);}





/* main_slide */
.main_slide {width: 100%; height: 650px; margin-top: 90px; background-color: #961db9;}

.main_slide .swiper-slide {position: relative; width: 100%; height: 100%;}
.main_slide .swiper-slide .box {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); max-width: 840px; width: 100%; height: 100%; display: flex; align-items: center;}
.main_slide .swiper-slide .box > img {height: 100%; object-fit: contain;}
.main_slide .swiper-slide .box .txt {color: #fff;}
.main_slide .swiper-slide .box .txt h2 {font-size: 30px; word-break: keep-all;}
.main_slide .swiper-slide .box .txt p {font-size: 50px; font-weight: 300; margin-bottom: 30px;}
.main_slide .swiper-slide .box .txt img {width: 215px;}

.main_slide .swiper-pagination {position: absolute; bottom: 40px; left: 50%; transform: translateX(-50%); z-index: 15; display: flex; align-items: center;}
.main_slide .swiper-pagination-bullet {width: 15px; height: 15px; border: 1px solid #fff; background-color: transparent; opacity: 1;}
.main_slide .swiper-pagination-bullet:last-child {margin-right: 0px;}
.main_slide .swiper-pagination-bullet-active {background-color: #fff; opacity: 1;}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {margin: 0 4px;}





/* service */
#service {width: 100%; padding-top: 120px;}

#service > h2 {font-size: 36px; font-weight: 900; color: #961db9; text-align: center;}

#service .title_radius {margin: 100px auto 0;}


#service .inner {width: 100%; background-color: #fff;}
#service .inner01 {width: 100%; background-color: #e6e6e6;}

#service .price {max-width: 1000px; width: 100%; margin: 0 auto; padding: 90px 0 120px;}

#service .price .contents_box {width: 100%; display: flex; justify-content: space-between; margin-top: 60px;}
#service .price .contents_box .contents {width: 280px; cursor: pointer;}
#service .price .contents_box .contents .box {position: relative; width: 100%; height: 280px; border: 1px solid #961db9; border-radius: 15px; padding: 35px 25px 25px; color: #961db9;}
#service .price .contents_box .contents .box .top h2 {font-size: 40px; line-height: 40px; font-weight: 900; margin-bottom: 15px;}
#service .price .contents_box .contents .box .top p {font-size: 24px; line-height: 24px; display: flex; justify-content: right;}

#service .price .contents_box .contents .box .line {width: 100%; height: 1px; background-color: #961db9; margin: 15px auto 10px;}

#service .price .contents_box .contents .box .middle .price_box {display: flex; justify-content: space-between; align-items: center;}
#service .price .contents_box .contents .box .middle .price_box p {font-size: 16px; font-weight: 700;}
#service .price .contents_box .contents .box .middle .price_box h2 {font-size: 24px; font-weight: 900;}

#service .price .contents_box .contents:hover .box {color: #fff; background-color: #961db9;}
#service .price .contents_box .contents:hover .line {background-color: #fff;}

#service .price .contents_box .contents .box p.vat {position: absolute; bottom: 25px; left: 25px; font-size: 14px;}

#service .price .contents_box .contents > span {display: block; font-size: 14px; line-height: 20px; padding: 20px 25px 0; color: #961db9; letter-spacing: -1px; word-break: keep-all;}


#service .process {padding: 80px 0;}

#service .process .process_category {display: flex; justify-content: center; align-items: center; gap: 30px; margin: 40px auto 50px;}
#service .process .process_category li {position: relative; width: 60px; height: 60px; background-color: #b3b3b3; border-radius: 50%; cursor: pointer;}
#service .process .process_category li h2 {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 21px; color: #fff; font-weight: 900;}

#service .process .process_category li.on {background-color: #961db9;}

#service .process .contents_box {display: flex; flex-direction: row; flex-wrap: wrap; gap: 25px; max-width: 1145px; margin: 0 auto;}
#service .process .contents_box .contents {width: 560px; height: 200px; border-radius: 15px; border: 1px solid #b3b3b3; background-color: #fff; color: #b3b3b3; padding: 25px 30px 0; cursor: pointer;}
#service .process .contents_box .contents h2 {font-size: 24px; line-height: 24px; font-weight: 900; word-break: keep-all;}
#service .process .contents_box .contents h3 {font-size: 21px; line-height: 21px; margin: 18px 0 12px; word-break: keep-all;}
#service .process .contents_box .contents p {font-size: 18px; line-height: 24px; font-weight: 300; word-break: keep-all;}

#service .process .contents_box .contents.active {border-color: #961db9; background-color: #961db9; color: #fff;}


#service .display {width: 100%; padding: 100px 0 60px;}

#service .display .contents {max-width: 1290px; width: 100%; margin: 50px auto 0; display: flex; flex-direction: row; flex-wrap: wrap; gap: 30px;}
#service .display .contents img {display: block; width: 300px; height: 300px; object-fit: cover;}


#service .list {width: 100%; padding: 100px 0;}

#service .list .list_nav {display: flex; justify-content: space-between; align-items: center; width: 300px; margin: 100px auto 35px;}
#service .list .list_nav img {width: 30px; height: 30px; cursor: pointer;}
#service .list .list_nav p {font-size: 36px; font-weight: 300; color: #961db9; position: relative; top: -3px;}

#service .list .list_slide {width: 100%; margin-left: 160px;}
#service .list .list_slide .swiper-slide {width: 300px;}
#service .list .list_slide .swiper-slide .img_box {width: 300px; height: 300px; border: 1px solid #90a2b1;}
#service .list .list_slide .swiper-slide .img_box img {width: 100%; height: 100%; object-fit: cover;}
#service .list .list_slide .swiper-slide .txt {margin-top: 25px; color: #961db9;}
#service .list .list_slide .swiper-slide .txt h2 {font-size: 24px; line-height: 24px;}
#service .list .list_slide .swiper-slide .txt div {display: flex; justify-content: space-between; width: 240px; margin-top: 15px;}





/* member */
#member {width: 100%; padding: 100px 0; background-color: #961db9;}

#member .inner {max-width: 1160px; width: 100%; margin: 0 auto;}

#member .inner > p {font-size: 36px; font-weight: 300; color: #fff; margin: 50px auto 60px; text-align: center;}
#member .inner > p br.mem_none {display: none;}

#member .inner .top_contents {display: flex; align-items: center; gap: 50px; color: #fff; margin-bottom: 90px;}

#member .inner .top_contents img {width: 560px; height: 640px; border-radius: 15px; object-fit: cover;}

#member .inner .top_contents .right {width: calc(100% - 560px);}
#member .inner .top_contents .right .ttop {margin-bottom: 90px;}
#member .inner .top_contents .right .ttop h2 {font-size: 36px; line-height: 36px; margin-bottom: 25px;}
#member .inner .top_contents .right .ttop p {font-size: 21px; line-height: 40px; word-break: keep-all;}

#member .inner .top_contents .right .bbot {display: flex; gap: 50px;}
#member .inner .top_contents .right .bbot div h2 {font-size: 24px; line-height: 24px; font-weight: 900; margin-bottom: 10px;}
#member .inner .top_contents .right .bbot div h3 {font-size: 36px; font-weight: 900;}

#member .inner .bottom_contents {max-width: 1020px; width: 100%; margin: 0 auto; display: flex; justify-content: space-between; align-items: flex-start; color: #fff; text-align: center;}

#member .inner .bottom_contents img {width: 450px; height: 450px; border-radius: 50%; object-fit: cover;}

#member .inner .bottom_contents h2 {font-size: 24px; line-height: 24px; margin: 30px 0 15px;}
#member .inner .bottom_contents p {font-size: 24px; font-weight: 300;}




/* reference */
#reference {width: 100%; padding: 100px 0;}

#reference .inner {max-width: 1300px; width: 100%; margin: 0 auto;}

#reference .inner .title_radius {margin-bottom: 35px;}

#reference .inner .title_p {margin: 60px auto 50px;}

#reference .inner > h2 {font-size: 36px; font-weight: 900; color: #961db9; margin-bottom: 50px; text-align: center;}

#reference .inner .swiper_inner {position: relative; width: 100%;}

#reference .inner .refer_slide {max-width: 1171px; width: 100%; margin: 0 auto;}
#reference .inner .refer_slide .swiper-slide {width: 357px; color: #961db9;}
#reference .inner .refer_slide .swiper-slide img {width: 100%; height: 640px; object-fit: cover;}
#reference .inner .refer_slide .swiper-slide .txt {margin-top: 20px; display: flex; justify-content: space-between; padding: 0 20px;}
#reference .inner .refer_slide .swiper-slide .txt div h2 {font-size: 21px; font-weight: 900;}
#reference .inner .refer_slide .swiper-slide .txt div p {font-size: 21px;}

#reference .inner .refer_nav {position: absolute; top: 0; left: 0; width: 100%; height: 640px;}
#reference .inner .refer_nav img {position: absolute; top: 50%; transform: translateY(-50%); width: 30px; cursor: pointer;}
#reference .inner .refer_nav img:first-child {left: 0;}
#reference .inner .refer_nav img:last-child {right: 0;}





/* request */
#request {width: 100%; padding: 100px 0; background-color: #961db9;}

#request .inner {max-width: 600px; width: 100%; margin: 0 auto;}

#request .inner .box {width: 100%; margin-top: 80px;}

#request .inner .box > div h2 {font-size: 36px; line-height: 36px; color: #fff; margin-bottom: 70px;}

#request .inner .box .contents_box {width: 600px;}

#request .inner .box .contents_box .contents {width: 100%; display: flex; align-items: center; margin-top: 15px;}
#request .inner .box .contents_box .contents:first-child {margin-top: 0;}

#request .inner .box .contents_box .contents h3 {font-size: 24px; color: #fff; width: 260px;}

#request .inner .box .contents_box .contents > input {width: calc(100% - 260px); height: 60px; border-radius: 15px; background-color: #fff; font-size: 18px; padding: 0 25px; outline: none;}

#request .inner .box .contents_box .contents select {width: calc(100% - 260px); height: 60px; border-radius: 15px; font-size: 18px; padding: 0 25px; outline: none; appearance: none; background: #fff url(../img/down-arrow.png) no-repeat 95%;}

#request .inner .box .contents_box .contents .label {width: calc(100% - 260px); display: flex; justify-content: center; align-items: center; gap: 15px;}
#request .inner .box .contents_box .contents .label label {display: flex; align-items: center; gap: 7px; cursor: pointer;}
#request .inner .box .contents_box .contents .label label input[type="radio"] {outline: none; appearance: none; cursor: pointer; width: 14px; height: 14px; border: 1px solid #fff; position: relative; top: 2px;}
#request .inner .box .contents_box .contents .label label input[type="radio"]:checked {background-color: #fff;}
#request .inner .box .contents_box .contents .label label span {font-size: 18px; font-weight: 700; color: #fff;}

#request .inner .box .contents_box .contents .time {width: calc(100% - 260px); height: 60px; background-color: #fff; border-radius: 15px; display: flex; justify-content: space-between; align-items: center; padding: 0 25px;}
#request .inner .box .contents_box .contents .time input {width: 120px; height: 100%; font-size: 18px; color: #4d4d4d; outline: none; background-color: #fff;}
#request .inner .box .contents_box .contents .time p {font-size: 18px; font-weight: 700; color: #4d4d4d;}

#request .inner .box .left_line {width: 100%; height: 1px; background-color: #fff; margin: 30px auto 20px;}

#request .inner .box .agree_box {width: 430px; margin: 0 auto;}
#request .inner .box .agree_box > div {display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px;}
#request .inner .box .agree_box > div:last-child {margin-bottom: 0;}
#request .inner .box .agree_box label {display: flex; align-items: center; gap: 7px; cursor: pointer;}
#request .inner .box .agree_box label input[type="checkbox"] {outline: none; appearance: none; cursor: pointer; width: 14px; height: 14px; border: 1px solid #fff; position: relative; top: 1px;}
#request .inner .box .agree_box label input[type="checkbox"]:checked {background-color: #fff;}
#request .inner .box .agree_box label span {font-size: 18px; font-weight: 700; color: #fff;}
#request .inner .box .agree_box p {font-size: 18px; font-weight: 700; color: #fff; cursor: pointer;}

#request .inner .box > button {position: relative; display: block; width: 180px; height: 60px; border-radius: 15px; background-color: #fff; margin: 50px auto 0;}
#request .inner .box > button p {position: absolute; top: 48%; left: 50%; transform: translate(-50%, -50%); width: 100%; text-align: center; font-size: 21px; color: #961db9; font-weight: 500;}





/* client */
#client {width: 100%; padding: 150px 0 120px;}

#client .inner {max-width: 1515px; width: 100%; margin: 0 auto;}

#client .inner .box {display: flex; flex-direction: row; flex-wrap: wrap; gap: 15px; width: 100%; margin: 60px auto 0;}
#client .inner .box .contents {display: flex; justify-content: center; align-items: center; width: 240px; height: 180px; border: 1px solid #b3b3b3; background-color: #fff;}
#client .inner .box .contents img {width: 100%; height: 100%; object-fit: cover;}








/* 동의 */
.info_bg {position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: #000; opacity: 0.6; z-index: 9998; cursor: pointer; display: none;}
.info_wrap {position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 650px; height: 600px; background-color: #fff; border-radius: 15px; padding: 15px; z-index: 9999; display: none;}
.info_wrap .in_title {display: flex; justify-content: space-between; align-items: center; border-top: 1px solid #000; border-bottom: 1px solid #000; padding: 8px 0; margin-bottom: 25px;}
.info_wrap .in_title h2 {font-size: 18px;}
.info_wrap .in_title .close {position: relative; width: 30px; height: 30px; cursor: pointer;}
.info_wrap .in_title .close span {position: absolute; top: 50%; left: 50%; width: 20px; height: 3px; background-color: #000; border-radius: 3px;}
.info_wrap .in_title .close span:first-child {transform: translate(-50%, -50%) rotate(45deg);}
.info_wrap .in_title .close span:last-child {transform: translate(-50%, -50%) rotate(-45deg);}
.info_wrap .contents {width: 100%; height: 490px; overflow-y: auto;}
.info_wrap .contents p {font-size: 14px; padding-bottom: 20px;}






/* modal_popup */
#modal_popup{width: auto; height: auto; position: fixed; z-index: 9999; background-color: #fff; left: 10%; top: 10%; border: 1px solid #bbb; max-width: 450px;}
#modal_popup .popup_wrap{display: flex;flex-wrap: wrap; align-content: space-between; height: 100%;}
#modal_popup .popup_wrap .pp_img{width: 100%; cursor: pointer;}
#modal_popup .popup_wrap .pp_img img{max-width: 100%; width: 100%;}
#modal_popup .popup_wrap .popup_btn_wrap { position: relative; display: flex; align-items: center; justify-content: space-between; padding: 0px 10px 5px; width: 100%;}
#modal_popup .popup_wrap .check_box{display: flex; align-items: center; cursor: pointer; }
#modal_popup .popup_wrap .check_box input{margin-right: 7px; cursor: pointer; }
#modal_popup .popup_wrap .check_box label{line-height: 1.1; cursor: pointer; }
#modal_popup .popup_wrap .close_btn{width: 52px;height: 25px; border: 1px solid #ccc; text-align: center; border-radius: 5px; cursor: pointer;background-color: #fff;}

/* slider popup */
#slider_popup{position: fixed; left: 0; top: 50%; transform: translateY(-50%); z-index: 10000; transition: .5s ease;}
#slider_popup .popup_sec{width: 520px; overflow: hidden; height: 715px; background-color: rgba(74,81,95,0.9); transition: .5s ease;}
#slider_popup .popup_sec .swiper-wrapper{}
#slider_popup .popup_sec .swiper-wrapper .swiper-slide{width: 100%;}
#slider_popup .popup_sec .swiper-wrapper .swiper-slide img{width: 100%; height: 100% ;position: absolute;}
#slider_popup .popup_sec .popup_page{bottom: 0; top: 20px;}
.popup_util{position: absolute;right: -50px; top: 50%; transform: translateY(-50%);}
.popup_util .p_util{cursor: pointer; font-weight: 500; font-size: 12px; width: 50px; padding: 7px 0 6px; color: #fff; border-radius: 0px 5px 5px 0; text-align: center;}
.popup_util .open{ background: #5c626f; display: none; }
.popup_util .close{ background: #5c626f; } /* #000; */
.popup_util .p_btn{width : 12px; display: block; margin: 0 auto -4px;}
.popup_util .p_btn img{width: 100%;}
.popup_util2{display: none;}

.slider_popup_close{left: -520px !important;}
.slider_popup_close .popup_util .close{display:none !important}
.slider_popup_close .popup_util .open{display: block !important}
.popup_black_bg{background: #00000070; width: 100%; height: 100%; position: fixed; z-index: 9999; display: none;}

@media(max-width:600px){
/* slider popup */
    #slider_popup{width: 100%; height: 140vw;}
    #slider_popup .popup_sec{width: 100%; height: 100%;}
    .popup_util{position: fixed; z-index: 10000; transform: none; left: 0; display: none; width: 50px;}
    .popup_util2{display: block;}

    .slider_popup_close{left: -100% !important;}
    /* .slider_popup_close .popup_sec{transform: translateX(-100%) !important;} */
    .popup_util.open_popup .close{display:none !important}
    .popup_util.open_popup .open{display: block !important}

    .popup_black_bg{display: block;}
}


















/* 반응형 시작 */
@media(max-width:1650px){

    

}

@media(max-width:1600px){

    

}

@media(max-width:1560px){

    #client .inner .box {max-width: 1005px;}

}

@media(max-width:1440px){

    

}

@media(max-width:1350px){

    header .inner {padding: 0 16px;}

    footer .inner {padding:  0 16px;}

    #service .display .contents {max-width: 1060px; gap: 20px;}
    #service .display .contents img {width: 250px; height: 250px;}

}

@media(max-width:1332px){

    #reference .inner .refer_nav img:first-child {left: 16px;}
    #reference .inner .refer_nav img:last-child {right: 16px;}

}

@media(max-width:1280px){

    #reference .inner .refer_slide {max-width: 906px;}
    #reference .inner .refer_slide .swiper-slide {width: 268px;}
    #reference .inner .refer_slide .swiper-slide img {height: 480px;}
    #reference .inner .refer_slide .swiper-slide .txt {padding: 0; margin-top: 15px;}
    #reference .inner .refer_slide .swiper-slide .txt div h2 {font-size: 18px;}
    #reference .inner .refer_slide .swiper-slide .txt div p {font-size: 18px;}

    #reference .inner .refer_nav {top: 0; left: 50%; transform: translateX(-50%); max-width: 1000px; height: 480px;}
    #reference .inner .refer_nav img:first-child {left: 0px;}
    #reference .inner .refer_nav img:last-child {right: 0px;}

}

@media(max-width:1240px){

    #service .price .contents_box {flex-direction: row; flex-wrap: wrap; justify-content: unset; gap: 40px; max-width: 600px; width: 100%; margin: 60px auto 0;}

}

@media(max-width:1200px){

    header .inner .gnb li {width: 120px;}


    .index_top > h2 {font-size: 36px; margin-bottom: 60px;}

    .index_top .index_check label {gap: 10px; max-width: 480px; width: 100%; margin: 0 auto 20px;}
    .index_top .index_check label input[type="checkbox"] {width: 24px; height: 24px; position: relative; top: 2px;}
    .index_top .index_check label p {font-size: 24px;}

    .index_top .index_correct {width: 480px; height: 80px; margin: 60px auto 0;}
    .index_top .index_correct p {font-size: 36px;}


    .index_after h2 {font-size: 48px; line-height: 48px;}
    .index_after h3 {font-size: 36px; line-height: 36px; margin: 20px auto 60px;}


    .index_but {padding: 0 16px 220px;}
    .index_but h2 {font-size: 100px; line-height: 100px; margin-bottom: 80px;}

    


    


    #service .process .contents_box {padding: 0 16px; max-width: 1017px;}
    #service .process .contents_box .contents {width: 480px; height: 225px;}


    #member .inner .top_contents {max-width: 920px; width: 100%; margin: 0 auto; gap: 30px;}
    #member .inner .top_contents img {width: 450px; height: 515px;}
    #member .inner .top_contents .right {width: calc(100% - 480px);}
    #member .inner .top_contents .right .ttop {margin-bottom: 50px;}
    #member .inner .top_contents .right .ttop h2 {font-size: 24px; line-height: 24px; margin-bottom: 20px;}
    #member .inner .top_contents .right .ttop p {font-size: 18px; line-height: 36px;}
    #member .inner .top_contents .right .bbot {gap: 30px;}
    #member .inner .top_contents .right .bbot div h2 {font-size: 20px; line-height: 20px;}
    #member .inner .top_contents .right .bbot div h3 {font-size: 26px;}


    #reference .inner .title_p {margin: 30px auto 20px;}
    #reference .inner > h2 {font-size: 24px; margin-bottom: 35px;}

    #reference .inner .refer_slide {max-width: 588px;}
    #reference .inner .refer_nav {max-width: 710px;}

}

@media(max-width:1100px){

    

}

@media(max-width:1080px){

    #service .display .contents {gap: 15px; max-width: 845px;}
    #service .display .contents img {width: 200px; height: 200px;}

    #member .inner > p {font-size: 30px;}


    #client {padding: 100px 0;}
    #client .inner .box {max-width: 750px;}

}

@media(max-width:1053px){

    

}

@media(max-width:1024px){

    header .inner h1 {width: 100px; height: 34px;}
    header .inner h1 a img {width: 100px;}
    header .inner .gnb {display: none;}
    .ham {display: block;}


    footer .inner {flex-direction: column; justify-content: center; align-items: center;}
    footer .inner .left {display: flex; flex-direction: column; justify-content: center; align-items: center;}
    footer .inner .right {top: 0; margin-top: 30px; display: flex; flex-direction: column; justify-content: center; align-items: center;}
    footer .inner .right .pri {order: 2; margin: 10px auto;}
    footer .inner .right .sns {order: 1; margin: 0 auto;}
    footer .inner .right .copy {order: 3; font-size: 14px; word-break: keep-all; text-align: center;}


    .main_slide {height: 450px;}
    .main_slide .swiper-slide .box {max-width: 640px;}
    .main_slide .swiper-slide .box .txt h2 {font-size: 24px;}
    .main_slide .swiper-slide .box .txt p {font-size: 36px;}
    .main_slide .swiper-slide .box .txt img {width: 170px;}
    .main_slide .swiper-pagination {bottom: 20px;}


    .title_radius {width: 140px;}
    .title_radius h2 {font-size: 16px;}
    .title_p {font-size: 24px;}


    #service {padding-top: 80px;}
    #service > h2 {font-size: 24px;}
    #service .title_radius {margin: 40px auto 0;}

    #service .price {padding: 50px 0 80px;}


    #service .process .contents_box {max-width: 857px;}
    #service .process .contents_box .contents {width: 400px; height: 255px;}
    #service .process .contents_box .contents h3 {line-height: 24px;}


    #service .list .list_nav {margin: 50px auto 30px;}
    #service .list .list_nav p {font-size: 24px;}

    #service .list .list_slide {margin-left: 40px;}
    #service .list .list_slide .swiper-slide {width: 240px;}
    #service .list .list_slide .swiper-slide .img_box {width: 240px; height: 240px;}
    #service .list .list_slide .swiper-slide .txt h2 {font-size: 20px; line-height: 20px;}
    #service .list .list_slide .swiper-slide .txt div {width: 200px; margin-top: 10px;}
    #service .list .list_slide .swiper-slide .txt div p {font-size: 14px;}
    #service .list .list_slide .swiper-slide .txt div span {font-size: 14px;}


    #member .inner > p br.mem_none {display: block;}

    #member .inner .top_contents {max-width: 740px;}
    #member .inner .top_contents .right {width: calc(100% - 390px);}
    #member .inner .top_contents img {width: 360px; height: 410px;}
    #member .inner .top_contents .right .ttop h2 {font-size: 21px; line-height: 21px; margin-bottom: 10px;}
    #member .inner .top_contents .right .ttop p {font-size: 14px; line-height: 26px;}
    #member .inner .top_contents .right .bbot div h2 {font-size: 16px; line-height: 16px; margin-bottom: 5px;}
    #member .inner .top_contents .right .bbot div h3 {font-size: 20px;}


    #request .inner .box {margin-top: 50px;}
    #request .inner .box .contents_box .contents h3 {font-size: 21px; width: 200px;}
    #request .inner .box .contents_box .contents > input {width: calc(100% - 200px);}
    #request .inner .box .contents_box .contents select {width: calc(100% - 200px);}
    #request .inner .box .contents_box .contents .label {width: calc(100% - 200px);}
    #request .inner .box .contents_box .contents .time {width: calc(100% - 200px);}

}

@media(max-width:939px){

    

} 

@media(max-width:880px){

    #service .display .contents {gap: 20px; max-width: 620px;}
    #service .display .contents img {width: 300px; height: 300px;}

} 

@media(max-width:864px){

    #service .process .contents_box {max-width: 100%;}
    #service .process .contents_box .contents {width: 100%; height: auto; padding: 25px;}

}

@media(max-width:810px){

    

}

@media(max-width:768px){


    .info_wrap {width: 340px; height: 500px;}

    .index_top {padding: 100px 16px;}
    .index_top > h2 {font-size: 24px; margin-bottom: 60px;}
    .index_top > h2 br.top_none {display: block;}

    .index_top .index_check label {gap: 10px; max-width: 343px; width: 100%; margin: 0 auto 20px;}
    .index_top .index_check label input[type="checkbox"] {width: 20px; height: 20px; position: relative; top: 2px;}
    .index_top .index_check label p {font-size: 16px;}

    .index_top .index_correct {width: 240px; height: 60px; margin: 60px auto 0;}
    .index_top .index_correct p {font-size: 24px;}


    .index_after {padding: 0 0 80px;}
    .index_after h2 {font-size: 36px; line-height: 36px;}
    .index_after h3 {font-size: 24px; line-height: 24px; margin: 20px auto 40px;}
    .index_after .circle {gap: 20px;}
    .index_after .circle p {width: 7px; height: 7px;}


    .index_but {padding: 0 16px 220px;}
    .index_but h2 {font-size: 75px; line-height: 75px; margin-bottom: 60px;}

    


    


    .main_slide {height: 300px;}
    .main_slide .swiper-slide .box {max-width: 440px;}
    .main_slide .swiper-slide .box .txt h2 {font-size: 16px;}
    .main_slide .swiper-slide .box .txt p {font-size: 28px; margin-bottom: 15px;}
    .main_slide .swiper-slide .box .txt img {width: 100px;}
    .main_slide .swiper-pagination {bottom: 15px;}
    .main_slide .swiper-pagination-bullet {width: 10px; height: 10px;}
    .swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {margin: 0 3px;}


    #service .price {padding: 30px 16px 80px;}
    #service .price .contents_box {margin: 30px auto 0;}
    #service .price .contents_box .contents {width: 100%;}
    #service .price .contents_box .contents .box {height: 250px;}
    #service .price .contents_box .contents .box .top h2 {font-size: 30px; line-height: 30px; margin-bottom: 10px;}
    #service .price .contents_box .contents .box .top p {font-size: 21px; line-height: 21px;}
    #service .price .contents_box .contents > span br {display: none;}


    #service .process .process_category {gap: 20px;}
    #service .process .contents_box .contents h2 {font-size: 21px;}
    #service .process .contents_box .contents h3 {font-size: 16px; line-height: 21px; margin: 10px 0;}
    #service .process .contents_box .contents p {font-size: 14px; line-height: 19px;}


    #service .list .list_nav {width: 240px;}
    #service .list .list_slide {margin-left: 16px;}


    #member .inner .top_contents {flex-direction: column; max-width: 550px;}
    #member .inner .top_contents img {width: 100%; height: auto;}
    #member .inner .top_contents .right {width: 100%;}
    #member .inner .top_contents .right .ttop h2 {font-size: 24px; line-height: 24px; margin-bottom: 20px; text-align: center;}
    #member .inner .top_contents .right .ttop p {font-size: 18px; line-height: 36px; text-align: center;}
    #member .inner .top_contents .right .bbot div h2 {font-size: 20px; line-height: 20px;}
    #member .inner .top_contents .right .bbot div h3{font-size: 26px;}
    #member .inner .top_contents .right .bbot {justify-content: center;}


    #reference .inner .refer_slide {max-width: 268px;}
    #reference .inner .refer_nav {max-width: 343px;}
    #reference .inner .refer_nav img {width: 18px;}


    #request .inner .box .contents_box {max-width: 480px; width: 100%; margin: 0 auto; padding: 0 16px;}
    #request .inner .box .contents_box .contents {flex-direction: column;}
    #request .inner .box .contents_box .contents h3 {width: 100%; margin-bottom: 10px;}
    #request .inner .box .contents_box .contents > input {width: 100%;}
    #request .inner .box .contents_box .contents select {width: 100%;}
    #request .inner .box .contents_box .contents .label {width: 100%; justify-content: unset;}
    #request .inner .box .contents_box .contents .time {width: 100%;}

    #request .inner .box .agree_box {max-width: 480px; width: 100%; padding: 0 16px;}


    #client .inner .box {gap: 10px; max-width: 560px; margin: 40px auto 0;}
    #client .inner .box .contents {width: 180px; height: 135px;}

}

@media(max-width:710px){

    

}

@media(max-width:676px){

    

}

@media(max-width:650px){

    #service .display .contents {gap: 10px; max-width: 410px;}
    #service .display .contents img {width: 200px; height: 200px;}

}

@media(max-width:600px){

    #member .inner .top_contents {padding: 0 16px;}


    #client .inner .box {max-width: 370px;}

}

@media(max-width:540px){

    footer .inner .right .pri {justify-content: center; flex-direction: row; flex-wrap: wrap; gap: 0;}
    footer .inner .right .pri a {width: 33%;}
    footer .inner .right .pri a:nth-child(odd) {margin-right: 23px; text-align: right;}
    footer .inner .right .pri a::before {right: -13px;}
    footer .inner .right .pri a:nth-child(2):before {display: none;}


    .index_but h2 {font-size: 75px; line-height: 75px; margin-bottom: 60px;}

    

    

    .index_but {padding: 0 16px 160px;}

    #member .inner > p {font-size: 21px;}

}

@media(max-width:480px){

    footer .inner .left .box .contents {flex-direction: column; justify-content: center; align-items: center; text-align: center;}
    footer .inner .left .box .contents h2 {width: 100%;}


    .main_slide {height: 250px;}
    .main_slide .swiper-slide .box {max-width: 350px;}
    .main_slide .swiper-slide .box .txt h2 {font-size: 14px;}
    .main_slide .swiper-slide .box .txt p {font-size: 21px; margin-bottom: 15px;}
    .main_slide .swiper-slide .box .txt img {width: 80px;}


    #member .inner .top_contents .right .ttop h2 {font-size: 21px; line-height: 21px; margin-bottom: 10px;}
    #member .inner .top_contents .right .ttop p {font-size: 14px; line-height: 25px;}
    #member .inner .top_contents .right .bbot {flex-direction: column; justify-content: center; align-items: center; text-align: center;}
    #member .inner .top_contents .right .bbot div h2 {font-size: 16px; line-height: 16px;}
    #member .inner .top_contents .right .bbot div h3 {font-size: 20px;}


    #reference .inner > h2 {font-size: 21px; word-break: keep-all;}

}

@media(max-width:440px){

    footer .inner .right .pri a {width: 40%;}


    #service .display .contents {gap: 10px; max-width: 310px;}
    #service .display .contents img {width: 150px; height: 150px;}


    #request .inner .box .agree_box label span {font-size: 14px;}
    #request .inner .box .agree_box p {font-size: 14px;}

}

@media(max-width:420px){

    #client .inner .box {max-width: 330px;}
    #client .inner .box .contents {width: 160px; height: 120px;}

}

@media(max-width:390px){



}

