/* ═══════════════════════════════════════════════════════════════
   ARTFORM — MANPOWER (재설계 · 모바일 우선 · 박스 기반)
   prefix: .mw-  /  레거시 .mp-* 및 _shared 오버라이드와 분리
   ═══════════════════════════════════════════════════════════════ */

.mw-sec { padding: 56px 0; }
.mw-eyebrow { margin-bottom: 18px; }
.mw-h2 { font-family: var(--display); font-weight: 900; font-size: clamp(28px, 7vw, 52px); line-height: 1.02; letter-spacing: -0.04em; color: var(--ink); text-wrap: balance; word-break: keep-all; }
.mw-h2 .it { color: var(--accent); }
.mw-lead { font-size: 14px; line-height: 1.7; color: var(--ink-2); max-width: 460px; }
.mw-lead b { color: var(--ink); font-weight: 700; }

/* ── 디렉터 레터 ── */
.mw-dir { background: var(--bg); border-bottom: 1px solid var(--line-2); }
.mw-dir .grid { display: grid; gap: 28px; align-items: center; }
.mw-dir .illust { width: 100%; max-width: 360px; height: auto; display: block; margin: 0 auto; }
.mw-dir .letter .tick { width: 48px; height: 2px; background: var(--accent); margin-bottom: 18px; }
.mw-dir .letter h2 { font-family: var(--display); font-weight: 900; font-size: clamp(24px, 6vw, 40px); line-height: 1.08; letter-spacing: -0.035em; color: var(--ink); margin-bottom: 20px; text-wrap: balance; word-break: keep-all; }
.mw-dir .letter h2 .it { color: var(--accent); }
.mw-dir .letter p { font-size: 14.5px; line-height: 1.85; color: var(--ink-2); }
.mw-dir .letter p b { color: var(--ink); font-weight: 700; }
.mw-dir .letter p + p { margin-top: 16px; }

/* ── 3 원칙 (다크) ── */
.mw-prin { background: var(--ink); color: #e7ddc8; position: relative; overflow: hidden; }
.mw-prin::before { content: ""; position: absolute; inset: 0; background: radial-gradient(700px 420px at 85% -10%, rgba(254,80,0,.16), transparent 60%); pointer-events: none; }
.mw-prin .wrap { position: relative; z-index: 1; }
.mw-prin .head { margin-bottom: 28px; }
.mw-prin .head .eyebrow { color: var(--accent); }
.mw-prin .head h2 { color: #fff; }
.mw-prin .head h2 .it { color: var(--accent-2); }
.mw-prin .head .mw-lead { color: rgba(255,255,255,.72); margin-top: 16px; }
.mw-prin .head .mw-lead b { color: #fff; }
.mw-prin .triad { display: grid; gap: 16px; }
.mw-prin .cell { background: #1c1813; border: 1px solid rgba(255,255,255,.1); border-radius: 14px; padding: 26px 24px; display: flex; flex-direction: column; gap: 14px; }
.mw-prin .cell .ix { font-family: var(--display); font-weight: 900; font-size: 44px; line-height: .8; color: var(--accent); letter-spacing: -0.04em; }
.mw-prin .cell .ix small { display: block; margin-top: 8px; font-family: var(--mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent-2); }
.mw-prin .cell h3 { font-family: var(--display); font-weight: 900; font-size: 22px; letter-spacing: -0.03em; color: #fff; line-height: 1.15; border-top: 1px solid rgba(255,255,255,.12); padding-top: 16px; }
.mw-prin .cell h3 .it { color: var(--accent-2); }
.mw-prin .cell p { font-size: 13.5px; line-height: 1.7; color: #c4baa5; }
.mw-prin .cell p b { color: #fff; font-weight: 700; }
.mw-prin .cell ul { margin-top: auto; list-style: none; display: flex; flex-direction: column; gap: 7px; padding-top: 6px; }
.mw-prin .cell ul li { font-family: var(--mono); font-size: 11.5px; letter-spacing: .02em; color: #e7ddc8; line-height: 1.5; display: flex; gap: 9px; }
.mw-prin .cell ul li::before { content: ""; flex: none; width: 5px; height: 5px; background: var(--accent); transform: rotate(45deg); margin-top: 6px; }

/* ── 강사 인덱스 ── */
.mw-idx { background: var(--bg); }
.mw-idx .head { margin-bottom: 22px; }
.mw-idx .head h2 { color: var(--ink); }
.mw-idx .head .mw-lead { margin-top: 14px; }

.mw-filter { padding: 14px 0; border-top: 1px solid var(--ink); display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px; }
.mw-filter:last-of-type { border-bottom: 1px solid var(--ink); }
.mw-filter .lb { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); font-weight: 600; flex: none; }
.mw-filter .lb b { color: var(--ink); }
.mw-filter .chips { display: flex; flex-wrap: wrap; gap: 6px; }
.mw-filter .chip { padding: 6px 13px; background: var(--bg); border: 1px solid var(--line-2); border-radius: 999px; font-size: 12.5px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); cursor: pointer; transition: background .15s, color .15s, border-color .15s; }
.mw-filter .chip:hover { border-color: var(--ink); }
.mw-filter .chip.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
.mw-filter .chip .ct { font-family: var(--mono); font-size: 10px; color: var(--muted); margin-left: 4px; }
.mw-filter .chip.is-active .ct { color: var(--accent-2); }

.mw-sort { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--line-2); font-family: var(--mono); font-size: 11px; letter-spacing: .04em; color: var(--muted); }
.mw-sort b { color: var(--ink); font-weight: 700; }

/* 강사 카드 그리드 — 스스로 접힘 */
.mw-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line-2); border-bottom: 1px solid var(--line-2); margin-top: 0; }
.mw-tcard { background: var(--bg); padding: 18px 16px; display: flex; flex-direction: column; gap: 13px; }
.mw-tcard.is-hidden { display: none; }
@keyframes mwCardIn { from { opacity: 0; translate: 0 10px; } to { opacity: 1; translate: 0 0; } }
.mw-tcard .top { display: flex; justify-content: space-between; align-items: flex-start; }
.mw-tcard .ix { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); font-weight: 600; }
.mw-tcard .ix b { color: var(--ink); }
.mw-tcard .yrs { font-family: var(--mono); font-weight: 600; font-size: 11px; color: var(--muted); letter-spacing: .02em; line-height: 1; }
.mw-tcard .yrs small { font-family: var(--sans); font-weight: 600; font-size: 10px; color: var(--muted); margin-left: 2px; }
.mw-tcard .portrait { aspect-ratio: 4/5; background: var(--paper-2); border: 1px solid var(--line-2); border-radius: 8px; position: relative; overflow: hidden; }
.mw-tcard .portrait > image-slot { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.mw-tcard .portrait .role { position: absolute; left: 8px; bottom: 8px; z-index: 2; padding: 4px 8px; background: var(--accent); color: #fff; border-radius: 6px; font-size: 9px; font-weight: 700; letter-spacing: .04em; }
.mw-tcard .nm { display: flex; align-items: baseline; gap: 7px; }
.mw-tcard .nm .k { font-size: 18px; font-weight: 900; letter-spacing: -0.03em; color: var(--ink); }
.mw-tcard .nm .e { font-family: var(--mono); font-size: 9px; color: var(--muted); letter-spacing: .08em; }
.mw-tcard .uni { font-size: 12px; color: var(--ink-2); font-weight: 600; letter-spacing: -0.01em; }
.mw-tcard .uni b { color: var(--accent); font-weight: 700; }
.mw-tcard .campus { font-family: var(--mono); font-size: 10px; color: var(--muted); letter-spacing: .04em; }
.mw-tcard .campus span { display: inline-block; padding: 2px 7px; background: var(--paper-2); color: var(--ink); border-radius: 6px; font-weight: 600; }
.mw-tcard .stats { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; border-top: 1px solid var(--line-2); padding-top: 11px; margin-top: auto; }
.mw-tcard .stats .s { display: flex; flex-direction: column; gap: 2px; }
.mw-tcard .stats .s .k { font-family: var(--mono); font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.mw-tcard .stats .s .v { font-family: var(--display); font-weight: 900; font-size: 16px; color: var(--ink); letter-spacing: -0.02em; line-height: 1; }
.mw-tcard .stats .s .v.ac { color: var(--accent); }

/* 헤드 코치 — 다크 카드 */
.mw-tcard.head { background: var(--ink); color: #e7ddc8; }
.mw-tcard.head .ix { color: var(--accent-2); }
.mw-tcard.head .ix b { color: #fff; }
.mw-tcard.head .yrs { color: var(--accent-2); }
.mw-tcard.head .yrs small { color: #8e8576; }
.mw-tcard.head .portrait { border-color: rgba(255,255,255,.12); background: #1c1813; }
.mw-tcard.head .nm .k { color: #fff; }
.mw-tcard.head .nm .e { color: #8e8576; }
.mw-tcard.head .uni { color: #e7ddc8; }
.mw-tcard.head .uni b { color: var(--accent-2); }
.mw-tcard.head .campus { color: #8e8576; }
.mw-tcard.head .campus span { background: #1c1813; color: #fff; }
.mw-tcard.head .stats { border-top-color: rgba(255,255,255,.12); }
.mw-tcard.head .stats .s .k { color: var(--accent-2); }
.mw-tcard.head .stats .s .v { color: #fff; }
.mw-tcard.head .stats .s .v.ac { color: var(--accent-2); }

.mw-page { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: 22px 0 0; font-family: var(--mono); font-size: 11px; letter-spacing: .04em; color: var(--muted); flex-wrap: wrap; }
.mw-page .pg { display: flex; gap: 6px; }
.mw-page .pg a { padding: 6px 11px; border: 1px solid var(--line-2); border-radius: 6px; font-weight: 600; color: var(--ink); }
.mw-page .pg a.on { background: var(--ink); color: #fff; border-color: var(--ink); }

/* ── 스포트라이트 (김종길) ── */
.mw-feat { background: var(--paper); border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); }
.mw-feat .head { margin-bottom: 28px; }
.mw-feat .head h2 { color: var(--ink); }
.mw-feat .head .mw-lead { margin-top: 14px; }
.mw-feat .grid { display: grid; gap: 28px; align-items: start; }
.mw-feat .portrait { position: relative; aspect-ratio: 4/5; max-width: 420px; margin: 0 auto; width: 100%; background: var(--paper-2); border: 1px solid var(--line-2); border-radius: 14px; overflow: hidden; }
.mw-feat .portrait > image-slot { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.mw-feat .portrait .grad { position: absolute; left: 0; right: 0; bottom: 0; height: 56%; background: linear-gradient(0deg, rgba(0,0,0,.82), rgba(0,0,0,.32) 45%, transparent); z-index: 1; }
.mw-feat .portrait .stmp { position: absolute; left: 16px; top: 16px; z-index: 2; font-family: var(--mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: #fff; background: rgba(0,0,0,.4); padding: 5px 10px; border-radius: 999px; }
.mw-feat .portrait .nmov { position: absolute; left: 18px; bottom: 18px; z-index: 2; color: #fff; }
.mw-feat .portrait .nmov .k { font-family: var(--display); font-weight: 900; font-size: clamp(34px, 9vw, 48px); letter-spacing: -0.03em; line-height: .95; }
.mw-feat .portrait .nmov .e { display: block; margin-top: 6px; font-family: var(--mono); font-size: 11px; letter-spacing: .12em; color: var(--accent-2); }
.mw-feat .content { display: flex; flex-direction: column; gap: 26px; }
.mw-feat .quote { font-family: var(--sans); font-weight: 700; font-size: clamp(20px, 5vw, 30px); line-height: 1.32; letter-spacing: -0.03em; color: var(--ink); padding-left: 18px; border-left: 3px solid var(--accent); text-wrap: balance; }
.mw-feat .quote em { font-style: normal; color: var(--accent); }
.mw-feat .body p { font-size: 14px; line-height: 1.8; color: var(--ink-2); }
.mw-feat .body p b { color: var(--ink); font-weight: 800; }
.mw-feat .body p + p { margin-top: 12px; }
.mw-feat .badges { display: flex; flex-wrap: wrap; gap: 8px; }
.mw-feat .badges .b { padding: 10px 16px; background: var(--bg); border: 1px solid var(--line-2); border-radius: 999px; font-size: 13px; font-weight: 700; letter-spacing: -0.01em; color: var(--ink-2); }
.mw-feat .badges .b.acc { background: var(--accent); color: #fff; border-color: var(--accent); }
.mw-feat .badges .b.ink { background: var(--ink); color: #fff; border-color: var(--ink); }
.mw-feat .pubs { border-top: 1px solid var(--ink); }
.mw-feat .pubs h6 { margin: 12px 0 4px; font-family: var(--mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); }
.mw-feat .pubs .row { display: grid; grid-template-columns: 48px 1fr auto; gap: 12px; padding: 11px 0; border-bottom: 1px solid var(--line-2); align-items: center; font-size: 13px; }
.mw-feat .pubs .row .yr { font-family: var(--mono); font-size: 10px; font-weight: 700; color: var(--accent); letter-spacing: .04em; }
.mw-feat .pubs .row .t { font-weight: 700; letter-spacing: -0.01em; color: var(--ink); }
.mw-feat .pubs .row .t small { display: block; font-family: var(--mono); font-weight: 500; font-size: 10px; letter-spacing: .04em; color: var(--muted); margin-top: 2px; }
.mw-feat .pubs .row .kind { font-family: var(--mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink); font-weight: 600; }

/* ── 채용 (다크) ── */
.mw-hire { background: var(--ink); color: #fff; }
.mw-hire .grid { display: grid; gap: 32px; align-items: start; }
.mw-hire .lf .eyebrow { color: var(--accent); margin-bottom: 16px; }
.mw-hire .lf h2 { color: #fff; margin-bottom: 18px; }
.mw-hire .lf h2 .it { color: var(--accent-2); }
.mw-hire .lf p { font-size: 15px; line-height: 1.7; color: #c4baa5; }
.mw-hire .lf p b { color: #fff; font-weight: 700; }
.mw-hire .jobs { display: flex; flex-direction: column; border-top: 1px solid rgba(255,255,255,.15); }
.mw-hire .job { display: grid; grid-template-columns: auto 1fr auto; gap: 16px; align-items: center; padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,.1); transition: padding .2s; }
.mw-hire .job:hover { padding-left: 8px; }
.mw-hire .job .ix { font-family: var(--mono); font-size: 11px; letter-spacing: .1em; color: var(--accent-2); font-weight: 700; }
.mw-hire .job .nm { font-size: 16px; font-weight: 800; letter-spacing: -0.02em; color: #fff; }
.mw-hire .job .nm small { display: block; font-family: var(--mono); font-size: 10px; font-weight: 500; letter-spacing: .06em; color: #8e8576; text-transform: uppercase; margin-top: 3px; }
.mw-hire .job .arr { width: 36px; height: 36px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25); display: grid; place-items: center; color: #fff; font-size: 13px; flex: none; }
.mw-hire .job:hover .arr { background: var(--accent); border-color: var(--accent); }
.mw-hire .btn-hire { margin-top: 20px; display: inline-flex; align-items: center; gap: 10px; height: 52px; padding: 0 26px; background: var(--accent); color: #fff; border-radius: 999px; font-size: 15px; font-weight: 700; letter-spacing: -0.01em; align-self: flex-start; }
.mw-hire .btn-hire .arr { width: 24px; height: 24px; background: #fff; color: var(--accent); border-radius: 999px; display: grid; place-items: center; font-size: 12px; font-weight: 700; }

/* ═══════════ 태블릿 이상 (≥ 720px) ═══════════ */
@media (min-width: 720px) {
  .mw-sec { padding: 72px 0; }
  .mw-prin .triad { grid-template-columns: repeat(3, 1fr); }
  .mw-grid { grid-template-columns: repeat(3, 1fr); }
  .mw-feat .pubs .row { grid-template-columns: 56px 1fr auto; }
}

/* ═══════════ 데스크톱 (≥ 1024px) ═══════════ */
@media (min-width: 1024px) {
  .mw-sec { padding: 96px 0; }
  .mw-dir .grid { grid-template-columns: 1fr 1.5fr; gap: 56px; }
  .mw-prin .head { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: end; }
  .mw-prin .head .mw-lead { justify-self: end; text-align: left; }
  .mw-grid { grid-template-columns: repeat(4, 1fr); }
  .mw-feat .grid { grid-template-columns: .95fr 1.15fr; gap: 56px; }
  .mw-feat .portrait { max-width: none; margin: 0; }
  .mw-hire .grid { grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center; }
}


/* 강사 특성 키워드 태그 */
.mw-tcard .fac-tags { display: flex; flex-wrap: nowrap; gap: 5px; border-top: 1px solid var(--line-2); padding-top: 12px; margin-top: auto; overflow: hidden; }
.mw-tcard .fac-tags .tag { font-family: var(--sans); font-size: 11px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink-2); background: var(--paper-2); border: 1px solid var(--line-2); border-radius: 999px; padding: 3px 9px; line-height: 1.4; }
.mw-tcard .fac-tags .tag-track { color: var(--accent); border-color: var(--accent); background: rgba(254,80,0,.06); }
.mw-tcard .fac-tags .tag { white-space: nowrap; flex: none; }


/* ═══════════ MOTION · 진입 애니메이션 + Hover (가볍게 / 고르게) ═══════════ */

/* 진입 페이드업 — translate 사용(hover transform 과 별개 속성이라 충돌 없음).
   <head> 인라인 스크립트가 js-reveal 을 첫 페인트 전에 설정 → 깜빡임 없이 숨김.
   숨김은 실제 선택자에 직접 적용(JS-부여 클래스 의존 X). reveal 시 .in 부여. */
.js-reveal .mw-dir .grid > *,
.js-reveal .mw-prin .head > *,
.js-reveal .mw-prin .triad .cell,
.js-reveal .mw-idx .head > *,
.js-reveal .mw-feat .head > *,
.js-reveal .mw-feat .grid > *,
.js-reveal .mw-hire .grid > *,
.js-reveal .mw-idx .mw-grid .mw-tcard {
  opacity: 0; translate: 0 16px;
  transition: opacity .55s ease, translate .6s cubic-bezier(.22,.61,.36,1);
  transition-delay: var(--rd, 0ms);
}
.js-reveal .mw-dir .grid > *.in,
.js-reveal .mw-prin .head > *.in,
.js-reveal .mw-prin .triad .cell.in,
.js-reveal .mw-idx .head > *.in,
.js-reveal .mw-feat .head > *.in,
.js-reveal .mw-feat .grid > *.in,
.js-reveal .mw-hire .grid > *.in,
.js-reveal .mw-idx .mw-grid .mw-tcard.in {
  opacity: 1; translate: 0 0;
}
@media (prefers-reduced-motion: reduce) {
  .js-reveal .mw-dir .grid > *, .js-reveal .mw-prin .head > *, .js-reveal .mw-prin .triad .cell,
  .js-reveal .mw-idx .head > *, .js-reveal .mw-feat .head > *, .js-reveal .mw-feat .grid > *,
  .js-reveal .mw-hire .grid > *, .js-reveal .mw-idx .mw-grid .mw-tcard {
    opacity: 1; translate: none; transition: none;
  }
}

/* ── Hover (가볍게) ── */
/* 강사 카드: 살짝 떠오름 + 포트레이트 미세 줌 + 이름 강조 */
.mw-tcard { transition: transform .24s cubic-bezier(.22,.61,.36,1), box-shadow .24s, border-color .24s; }
.mw-tcard:hover { transform: translateY(-4px); box-shadow: 0 16px 34px -18px rgba(20,17,16,.34); z-index: 2; }
.mw-tcard .portrait > image-slot { transition: transform .45s cubic-bezier(.22,.61,.36,1); }
.mw-tcard:hover .portrait > image-slot { transform: scale(1.045); }
.mw-tcard .nm .k { transition: color .2s; }
.mw-tcard:hover .nm .k { color: var(--accent); }

/* 3원칙 셀: 떠오름 + 강조 보더 */
.mw-prin .cell { transition: transform .26s cubic-bezier(.22,.61,.36,1), box-shadow .26s, border-color .26s; }
.mw-prin .cell:hover { transform: translateY(-5px); box-shadow: 0 22px 46px -22px rgba(0,0,0,.55); border-color: rgba(255,255,255,.3); }

/* 히어로 통계: 미세 상승 */
.pg-head .stats .s { transition: transform .2s cubic-bezier(.22,.61,.36,1); }
.pg-head .stats .s:hover { transform: translateY(-3px); }

/* 필터 칩: hover 배경 톤 */
.mw-filter .chip { transition: border-color .18s, background .18s, color .18s; }
.mw-filter .chip:hover:not(.is-active) { background: var(--paper-2); }

/* 스포트라이트: 포트레이트 줌 / 저서 행 / 배지 */
.mw-feat .portrait > image-slot { transition: transform .5s cubic-bezier(.22,.61,.36,1); }
.mw-feat .portrait:hover > image-slot { transform: scale(1.03); }
.mw-feat .pubs .row { transition: background .2s, padding-left .2s; }
.mw-feat .pubs .row:hover { background: var(--paper-2); padding-left: 10px; }
.mw-feat .badges .b { transition: transform .18s, border-color .2s, background .2s; }
.mw-feat .badges .b:hover { transform: translateY(-2px); border-color: var(--ink); }

/* 디렉터 일러스트: 미세 줌 */
.mw-dir .illust-wrap { overflow: hidden; }
.mw-dir .illust { transition: transform .5s cubic-bezier(.22,.61,.36,1); }
.mw-dir .illust-wrap:hover .illust { transform: scale(1.03); }
