/* ============================================================
   MNNBOX — "Verified Stage" 디자인 시스템 v1.0
   무대감(신뢰) + 정보 플랫폼(정렬·배지·계량)
   블루프린트 ⑥ 디자인 방향·토큰 기반. 목업 전 화면 공용.
   ============================================================ */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");

:root {
  /* 컬러 */
  --navy: #0A2472;
  --navy-deep: #071A4A;
  --amber: #FFBA08;      /* 스포트라이트·포커스링·타이머 노란링 한정 */
  --amber-rgb: 255, 186, 8;
  --gold: #F5A623;       /* CTA·D-day 강조(대량) */
  --gold-rgb: 245, 166, 35;
  --teal: #0E9F6E;       /* 본인인증 성공 */
  --ink: #14181F;
  --slate: #5B6472;
  --line: #E4E7EC;
  --surface: #F7F8FA;
  --white: #FFFFFF;
  /* 카테고리 hue (S~55 L~55 통일) */
  --cat-film: #C0483F;     /* 영화 */
  --cat-drama: #2F7ED8;    /* 드라마/OTT */
  --cat-ad: #6E56C9;       /* 광고/CF */
  --cat-mv: #C7477E;       /* 뮤비 */
  --cat-model: #0E9F6E;    /* 모델 */
  --cat-etc: #8A6D3B;      /* 기타/연극 */
  /* 간격/모양 */
  --r-card: 14px;
  --r-btn: 10px;
  --r-input: 10px;
  --shadow-sm: 0 1px 2px rgba(20,20,30,.05);
  --shadow-md: 0 2px 4px rgba(20,20,30,.05), 0 10px 28px rgba(20,20,30,.07);
  --shadow-lg: 0 8px 40px rgba(7,26,74,.16);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0; font-family: "Pretendard", system-ui, sans-serif;
  color: var(--ink); background: var(--surface);
  line-height: 1.6; letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.tnum { font-variant-numeric: tabular-nums; }

/* ---------- 레이아웃 ---------- */
.ds-container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.ds-section { padding: 64px 0; }
@media (max-width: 768px) { .ds-section { padding: 40px 0; } .ds-container { padding: 0 18px; } }

/* ---------- 타이포 ---------- */
.ds-h1 { font-size: 44px; line-height: 1.24; font-weight: 800; letter-spacing: -0.025em; margin: 0; }
.ds-h2 { font-size: 30px; line-height: 1.3; font-weight: 800; letter-spacing: -0.02em; margin: 0; }
.ds-h3 { font-size: 20px; font-weight: 700; letter-spacing: -0.01em; margin: 0; }
.ds-lead { font-size: 17px; color: var(--slate); line-height: 1.65; }
.ds-eyebrow { font-size: 12.5px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--gold); }
@media (max-width: 768px) { .ds-h1 { font-size: 28px; } .ds-h2 { font-size: 23px; } }

/* ---------- 버튼 ---------- */
.ds-btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: inherit; font-weight: 700; font-size: 15px; border-radius: var(--r-btn);
  padding: 13px 22px; border: 1.5px solid transparent; cursor: pointer; transition: .16s; white-space: nowrap; }
.ds-btn--primary { background: var(--gold); color: var(--navy-deep); box-shadow: 0 2px 10px rgba(var(--gold-rgb),.35); }
.ds-btn--primary:hover { filter: brightness(1.04); transform: translateY(-1px); }
.ds-btn--secondary { background: transparent; color: var(--navy); border-color: var(--navy); }
.ds-btn--secondary:hover { background: rgba(10,36,114,.05); }
.ds-btn--ghost { background: transparent; color: var(--slate); padding: 10px 12px; }
.ds-btn--ghost:hover { color: var(--navy); }
.ds-btn--lg { font-size: 16.5px; padding: 16px 30px; }
.ds-btn--block { width: 100%; }
.ds-btn:focus-visible { outline: 2px solid var(--amber); outline-offset: 2px; }
.ds-btn--kakao { background: #FEE500; color: #191600; }
.ds-btn--naver { background: #03C75A; color: #fff; }
.ds-btn--google { background: #fff; color: #1f1f1f; border-color: var(--line); }

/* ---------- 배지 ---------- */
.ds-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 700;
  padding: 3px 9px; border-radius: 999px; line-height: 1.4; }
.ds-badge--cert { background: rgba(10,36,114,.08); color: var(--navy); }          /* 디렉터 인증 실드 */
.ds-badge--verified { background: rgba(14,159,110,.12); color: var(--teal); }     /* 배우 본인인증 */
.ds-badge--career { background: transparent; color: var(--navy); border: 1px solid rgba(10,36,114,.35); }
.ds-badge--new { background: transparent; color: var(--gold); border: 1px solid rgba(var(--gold-rgb),.5); }
.ds-badge--open { background: rgba(14,159,110,.12); color: var(--teal); }
.ds-badge--closed { background: #EEF0F3; color: var(--slate); }
.ds-badge--dday { background: #EEF0F3; color: var(--slate); font-weight: 800; }
.ds-badge--dday-soon { background: var(--gold); color: var(--navy-deep); font-weight: 800; }
.ds-badge--exclusive { background: var(--navy-deep); color: var(--amber); letter-spacing: .04em; }
.ds-badge--dot::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; display: inline-block; }
/* 카테고리 배지 */
.ds-cat { color: #fff; font-weight: 700; font-size: 11.5px; padding: 3px 9px; border-radius: 6px; }
.ds-cat--film { background: var(--cat-film); }
.ds-cat--drama { background: var(--cat-drama); }
.ds-cat--ad { background: var(--cat-ad); }
.ds-cat--mv { background: var(--cat-mv); }
.ds-cat--model { background: var(--cat-model); }
.ds-cat--etc { background: var(--cat-etc); }

/* ---------- 칩 (조건/스펙) ---------- */
.ds-chip { display: inline-flex; align-items: center; gap: 4px; font-size: 12.5px; font-weight: 500;
  color: var(--slate); background: var(--surface); border: 1px solid var(--line); padding: 4px 10px; border-radius: 999px; }
.ds-chip--solid { background: var(--navy); color: #fff; border-color: var(--navy); }

/* ---------- 카드 (배우) ---------- */
.ds-actor-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-card);
  overflow: hidden; transition: .18s; box-shadow: var(--shadow-sm); }
.ds-actor-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); border-color: rgba(var(--amber-rgb),.55); }
.ds-actor-photo { position: relative; aspect-ratio: 3/4; background: linear-gradient(150deg, #2b3a6b, #0f1c44); overflow: hidden; }
.ds-actor-photo .ph-figure { position: absolute; inset: 0; display: grid; place-items: center; color: rgba(255,255,255,.22); font-size: 60px; }
.ds-actor-photo .ph-badges { position: absolute; top: 8px; left: 8px; display: flex; gap: 5px; }
.ds-actor-body { padding: 12px 14px 14px; }
.ds-actor-name { display: flex; align-items: center; gap: 6px; font-size: 15px; font-weight: 700; color: var(--ink); }
.ds-actor-name .lock { color: var(--slate); font-size: 12px; }
.ds-actor-meta { font-size: 12.5px; color: var(--slate); margin-top: 3px; }
.ds-actor-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 9px; }
.ds-actor-trust { display: flex; align-items: center; gap: 6px; margin-top: 10px; padding-top: 9px; border-top: 1px solid var(--line); }

/* ---------- 카드 (공고) ---------- */
.ds-job-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-card);
  padding: 16px 18px; transition: .18s; box-shadow: var(--shadow-sm); cursor: pointer; }
.ds-job-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); border-color: rgba(var(--amber-rgb),.5); }
.ds-job-top { display: flex; align-items: center; gap: 6px; margin-bottom: 10px; }
.ds-job-pay { font-size: 22px; font-weight: 800; color: var(--navy); letter-spacing: -.02em; }
.ds-job-title { font-size: 16px; font-weight: 700; margin: 6px 0 2px; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ds-job-prod { font-size: 12.5px; color: var(--slate); }
.ds-job-chips { display: flex; flex-wrap: wrap; gap: 5px; margin: 11px 0; }
.ds-job-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 11px; padding-top: 11px; border-top: 1px solid var(--line); }
.ds-job-stamp { font-size: 12px; color: var(--slate); }

/* ---------- 통계바 (StatBar) ---------- */
.ds-statbar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line);
  border: 1px solid var(--line); border-radius: 14px; overflow: hidden; }
.ds-stat { background: #fff; padding: 18px 16px; text-align: center; }
.ds-stat b { display: block; font-size: 26px; font-weight: 800; color: var(--navy); letter-spacing: -.02em; }
.ds-stat span { display: block; font-size: 12.5px; color: var(--slate); margin-top: 3px; }
@media (max-width: 640px) { .ds-statbar { grid-template-columns: 1fr 1fr; } .ds-stat b { font-size: 22px; } }

/* ---------- 잠금 필드 (마스킹 = 프리미엄) ---------- */
.ds-locked { display: flex; align-items: center; gap: 10px; background: repeating-linear-gradient(-45deg, #f3f5f9, #f3f5f9 8px, #eef1f6 8px, #eef1f6 16px);
  border: 1px dashed #c3ccdb; border-radius: 10px; padding: 12px 14px; }
.ds-locked .lk-icon { width: 28px; height: 28px; border-radius: 8px; background: rgba(10,36,114,.08); color: var(--navy); display: grid; place-items: center; flex: none; }
.ds-locked .lk-txt { font-size: 13px; color: var(--slate); }
.ds-locked .lk-txt b { color: var(--navy); }

/* ---------- 입력 ---------- */
.ds-input, .ds-select { width: 100%; font-family: inherit; font-size: 15px; color: var(--ink);
  background: #fff; border: 1.5px solid var(--line); border-radius: var(--r-input); padding: 12px 14px; }
.ds-input:focus, .ds-select:focus { outline: none; border-color: var(--navy); box-shadow: 0 0 0 3px rgba(10,36,114,.1); }
.ds-label { font-size: 14px; font-weight: 700; color: var(--ink); margin-bottom: 7px; display: block; }

/* ---------- 헤더/GNB ---------- */
.ds-gnb { background: #fff; border-bottom: 1px solid var(--line); position: sticky; top: 0; z-index: 30; }
.ds-gnb-in { display: flex; align-items: center; gap: 24px; height: 62px; }
.ds-logo { font-size: 20px; font-weight: 900; letter-spacing: -.02em; color: var(--navy); }
.ds-gnb-nav { display: flex; gap: 20px; font-size: 14.5px; font-weight: 600; color: var(--slate); }
.ds-gnb-nav a:hover { color: var(--navy); }
.ds-gnb-sp { flex: 1; }
@media (max-width: 768px) { .ds-gnb-nav { display: none; } }

/* ---------- 유틸 ---------- */
.ds-grid { display: grid; gap: 16px; }
.ds-grid--5 { grid-template-columns: repeat(5, 1fr); }
.ds-grid--4 { grid-template-columns: repeat(4, 1fr); }
.ds-grid--3 { grid-template-columns: repeat(3, 1fr); }
.ds-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 1024px) { .ds-grid--5 { grid-template-columns: repeat(3, 1fr); } .ds-grid--4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .ds-grid--5, .ds-grid--4, .ds-grid--3 { grid-template-columns: repeat(2, 1fr); } .ds-grid--2 { grid-template-columns: 1fr; } }
.ds-trust-row { display: flex; flex-wrap: wrap; gap: 14px; font-size: 13.5px; color: var(--slate); }
.ds-trust-row b { color: var(--navy); }
.ds-note { font-size: 12px; color: var(--slate); }
.ds-hero-dark { background: linear-gradient(155deg, var(--navy-deep), var(--navy)); color: #fff; position: relative; overflow: hidden; }
.ds-hero-dark::after { content: ""; position: absolute; top: -30%; right: -8%; width: 480px; height: 480px;
  background: radial-gradient(circle, rgba(var(--amber-rgb),.20), transparent 62%); pointer-events: none; }
