/* 어그로체 */
@font-face {
    font-family: 'Aggravo';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2108@1.1/SBAggroB.woff') format('woff');
    font-weight: 700;
    font-display: swap;
}

/* 공통 */
.inner_{
    max-width:1200px;
    width:100%;
    margin:0 auto;
    position: relative;
}
h2{
    text-align: center;
}
section{
    padding:110px 0;
}
.sub_tit{
    font-size:14px;
    color:#666;
    line-height: 1.6;
}
.btn_box{
    width:561px;
    position: relative;
    height:84px;
    color:#fff;
    border-radius: 50px;
    font-size:30px;
    font-weight: 700;
}
.btn_box a{
    width: 100%;
    height: 100%;
    display:flex;
    justify-content: center;
    align-items: center;
}
.btn_box_icon{
    position: absolute;
    right: 0;
    top: 36px;
    animation: click-animation 1s infinite;
}
@keyframes click-animation {
    0% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-5px);
    }
}


.visual_wrp{
    background: url('https://image.engineerlab.co.kr/data/www/engr/promotion/2026/final_pass/visual/bg_02.jpg') 
    no-repeat top center / cover;
    height:1827px;
    width:100%;
    position: relative;
}
.text_box{
    position: absolute;
    top: 332px;
    left: 921px;
    overflow: hidden;
}
.text_box ul{
    margin: 0;
    padding: 0;
    list-style: none;
}
.text_box li{
    margin: 0;
    padding: 0;
}
.text_box li img{
    display: block;
}

.text_box_02{
    position: absolute;
    top: 1053px;
    width: 100%;
}
.text_box_02 .tab_list{
    display:flex;
    justify-content:center;
    gap:10px;
}
.text_box_02 .tab_list li{
    position:relative;
    flex:1;
}
.text_box_02 .tab_bg{
    display:block;
    width:100%;
}
.text_box_02 .tab_txt{
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    display:block;
    pointer-events:none;
}


.visual_ev_wrp{
    position: absolute;
    top: 1242px;
    width:100%;
}
.visual_ev_wrp ul{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap:20px;
}
.visual_ev_wrp li a{
    height:217px;
    width: 100%;
    background-color:#fff;
    display: flex;
    justify-content: space-between;
    padding:40px;
    align-items: center;
}
.visual_ev_wrp li a:hover{
    background-color: #fff08d;
}
.visual_ev_wrp li a .left .event_tit{
    font-size:20px;
    font-weight:700;
    font-family: 'Aggravo';
    color:#fff;
    background-color: #200545;
    padding:10px 20px;
    margin-bottom:20px;
}
.visual_ev_wrp li a .left .event_txt{
    font-size:34px;
    font-weight:700;
    color:#10122d;
}

.section_01{
    background-color: #edeef4;
}

.winner-track-title{
    background: rgba(224, 158, 0, 0.9);
    height:52px;
}
.winner-slide p{
    color:#0c0f36;
}

.section_01 .con_box img{
    margin-bottom:20px;
}

.section_01 .btn_box{
    background:#100564;
    margin:50px auto 0;
}

/* 섹션2 */
.section_02{
    overflow:hidden;
}
.section_02 h2{
    background-color:#200545;
    font-family: 'Aggravo';
    font-size:36px;
    font-weight: 700;
    color:#fff;
    width:200px;
    height:58px;
}

.tit_line{
    position:relative;
    text-align:center;
}
.tit_line::before{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%, -50%);
    width:100vw;
    height:1px;
    background:#ccc;
    z-index:0;
}
.tit_line .tit{
    position:relative;
    z-index:1;
    margin:0 auto;
    display: flex;
    align-items:center;
    justify-content:center;
    padding-top: 4px;
}

/* 이벤트1 */
.tit_line .tit img{
    display:block;
}

/* 섹션2 공통 */
.section_02 .con_box{padding-top:80px;}
.section_02 .btn_box{background:#ac31d2;margin:0 auto;}
.sub_tit_wrp{padding-top:40px;}
.sub_tit_wrp h3{font-size:30px;font-weight:700;color:#101126;padding-bottom:10px;}
.sub_tit_wrp .sub_tit p{display:flex;position:relative;padding-left:10px;}
.sub_tit_wrp .sub_tit p::before{
    content:'-';
    position:absolute;
    left:0;
    top:0;
}
.sub_tit_wrp .sub_tit a{
    background-color:#10122d;
    color:#fff;
    padding:2px 37px;
    margin-left:20px;
}

/* 이벤트1 */
.ent_1, .ent_2, .ent_3 {padding-bottom:100px;}


/* ===== 참여 방법 ===== */
.how_wrp{
}
.how_step{
    padding:14px 16px 20px;
    display:flex;
    flex-direction:column;
    gap:12px;
}
.how_step_item{
    display: flex;
    gap: 20px;
    border: 1px solid #e0e0e0;
    border-radius: 4px;
    padding: 27px 42px;
    background: #fff;
}
.how_step_label{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width: 121px;
    height:33px;
    border-radius:20px;
    font-size:16px;
    font-weight:700;
    color:#91929d;
    background: #e0e0e8;
}
.how_step_body{
    flex:1;
    min-width:0;
}
.how_step_tit{
    margin:0 0 6px;
    font-size:24px;
    font-weight:700;
    color:#111;
}
.how_step_desc{
    margin:0;
    font-size:13px;
    color:#777;
    line-height:1.5;
}
/* STEP 1 아이콘 */
.how_icon_row{
    display:flex;
    gap:6px;
    align-items:center;
}
.how_icon{
    width:30px;
}
.how_step_icons{
    flex-direction:row;
    gap:6px;
}
.how_step_icons_wrp{display:flex;justify-content: space-between;gap:10px;padding-bottom:10px;}
.how_example_btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:100%;
    height:28px;
    background-color:#ba54cd;
    font-size:16px;
    color:#fff;
}
.how_example_btn:hover{ background:#ac31d2; color:#fff; }
/* STEP 2 URL */
.how_step_body_url{ padding-right:10px; }
.how_url_row{
    display:flex;
    gap:10px;
    align-items:center;
    margin-bottom:6px;
}
.how_url_input{
    flex:1;
    height:42px;
    border:1px solid #ccc;
    border-radius:3px;
    padding:0 12px;
    font-size:14px;
    color:#333;
    outline:none;
    box-sizing:border-box;
}
.how_url_input:focus{ border-color:#0c0f36; }
.how_url_btn{
    flex-shrink:0;
    height:42px;
    padding:0 22px;
    background:#0c0f36;
    border:none;
    border-radius:3px;
    font-size:15px;
    font-weight:700;
    color:#fff;
    cursor:pointer;
    white-space:nowrap;
}
.how_url_btn:hover{ background:#1a2060; }
.btn_box_dual{
    display:flex;
    gap:30px;
    justify-content:center;
    align-items:center;
    margin:0 auto;
}
/* 이미지 첨부방법 팝업 */
.blind,
#pop_attach_guide .sound_only{
    overflow:hidden;
    position:absolute;
    width:1px;
    height:1px;
    margin:-1px;
    clip:rect(0, 0, 0, 0);
}
.butn.btn_white{display: flex;align-items: center;}
/* agree-form, form-btn, butn → common.css */
.agree-form-item{
    border:5px solid #e60012;
    padding:10px;
}
.agree-form-item .item_2{
    padding-top:20px;
}
.pop_attach_wrp{
    display:none;
    position:fixed;
    inset:0;
    z-index:9999;
    background:rgba(0, 0, 0, 0.7);
    align-items:center;
    justify-content:center;
    padding:30px 20px;
    box-sizing:border-box;
}
.butn.btn_blue{border:5px solid #e60012;}
.pop_attach_close{
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
}
.pop_attach_box{
    width:800px;
    max-width:100%;
    max-height:calc(80vh - 60px);
    overflow-y:auto;
    background:#fff;
    box-shadow:0 12px 40px rgba(0, 0, 0, 0.25);
    font-family:'Malgun Gothic', sans-serif;
}
.pop_attach_head{
    position:relative;
    padding:28px 56px 24px;
    border-bottom:1px solid #e5e5e5;
}
.pop_attach_tit{
    margin:0;
    font-size:28px;
    font-weight:700;
    line-height:1.3;
    color:#111;
    text-align:center;
}
.pop_attach_close{
    position:absolute;
    top:22px;
    right:22px;
    width:32px;
    height:32px;
}
.pop_attach_close::before,
.pop_attach_close::after{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    width:22px;
    height:2px;
    background:#111;
}
.pop_attach_close::before{
    transform:translate(-50%, -50%) rotate(45deg);
}
.pop_attach_close::after{
    transform:translate(-50%, -50%) rotate(-45deg);
}
.pop_attach_body{
    padding:24px 28px 20px;
}
#pop_attach_guide #bo_w.pop_attach_preview{
    font-size:14px;
}
#pop_attach_guide #bo_w.pop_attach_preview .write_div{
    margin:10px 0;
    position:relative;
}
#pop_attach_guide #bo_w.pop_attach_preview .bo_w_link label{
    position:absolute;
    top:1px;
    left:1px;
    border-radius:3px 0 0 3px;
    height:38px;
    line-height:38px;
    width:40px;
    font-size:1.2em;
    text-align:center;
    color:#b2b2b2;
}
#pop_attach_guide #bo_w.pop_attach_preview .bo_w_link .frm_input{
    padding-left:50px;
    width:100%;
    height:40px;
    border:1px solid #ccc;
    border-radius:3px;
    box-sizing:border-box;
}
#pop_attach_guide #bo_w.pop_attach_preview .bo_w_flie .lb_icon{
    position:absolute;
    top:0;
    left:0;
    border-radius:3px 0 0 3px;
    height:38px;
    line-height:38px;
    width:40px;
    font-size:1.2em;
    text-align:center;
    color:#b2b2b2;
}
#pop_attach_guide #bo_w.pop_attach_preview .bo_w_flie .frm_file{
    padding-left:50px;
    margin-top:3px;
}
#pop_attach_guide #bo_w.pop_attach_preview .bo_w_flie .file_wr{
    position:relative;
    border:5px solid #e60012;
    background:#fff;
    border-radius:3px;
    padding:5px;
    min-height:40px;
    margin:0;
    color:#222;
    font-size:13px;
}
.pop_attach_btn_close{
    cursor:pointer;
    background:#fff;
}
.pop_attach_guide{
    margin-top:20px;
    padding:22px 20px;
    border:1px solid #ccc;
    background:#f4f4f4;
}
.pop_attach_guide ol{
    margin:0;
    padding:0;
    list-style:none;
}
.pop_attach_guide li + li{
    margin-top:14px;
}
.pop_attach_guide p{
    margin:0;
    font-size:14px;
    line-height:1.65;
    color:#111;
    word-break:keep-all;
}
.pop_attach_guide strong{
    font-weight:700;
}
.pop_attach_notice{
    margin-top:6px !important;
    color:#e60012 !important;
}
.pop_attach_foot{
    padding:8px 28px 28px;
    text-align:center;
}
.pop_attach_btn_close{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:200px;
    height:52px;
    border:2px solid #0c0f36;
    font-size:18px;
    font-weight:700;
    color:#0c0f36;
    background:#fff;
    box-sizing:border-box;
}
.pop_no_action{
    pointer-events:none;
    cursor:default;
}
.pop_badge_wrap{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin-bottom:4px;
}
.pop_badge_wrap > *:first-child{
    flex:1;
    min-width:0;
}
.pop_badge{
    flex-shrink:0;
    width:26px;
    height:26px;
    border:2px solid #e60012;
    border-radius:50%;
    background:#fff;
    font-size:13px;
    font-weight:700;
    color:#e60012;
    display:flex;
    align-items:center;
    justify-content:center;
    line-height:1;
    margin-top:10px;
}
.pop_badge_wrap_btn .pop_badge{
    margin-top:14px;
}
.pop_btn_badge_wrap{
    position:relative;
    display:inline-flex;
    align-items:center;
}
.pop_badge_inline{
    position:absolute;
    right:-34px;
    top:50%;
    transform:translateY(-50%);
    margin-top:0;
}

/* ===== 합격 영상 인터뷰 지원 팝업 ===== */
.iv_pop_wrp{
    position:fixed;
    inset:0;
    z-index:9999;
    background:rgba(0,0,0,0.65);
    align-items:center;
    justify-content:center;
    padding:24px 16px;
    box-sizing:border-box;
}
.iv_pop_box{
    width:500px;
    max-width:100%;
    max-height:calc(100vh - 48px);
    overflow-y:auto;
    background:#fff;
    border:2px solid #0c0f36;
    box-shadow:0 8px 32px rgba(0,0,0,0.25);
    font-size:14px;
    color:#222;
    font-family:'Malgun Gothic',sans-serif;
    box-sizing:border-box;
}
.iv_pop_head{
    position:relative;
    padding:20px 50px 18px;
    border-bottom:2px solid #0c0f36;
    text-align:center;
}
.iv_pop_tit{
    margin:0;
    font-size:20px;
    font-weight:700;
    color:#0c0f36;
    letter-spacing:-0.5px;
}
.iv_pop_close{
    position:absolute;
    top:50%;
    right:16px;
    transform:translateY(-50%);
    width:28px;
    height:28px;
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
}
.iv_pop_close::before,
.iv_pop_close::after{
    content:'';
    position:absolute;
    left:50%;
    top:50%;
    width:18px;
    height:2px;
    background:#333;
    border-radius:1px;
}
.iv_pop_close::before{ transform:translate(-50%,-50%) rotate(45deg); }
.iv_pop_close::after{  transform:translate(-50%,-50%) rotate(-45deg); }
.iv_pop_body{
    padding:20px 24px 16px;
}
.iv_pop_body input{
padding: 8px 10px;
width:100%;
border: 1px solid #ddd;
}
/* 테이블 */
.iv_pop_tbl{
    width:100%;
    border-collapse:collapse;
    margin-bottom:20px;
    border-top:2px solid #0c0f36;
    border-bottom:1px solid #ddd;
}
.iv_pop_tbl th{
    width:90px;
    padding:12px 14px;
    background:#f5f5f5;
    border:1px solid #ddd;
    font-size:14px;
    font-weight:700;
    color:#222;
    text-align:center;
    white-space:nowrap;
}
.iv_pop_tbl td{
    padding:8px 10px;
    border:1px solid #ddd;
    background:#fff;
}
.iv_input{
    width:100%;
    height:36px;
    border:1px solid #ccc;
    border-radius:2px;
    padding:0 10px;
    font-size:13px;
    color:#333;
    box-sizing:border-box;
    outline:none;
}
.iv_input:focus{ border-color:#0c0f36; }
.iv_select{
    width:100%;
    height:36px;
    border:1px solid #ccc;
    border-radius:2px;
    padding:0 8px;
    font-size:13px;
    color:#333;
    background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23555'/%3E%3C/svg%3E") no-repeat right 10px center;
    appearance:none;
    -webkit-appearance:none;
    cursor:pointer;
    outline:none;
    box-sizing:border-box;
}
/* 동의 */
.iv_agree_row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:10px;
}
.iv_agree_tit{
    font-size:15px;
    font-weight:700;
    color:#111;
}
.iv_agree_tit em{
    color:#e60012;
    font-style:normal;
    font-size:13px;
    margin-left:2px;
}
.iv_agree_toggle{
    display:inline-flex;
    align-items:center;
    gap:7px;
    height:36px;
    padding:0 16px;
    border:1px solid #0c0f36;
    border-radius:4px;
    background:#fff;
    font-size:14px;
    font-weight:700;
    color:#0c0f36;
    cursor:pointer;
}
.iv_agree_chk{
    position:absolute;
    width:1px;
    height:1px;
    margin:-1px;
    padding:0;
    overflow:hidden;
    clip:rect(0, 0, 0, 0);
    border:0;
}
.iv_chk_box{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:18px;
    height:18px;
    border:2px solid #ccc;
    border-radius:3px;
    background:#fff;
    flex-shrink:0;
    transition:border-color 0.15s, background 0.15s;
    position:relative;
}
.iv_chk_mark{
    display:none;
    width:10px;
    height:6px;
    border-left:2px solid #fff;
    border-bottom:2px solid #fff;
    transform:rotate(-45deg) translate(1px, -1px);
}
.iv_agree_toggle:has(.iv_agree_chk:checked){
    border-color:#0c0f36;
    color:#0c0f36;
}
.iv_agree_toggle:has(.iv_agree_chk:checked) .iv_chk_box{
    border-color:#0c0f36;
    background:#0c0f36;
}
.iv_agree_toggle:has(.iv_agree_chk:checked) .iv_chk_mark{
    display:block;
}
.iv_agree_txt{
    padding:14px 16px;
    border:1px solid #ddd;
    background:#f9f9f9;
    font-size:13px;
    line-height:1.7;
    color:#444;
    border-radius:2px;
}
/* 푸터 버튼 */
.iv_pop_foot{
    display:flex;
    justify-content:center;
    gap:12px;
    padding:16px 24px 24px;
}
.iv_btn{
    min-width:130px;
    height:46px;
    font-size:16px;
    font-weight:700;
    border-radius:2px;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    box-sizing:border-box;
}
.iv_btn_close{
    border:1px solid #ccc;
    background:#fff;
    color:#333;
}
.iv_btn_confirm{
    border:none;
    background:#0c0f36;
    color:#fff;
}

/* 예시 내용 보기 팝업 */
.ex_pop_wrp{
    position:fixed;
    inset:0;
    z-index:9999;
    background:rgba(0,0,0,0.65);
    align-items:center;
    justify-content:center;
    padding:24px 16px;
    box-sizing:border-box;
}
.ex_pop_box{
    width:500px;
    max-width:100%;
    max-height:calc(100vh - 48px);
    overflow-y:auto;
    background:#fff;
    border:2px solid #0c0f36;
    box-shadow:0 8px 32px rgba(0,0,0,0.25);
    font-size:14px;
    color:#222;
    font-family:'Malgun Gothic',sans-serif;
    box-sizing:border-box;
}
.ex_pop_head{
    position:relative;
    padding:20px 50px 18px;
    border-bottom:2px solid #0c0f36;
    text-align:center;
}
.ex_pop_tit{
    margin:0;
    font-size:20px;
    font-weight:700;
    color:#0c0f36;
    letter-spacing:-0.5px;
}
.ex_pop_close{
    position:absolute;
    top:50%;
    right:16px;
    transform:translateY(-50%);
    width:28px;
    height:28px;
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
}
.ex_pop_close::before,
.ex_pop_close::after{
    content:'';
    position:absolute;
    top:50%;left:50%;
    width:18px;height:2px;
    background:#0c0f36;
    border-radius:2px;
}
.ex_pop_close::before{ transform:translate(-50%,-50%) rotate(45deg); }
.ex_pop_close::after{  transform:translate(-50%,-50%) rotate(-45deg); }
.ex_pop_body{
    padding:22px 24px 16px;
}
.ex_intro_txt{
    font-size:14px;
    line-height:1.8;
    color:#333;
    margin:0 0 18px;
}
.ex_content{
    background:#f5f5f5;
    padding:16px 18px;
}
.ex_section_label{
    font-size:14px;
    font-weight:700;
    color:#222;
    margin:0 0 10px;
}
.ex_main_txt{
    font-size:14px;
    line-height:1.8;
    color:#444;
    margin:0 0 14px;
}
.ex_main_txt:last-child{
    margin-bottom:0;
}
.ex_pop_foot{
    display:flex;
    justify-content:center;
    gap:12px;
    padding:16px 24px 24px;
}

/* 이벤트3 */
.ent_3 .con_box{
    position: relative;
}
.ent_3 .con_box .con3_img{
    position: absolute;
    bottom: 10px;
    right: -65px;
}


/* 섹션3 */
.section_03{
    background-color: #edeef4;
}
.faq_list{
    list-style:none;
    margin:30px 0 0;
    padding:0;
}
.faq_item{
    border-bottom:1px solid #d0d2de;
    word-break:keep-all;
}
.faq_item:first-child{
    border-top:1px solid #d0d2de;
}
.faq_q{
    width:100%;
    text-align:left;
    padding:22px 48px 22px 0;
    font-size:32px;
    font-weight:700;
    color:#10122d;
    cursor:pointer;
    position:relative;
    line-height:1.4;
}
.faq_q::after{
    content:'+';
    position:absolute;
    right:4px;
    top:50%;
    transform:translateY(-50%);
    font-size:22px;
    font-weight:300;
    color:#888;
    transition:opacity .2s;
}
.faq_item.is-open .faq_q::after{
    content:'−';
}
.faq_a{
    display:none;
    padding:0 0 24px;
    font-size:24px;
    color:#10122d;
    line-height:1.8;
    font-weight: 300;
    word-break: keep-all;
}
.faq_a p+p{
    margin-top:10px;
    padding-top:10px;
    border-top:1px dashed #d8dae8;
}
.faq_item.is-open .faq_a{
    display:block;
}


.faq_a a{
background-color: #10122d;
color: #fff;
font-size:14px;
padding:2px 37px;
margin-left:20px;
}

/* 유튜브 팝업 */
.yt_pop_wrp{
    position:fixed;
    inset:0;
    z-index:9999;
    background:rgba(0,0,0,.85);
    align-items:center;
    justify-content:center;
    padding:20px;
    box-sizing:border-box;
}
.yt_pop_box{
    position:relative;
    width:100%;
    max-width:900px;
}
.yt_pop_close{
    position:absolute;
    top:-40px;
    right:0;
    width:32px;
    height:32px;
    background:none;
    border:none;
    cursor:pointer;
    padding:0;
    z-index:1;
}
.yt_pop_close::before,
.yt_pop_close::after{
    content:'';
    position:absolute;
    top:50%;left:50%;
    width:22px;height:2px;
    background:#fff;
    border-radius:2px;
}
.yt_pop_close::before{transform:translate(-50%,-50%) rotate(45deg);}
.yt_pop_close::after{ transform:translate(-50%,-50%) rotate(-45deg);}
.yt_iframe_wrp{
    position:relative;
    width:100%;
    padding-top:56.25%;
}
.yt_iframe_wrp iframe{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
}

/* 마지막 */
.section_04{background-color:#111;}