@charset "utf-8";
@import url(../../fonts/NotoSansCJK/NotoSansCJK.css);

/* CSS Reset */
html, body, div , span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {margin: 0; padding: 0; border: 0; font-size: 100%;}
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {display: block;}
body {font-family: "Noto Sans KR"; font-size: 16px; color: #1F1F1F; }
ol, ul, li {list-style: none;}
table {border-collapse: collapse; border-spacing: 0;}
address {font-style: normal;}
a {color: #333; text-decoration: none;}
img {border: 0; /*vertical-align: top;pointer-events : none;*/}

.hidden {display: none;}

button {cursor:pointer}

html, body{
    -webkit-text-size-adjust : none;  /* 크롬, 사파리, 오페라 신버전 */
    -ms-text-size-adjust : none;  /* IE */
    -moz-text-size-adjust : none;  /* 파이어폭스 */
    -o-text-size-adjust : none;  /* 오페라 구버전 */
  }

body {
    min-height: 80vh;
    /* mobile viewport bug fix */
    min-height: -webkit-fill-available;
    -webkit-touch-callout:none;
}

/* content */
#landing_container {
    width: 100%;
    box-sizing: border-box;
}

.container_wrap {
    width:100%;
    max-width: 800px;
    margin: auto;
    background: #EED8FF;
    font-size: 38px;
}

#landing_container .top{
    overflow:hidden;
}

.landing-header {
    padding: 76px 0;
}
.landing-header-slogun {
    font-family: 'Spoqa Han Sans Neo';
    font-style: normal;
    font-weight: 300;
    font-size: 45px;
    line-height: 68px;
    text-align: center;
    letter-spacing:-0.em;
}

.landing-header-slogun strong {
    font-size: 50px;
}
.progress-container{
    position: relative;
    margin-top: 35px;
    padding:0 60px;
}
.progress-bar{
    width: 100%;
    height: 68px;
    background: #fff;
    border-radius: 100px;
    padding: 6px 7px;
    box-sizing: border-box;
}
.progress-fill {
  height: 100%;
  background: linear-gradient(180deg, #8FFE65 0%, #37E783 100%);;
  border-radius: 100px;
  transition: width 0.5s ease;
}
.progress-text{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 28px;
    font-weight:500;
    color: #000;
}
.help-text {
    font-family: 'Spoqa Han Sans Neo';
    text-align: center;
    font-size: 25px;
    padding: 20px 0;
}


.section {
    position: relative;
}

canvas {
    z-index: 9999999;
    pointer-events: none;
    position: fixed;
    top: 0;
    transform: scale(1.1);
    left: 0;
}


/* 라디오 버튼 초기화*/
.intro_sul input[type=radio] {
    display: none;
}

.intro_sul input[type=radio]+label {
    display: inline-block;
    cursor: pointer;
    position: relative;
}


/* 라디오 버튼 초기화*/
.sectionChk input[type=radio] {
    width: 35px;
    height: 35px;
    background: #E9E9E9;
    border: 2px solid #DDDDDD;
    border-radius: 50%;
    line-height: 40px;
    appearance: none;
    position: relative;
}
.sectionChk input[type=radio]:checked:before{
    content:"";
    width:22px;
    height:22px;
    background: #8145FF;
    border-radius: 50%;
    display: block;
    position:absolute;
    left:50%;
    top:50%;
    transform: translate(-50%, -50%);
}

.sectionChk input[type=checkbox] {
    display: none;
}

.sectionChk input[type=checkbox]+label {
    display: inline-block;
    cursor: pointer;
}


.hidden {
    display: none
}

.puple_bg {
    width: 100%;
    background-color: #fff;
    /* min-height: 1245px;
    background: url('./lading_bg.png?ver=2') no-repeat center 70px; */
    position: relative;
    padding: 100px 0;
    border-top-left-radius: 50px;
    border-top-right-radius: 50px;
}


.page_num {
    position: absolute;
    left: 50%;
    top: 100px;
    transform: translate(-50%);
    color: #fff;
}

.q-text {
    text-align: center;
    padding: 270px 0 70px;
    font-size: 55px;
    font-family: Noto Sans CJK KR;
    font-weight: 400;
    color: #2f284d;
    letter-spacing: -0.03em;
    line-height: 76px;
}

.q-text .point {
    color: #8C64FF;
    font-size: 55px;
}

.check_list {
}

.check_list li {
    background-color: #fff;
}

break {
    flex-basis: 100%;
    width: 0px;
    height: 0px;
    overflow: hidden;
}


.img_ul {
    display: flex;
    flex-wrap: nowrap;
    flex-direction: row;
    gap: 10px;
}

.img_ul li {
    width: 50%;
    text-align: center;
}

.ft_text {
    text-align: left;
    margin: 0 0 50px;
    font-size: 25px;
    font-family: Noto Sans KR;
    font-weight: 300;
    letter-spacing: -0.082em;
    margin-top: 36px;
}

.action_btn {
    font-family: 'Spoqa Han Sans Neo';
    width: 680px;
    height: 130px;
    background: #8145FF;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    border-radius: 100px;
    color: #fff;
    margin:0 auto;
    display: block ;
    font-style: normal;
    font-weight: 500;
    font-size: 48px;
    line-height:130px;
    border:0;
}

.fixed {
    background: #fff;
}


.question {
    margin: 0px 60px 55px;
    display: flex;
    gap: 40px;
}
.qnum {
    font-family: 'Inter';
    font-style: normal;
    font-weight: 200;
    font-size: 120px;
    color: #8145FF;
    line-height: 80px;
}
.qtext {
    font-family: 'Spoqa Han Sans Neo';
    word-break: keep-all;
}

.section .check_list {
    display: flex;
    gap: 20px 0;
    flex-direction: row;
    margin: 0 auto;
    flex-wrap: wrap;
    justify-content: center;
}

.section .check_list li {
    width: 680px;
    height: 120px;
    background: #FFFFFF;
    border: 1px solid #B6B6B6;
    box-shadow: 7px 7px 5px rgba(0, 0, 0, 0.05);
    border-radius: 15px;
    display: block;
    line-height: 40px;
    box-sizing: border-box;
}
.section .check_list li.on {
    border:1px solid #8145FF;
}
.section .check_list li label {
    display:block;
    cursor: pointer;
    padding: 40px 35px;
}
.section .check_list li label span {
    display: inline-block;
    height: 40px;
    box-sizing: border-box;
    line-height: 40px;
    /* width: calc(100% - 50px); */
    padding-left: 10px;
    font-family: 'Spoqa Han Sans Neo';
}

.next_viewbox{
    background:#FFF;
}
.request .next_viewbox{
    padding-top:70px;
}
/* input box */
.input_wrap {
    box-sizing: border-box;
    padding: 0 60px 156px;
}
.input_wrap select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.input_wrap select::-ms-expand {
    display: none;
}
.input_wrap input[type='text'],
.input_wrap input[type='number']{
    margin-bottom:0;
}

.request .input_wrap {
    padding: 0 60px;
}

/* 이름 input */
#name, #tel{
    width: 100%;
    box-sizing: border-box;
    font-size: 38px;
    padding: 40px 35px;
    line-height: 40px;
    font-family: "Noto Sans KR";
    height:120px;
}

#age{
    width: 100%;
    padding-left: 30px;
    background: url('./images/dropdown_icon.png') no-repeat center right 30px #fff;
}
.age_box{
    width: 40%;
    float: right;
    height: 104px;
}
.input_wrap select{
    background: url(./images/dropdown_icon.png) no-repeat center right 30px #fff;
    width:100%;
    font-size: 38px;
    padding: 40px 35px;
    line-height: 40px;
    box-sizing: border-box;
    font-family: "Noto Sans KR";
    border: 1px solid #B6B6B6;
    cursor: pointer;
}

#gift {
    width: 100%;
    height: 100px;
    border: 1px solid #707070;
    box-sizing: border-box;
    font-size: 33px;
    padding: 23px 0 23px 28px;
    margin-bottom: 30px;
    font-family: "Noto Sans KR";
    margin-top: 30px;
}

/* 전화번호 input */
.tel_wrap {
    width: 100%;
    height: 100px;
    white-space: nowrap;
    text-align: center;
}

.tel_wrap .select_box {
    width: 25%;
    float: left;
    position: relative;
    background-color: #fff;
    z-index: 10;
}

.tel_wrap .select_box #tel {
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    border: 1px solid #707070;
    font-size: 36px;
    padding-left: 28px;
    z-index: 100;
    background-color: transparent;
}

.tel_wrap .select_box img {
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translate(-50%, -30%);
    z-index: -1;
}

.tel_wrap #tel_2 {
    width: 34%;
    height: 100%;
    box-sizing: border-box;
    border: 1px solid #707070;
    max-width: 230px;
    padding-left: 28px;
    font-size: 36px;
    display: inline-block;
}

.tel_wrap #tel_3 {
    width: 34%;
    height: 100%;
    float: right;
    box-sizing: border-box;
    border: 1px solid #707070;
    max-width: 230px;
    padding-left: 28px;
    font-size: 36px;
}

/* 개인정보 */
input[type="checkbox"] {
    width: 35px;
    height: 35px;
    vertical-align: middle;
    margin-right: 6px;
}

.text_label span {
    font-size: 38px;
    vertical-align: middle;
}

.text_label {
    text-align: center;
    width: 100%;
    display: block;
    margin-bottom: 20px !important;

}

.text_label a {
    display: inline-block;
    font-size: 18px;
    background-color: #fff;
    border: 1px solid #3F3F3F;
    color: #3F3F3F;
    vertical-align: middle;
    padding: 8px;
    margin-left: 10px;
}

.request .bna_content{
    position:relative;
}
.request .bna_content .case_box{
    width:100%;
    position:absolute;
    top:399px;
    left:50%;
    transform: translate(-50%);
}
.request .bna_content .case_box .swiper-container{
    position:relative;
    overflow: hidden;
    margin:auto;
}
.bottom_info li {
    position: relative;
    padding-left: 15px;
    word-break: keep-all;
}
.bottom_info li:before {
    content: "*";
    position: absolute;
    top: 4px;
    left: 0;
}

.alert-div {color:red;font-size: 15px;margin: -50px 165px 50px;}