@charset "euc-kr";

/* ==================================================
   RESET / COMMON
================================================== */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, 'Apple SD Gothic Neo', sans-serif; color: #111; background: #fff; -webkit-text-size-adjust: 100%; }
h1, h2, h3, p, dl, dt, dd, ul, li { margin: 0; padding: 0; }
ul { list-style: none; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; vertical-align: middle; }
strong { font-weight: 700; }

/* ==================================================
   TOKENS
================================================== */
:root { --c-primary: #0376f0; --c-text: #111; --c-sub: #333; --c-mute: #999; --c-line: #e2e2e2; --c-bg-soft: #f7f7f7; --c-bg-blue: #e8f1ff; --c-bg-blue2: #ebf3ff; }
.c-blue { color: var(--c-primary); }

/* ==================================================
   WRAPPER
================================================== */
.briefing-wrap { width: 100%; overflow: hidden; }

/* ==================================================
   VISUAL
================================================== */
.visual { position: relative; width: 100%; padding: 60px 0 80px; overflow: hidden; background: linear-gradient(180deg, #EEE 0%, #FFF 82.91%); }
.visual__inner { position: relative; max-width: 1000px; margin: 0 auto; text-align: center; }
.visual__kicker { text-align: center; font-size: 22px; font-weight: 500; line-height: 140%; color: #000; }
.visual__title { font-size: 52px; font-weight: 700; line-height: 120%; color: #000; letter-spacing: -0.01em; }
.visual__divider { display: block; width: 1px; height: 36px; margin: 16px auto; background: #000; }
.visual__desc { font-size: 20px; font-weight: 400; line-height: 140%; color: #000; }
.visual__desc strong { font-weight: 800; }
.visual__inner .flex-box { position: relative; display: flex; justify-content: center; align-items: center; gap: 39px; }
.visual__badge { flex: 0 0 100px; width: 100px; height: 100px; border-radius: 50%; background: linear-gradient(156.05deg, rgba(87,174,255,0.9) 0.3%, rgba(0,96,197,0.9) 72.5%); display: flex; align-items: center; justify-content: center; }
.visual__spacer { flex: 0 0 100px; align-self: stretch; }
.visual__badge span { font-size: 22px; font-weight: 800; line-height: 120%; color: #fff; text-align: center; letter-spacing: -0.22px; }

/* ==================================================
   CONTENT COMMON
================================================== */
.content-wrap { max-width: 1000px; margin: 0 auto; padding: 0 0 80px; display: flex; flex-direction: column; gap: 60px; }
.section { width: 100%; }
.section__title { font-size: 26px; font-weight: 700; line-height: 130%; color: #000; margin-bottom: 16px; }

/* ==================================================
   CARD
================================================== */
.card { background: #fff; border: 1px solid var(--c-line); border-radius: 10px; padding: 30px 40px; }
.card + .card { margin-top: 16px; }
.card__head { display: flex; align-items: baseline; gap: 8px; font-size: 24px; font-weight: 600; line-height: 140%; color: #000; margin-bottom: 16px; }
.card__head strong { flex-shrink: 0; }
.card__head > span { flex: 1; min-width: 0; }
.card__body { background: var(--c-bg-soft); border-radius: 6px; padding: 20px; }
.card__presenter { margin-top: 16px; font-size: 18px; font-weight: 600; line-height: 140%; text-align: right; color: #000; }
.card--plain { padding: 30px 40px; }

/* ==================================================
   BULLET LIST
================================================== */
.bullet-list { padding-left: 0; list-style: none; color: var(--c-sub); font-size: 18px; font-weight: 400; line-height: 130%; }
.bullet-list li { position: relative; padding-left: 20px; }
.bullet-list li::before { content: ''; position: absolute; left: 4px; top: 50%; width: 4px; height: 4px; border-radius: 50%; background: currentColor; transform: translateY(-50%); }
.bullet-list li + li { margin-top: 12px; }

/* ==================================================
   NOTE
================================================== */
.note { margin-top: 16px; font-size: 13px; color: var(--c-mute); text-align: center; line-height: 130%; }

/* ==================================================
   SCHEDULE
================================================== */
.schedule { background: #fff; border: 1px solid var(--c-line); border-radius: 10px; padding: 32px 40px; display: flex; align-items: center; gap: 30px; }
.schedule + .schedule {margin-top: 16px;}
.note + .schedule {margin-top: 24px;}
.schedule__text { flex: 1 0 0; min-width: 0; display: flex; align-items: center; gap: 40px; }
.schedule__region { width: 65px; text-align: center; font-size: 24px; font-weight: 700; line-height: 130%; color: #000; }
.schedule__meta { flex: 1 0 0; min-width: 0; display: flex; flex-direction: column; gap: 6px; }
.schedule__meta > div { display: flex; gap: 16px; align-items: center; }
.schedule__meta dt { font-size: 16px; font-weight: 600; color: var(--c-text); }
.schedule__meta dd { font-size: 16px; font-weight: 400; color: var(--c-text); }
.schedule__btns { display: flex; gap: 8px; align-items: stretch; }

/* ==================================================
   BUTTONS
================================================== */
.btn-apply {display: flex; width: 160px; padding: 0 24px; justify-content: center; align-items: center; align-self: stretch; border-radius: 999px; border: 1px solid var(--Primary, #0376F0); background: #EBF3FF; color: var(--Primary, #0376F0); text-align: center; font-family: Pretendard; font-size: 16px; font-style: normal; font-weight: 600; line-height: 130%; /* 20.8px */}
.btn-apply.off {border-radius: 999px; border: 1px solid #E2E2E2; background: #EFEFEF; color: #999; text-align: center; font-family: Pretendard; font-size: 14px; font-style: normal; font-weight: 600; line-height: 130%; /* 18.2px */}
.btn-icon { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: #fff; border-radius: 50%; flex-shrink: 0; }
.btn-icon img { height: auto; }

/* ==================================================
   BOTTOM BAR
================================================== */
.btm-bar { width: 100%; padding: 30px 20px; background: var(--c-bg-blue); text-align: center; }
.btm-bar p { font-size: 22px; line-height: 130%; color: #000; }
.btm-bar p span { font-weight: 500; display: block; }
.btm-bar p strong { font-weight: 700; display: block; }

/* ==================================================
   TABLET (768 ~ 1199)
================================================== */
@media screen and (max-width: 1199px) {
	.content-wrap {padding: 0 24px 80px;}
	.visual__inner .flex-box {gap: 19px;}
}

/* ==================================================
   MOBILE (~ 767)
================================================== */
@media screen and (max-width: 767px) {
	.visual { padding: 30px 16px; }
	.visual__kicker { font-size: 15px; }
	.visual__title { margin-top: 14px; font-size: 30px; line-height: 120%; }
	.visual__divider { height: 20px; margin: 10px auto; }
	.visual__desc { font-size: 13px; }
	.visual__inner .flex-box { width: 234px; gap: 12px; margin: 0 auto;}
	.visual__badge { position: absolute; left: -57px; bottom: -50px; width: 56px; height: 56px; padding-top: 3px; }
	.visual__badge span { font-size: 13px; letter-spacing: -0.13px; }
	.visual__spacer { flex: 0 0 56px; }

	.content-wrap { padding: 0 16px 40px; gap: 30px; }
	.section__title { font-size: 18px; margin-bottom: 10px; }

	.card { padding: 20px 16px; }
	.card + .card { margin-top: 10px; }
	.card__head { font-size: 16px; margin-bottom: 10px; }
	.card__body { padding: 16px 10px; }
	.card__presenter { font-size: 13px; margin-top: 10px; }
	.card--plain { padding: 20px 16px; }

	.bullet-list { font-size: 13px; }
	.bullet-list li { padding-left: 14px; }
	.bullet-list li::before { left: 3px; width: 3px; height: 3px; }
	.bullet-list li + li { margin-top: 12px; }

	.note { font-size: 12px; margin-top: 8px; }

	.schedule { flex-direction: column; align-items: stretch; gap: 16px; padding: 24px 20px; }
	.schedule + .schedule {margin-top: 10px;}
	.note + .schedule {margin-top: 16px;}
	.schedule__text { flex-direction: column; align-items: flex-start; gap: 10px; }
	.schedule__region { width: auto; font-size: 18px; }
	.schedule__meta { width: 100%; }
	.schedule__meta dt, .schedule__meta dd { font-size: 12px; }
	.schedule__btns { justify-content: end; width: 100%; gap: 8px; }
	.btn-apply { order: -1;  width: 100%; min-width: 190px; min-height: 40px; font-size: 16px; }

	.btm-bar { padding: 16px 20px; }
	.btm-bar p {color: #000; text-align: center; font-family: Pretendard; font-size: 14px; font-style: normal; font-weight: 500; line-height: 130%; /* 18.2px */ }
	.btm-bar p span, .btm-bar p strong { display: block; }
}
