/* ==================================================
   COMMON
================================================== */
*, *::before, *::after {margin: 0;padding: 0;box-sizing: border-box;}
html {-webkit-text-size-adjust: none;-ms-text-size-adjust: none;-moz-text-size-adjust: none;font-family: 'Pretendard', 'Malgun Gothic', 'Noto Sans KR', sans-serif;color: #222;line-height: 1.5;letter-spacing: -0.04em;}
body {font-family: 'Pretendard', 'Malgun Gothic', 'Noto Sans KR', dotum;font-weight: normal;word-break: keep-all;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;letter-spacing: 0;}
h1, h2, h3, h4, h5, h6, p, ul, ol, li, dl, dt, dd, form, fieldset, input, table, tr, th, td, article, aside, canvas, details, figure, footer, header, nav, section, summary, textarea, pre {margin: 0;padding: 0;}
ul, ol, li { list-style: none; }
img, svg, video {/* max-width: 100%; */height: auto;vertical-align: middle;border: none;}
a {text-decoration: none;color: inherit;display: inline-block;}
button {border: none;background: none;cursor: pointer;font-family: inherit;color: inherit;}
table {width: 100%;border-collapse: collapse;border-spacing: 0;}
pre {white-space: pre-wrap;word-wrap: break-word;}
em { font-style: normal; }

.flex-box { display: flex; gap: 4px; }
/* ==================================================
   TITLE SECTION
================================================== */
.title-section { background: url('https://russeldata.megastudy.net/campus/images/russel/intro/2026/online-mock/bg.png') repeat-x; }
.title-section .title-wrap { display: flex; flex-direction: column; justify-content: center; align-items: center; padding: clamp(48px, calc(48px + 12 * ((100vw - 360px) / 840)), 60px) 0; }
.title-section .title-wrap > span { display: flex; padding: 8px 20px; justify-content: center; align-items: center; gap: 8px; border-radius: 999px; background: linear-gradient(95deg, #FFA462 22.8%, #F6575A 83.61%); color: #FFF; text-align: center; font-size: clamp(16px, calc(16px + 8 * ((100vw - 360px) / 840)), 24px); font-weight: 600; line-height: 140%; letter-spacing: -0.02em; }
.title-section .title-wrap > h3 span:nth-of-type(1) { display: block; margin-top: 24px; color: #222; text-align: center; font-size: clamp(28px, calc(28px + 18 * ((100vw - 360px) / 840)), 46px); font-weight: 600; line-height: 130%; letter-spacing: -0.02em; }
.title-section .title-wrap > h3 span:nth-of-type(2) { display: flex; justify-content: center; align-items: center; text-align: center; font-size: clamp(48px, calc(48px + 36 * ((100vw - 360px) / 840)), 84px); font-weight: 800; line-height: 110%; letter-spacing: -0.025em; background: linear-gradient(95deg, #FFA462 22.8%, #F6575A 83.61%); background-clip: text; -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.title-section .title-wrap > p { margin-top: 24px; color: #101010; text-align: center; font-size: clamp(16px, calc(16px + 4 * ((100vw - 360px) / 840)), 20px); font-weight: 400; line-height: 140%; letter-spacing: -0.02em; }


/* ==================================================
   NOTICE SECTION
================================================== */
.notice-section { padding: clamp(48px, calc(48px + 12 * ((100vw - 360px) / 840)), 60px) 0; background: #FFF3F3; }
.notice-section .box-notice { max-width: 1024px; margin: 0 auto; }
.notice-section .tit { color: #333; text-align: center; font-size: clamp(24px, calc(24px + 8 * ((100vw - 360px) / 840)), 32px); font-weight: 700; line-height: 130%; letter-spacing: -0.02em; }
.notice-section .stit { margin-top: clamp(16px, calc(16px + 4 * ((100vw - 360px) / 840)), 20px); color: #333; text-align: center; font-size: clamp(18px, calc(18px + 4 * ((100vw - 360px) / 840)), 22px); font-weight: 400; line-height: 140%; letter-spacing: -0.01em; }
.notice-section .list-notice {margin: clamp(28px, calc(28px + 12 * ((100vw - 360px) / 840)), 40px) auto 0; padding: clamp(24px, calc(24px + 16 * ((100vw - 360px) / 840)), 40px) clamp(24px, calc(24px + 36 * ((100vw - 360px) / 840)), 60px); box-sizing: border-box; border-radius: 20px; background: #FFF; box-shadow: 0 4px 50px 0 rgba(0, 0, 0, 0.08); }
.notice-section .list-notice li span { color: #333; font-size: 14px; font-style: normal; font-weight: 400; line-height: 160%; letter-spacing: -0.01em; }

/* ==================================================
   APPLY SECTION
================================================== */
.apply-section { padding: clamp(48px, calc(48px + 12 * ((100vw - 360px) / 840)), 60px) 0 clamp(66px, calc(66px + 26 * ((100vw - 360px) / 840)), 92px); }
.apply-section .apply-title { color: #333; text-align: center; font-size: clamp(24px, calc(24px + 8 * ((100vw - 360px) / 840)), 32px); font-weight: 700; line-height: 130%; letter-spacing: -0.02em; }
.apply-section .apply-list-wrap { max-width: 1024px; margin: 28px auto 0; }
.apply-section .apply-list-wrap .apply-list { display: flex; border-top: 1px solid #EBEBEB; }
.apply-section .apply-list-wrap .apply-list:last-child { border-bottom: 1px solid #EBEBEB; }
.apply-section .apply-list-wrap .apply-list .apply-list-box { display: flex; flex-wrap: wrap; padding: 22px 16px; width: 100%; justify-content: space-between; gap: 16px; }
.apply-section .apply-list-wrap .apply-list .apply-list-box .checkbox { display: flex; align-items: center; justify-content: center; cursor: pointer; }
.apply-section .apply-list-wrap .apply-list .apply-list-box .checkbox svg:first-child { display: none; }
.apply-section .apply-list-wrap .apply-list .apply-list-box.is-checked { background: #F1F3F8; }
.apply-section .apply-list-wrap .apply-list .apply-list-box.is-checked .checkbox svg:first-child { display: flex; }
.apply-section .apply-list-wrap .apply-list .apply-list-box.is-checked .checkbox svg:last-child { display: none; }
.apply-section .apply-list-wrap .apply-list .apply-list-box .apply-text-wrap { display: flex; flex-direction: column; cursor: pointer; gap: 4px; }
.apply-section .apply-list-box .apply-box { display: flex; align-items: center; justify-content: space-between; flex: 1; gap: 16px; }
.apply-section .apply-list-box .apply-box .apply-price-wrap { display: flex; gap: 24px; }
.apply-section .apply-list-box .apply-box .apply-price-wrap .apply-price { display: flex; align-items: center; color: #333; font-size: 16px; font-weight: 600; line-height: 140%; letter-spacing: -0.01em; }
.apply-section .apply-list-box .apply-toggle { display: flex; align-items: center; margin-left: 2px; }
.apply-section .apply-list-box .flex-box .mock-title-info + .apply-toggle { color: #2C5BF6; font-size: clamp(15px, calc(15px + 1 * ((100vw - 360px) / 840)), 16px); font-weight: 600; line-height: 140%; letter-spacing: -0.01em; }
.apply-section .apply-list-box .flex-box .mock-title-info + .apply-toggle .apply-count { color: #2C5BF6; font-size: clamp(15px, calc(15px + 1 * ((100vw - 360px) / 840)), 16px); font-weight: 600; line-height: 140%; letter-spacing: -0.01em; margin-left: 3px; }
.apply-section .apply-list-box .flex-box .mock-title-info + .apply-toggle .toggle-arrow { color: #2C5BF6; font-size: clamp(15px, calc(15px + 1 * ((100vw - 360px) / 840)), 16px); font-weight: 600; line-height: 140%; letter-spacing: -0.01em; margin-left: 4px; }
.apply-section .apply-list-box .toggle-arrow em { font-size: 9px; }
.apply-section .apply-list-box .toggle-arrow em:first-child { display: none; }
.apply-section .apply-list-box .toggle-arrow em:last-child { display: flex; }
.apply-section .apply-list-box.is-open .toggle-arrow em:first-child { display: flex; }
.apply-section .apply-list-box.is-open .toggle-arrow em:last-child { display: none; }
.apply-section .apply-list-box .sub-apply-wrap { display: none; width: 100%; cursor: pointer; background-color: #f5f5f5; margin-left: 36px; border-radius: 8px; padding-left: 24px; }
.apply-section .apply-list-box.is-open .sub-apply-wrap { display: block; pointer-events: none; padding-right: 144px; }
.apply-section .apply-list-box .sub-apply-wrap li { display: flex; padding: 22px 0 16px; }
.apply-section .apply-list-box .sub-apply-wrap li + li { padding: 16px 0; border-top: 1px solid #E5E5E5; }
.apply-section .apply-list-box .sub-apply-wrap li:last-of-type { padding: 16px 0 22px; }
.apply-section .apply-list-box .sub-apply-wrap li .apply-text-wrap { flex: 1; }
.apply-section .flex-box span { color: #555; text-align: center; font-size: clamp(13px, calc(13px + 1 * ((100vw - 360px) / 840)), 14px); font-weight: 500; line-height: 120%; letter-spacing: -0.025em; }
.apply-section .apply-list-box .apply-text-wrap .flex-box .mock-title-info,
.apply-section .apply-list-box .sub-apply-wrap .flex-box .mock-title-info,
.apply-section .apply-list-box .sub-apply-wrap .flex-box.mock-title-info > span { color: #333; font-size: clamp(15px, calc(15px + 1 * ((100vw - 360px) / 840)), 16px); font-weight: 600; line-height: 140%; letter-spacing: -0.01em; }
.apply-section .apply-list-box .apply-text-wrap .apply-line { display: flex; justify-content: center; width: 1px; height: 12px; background: #ccc; margin-top: 2px; }
.apply-section .apply-list-box .sub-apply-wrap .apply-price-wrap { display: flex; align-items: flex-end; gap: 24px; }
.apply-section .apply-list-box .sub-apply-wrap .apply-price-wrap .apply-price { display: flex; align-items: center; color: #333; font-size: clamp(15px, calc(15px + 1 * ((100vw - 360px) / 840)), 16px); font-weight: 600; line-height: 140%; letter-spacing: -0.01em; }
.apply-section .pay-btn { display: flex; width: clamp(104px, calc(104px + 16 * ((100vw - 360px) / 840)), 120px); height: clamp(32px, calc(32px + 4 * ((100vw - 360px) / 840)), 36px); padding: clamp(9px, calc(9px + 3 * ((100vw - 360px) / 840)), 12px) 0; justify-content: center; align-items: center; gap: 4px; border-radius: 6px; background: #2C5BF6; color: #FFF; text-align: center; font-size: clamp(13px, calc(13px + 2 * ((100vw - 360px) / 840)), 15px); font-weight: 500; line-height: 110%; letter-spacing: -0.025em; }
.refund-wrap {display: flex; flex-direction: column; gap: 8px;  margin-top: clamp(16px, calc(16px + 6 * ((100vw - 360px) / 840)), 22px); }
.refund-wrap > button { display: flex; width: fit-content; padding: 4px 10px; justify-content: center; align-items: center; gap: 2px; border-radius: 999px; border: 1px solid #E5E5E5; background: transparent; color: #777; font-family: inherit; font-size: clamp(12px, calc(12px + 1 * ((100vw - 360px) / 840)), 13px); font-weight: 400; line-height: 150%; letter-spacing: -0.01em; cursor: pointer; -webkit-appearance: none; appearance: none; }
.apply-section .ex { position: relative; display: inline-flex; align-items: center; cursor: pointer; pointer-events: auto; }
.apply-section .ex img { width: 16px; height: 16px; }
.apply-section .ex .tooltip { display: none; position: absolute; left: 0px; top: 24px; background: #fff; border: 1px solid #E0E0E0; border-radius: 6px; padding: 8px 10px; white-space: nowrap; box-shadow: 0 4px 12px rgba(0,0,0,0.1); z-index: 10; }
.apply-section .ex .tooltip span { display: block; color: #333; font-size: 13px; text-align: left; font-style: normal; font-weight: 500; line-height: 130%; letter-spacing: -0.325px; }
.apply-section .ex .tooltip span:nth-of-type(2) { font-weight: 300; }
.apply-section .ex.is-tooltip-open .tooltip { display: block; }
.apply-section .ex .tooltip .close-btn { display: none; }

@media (hover: hover) and (pointer: fine) {
   .apply-section .ex:hover .tooltip { display: block; }
}


/* ==================================================
   PAYMENT SECTION
================================================== */
.payment-section { display: none; position: fixed; bottom: 0; width: 100%; justify-content: center; align-items: center; z-index: 30; }
.payment-section.is-visible { display: flex; }
.payment-section > a { display: flex; width: min(1000px, 100%); height: clamp(56px, calc(56px + 14 * ((100vw - 360px) / 840)), 70px); padding: 0 clamp(24px, calc(24px + 2 * ((100vw - 360px) / 840)), 26px) 0 clamp(24px, calc(24px + 16 * ((100vw - 360px) / 840)), 40px); justify-content: space-between; align-items: center; border-radius: 10px; background: #2C5BF6; color: #FFF; font-size: clamp(18px, calc(18px + 6 * ((100vw - 360px) / 840)), 24px); font-weight: 700; line-height: 120%; text-decoration: none; }


/* ==================================================
   POP-UP
================================================== */
.pop-wrap { position: fixed; inset: 0; z-index: 100; }
.pop-dim { position: absolute; inset: 0; background: rgba(0, 0, 0, 0.5); }
.pop-inner { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 648px; max-width: 648px; max-height: calc(100% - 80px); display: flex; }
.pop-box { width: 100%; max-height: 100%; background: #fff; overflow: hidden; display: flex; flex-direction: column; }
.pop-inner:has(.refund) .pop-box { border-radius: 10px; }
body.is-pop-open { overflow: hidden; }

.pop-box-header { position: relative; display: flex; justify-content: center; align-items: center; padding: 32px 56px 20px; border-bottom: 1px solid #DBDEE5; flex-shrink: 0; }
.pop-box-header h3 { margin: 0; color: #222; font-size: 18px; font-weight: 600; line-height: 140%; letter-spacing: -0.36px; text-align: center; }
.pop-box-back,
.pop-box-close { position: absolute; top: 50%; transform: translateY(-50%); width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: none; border: 0; padding: 0; cursor: pointer; }
.pop-box-back { left: 16px; display: none; }
.pop-box-close { right: 16px; }

.pop-box-body { flex: 1 1 auto; overflow-y: auto; padding: 0 24px 14px; }

.pop-box-footer { flex-shrink: 0; padding: 12px 0 40px; margin: 0 24px; border-top: 1px solid #F0F0F0; }
.pop-box-footer p { margin: 0; color: #7E7E7E; font-size: 14px; font-weight: 400; line-height: 140%; letter-spacing: -0.28px; }


/* ==================================================
   REFUND
================================================== */
.refund-group { margin-top: 15px; }
.refund-group:first-child { margin-top: 20px; }
.refund-group-title { display: flex; padding: 12px 20px; justify-content: center; align-items: center; text-align: center; background: #EDEDED; color: #222; font-size: 14px; font-weight: 600; line-height: 130%; letter-spacing: -0.14px; }
.refund-group ul { display: flex; flex-direction: column; gap: 6px; padding: 12px 50px 0; margin: 0; list-style: none; }
.refund-group li { color: #333; font-size: 13px; font-weight: 400; line-height: 140%; letter-spacing: -0.13px; padding-left: 12px; text-indent: -9px; }
.refund-group li em { color: #ED2024; font-style: normal; }
.refund .pop-box-header { position: static; justify-content: start; margin: 0 24px; padding: 32px 0 20px; }
.refund .pop-box-close { width: 28px; height: 28px; top: 24px; right: 24px; transform: none; }


/* ==================================================
   APPLY FORM
================================================== */
.pop-date-header { margin-top: 20px; padding: 16px 0; text-align: center; font-size: 15px; color: #222; line-height: 150%; }
.pop-date-header strong { display: inline-block; margin-top: 4px; font-size: 18px; font-weight: 700; }

.pop-form-section-title { margin-top: 20px; padding: 10px 0; font-size: 15px; font-weight: 600; color: #222; border-bottom: 1px solid #DBDEE5; }

.pop-form-row { display: flex; align-items: center; gap: 12px; padding: 10px 0; border-bottom: 1px solid #F0F0F0; }
.pop-form-row > label { flex: 0 0 110px; font-size: 13px; font-weight: 500; color: #333; letter-spacing: -0.13px; }
.pop-form-row .pop-form-note { margin-left: 4px; color: #ED2024; font-size: 12px; font-weight: 400; }

.pop-form-row input[type="text"],
.pop-form-row select { height: 36px; padding: 0 10px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 13px; color: #222; background: #fff; box-sizing: border-box; }
.pop-form-row > input[type="text"],
.pop-form-row > select { flex: 1; }
.pop-form-row input::placeholder { color: #B1B1B1; }

.apply .pop-form-row > input[readonly], textarea[readonly]{	background:#F5F5F5 !important;	color:#999 !important;	border-color:#DBDEE5 !important;	pointer-events:none;	cursor:default;}
input[readonly]{background:#F5F5F5 !important;color:#999 !important;pointer-events:none;cursor:default;}
.pop-inline-buttons.is-complete .pop-radio-btn{	background:#F5F5F5;	color:#999;	border:1px solid #DBDEE5;	pointer-events:none;}
.pop-inline-buttons.is-complete .pop-radio-btn.is-active{background:#2C5BF6;color:#fff;border-color:#2C5BF6;}
select.is-readonly{	background:#F5F5F5 !important;	color:#999 !important;	border-color:#DBDEE5 !important;pointer-events:none;	cursor:default;appearance:none;-webkit-appearance:none;-moz-appearance:none;}



.pop-inline-buttons,
.pop-check-group { display: flex; flex-wrap: wrap; gap: 8px; flex: 1; }

.pop-check-item { display: inline-flex; align-items: center; gap: 6px; padding: 6px 10px; border: 1px solid #DBDEE5; border-radius: 4px; background: #fff; color: #555; font-size: 13px; cursor: pointer; }
.pop-check-item.is-checked { border-color: #2C5BF6; color: #2C5BF6; background: #F5F8FF; }
.pop-check-item .checkbox { position: relative; width: 18px; height: 18px; flex-shrink: 0; }
.pop-check-item .checkbox svg { position: absolute; top: 0; left: 0; }
.pop-check-item .checkbox svg:first-child { display: none; }
.pop-check-item .checkbox svg:last-child { display: block; }
.pop-check-item.is-checked .checkbox svg:first-child { display: block; }
.pop-check-item.is-checked .checkbox svg:last-child { display: none; }

.pop-radio-btn { display: inline-flex; align-items: center; padding: 7px 16px; border: 1px solid #DBDEE5; border-radius: 4px; background: #fff; color: #555; font-size: 13px; cursor: pointer; }
.pop-radio-btn.is-active { border-color: #2C5BF6; color: #2C5BF6; background: #F5F8FF; }
.pop-radio-btn.is-required { border-color: #ED2024; color: #ED2024; background: #FFF5F5; cursor: default; }

.pop-dob { display: flex; align-items: center; gap: 6px; flex: 1; }
.pop-dob input { height: 36px; padding: 0 8px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 13px; text-align: center; box-sizing: border-box; }
.pop-dob input[name="birthY"] { flex: 0 0 70px; }
.pop-dob input[name="birthM"],
.pop-dob input[name="birthD"] { flex: 0 0 48px; }
.pop-dob span { font-size: 13px; color: #555; }

.pop-phone-row { display: flex; align-items: center; gap: 6px; flex: 1; }
.pop-phone-row select { flex: 0 0 80px; height: 36px; padding: 0 8px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 13px; background: #fff; box-sizing: border-box; }
.pop-phone-row input { flex: 1; height: 36px; padding: 0 8px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 13px; text-align: center; box-sizing: border-box; }
.pop-phone-row span { color: #555; }

.pop-form-search-row { display: flex; gap: 6px; flex: 1; }
.pop-form-search-row input { flex: 1; }
.pop-form-search-btn { flex: 0 0 auto; height: 36px; padding: 0 14px; background: #222; color: #fff; border: 0; border-radius: 4px; font-size: 13px; cursor: pointer; }

.pop-consent-body { margin-top: 12px; font-size: 13px; color: #333; text-align: center; line-height: 170%; }
.pop-consent-note { margin-top: 8px; color: #ED2024; font-size: 12px; text-align: center; }

.pop-sign-wrap{display:flex;align-items:center;justify-content:center;gap:10px;margin:14px 0 24px;}
.pop-sign-label{font-size:14px;font-weight:700;color:#333;line-height:1;}
.pop-sign-box{display:flex;align-items:center;width:130px;height:38px;padding:12px;border-radius: 4px;border: 1px solid #DBDEE5;background: #F5F5F5;font-size:14px;font-weight:400;color:#7E7E7E;box-sizing:border-box;}
.pop-sign-text{font-size:14px;font-weight:400;color:#333;line-height:1;}

.pop-info-box { margin-top: 20px; padding: 16px; background: #F7F8FA; border-radius: 6px; }
.pop-info-box h4 { margin: 0 0 8px; font-size: 14px; font-weight: 600; color: #222; }
.pop-info-box p { margin: 6px 0 0; font-size: 12px; line-height: 160%; color: #555; }
.pop-info-box strong { color: #222; font-weight: 600; }

.pop-notice { margin-top: 16px; padding: 14px 16px; background: #FAFAFA; border-radius: 6px; }
.pop-notice ul { margin: 0; padding: 0; list-style: none; }
.pop-notice li { font-size: 12px; color: #666; line-height: 170%; letter-spacing: -0.12px; }
.pop-notice li:first-child { margin-bottom: 4px; color: #222; font-weight: 600; }

.pop-submit { display: block; width: 100%; margin: 20px 0; padding: 14px 0; background: #2C5BF6; color: #fff; border: 0; border-radius: 6px; font-size: 15px; font-weight: 600; cursor: pointer; }
.pop-submit:hover { background: #1E4AE0; }


/* ==================================================
   RESPONSIVE
================================================== */
@media (max-width: 1199px) {
   .notice-section { padding-left: 24px; padding-right: 24px; }
   .apply-section { padding-left: 24px; padding-right: 24px; }
   .payment-section { padding: 0 24px; }
}

@media (max-width: 767px) {
   .notice-section { padding-left: 16px; padding-right: 16px; }

   .apply-section { padding-left: 0; padding-right: 0; }
   .apply-section .apply-list-wrap { margin: 20px 0 0; }
   .apply-section .apply-list-wrap .apply-list .apply-list-box { position: relative; padding: 16px; gap: 12px; flex-direction: column; flex-wrap: nowrap; }
   .apply-section .apply-list-wrap .apply-list .apply-list-box .checkbox { position: absolute; top: 16px; right: 16px; }
   .apply-section .apply-list-wrap .apply-list .apply-list-box .apply-text-wrap { gap: 5px; }
   .apply-section .apply-list-box .apply-box { display: contents; }
   .apply-section .apply-list-box .apply-text-wrap { order: 1; padding-right: 30px; }
   .apply-section .apply-list-box .sub-apply-wrap { order: 2; }
   .apply-section .apply-list-box .apply-price-wrap { order: 3; display: flex; justify-content: space-between; align-items: center; gap: 0; width: 100%; }
   .apply-section .apply-list-box .apply-text-wrap .flex-box .mock-title-info { text-align: left; }
   .apply-section .apply-list-box .sub-apply-wrap { margin-left: 0; padding: 0 16px; }
   .apply-section .apply-list-box.is-open .sub-apply-wrap { padding-right: 16px; }
   .apply-section .apply-list-box .sub-apply-wrap li { padding: 16px 0; flex-direction: column; }
   .apply-section .apply-list-box .sub-apply-wrap li + li { padding: 16px 0; }
   .apply-section .apply-list-box .sub-apply-wrap .apply-price-wrap { gap: 0; justify-content: space-between; margin-top: 4px; }

   .apply-section .ex .tooltip .close-btn { position: absolute; display: flex; align-items: center; justify-content: center; top: 0; right: 0; width: 24px; height: 24px; cursor: pointer; }
   .apply-section .ex .tooltip .close-btn img { width: 8px; height: 8px; }

   .payment-section { padding: 0 16px 16px; }
   .payment-section > a { width: 100%; }
   .refund-wrap { padding: 0 16px; }

   .refund-group { margin-top: 12px; }
   .refund-group-title { padding: 10px 16px; font-size: 13px; line-height: 140%; }
   .refund-group ul { padding: 12px 14px 0; gap: 4px; }
   .refund-group li { font-size: 12px; line-height: 170%; }
}

/* popup generic rules share the 648/647 system-popup breakpoint (refund excluded). */
@media (max-width: 647px) {
   .pop-inner { width: calc(100% - 32px); max-height: calc(100% - 40px); }
   .pop-box { border-radius: 10px; }

   .pop-box-header { padding: 20px 48px 14px; }
   .pop-box-header h3 { font-size: 15px; line-height: 140%; }
   .pop-box-back,
   .pop-box-close { width: 28px; height: 28px; }
   .pop-box-back { left: 12px; }
   .pop-box-close { right: 12px; }

   .pop-box-body { padding: 0 16px 16px; }
   .pop-box-footer { margin: 0 16px; padding: 10px 0 20px; }
   .pop-box-footer p { font-size: 12px; }

   .pop-form-row { flex-wrap: wrap; gap: 6px; padding: 10px 0; }
   .pop-form-row > label { flex: 0 0 100%; font-size: 12px; }
   .pop-dob input[name="birthY"] { flex: 0 0 60px; }
   .pop-dob input[name="birthM"],
   .pop-dob input[name="birthD"] { flex: 0 0 44px; }
   .pop-phone-row select { flex: 0 0 72px; }
}


/* ==================================================
   PAY POPUP
================================================== */
.pay .pop-box-header,
.nothing .pop-box-header,
.apply .pop-box-header { padding: 17px 15px; border-bottom: 1px solid #EBEBEB; }
.pay .pop-box-header h3,
.nothing .pop-box-header h3,
.apply .pop-box-header h3 { font-size: 18px; font-weight: 600; letter-spacing: 0.54px; line-height: 1; }
.pay .pop-box-body { padding: 0; }

.pay .pop-desc { margin: 0; padding: 16px 24px; color: #333; text-align: center; font-size: 14px; font-style: normal; font-weight: 400; line-height: 150%; letter-spacing: -0.14px; }

.pay .pop-section-title,
.apply .pop-section-title { margin: 0 0 5px 0; color: #7E7E7E; font-size: 14px; font-weight: 700; line-height: 150%; letter-spacing: -0.14px; background: #fff; }

.pay .pop-section-body { height: 158px; margin: 0; padding: 16px 24px; overflow-y: auto; border-bottom: 1px solid #EDEDED; border-top: 1px solid #EDEDED; }
.pay .pop-section-sub,
.apply .pop-section-sub { margin: 0 0 20px; color: #7E7E7E; font-size: 13px; font-weight: 400; line-height: 150%; letter-spacing: -0.13px; }
.pay .pop-section-sub:last-child,
.apply .pop-section-sub:last-child { margin-bottom: 0; }

.pay .pop-label { display: block; margin: 32px 24px 10px; color: #222; font-size: 14px; font-weight: 600; line-height: 150%; letter-spacing: -0.14px; }

.pay .pop-phone-row { gap: 8px; margin: 0 24px; }
.pay .pop-phone-row select,
.pay .pop-phone-row input { width: 33.33%; flex: 1; height: 38px; padding: 0 12px; font-size: 14px; color: #333; text-align: left; border: 1px solid #DBDEE5; border-radius: 4px; background: #fff; box-sizing: border-box; letter-spacing: -0.28px; }
.pay .pop-phone-row span { color: #555; }

.pay .pop-submit { display: block; width: 240px; margin: 26px auto 32px; padding: 12px 10px; background: #2C5BF6; color: #fff; border: 0; border-radius: 5px; font-size: 16px; font-weight: 600; line-height: 150%; letter-spacing: -0.16px; cursor: pointer; }
.pay .pop-submit:hover,
.nothing .pop-submit:hover,
.apply .pop-submit:hover { background: #1E4AE0; }

.apply .pop-btn-wrap{display:flex;gap:10px;margin:20px auto 24px;padding:0 16px;}
.apply .pop-btn-wrap .pop-submit{flex:1;display:flex;align-items:center;justify-content:center;height:46px;margin:0;padding:0;border-radius:6px;font-size:16px;font-weight:700;line-height:1;background:#2C5BF6;color:#fff;}
.apply .pop-btn-wrap .pop-submit.is-print{background:#AEB4BF;color:#fff;}
.apply .pop-btn-wrap .pop-submit:hover{background:#1E4AE0;}
.apply .pop-btn-wrap .pop-submit.is-print:hover{background:#969DA8;}


@media (max-width: 647px) {
   .pay .pop-box-back { display: flex; }
   .pay .pop-desc { padding: 16px; }
   .pay .pop-section-body { padding: 16px; }
   .pay .pop-label { margin: 32px 16px 10px; }
   .pay .pop-phone-row { margin: 0 16px; }
   .pay .pop-submit { width: calc(100% - 30px); max-width: 330px; }

   
}

.pay .pop-phone-row select { appearance: none !important; -webkit-appearance: none !important; -moz-appearance: none !important; padding-right: 32px !important; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='7' viewBox='0 0 13 7' fill='none'%3E%3Cpath d='M12.1736 0.499994L6.3368 6.33679L0.5 0.499994' stroke='%23333333' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important; background-repeat: no-repeat !important; background-position: right 12px center !important; background-size: 13px 7px !important; }
.pay .pop-phone-row select::-ms-expand { display: none; }


/* ==================================================
   MOBILE FULLSCREEN POPUP
================================================== */
@media (max-width: 647px) {
   .pop-inner { top: 0; left: 0; transform: none; width: 100%; max-width: 100%; height: 100%; max-height: 100%; }
   .pop-box { border-radius: 0; }

   .pop-inner:has(.refund) { top: 50%; left: 50%; transform: translate(-50%, -50%); width: calc(100% - 32px); max-width: calc(100% - 32px); height: auto; max-height: calc(100% - 40px); }
   .pop-inner:has(.refund) .pop-box { border-radius: 10px; }
}


/* ==================================================
   MOBILE BACK/CLOSE TOGGLE
================================================== */
@media (max-width: 647px) {
   .pop-box-back { display: flex; }
   .pop-box-close { display: none; }
   .pop-inner:has(.refund) .pop-box-back { display: none; }
   .pop-inner:has(.refund) .pop-box-close { display: flex; }
}


/* ==================================================
   NOTHING POPUP
================================================== */
/* .nothing .pop-box-body { padding: 0 0 293px 0; } */

.nothing .pop-empty { display: flex; flex-direction: column; gap: 10px; padding: 32px 16px 16px; text-align: center; }
.nothing .pop-empty > p { margin: 0; color: #2C5BF6; font-size: 16px; font-weight: 600; line-height: 150%; letter-spacing: -0.16px; }
.nothing .pop-empty > ul { list-style: none; margin: 0; padding: 0; }
.nothing .pop-empty > ul > li { color: #333; font-size: 13px; font-weight: 400; line-height: 150%; letter-spacing: -0.13px; }

.nothing .pop-submit { display: block; width: 240px; margin: 16px auto; padding: 12px 10px; background: #2C5BF6; color: #fff; border: 0; border-radius: 5px; font-size: 16px; font-weight: 600; line-height: 150%; letter-spacing: -0.16px; cursor: pointer; }

@media (max-width: 647px) {
   .nothing .pop-submit { width: calc(100% - 30px); max-width: 330px; }
}


/* ==================================================
   APPLY POPUP
================================================== */
.apply .pop-box-body { padding: 0 24px; }

.apply .pop-date-header.main-header { border: none; margin: 0; font-size: 18px; }
.apply .pop-date-header { margin: 20px 0 0; padding: 20px 0 0; text-align: center; color: #333; font-size: 14px; font-weight: 400; line-height: 150%; letter-spacing: -0.18px; border-bottom: 0; border-top: 1px solid var(--Gray-Line1, #EDEDED); }
.apply .pop-date-header strong { display: block; color: #2C5BF6; font-weight: 600; font-size: 18px; margin-top: 0; }

.apply .pop-form-section-title { margin: 20px 0; padding: 9px 16px; display: flex; align-items: center; justify-content: start; color: #333; font-size: 16px; font-style: normal; font-weight: 600; line-height: 140%; letter-spacing: -0.32px; background: #F1F3F8; border: none; }

.apply .pop-form-row { display: flex; flex-direction: row; align-items: center; gap: 0px; row-gap: 10px; margin-left: 16px; border-bottom: 0; padding: 0; }
.apply .pop-form-row > label { flex: 0 0 134px; color: #222; font-size: 14px; font-weight: 600; letter-spacing: -0.14px; line-height: 1.5; }
.apply .pop-form-row > label.full { flex: 1 1 100%; padding-left: 0; }
.apply .pop-form-row .pop-form-note { margin-left: 4px; color: #2C5BF6; font-weight: 600; font-size: 14px; }

.apply .pop-form-row:has(.pop-check-group) { flex-wrap: wrap; }
.apply .pop-form-row .pop-check-group { flex: 0 0 auto; width: calc(100% - 140px); margin-left: 140px; }

.apply .pop-form-row > input[type="text"],
.apply .pop-form-row > select { flex: 1; height: 38px; padding: 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; background: #fff; box-sizing: border-box; letter-spacing: -0.28px; }

.apply .flex-box { flex-direction: column; gap: 14px; }
.apply .flex-box2 { display: flex; flex-direction: column; gap: 24.8px; }

.apply .pop-dob { flex: 1; display: flex; align-items: center; gap: 5px; }
.apply .pop-dob input { flex: 0 0 117px; height: 38px; padding: 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; text-align: left; box-sizing: border-box; }
.apply .pop-dob { flex: 1; display: flex; align-items: center; gap: 5px; min-width: 0; }
.apply .pop-dob input { flex: 1 1 0; width: auto; min-width: 0; height: 38px; padding: 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; text-align: left; box-sizing: border-box; }
.apply .pop-dob span { flex: 0 0 auto; font-size: 14px; color: #333; letter-spacing: -0.28px; }



.apply .pop-dob span { font-size: 14px; color: #333; letter-spacing: -0.28px; }

.apply .pop-phone-row { flex: 1; gap: 8px; }
.apply .pop-phone-row { flex: 1; display: flex; align-items: center; gap: 8px; min-width: 0; }
.apply .pop-phone-row .select-wrap, .apply .pop-phone-row input { flex: 1 1 0; width: auto; min-width: 0; height: 38px; box-sizing: border-box; }
.apply .pop-phone-row input { padding: 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; text-align: left; background: #fff; }
.apply .pop-phone-row .select-btn { width: 100%; height: 38px; padding: 0 12px 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; text-align: left; background: #fff; box-sizing: border-box; }
.apply .pop-phone-row .select-list { width: 100%; }


.apply .pop-inline-buttons { flex: 1; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.apply .pop-check-group { flex: 1; display: flex; flex-wrap: wrap; gap: 12px; padding: 8px 12px; background: #F1F3F8; border-radius: 6px; }
.apply .pop-check-group.is-disabled { display: none; pointer-events: none; }
.apply .pop-check-group.is-disabled .pop-check-item { cursor: not-allowed; }

.apply .pop-check-item { display: inline-flex; align-items: center; gap: 4px; padding: 0; border: 0; background: none; color: #222; font-size: 14px; font-weight: 400; letter-spacing: -0.14px; line-height: 1.5; cursor: pointer; }
.apply .pop-check-item.is-checked { border: 0; background: none; color: #222; }
.apply .pop-check-item span { color: #222; }
.apply .pop-check-item .checkbox { position: relative; width: 18px; height: 18px; flex-shrink: 0; }
.apply .pop-check-item .checkbox svg { position: absolute; top: 0; left: 0; width: 18px; height: 18px; }

.apply .pop-radio-btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; height: 38px; padding: 14px 30px; border: 1px solid #DBDEE5; border-radius: 4px; background: #fff; color: #333; font-size: 14px; font-weight: 500; letter-spacing: -0.28px; line-height: 1.5; cursor: pointer; }
.apply .pop-radio-btn.is-active { border-color: #2C5BF6; background: #2C5BF6; color: #fff; font-weight: 700; }
.apply .pop-radio-btn.is-required { flex: 0 0 auto; padding: 0; border: 0; background: none; color: #2C5BF6; font-weight: 600; font-size: 14px; cursor: default; height: auto; justify-content: flex-start; }

.apply .pop-form-search-row { flex: 1; display: flex; gap: 8px; }
.apply .pop-form-search-row input::placeholder { color: #7E7E7E; }
.apply .pop-form-search-row input { flex: 1; height: 38px; padding: 0 12px; border: 1px solid #DBDEE5; border-radius: 4px; font-size: 14px; color: #333; box-sizing: border-box; }
.apply .pop-form-search-btn { flex: 0 0 85px; height: 38px; padding: 0 8px; background: #9AA3B2; color: #fff; border: 0; border-radius: 4px; font-size: 14px; font-weight: 600; letter-spacing: -0.28px; cursor: pointer; }

.apply .pop-consent-body { margin: 0; color: #333; font-size: 14px; line-height: 1.5; letter-spacing: -0.14px; text-align: center; }
.apply .pop-consent-note { margin: 0; padding: 0; color: #333; font-size: 14px; text-align: center; line-height: 1.5; }

.apply .pop-info-box { margin: 16px 24px; padding: 0; background: none; border-radius: 0; height: 100px; overflow-y: auto; }
.apply .pop-info-box h4 { margin: 0 0 5px; color: #7E7E7E; font-size: 14px; font-weight: 700; line-height: 1.5; letter-spacing: -0.14px; }
.apply .pop-info-box p { margin: 0; color: #7E7E7E; font-size: 13px; line-height: 1.5; letter-spacing: -0.13px; }
.apply .pop-info-box strong { color: #7E7E7E; font-weight: 700; }


.pop-ticket-wrap{margin:44px 0 0;text-align:center;color:#333;}
.pop-ticket-title{margin:0 0 20px;font-size:18px;font-weight:400;line-height:1.35;}
.pop-ticket-title strong{display:inline-block;color:#2C5BF6;font-weight:600;}

.pop-ticket-confirm{margin:32px 0 0px;font-size:14px;line-height:1.55;padding-bottom: 16px;}
.pop-ticket-confirm p{margin:0;}
.pop-ticket-confirm strong{display:block;margin:12px 0;font-size:14px;font-weight:700;}
.pop-ticket-confirm em{color:#2C5BF6;font-style:normal;font-weight:700;}


.apply .pop-section-body { height: 138px; margin: 0; padding: 16px 0; overflow-y: auto; }

.apply .pop-notice { margin-top: 16px; padding: 0; background: none; border-radius: 0; }
.apply .pop-notice ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 3px; }
.apply .pop-notice li { text-indent: -9px; margin-left: 9px; color: #333; font-size: 13px; line-height: 1.5; letter-spacing: -0.13px; }
.apply .pop-notice li:first-child { text-indent: -9px; color: #333; font-weight: 600; margin: 0 0 0 9px; }
.apply .pop-notice li:nth-child(4), .apply .pop-notice li:nth-child(5) { color: #ED2024; }
.apply .pop-notice li:last-child { color: #333; }
/* override global rwd/css/layout.css:194 `li:has(> .only-pc-ta:only-child)` collapse rule */
.apply .pop-notice li:has(> .only-pc-ta:only-child) { height: auto; line-height: 1.5; margin-left: 9px; }
.apply .pop-submit { display: block; width: 330px;height: 46px; margin: 20px auto; padding: 12px 10px; text-align: center; background: #2C5BF6; color: #fff; border: 0; border-radius: 5px; font-size: 16px; font-weight: 600; line-height: 150%; letter-spacing: -0.16px; cursor: pointer; }


/* ÀÀ½Ã ¿Ï·á ÆË¾÷ÀÏ °æ¿ì Ã¼Å©¹Ú½º ·¹ÀÌ¾Æ¿ô ¼öÁ¤ */
.apply.is-complete .pop-check-item:not(.is-checked){color:#222}
.apply.is-complete .pop-check-item:not(.is-checked) .checkbox svg:first-child{display:none}
.apply.is-complete .pop-check-item:not(.is-checked) .checkbox svg:last-child{display:block}
.apply.is-complete .pop-check-item:not(.is-checked) .checkbox{border-radius: 3px;background: #F5F5F5;}
.apply.is-complete .pop-check-item:not(.is-checked) span{color:#222}
.apply.is-complete .pop-check-item:not(.is-checked){pointer-events:none}
.apply.is-complete .pop-check-item.is-checked{color:#111}
.apply.is-complete .pop-sign-wrap {border-bottom: 1px solid #EDEDED;padding-bottom: 24px;}
.apply.is-complete .custom-dropdown {width: 100%;}
.apply.is-complete .custom-dropdown .select-btn {width: 100%;}
.apply.is-complete .pop-notice li:nth-child(4), .apply .pop-notice li:nth-child(5) { color: unset; }
.apply.is-complete .pop-notice li.red_txt {color: #ED2024;}

.apply.is-complete .pop-ticket-table{width:100%;border-top:1px solid #B1B1B1;border-bottom:1px solid #B1B1B1;text-align:center}
.apply.is-complete .pop-ticket-table table{width:100%;border-collapse:collapse;table-layout:fixed}
.apply.is-complete .pop-ticket-table .col-group{width:100px}
.apply.is-complete .pop-ticket-table th,.pop-ticket-table td{height:42px;padding:8px 10px;border-left:1px solid #EDEDED;border-top:1px solid #EDEDED;background:#fff;color:#333;font-size:14px;font-weight:400;line-height:1.5;text-align:center;vertical-align:middle;word-break:keep-all}
.apply.is-complete .pop-ticket-table tr td:first-of-type {border-left: 0;}
.apply.is-complete .pop-ticket-table tr:first-child th{border-top:0;}
.apply.is-complete .pop-ticket-table tr:first-child th:nth-of-type(2){border-left:0;}
.apply.is-complete .pop-ticket-table th:first-child,.pop-ticket-table td:first-child{border-left:0}
.apply.is-complete .pop-ticket-table .ticket-group{background:#EDEDED;border-left:0;color:#333;font-weight:400}
.apply.is-complete .pop-ticket-table tr:last-child .ticket-group {border-top: 1px solid #fff;}
.apply.is-complete .pop-ticket-table .ticket-value{color:#2C5BF6;font-weight:400}
.apply.is-complete .pop-ticket-table .ticket-price{height:54px;color:#333;font-size:16px;font-weight:700;line-height:1.4}


@media (max-width: 647px) {
   .apply .pop-box-body { padding: 0; }
   .apply .pop-date-header.main-header { margin: 0; padding: 20px 16px; border: none; }
   .apply .pop-date-header { margin: 0; padding: 20px 16px 0; }
   .apply .pop-section-body { padding: 0 16px; margin: 16px 0; }
   .apply .pop-section-title { margin: 0 0 3px 0; }
   .apply .pop-form-section-title { margin: 0; padding: 4px 16px; min-height: 40px; box-sizing: border-box; }
   .apply .flex-box, .apply .flex-box2 { padding: 20px 16px; gap: 14px; }
   .apply .pop-form-row { flex-direction: column; align-items: stretch; gap: 6px; margin: 0; padding: 0; }
   .apply .pop-form-row > label { flex: none; padding-left: 0; }
   .apply .pop-form-row > input[type="text"], .apply .pop-form-row > select { flex: 0 0 38px; width: 100%; height: 38px; padding: 0 12px; font-size: 14px; box-sizing: border-box; }
   .apply .pop-form-row .pop-inline-buttons { flex: 0 0 auto; width: 100%; gap: 12px; }
   .apply .pop-form-row .pop-check-group { margin: 4px 0 0; width: 100%; gap: 12px; }
   .apply .pop-dob, .apply .pop-phone-row, .apply .pop-form-search-row { flex: 0 0 auto; width: 100%; gap: 8px; }
   .apply .pop-dob { gap: 6px; }
   .apply .pop-dob input, .apply .pop-phone-row .select-wrap, .apply .pop-phone-row input, .apply .pop-form-search-row input { flex: 1 1 0; width: auto; min-width: 0; height: 38px; box-sizing: border-box; }
   .apply .pop-phone-row input { padding: 0 12px; font-size: 14px; }
   .apply .pop-phone-row .select-btn { width: 100%; height: 38px; font-size: 14px; }
   .apply .pop-consent-body, .apply .pop-consent-note { margin: 0 16px; }
   .apply .pop-info-box { margin: 16px; }
   .apply .pop-notice { margin: 16px 16px 0; }
   .apply .pop-submit { width: calc(100% - 30px); }

	.apply.is-complete .pop-ticket-wrap{padding:0 16px}
	.apply.is-complete .pop-ticket-table .col-group{width:80px}
	.apply.is-complete .pop-ticket-table th,.pop-ticket-table td{height:41px;padding:8px 4px;font-size:12px;line-height:1.45}
	.apply.is-complete .pop-ticket-table .ticket-price{height:49px;font-size:13px}
}

.pop-box select { appearance: none !important; -webkit-appearance: none !important; -moz-appearance: none !important; padding-right: 32px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='13' height='7' viewBox='0 0 13 7' fill='none'%3E%3Cpath d='M12.1736 0.499994L6.3368 6.33679L0.5 0.499994' stroke='%23333333' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") !important; background-repeat: no-repeat !important; background-position: right 12px center !important; background-size: 13px 7px !important; }
.pop-box select::-ms-expand { display: none; }



