@charset "UTF-8";

/* ===================== Fonts ===================== */
@font-face {
    font-family: 'Pretendard';
    font-style: normal;
    font-weight: 300;
    src: url(../fonts/contest2026/Pretendard-Light.woff2) format('woff2'),
         url(../fonts/contest2026/Pretendard-Light.woff) format('woff');
}
@font-face {
    font-family: 'Pretendard';
    font-style: normal;
    font-weight: 500;
    src: url(../fonts/contest2026/Pretendard-Medium.woff2) format('woff2'),
         url(../fonts/contest2026/Pretendard-Medium.woff) format('woff');
}
@font-face {
    font-family: 'Pretendard';
    font-style: normal;
    font-weight: 700;
    src: url(../fonts/contest2026/Pretendard-Bold.woff2) format('woff2'),
         url(../fonts/contest2026/Pretendard-Bold.woff) format('woff');
}

@font-face {
    font-family: 'GmarketSans';
    font-style: normal;
    font-weight: 300;
    src: url('../fonts/contest2026/GmarketSansLight.woff') format('woff'),
         url(../fonts/contest2026/GmarketSansLight.otf) format('opentype');
}
@font-face {
    font-family: 'GmarketSans';
    font-style: normal;
    font-weight: 500;
    src: url('../fonts/contest2026/GmarketSansMedium.woff') format('woff'),
         url(../fonts/contest2026/GmarketSansMedium.otf) format('opentype');
}
@font-face {
    font-family: 'GmarketSans';
    font-style: normal;
    font-weight: 700;
    src: url('../fonts/contest2026/GmarketSansBold.woff') format('woff'),
         url(../fonts/contest2026/GmarketSansBold.otf) format('opentype');
}


/* ===================== 경진대회 스타일 ===================== */
/* --primary 는 .sub_contest_wrap 내부로 한정 (전역 :root 누설 방지) */
.sub_contest_wrap { font-family: Pretendard; --primary: #1759a1; margin-top: 40px; margin-bottom: 80px; }

.s_c_tit_box { display: flex; justify-content: space-between; }
.s_c_title { }
.s_c_title span { display: inline-block; background: #15273c; padding:5px 15px; border-radius: 5px; color: #fff; font-size: 14px; margin-bottom: 5px; }
.s_c_title .s_c_t_row { font-family: GmarketSans; font-weight: 700; font-size: 30px; color: #000; }
.s_c_title p { font-size: 16px; }
.s_c_bt_box { display: flex; align-items: flex-end; }


.sub_contest_tab .tabs { display: flex; justify-content: space-around }
.sub_contest_tab .tabs li { float: none; width: 100%; }
.sub_contest_tab .tabs li a { font-size: 16px; }

.sub_contest_tab .sub_contest_sel { display: none; margin-bottom: 20px }
.sub_contest_tab .sub_contest_sel select { width: 100%; border: 1px solid #000; height: 40px; border-radius: 6px; }

.section-h2 { font-size: 25px; color: #1759a1; border-bottom: 1px solid #0561ac; margin-bottom: 25px; padding-bottom: 15px; }
.section-h3 { font-size: 20px; color: #000; margin-top: 30px; margin-bottom: 12px; }
.desc-p { padding: 0 0 0 16px; position: relative; font-size: 16px; line-height: 25px; }
.desc-p:after { content: ''; display: block; position: absolute; left: 4px; top:9px; width: 4px; height: 4px; background: #0b0b0b; border-radius: 4px; }
.sub_contest_wrap .table.v3 th { font-size: 16px; }
.sub_contest_wrap .table.v3 td { font-size: 16px; }

.section-h3 .bg_t_t { background: #1759a1; color: #fff; font-style: normal; font-size: 16px; padding: 3px 10px; display: inline-block; vertical-align: middle; border-radius: 20px }

.section-h3 em { display: inline-block; vertical-align: middle; border-radius: 30px; background: #15273c; color: #fff; text-align: center; line-height: 30px; width: 30px; margin-right: 5px; font-style: normal; font-size: 16px; }

.s_c_bottom_box { margin-top: 30px; display: flex; justify-content: space-between; align-items: center; }
.s_c_a_t { font-size: 16px; color: #000; padding: 0 0 0 20px; background: url(../img/contest2026/bottom_alert_i.png) no-repeat 0 50%; }

.s_c_bottom_box ul { list-style: none; }
.s_c_bottom_box ul li { font-size: 16px; color: #000; padding: 0 0 0 20px; background: url(../img/contest2026/bottom_alert_i.png) no-repeat 0 50%; margin-bottom: 10px; }
.s_c_bottom_box ul li:last-child { margin-bottom: 0px; }

.s_c_b_bg { background: #d8f4ff; border-radius:15px; padding: 20px; }

.s_c_b_bg dl dt { font-size: 16px; color: #000; padding: 0 0 0 20px; background: url(../img/contest2026/bottom_alert_i.png) no-repeat 0 50%; margin-bottom: 10px; }
.s_c_b_bg dl dd { font-size: 15px; padding: 0 0 0 20px; }


.c_schedule_top { font-size: 20px; text-align: center; padding: 15px 0 0 0; margin-bottom: 25px; }
.c_schedule_top strong { color: #0561ac; line-height: 34px; }

.c_s_step_box { background: #fff; border:1px solid #dadada; border-radius: 15px; }

.add_step_arr { position: relative; }
.add_step_arr:after { content: ''; display: block; position: absolute; right: -21px; top:50%; background: url(../img/contest2026/s_contact_step_arr.png) no-repeat 0 0; width: 11px; height: 23px; margin-top: -11px; }

.c_s_step_top { font-family: GmarketSans; font-size: 18px; color: #000; text-align: right; padding: 15px 15px 0 0; margin-bottom: 15px; }
.c_s_step_top span { display: inline-block; font-size: 12px; color: #555; vertical-align: middle; margin: 0 4px 0 0; }

.c_s_step_con { text-align: center; margin-bottom: 15px; }
.c_s_step_con span { display: block; margin: 0 auto 10px auto; overflow: hidden; text-indent: -9999px; width: 72px; height: 72px; border-radius: 36px; }
.c_s_step_con .s_step_i01 { background:#00a3eb url(../img/contest2026/s_pencil_icon.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i02 { background:#1759a1 url(../img/contest2026/s_step_icon02.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i03 { background:#00a3eb url(../img/contest2026/s_step_icon03.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i04 { background:#1759a1 url(../img/contest2026/s_step_icon04.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i05 { background:#00a3eb url(../img/contest2026/s_step_icon05.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i06 { background:#1759a1 url(../img/contest2026/s_pencil_icon.png) no-repeat 50% 50%; }
.c_s_step_con .s_step_i07 { background:#00a3eb url(../img/contest2026/s_step_icon06.png) no-repeat 50% 50%; }


.c_s_step_con p { margin-bottom: 5px; font-size: 18px; font-weight: 700; color: #000; height:42px; line-height: 22px; display: flex; align-items: center; width: 100%; justify-content: center; }
.c_s_step_con em { display: block; font-style: normal; font-family: GmarketSans; font-size: 16px; color: #1759a1; }


.c_s_step_bottom { background: #f3f3f3; padding: 20px 15px; border-radius: 0 0 15px 15px; }
.c_s_step_bottom p { font-size:14px; position: relative; padding: 0 0 0 10px; }
.c_s_step_bottom p:after { content: ''; display: block; position: absolute; left: 0px; top:9px; width: 4px; height: 4px; background: #0b0b0b; border-radius: 4px; }


.sub_contest_wrap .doc-list { list-style-type: none; }
.sub_contest_wrap .doc-list li { padding: 0 0 0 16px; position: relative; font-size: 16px; line-height: 25px; margin-bottom: 10px; }
.sub_contest_wrap .doc-list li:last-child { margin-bottom: 0px; }
.sub_contest_wrap .doc-list li:after { content: ''; display: block; position: absolute; left: 4px; top:9px; width: 4px; height: 4px; background: #0b0b0b; border-radius: 4px; }

.sub_contest_wrap .doc-list ul { margin-top: 10px; background: #f3f3f3; padding: 10px; border-radius: 12px; }
.sub_contest_wrap .doc-list ul li { margin-bottom: 5px; }
.sub_contest_wrap .doc-list ul li:after { width: 5px; height: 2px; background: #888; top: 11px; }


.s_c_l_inner { padding: 0 0 0 18px; margin-top: 15px; }
.s_c_h4 { font-size: 16px; margin-bottom: 5px; margin-top: 15px; }

.sub_contest_wrap .add_r_line.table.v3 th,
.sub_contest_wrap .add_r_line.table.v3 td { border-right: 1px solid #dedede }
.sub_contest_wrap .add_r_line.table.v3 th:last-child,
.sub_contest_wrap .add_r_line.table.v3 td:last-child { border-right: 0px; }
.sub_contest_wrap .tbl_align_center th,
.sub_contest_wrap .tbl_align_center td { text-align: center; }
.sub_contest_wrap .tbl_align_center td { padding:12px }
.s_c_help_box { border:1px solid #0094d5; background:#fff; border-radius: 15px; padding: 15px; }
.s_c_help_box p { font-size: 17px; color: #000; padding: 0 0 0 25px; background: url(../img/contest2026/s_c_help_i.png) no-repeat 0 2px; font-weight: 700; color: var(--primary) }

.s_c_g_b { border:1px solid #dadada; background: #fff; padding: 10px 20px 20px 20px; border-radius: 15px; }
.s_c_round_t h4 { color: #fff; background: var(--primary); font-size: 15px; margin-bottom: 5px; display: inline-block; padding: 3px 15px; border-radius: 20px; margin-top: 15px; }


.step_bottom_info { padding: 0 0 0 10px; margin-top: 20px }
.step_bottom_info dl { display: flex; margin-bottom: 15px; }
.step_bottom_info dl dt { position: relative; padding: 0 0 0 15px; font-size: 16px; width: 120px; }
.step_bottom_info dl dt:after { content: ''; display: block; position: absolute; left: 4px; top:9px; width: 4px; height: 4px; background: #0b0b0b; border-radius: 4px; }
.step_bottom_info dl dd { font-size: 16px; }


.tab_contact_wrap { position: relative; border:1px solid #dadada; background: #fff; padding: 15px 20px 15px 25px; border-radius: 0 15px 15px 0; margin-top: 40px; }
.tab_contact_wrap:after { content: ''; display: block; position: absolute; left: 0; top:0; bottom:0; width: 4px; background: #0091d2; }
.tab_contact_wrap .section-h3 { margin-top: 0; }
.tab_contact_wrap dl dt { width: 100px; float: left; }
.tab_contact_wrap dl dd { margin: 0 0 0 110px }
.tab_contact_wrap dl dd a { display: block; color: var(--primary); text-decoration: none; font-weight: 700; }
.tab_contact_wrap dl dd p { margin-top: 5px }
.s_contant_step { margin-top: 20px; }


@media (max-width: 991px) {
    .sub_contest_tab .tabs { display: none; }
    .sub_contest_tab .sub_contest_sel { display: block; }
    .s_c_tit_box { flex-direction: column; }
    .s_c_bt_box { margin-top: 10px; }
    .s_c_bt_box .btn { width: 100%; }
    .s_c_title .s_c_t_row { font-size: 22px; }
    .add_step_arr:after { transform: rotate(90deg); right: 50%; top:auto; margin-top: 0; }
}
