/* mission/fix/html-ref/home.html — 스코프: .mission-home-page */

/* ═══════════════════════════════════════════════════
   VARIABLES
═══════════════════════════════════════════════════ */
:root {
  /* 레벨 색상 — 카드/피드 pill·모바일 원형 배지(흰 글자·아이콘) 대비용 찐한 톤 */
  --lv1: #92400e; /* bronze */
  --lv2: #52525b; /* silver */
  --lv3: #b45309; /* gold */
  --lv4: #3f4f5f; /* platinum */
  --lv5: #0e7490; /* diamond */
  --lv6: #166534; /* elite */
  --tab-h: 62px;
  --tab-safe: min(env(safe-area-inset-bottom, 0px), 10px);
  --header-h: 64px;
  --r-card: 20px;
  --r-btn: 12px;
  /* Acts 정렬용 px 토큰 */
  --fs-base: 14px;
  --fs-sm: 12px;
  --fs-2xs: 10px;
  --mcard-fix: 155px;
}
.mission-home-page[data-theme="dark"] {
  --bg:            #0a0c10;
  --bg2:           #0d1014;
  --panel:         #111318;
  --panel2:        #181c24;
  --text:          #eaf0ed;
  --text2:         #94a3b8;
  --text3:         #5a6578;
  --line:          rgba(255,255,255,.07);
  --line2:         rgba(255,255,255,.12);
  --shadow:        0 12px 32px rgba(0,0,0,.45);
  --tab-bg:        #111318;
  --chip-bg:       rgba(255,255,255,.06);
  --chip-on-bg:    rgba(34,197,94,.12);
  --chip-on-cl:    #4ADE80;
  --chip-on-bd:    rgba(34,197,94,.28);
  --scroll-track:  rgba(255,255,255,.05);
  /* accent = 그린 */
  --accent:        #22C55E;
  --accent2:       #10B981;
  --accent-soft:   rgba(34,197,94,.12);
  --accent-border: rgba(34,197,94,.25);
  --green:  #22C55E;
  --yellow: #fbbf24;
  --red:    #f87171;
  /* 등급 pill은 :root --lv1~6(찐한 색) 상속 — 밝은 오버라이드 제거 */
}
.mission-home-page[data-theme="light"] {
  --bg:            #f4f6fb;
  --bg2:           #eceef5;
  --panel:         #ffffff;
  --panel2:        #f8f9fd;
  --text:          #0c1426;
  --text2:         #6b7a99;
  --text3:         #a0adc4;
  --line:          rgba(12,20,38,.09);
  --line2:         rgba(12,20,38,.14);
  --shadow:        0 8px 32px rgba(12,20,38,.08);
  --tab-bg:        rgba(255,255,255,.97);
  --chip-bg:       rgba(12,20,38,.05);
  --chip-on-bg:    rgba(34,197,94,.09);
  --chip-on-cl:    #16A34A;
  --chip-on-bd:    rgba(34,197,94,.22);
  --scroll-track:  rgba(12,20,38,.05);
  /* accent = 그린 */
  --accent:        #16A34A;
  --accent2:       #10B981;
  --accent-soft:   rgba(34,197,94,.09);
  --accent-border: rgba(34,197,94,.18);
  --green:  #16A34A;
  --yellow: #d97706;
  --red:    #dc2626;
}

/* ── Reset (스코프: .mission-home-page 내부만) ── */
.mission-home-page *, .mission-home-page *::before, .mission-home-page *::after { box-sizing: border-box; margin: 0; padding: 0; }
.mission-home-page { scroll-behavior: smooth; scrollbar-gutter: stable; }
.mission-home-page {
  font-family: sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  transition: background .25s, color .25s;
}
.mission-home-page a { color: inherit; text-decoration: none; }
.mission-home-page button { font-family: inherit; cursor: pointer; border: none; background: none; }
.mission-home-page img { display: block; object-fit: cover; }

/* ═══════════════════════════════════════════════════
   LAYOUT SHELL
═══════════════════════════════════════════════════ */
.mission-home-page.page {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* ═══════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════ */
.mission-home-page .header {
  position: sticky; top: 0; z-index: 1;
  height: var(--header-h);
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(20px);
  display: flex; align-items: center;
  transition: background .25s, border-color .25s;
}
.mission-home-page .header-inner {
  width: 100%; max-width: 1400px; margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 40px);
  display: flex; align-items: center; gap: 10px;
}

/* 검색창 */
.mission-home-page .hdr-search-wrap {
  flex: 1;
  min-width: 0;
  display: flex; align-items: center; gap: 8px;
  background: var(--panel2);
  border: 1px solid var(--line2);
  border-radius: 12px;
  padding: 0 14px;
  height: 38px;
  transition: border-color .15s, box-shadow .15s;
}
.mission-home-page .hdr-search-wrap:focus-within {
  border-color: var(--accent-border);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.mission-home-page .hdr-search-icon { font-size: 18px; color: var(--text3); flex-shrink: 0; }
.mission-home-page .hdr-search-input {
  flex: 1; background: none; border: none; outline: none;
  font-family: inherit; font-size: .88rem; color: var(--text);
}
.mission-home-page .hdr-search-input::placeholder { color: var(--text3); }
.mission-home-page .logo {
  display: flex; align-items: center; gap: 8px;
  font-family: 'Pretendard', sans-serif;
  font-size: 1.2rem; font-weight: 900; letter-spacing: -.4px;
  white-space: nowrap;
}
.mission-home-page .logo i { font-size: 1.4rem; color: var(--accent); }
.mission-home-page .logo-text { color: var(--text); }
.mission-home-page .logo-text b {
  background: var(--accent);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}

/* Acts acts-v3: 모바일에서 검색창 앞에는 지구본 아이콘만 */
.mission-home-page .hdr-mobile-brand {
  display: none;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 38px;
  border-radius: 10px;
  text-decoration: none;
  box-sizing: border-box;
  color: var(--accent);
  border: 1px solid var(--line2);
  background: var(--panel2);
  transition: background 0.15s, opacity 0.15s, color 0.15s;
}
.mission-home-page .hdr-mobile-brand i { font-size: 22px; }
.mission-home-page .hdr-mobile-brand:active { opacity: 0.88; }
@media (max-width: 767px) {
  .mission-home-page .header .logo { display: none !important; }
  .mission-home-page .hdr-mobile-brand { display: inline-flex; }
  .mission-home-page .header-inner { padding: 0 12px; gap: 8px; }
}
@media (min-width: 768px) {
  .mission-home-page .hdr-mobile-brand { display: none !important; }
}

/* 데스크탑 탭 네비 (헤더 안) */
.mission-home-page .header-nav {
  display: flex; align-items: center; gap: 4px;
  margin-left: 32px; flex: 1;
}
.mission-home-page .nav-item {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 10px;
  font-size: .88rem; font-weight: 600;
  color: var(--text2);
  transition: all .15s; position: relative;
  white-space: nowrap;
}
.mission-home-page .nav-item i { font-size: 18px; }
.mission-home-page .nav-item:hover { background: var(--chip-bg); color: var(--text); }
.mission-home-page .nav-item.active { color: var(--accent); background: var(--chip-on-bg); }
.mission-home-page .nav-badge {
  width: 18px; height: 18px; border-radius: 50%;
  background: #F05A5A; color: #fff;
  font-size: .62rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  margin-left: -2px;
}

.mission-home-page .header-right { display: flex; align-items: center; gap: 6px; margin-left: auto; }
.mission-home-page .hdr-btn {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text2); transition: all .15s;
}
.mission-home-page .hdr-btn i { font-size: 21px; }
.mission-home-page .hdr-btn:hover { background: var(--chip-bg); color: var(--text); }
/* 그룹신청 버튼: 모바일 + 아이콘만, 데스크탑 텍스트+아이콘 */
.mission-home-page .hdr-btn-apply {
  text-decoration: none; flex-shrink: 0; gap: 6px; padding: 0 14px;
  font-size: .88rem; font-weight: 600; color: var(--accent);
}
.mission-home-page .hdr-btn-apply:hover { background: var(--chip-on-bg); color: var(--accent); }
.mission-home-page .hdr-btn-apply i { font-size: 20px; }
.mission-home-page .hdr-btn-apply .hdr-btn-apply-label { display: none; }
@media (min-width: 768px) {
  .mission-home-page .hdr-btn-apply { width: auto; padding: 0 14px; }
  .mission-home-page .hdr-btn-apply .hdr-btn-apply-label { display: inline; }
}
@media (max-width: 767px) {
  .mission-home-page .hdr-btn-apply { width: 38px; padding: 0; justify-content: center; }
  .mission-home-page .hdr-btn-apply .hdr-btn-apply-label { display: none; }
}

/* ═══════════════════════════════════════════════════
   MAIN CONTENT
═══════════════════════════════════════════════════ */
.mission-home-page .main {
  flex: 1;
  padding-bottom: calc(var(--tab-h) + var(--tab-safe) + 16px); /* 모바일 탭바 여백 (Acts 사역자와 동일) */
  width: 100%; max-width: 1400px; margin: 0 auto;
  padding-left: clamp(0px, 2vw, 0px);
  padding-right: clamp(0px, 2vw, 0px);
}

/* 탭 콘텐츠 */
.mission-home-page .tab-pane { display: none; }
.mission-home-page .tab-pane.active { display: block; }

/* ═══════════════════════════════════════════════════
   BANNER (Acts acts-public-v3 히어로와 동일)
═══════════════════════════════════════════════════ */
.mission-home-page .banner-section {
  padding: 0;
}
.mission-home-page .banner-track {
  display: flex;
  gap: 0;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  scroll-behavior: smooth;
  touch-action: pan-x;
  -webkit-text-size-adjust: none;
}
.mission-home-page .banner-track * {
  -webkit-text-size-adjust: none;
}
.mission-home-page .banner-track::-webkit-scrollbar { display: none; }
.mission-home-page .banner-slide {
  flex: 0 0 100%;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  border-radius: 0;
  overflow: hidden;
  aspect-ratio: 21/7;
  position: relative;
  background: var(--panel2);
  box-shadow: none;
  cursor: pointer;
  transition: box-shadow 0.2s;
}
.mission-home-page .banner-slide img { width: 100%; height: 100%; object-fit: cover; }
.mission-home-page .banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(0,0,0,.65) 0%, rgba(0,0,0,.1) 55%, transparent 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 20px;
}
.mission-home-page .banner-tag {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 10px;
  align-self: flex-start;
}
.mission-home-page .banner-title {
  font-family: 'Pretendard', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  line-height: 1.25;
  text-shadow: 0 2px 10px rgba(0,0,0,.4);
}
.mission-home-page .banner-desc { font-size: 14px; color: rgba(255,255,255,.8); margin-top: 6px; }

.mission-home-page .banner-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
}
.mission-home-page .b-dot { width: 6px; height: 6px; border-radius: 3px; background: var(--line2); transition: all 0.3s; cursor: pointer; }
.mission-home-page .b-dot.on { width: 20px; background: var(--accent); }
@media (max-width: 767px) {
  .mission-home-page .banner-slide { aspect-ratio: 21/9.1; }
}

/* 기본 히어로 배너: Unsplash 배경 위에 지구본 아이콘만 표시 (배경은 img로) */
.mission-home-page .banner-slide-hero-default .banner-hero-bg {
  position: absolute; inset: 0;
  background: transparent;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.mission-home-page .banner-slide-hero-default .banner-hero-icon {
  font-size: clamp(72px, 18vw, 140px);
  color: var(--accent);
  opacity: 0.95;
  text-shadow: 0 2px 20px rgba(0,0,0,.4);
}

/* ═══════════════════════════════════════════════════
   FILTER CHIPS
═══════════════════════════════════════════════════ */
.mission-home-page .filter-bar {
  display: flex; gap: 8px; align-items: center;
  overflow-x: auto; scrollbar-width: none;
  padding: 16px clamp(16px, 3vw, 40px);
}
.mission-home-page .filter-bar::-webkit-scrollbar { display: none; }
.mission-home-page .chip {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 16px; border-radius: 999px;
  background: var(--chip-bg); color: var(--text2);
  border: 1px solid transparent;
  font-size: .84rem; font-weight: 600;
  transition: all .18s; white-space: nowrap; cursor: pointer;
}
.mission-home-page .chip i { font-size: 15px; }
.mission-home-page .chip:hover { background: var(--line2); color: var(--text); }
.mission-home-page .chip.on {
  background: var(--chip-on-bg); color: var(--chip-on-cl);
  border-color: var(--chip-on-bd);
}

/* ═══════════════════════════════════════════════════
   SECTION
═══════════════════════════════════════════════════ */
.mission-home-page .section { margin-bottom: 12px; }
.mission-home-page .sec-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px clamp(16px, 3vw, 40px) 14px;
}
.mission-home-page .sec-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 1rem; font-weight: 700; color: var(--text);
}
.mission-home-page .sec-title i { font-size: 19px; color: var(--accent); }
.mission-home-page .sec-more {
  display: flex; align-items: center; gap: 2px;
  font-size: .8rem; font-weight: 600; color: var(--text3);
  padding: 5px 10px; border-radius: 8px;
  transition: all .15s;
}
.mission-home-page .sec-more i { font-size: 15px; }
.mission-home-page .sec-more:hover { background: var(--chip-bg); color: var(--text2); }

/* ── 서브 필터 칩바 ── */
.mission-home-page .sub-filter-bar {
  display: flex; gap: 8px; align-items: center;
  overflow-x: auto; scrollbar-width: none;
  padding: 0 clamp(16px, 3vw, 40px) 14px;
  animation: subFilterIn .2s ease;
}
.mission-home-page .sub-filter-bar::-webkit-scrollbar { display: none; }
@keyframes subFilterIn {
  from { opacity: 0; transform: translateY(-5px); }
.mission-home-page to { opacity: 1; transform: translateY(0); }
}
/* 서브칩 레벨 컬러 */
.chip.lv1.on { background: rgba(52,211,153,.14);  color: var(--lv1); border-color: rgba(52,211,153,.35); }
.mission-home-page .chip.lv2.on { background: rgba(79,142,247,.14);  color: var(--lv2); border-color: rgba(79,142,247,.35); }
.mission-home-page .chip.lv3.on { background: rgba(157,120,248,.14); color: var(--lv3); border-color: rgba(157,120,248,.35); }
.mission-home-page .chip.lv4.on { background: rgba(251,191,36,.14);  color: var(--lv4); border-color: rgba(251,191,36,.35); }
.mission-home-page .chip.lv5.on { background: rgba(185,242,255,.14); color: var(--lv5); border-color: rgba(185,242,255,.35); }
.mission-home-page .chip.lv6.on { background: rgba(34,197,94,.14); color: var(--lv6); border-color: rgba(34,197,94,.35); }

/* ── 카드 순위 뱃지 ── */
.mission-home-page .m-card-rank {
  position: absolute; top: 9px; left: 9px;
  min-width: 24px; height: 24px; border-radius: 8px;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  color: #fff; font-family: 'Pretendard', sans-serif;
  font-size: .78rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  padding: 0 6px;
  border: 1px solid rgba(255,255,255,.18);
}
.mission-home-page .m-card:nth-child(1) .m-card-rank { background: rgba(255,180,0,.85); color: #000; border-color: transparent; }
.mission-home-page .m-card:nth-child(2) .m-card-rank { background: rgba(180,185,195,.8); color: #000; border-color: transparent; }
.mission-home-page .m-card:nth-child(3) .m-card-rank { background: rgba(180,100,40,.8);  color: #fff; border-color: transparent; }
.mission-home-page .m-card { transition: transform .22s, box-shadow .22s, opacity .2s; }
.mission-home-page .m-card.filtered-out {
  display: none;
}

/* ── 빈 섹션 숨김 ── */
.section.section-empty { display: none; }
.mission-home-page .sec-divider.divider-hidden { display: none; }

/* ── 필터 empty state ── */
/* 목록만 보이도록: 빈 상태 메시지는 .show 있을 때만 표시 */
.mission-home-page .filter-empty {
  display: none !important;
  flex-direction: column; align-items: center; justify-content: center;
  gap: 12px;
  padding: 60px 20px;
  color: var(--text3);
}
.mission-home-page .filter-empty.show { display: flex !important; }
.mission-home-page .filter-empty i { font-size: 48px; opacity: .35; }
.mission-home-page .filter-empty p { font-size: .9rem; font-weight: 600; }

/* ── 가로 스크롤 카드 행 (Acts Netflix 스타일) ── */
.mission-home-page .cards-row {
  display: flex; gap: 12px;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: thin; scrollbar-color: var(--scroll-track) transparent;
  padding: 4px 24px 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: none;
}
.mission-home-page .cards-row .m-card,
.mission-home-page .cards-row .m-card * {
  -webkit-text-size-adjust: none;
}
/* 모바일 520px 이하: 뷰포트에 정확히 3열 배치 */
@media (max-width: 520px) {
  .mission-home-page .cards-row {
    --mcard-row-gap: 8px;
    gap: var(--mcard-row-gap);
    padding: 4px max(12px, env(safe-area-inset-left, 0px)) 16px max(12px, env(safe-area-inset-right, 0px));
    box-sizing: border-box;
  }
  .mission-home-page .cards-row .m-card {
    flex: 0 0 calc((100% - 2 * var(--mcard-row-gap)) / 3);
    width: calc((100% - 2 * var(--mcard-row-gap)) / 3);
    min-width: 0;
  }
}
.mission-home-page .cards-row::-webkit-scrollbar { height: 4px; }
.mission-home-page .cards-row::-webkit-scrollbar-track { background: transparent; }
.mission-home-page .cards-row::-webkit-scrollbar-thumb { background: var(--scroll-track); border-radius: 2px; }

/* ── Netflix 세로 카드 (Acts와 동일: 155px 고정) ── */
.mission-home-page .m-card {
  flex: 0 0 var(--mcard-fix, 155px);
  scroll-snap-align: start;
  border-radius: 16px; overflow: hidden;
  position: relative; cursor: pointer;
  aspect-ratio: 2/3;
  background: var(--panel2);
  box-shadow: var(--shadow);
  transition: transform .22s, box-shadow .22s;
}
.mission-home-page .m-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 20px 48px rgba(0,0,0,.45);
  z-index: 2;
}
.mission-home-page .m-card img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform .3s; }
.mission-home-page .m-card:hover img { transform: scale(1.06); }
.mission-home-page .m-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.25) 50%, transparent 100%);
}
.mission-home-page .m-card-info {
  position: absolute; bottom: 0; left: 0; right: 0;
  padding: 10px 10px 12px;
}
.mission-home-page .m-card-lv {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 3px 8px; border-radius: 999px;
  font-size: .65rem; font-weight: 700; color: #fff;
  margin-bottom: 5px;
}
.mission-home-page .m-card-lv i { font-size: 10px; }
.mission-home-page .lv1-bg { background: var(--lv1); color: #fff; }
.mission-home-page .lv2-bg { background: var(--lv2); color: #fff; }
.mission-home-page .lv3-bg { background: var(--lv3); color: #fff; }
.mission-home-page .lv4-bg { background: var(--lv4); color: #fff; }
.mission-home-page .lv5-bg { background: var(--lv5); color: #fff; }
.mission-home-page .lv6-bg { background: var(--lv6); color: #fff; }
.mission-home-page .m-card-name {
  display: block; font-weight: 700; color: #fff;
  font-size: var(--fs-base, 14px); line-height: 1.2;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
}
.mission-home-page .m-card-spec { font-size: var(--fs-sm, 12px); color: rgba(255,255,255,.88); margin-top: 2px; }
.mission-home-page .m-card-feat {
  position: absolute; top: 9px; right: 9px;
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
}
.mission-home-page .m-card-feat i { font-size: 14px; color: #fff; }

/* ── 섹션 구분선 ── */
.mission-home-page .sec-divider { height: 6px; background: var(--bg2); margin: 4px 0; }

/* ═══════════════════════════════════════════════════
   피드 피드
═══════════════════════════════════════════════════ */
.mission-home-page .lounge-wrap {
  padding: 16px clamp(16px, 3vw, 40px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
@media (min-width: 768px) { .lounge-wrap { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .lounge-wrap { grid-template-columns: 1fr 1fr 1fr; } }

.mission-home-page .feed-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 18px; overflow: hidden;
  transition: box-shadow .2s, transform .2s; cursor: pointer;
}
.mission-home-page .feed-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.mission-home-page .feed-head { display: flex; align-items: center; gap: 10px; padding: 14px 16px 10px; }
.mission-home-page .feed-avatar { width: 40px; height: 40px; border-radius: 12px; overflow: hidden; flex-shrink: 0; }
.mission-home-page .feed-avatar img { width: 100%; height: 100%; }
.mission-home-page .feed-meta { flex: 1; min-width: 0; }
.mission-home-page .feed-name { font-weight: 700; font-size: .9rem; }
.mission-home-page .feed-lv {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 999px;
  font-size: .65rem; font-weight: 700; color: #fff;
  margin-left: 6px;
}
.mission-home-page .feed-lv i { font-size: 10px; }
.mission-home-page .feed-time { font-size: .75rem; color: var(--text3); margin-top: 1px; }
.mission-home-page .feed-img { width: 100%; aspect-ratio: 16/9; overflow: hidden; }
.mission-home-page .feed-img img { width: 100%; height: 100%; }
.mission-home-page .feed-body { padding: 12px 16px 14px; }
.mission-home-page .feed-text { font-size: .88rem; color: var(--text2); line-height: 1.6; margin-bottom: 12px; }
.mission-home-page .feed-actions { display: flex; gap: 16px; }
.mission-home-page .feed-act {
  display: flex; align-items: center; gap: 5px;
  font-size: .8rem; color: var(--text3); font-weight: 600;
  padding: 5px 10px; border-radius: 8px; transition: all .15s;
}
.mission-home-page .feed-act i { font-size: 17px; }
.mission-home-page .feed-act:hover { background: var(--chip-bg); color: var(--text2); }
.mission-home-page .feed-act.liked { color: #F05A7E; }

/* ═══════════════════════════════════════════════════
   마이페이지
═══════════════════════════════════════════════════ */
/* 프로필 요약 바 */
.mission-home-page .my-profile-bar {
  margin: 20px clamp(16px,3vw,40px) 0;
  padding: 16px 18px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  column-gap: 12px;
  row-gap: 12px;
  align-items: center;
}
/* 아바타: 두 행 span */
.mission-home-page .my-avatar {
  width: 52px; height: 52px; border-radius: 16px;
  grid-row: 1 / 3;
  background: linear-gradient(135deg, var(--accent), var(--accent2, #9d78f8));
  color: #fff; font-size: 1.4rem; font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mission-home-page .my-profile-info {
  grid-column: 2; grid-row: 1;
  min-width: 0;
}
.mission-home-page .my-stats {
  grid-column: 3; grid-row: 1;
  display: flex; gap: 14px;
  flex-shrink: 0;
}
.mission-home-page .my-profile-link {
  grid-column: 2 / 4; grid-row: 2;
  display: inline-flex; align-items: center; justify-content: center; gap: 5px;
  padding: 8px 14px; border-radius: 10px;
  background: var(--panel2);
  color: var(--text);
  font-size: .8rem; font-weight: 600;
  border: 1px solid var(--line2);
  transition: all .15s; white-space: nowrap;
  text-align: center;
}
.mission-home-page .my-profile-link i { font-size: 15px; }
.mission-home-page .my-profile-link:hover { background: var(--chip-on-bg); color: var(--chip-on-cl); border-color: var(--chip-on-bd); }
.mission-home-page .my-name { font-weight: 800; font-size: 1rem; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mission-home-page .my-lv {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 999px;
  font-size: .62rem; font-weight: 700; color: #fff;
}
.mission-home-page .my-lv i { font-size: 10px; }
.mission-home-page .my-church { font-size: .8rem; color: var(--text2); margin-top: 2px; }
.mission-home-page .my-stat { display: flex; flex-direction: column; align-items: center; gap: 1px; }
.mission-home-page .my-stat-n { font-size: .95rem; font-weight: 800; color: var(--text); font-family: 'Pretendard', sans-serif; }
.mission-home-page .my-stat-l { font-size: .68rem; font-weight: 600; color: var(--text2); }

/* 서브 탭 */
.mission-home-page .my-subtabs {
  display: flex; gap: 6px;
  padding: 16px clamp(16px,3vw,40px) 4px;
  overflow-x: auto; scrollbar-width: none;
}
.mission-home-page .my-subtabs::-webkit-scrollbar { display: none; }
.mission-home-page .my-subtab {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; gap: 5px;
  padding: 8px 14px; border-radius: 10px;
  font-size: .84rem; font-weight: 600; color: var(--text2);
  background: var(--chip-bg); border: 1px solid transparent;
  transition: all .15s; white-space: nowrap;
}
.mission-home-page .my-subtab i { font-size: 16px; }
.mission-home-page .my-subtab:hover { background: var(--line2); color: var(--text); }
.mission-home-page .my-subtab.active { background: var(--chip-on-bg); color: var(--chip-on-cl); border-color: var(--chip-on-bd); }

/* 서브 탭 콘텐츠 */
.mission-home-page .my-pane { display: none; }
.mission-home-page .my-pane.active { display: block; min-height: 300px; }

/* 북마크·팔로잉 공통 리스트 */
.mission-home-page .my-list-wrap {
  padding: 12px clamp(16px,3vw,40px);
  display: flex; flex-direction: column; gap: 4px;
}
.mission-home-page .my-list-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-radius: 14px;
  transition: background .15s; cursor: pointer;
}
.mission-home-page .my-list-item:hover { background: var(--chip-bg); }
.mission-home-page .my-list-thumb {
  width: 40px; height: 40px; border-radius: 11px; flex-shrink: 0;
  background: var(--panel2); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.mission-home-page .my-list-thumb i { font-size: 20px; }
.mission-home-page .my-list-info { flex: 1; min-width: 0; }
.mission-home-page .my-list-title { font-size: .88rem; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mission-home-page .my-list-meta { font-size: .75rem; color: var(--text2); margin-top: 2px; }
.mission-home-page .my-list-action {
  color: var(--accent); padding: 6px; border-radius: 8px;
  transition: background .13s;
}
.mission-home-page .my-list-action i { font-size: 18px; }
.mission-home-page .my-list-action:hover { background: var(--chip-bg); }

/* 팔로잉 리스트 */
.mission-home-page .my-follow-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; border-radius: 14px;
  cursor: pointer; transition: background .15s;
}
.mission-home-page .my-follow-item:hover { background: var(--chip-bg); }
.mission-home-page .my-follow-avatar { width: 44px; height: 44px; border-radius: 13px; overflow: hidden; flex-shrink: 0; }
.mission-home-page .my-follow-avatar img { width: 100%; height: 100%; object-fit: cover; }
.mission-home-page .my-follow-info { flex: 1; min-width: 0; }
.mission-home-page .my-follow-name { font-size: .9rem; font-weight: 700; display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.mission-home-page .my-follow-spec { font-size: .76rem; color: var(--text2); margin-top: 2px; }
.mission-home-page .my-unfollow-btn {
  flex-shrink: 0;
  padding: 6px 14px; border-radius: 8px;
  font-size: .78rem; font-weight: 700;
  background: var(--chip-bg); color: var(--text2);
  border: 1px solid var(--line);
  transition: all .15s;
}
.mission-home-page .my-unfollow-btn:hover { background: rgba(240,90,126,.1); color: #F05A7E; border-color: rgba(240,90,126,.3); }

/* ═══════════════════════════════════════════════════
   멤버 스토리 바
═══════════════════════════════════════════════════ */
.mission-home-page .story-bar {
  padding: 16px 0 4px;
  position: relative;
}
.mission-home-page .story-track {
  display: flex; gap: 4px;
  overflow-x: auto; scroll-snap-type: x mandatory;
  scrollbar-width: none; scroll-behavior: smooth;
  padding: 8px clamp(16px, 3vw, 40px) 12px;
}
.mission-home-page .story-track::-webkit-scrollbar { display: none; }

.mission-home-page .story-item {
  flex: 0 0 auto; scroll-snap-align: start;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  width: 68px; position: relative;
  background: none; padding: 0;
  cursor: pointer;
  transition: transform .18s;
}
.mission-home-page .story-item:hover { transform: translateY(-2px); }
.mission-home-page .story-item:active { transform: scale(.95); }

/* 링 + 아바타 */
.mission-home-page .story-ring {
  width: 58px; height: 58px; border-radius: 50%;
  padding: 2.5px;
  background: var(--panel2);   /* 기본 — 새 소식 없음 */
  border: 2px solid var(--line2);
  position: relative; z-index: 1;
  transition: border-color .2s, background .2s;
}
.mission-home-page .story-ring img {
  width: 100%; height: 100%; border-radius: 50%;
  object-fit: cover;
  display: block;
}

/* 새 소식 있음 — 링 없음, 점만 */
.story-item.has-new .story-ring {
  border-color: var(--line2);
  background: var(--panel2);
}

/* 파란 점 뱃지 — 링 오른쪽 하단 */
.mission-home-page .story-glow {
  position: absolute;
  bottom: 20px;
  right: 4px;
  width: 11px; height: 11px;
  border-radius: 50%;
  background: #22C55E;
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 1.5px rgba(79,142,247,.4), 0 0 8px 2px rgba(79,142,247,.5);
  z-index: 2;
  pointer-events: none;
  animation: dotPulse 2.4s ease-in-out infinite;
}
@keyframes dotPulse {
  0%, 100% { box-shadow: 0 0 0 1.5px rgba(79,142,247,.4), 0 0 8px 2px rgba(79,142,247,.45); }
  50%       { box-shadow: 0 0 0 3px   rgba(79,142,247,.2), 0 0 14px 4px rgba(79,142,247,.6); }
}

/* 이름 */
.mission-home-page .story-name {
  font-size: .68rem; font-weight: 600;
  color: var(--text2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 66px; text-align: center;
  position: relative; z-index: 1;
}
.mission-home-page .story-brand { cursor: default; }
.mission-home-page .story-brand:hover { transform: none; }
.mission-home-page .story-brand-ring {
  background: linear-gradient(135deg, var(--accent), var(--accent2, #9d78f8)) !important;
  border-color: transparent !important;
  display: flex; align-items: center; justify-content: center;
}
.mission-home-page .story-brand-ring i { font-size: 26px; color: #fff; }

/* ═══════════════════════════════════════════════════
   홈 피드 (그룹 소식)
═══════════════════════════════════════════════════ */
.mission-home-page .home-feed {
  padding: 0 clamp(16px, 3vw, 40px) 8px;
  display: flex; flex-direction: column; gap: 1px;
}

.mission-home-page .hf-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 12px;
  transition: box-shadow .2s;
}
.mission-home-page .hf-card:hover { box-shadow: var(--shadow); }
/* ⋮ 메뉴가 본문·다음 카드에 가리지 않도록 */
.mission-home-page .hf-card:has(.hf-dropdown.is-open) {
  position: relative;
  z-index: 50;
  overflow: visible;
}

/* 헤더 */
.mission-home-page .hf-head {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 16px 10px;
  position: relative;
  z-index: 3;
}
.mission-home-page .hf-head .feed-avatar {
  cursor: pointer; flex-shrink: 0;
  transition: opacity .15s;
}
.mission-home-page .hf-head .feed-avatar:hover { opacity: .82; }
.mission-home-page .hf-menu-wrap {
  margin-left: auto;
  flex-shrink: 0;
  position: relative;
}
.mission-home-page .hf-more {
  flex-shrink: 0;
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text3); transition: all .15s;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  font: inherit;
}
.mission-home-page .hf-more i { font-size: 20px; }
.mission-home-page .hf-more:hover { background: var(--chip-bg); color: var(--text2); }

.mission-home-page .hf-dropdown {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  min-width: 200px;
  padding: 6px 0;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(12, 20, 38, 0.18), 0 4px 12px rgba(12, 20, 38, 0.1);
  z-index: 100;
}
.mission-home-page .hf-dropdown.is-open { display: block; }
.mission-home-page .hf-dd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  border: 0;
  background: transparent;
  text-align: left;
  font-size: .86rem;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  font-family: inherit;
  text-decoration: none;
  box-sizing: border-box;
}
.mission-home-page .hf-dd-item:hover {
  background: var(--chip-bg);
  color: var(--text);
}
.mission-home-page .hf-dd-item i { font-size: 18px; color: var(--text3); flex-shrink: 0; }
.mission-home-page .hf-dd-item--link { color: inherit; }
.mission-home-page .hf-dd-item--danger { color: #dc2626; }
.mission-home-page .hf-dd-item--danger i { color: #dc2626; }
.mission-home-page .hf-dd-item--danger:hover { background: rgba(220,38,38,.08); }
.mission-home-page .hf-dd-form { margin: 0; padding: 0; }
.mission-home-page .hf-dd-item--submit { width: 100%; }

/* 이미지 */
.mission-home-page .hf-img {
  width: 100%; aspect-ratio: 16/9; overflow: hidden;
  position: relative;
  z-index: 1;
}
.mission-home-page .hf-img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .3s;
}
.mission-home-page .hf-card:hover .hf-img img { transform: scale(1.02); }

/* 본문 */
.mission-home-page .hf-body {
  padding: 12px 16px 14px;
  position: relative;
  z-index: 1;
}
.mission-home-page .hf-text {
  font-size: .88rem; color: var(--text2);
  line-height: 1.65; margin-bottom: 10px;
}
.mission-home-page .hf-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 12px;
}
.mission-home-page .hf-tag {
  font-size: .76rem; font-weight: 600;
  color: var(--accent); padding: 3px 8px;
  background: var(--accent-soft);
  border-radius: 999px;
}

/* 액션 바 */
.mission-home-page .hf-actions {
  display: flex; align-items: center; gap: 4px;
}
.mission-home-page .hf-act {
  display: flex; align-items: center; gap: 5px;
  padding: 6px 10px; border-radius: 10px;
  font-size: .82rem; font-weight: 600;
  color: var(--text3); transition: all .15s;
}
.mission-home-page .hf-act i { font-size: 18px; }
.mission-home-page .hf-act:hover { background: var(--chip-bg); color: var(--text2); }
.mission-home-page .hf-act-liked { color: #F05A7E !important; }
.mission-home-page .hf-act-liked i { animation: heartPop .25s ease; }
@keyframes heartPop {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.35); }
  100% { transform: scale(1); }
}
.mission-home-page .js-mission-home-feed-like:hover { color: var(--accent); }

/* 더 보기 버튼 */
.mission-home-page .hf-load-more {
  width: 100%; padding: 13px;
  border-radius: 14px;
  background: var(--chip-bg);
  border: 1px solid var(--line);
  color: var(--text2); font-size: .86rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; gap: 6px;
  transition: all .15s; margin-top: 4px;
}
.mission-home-page .hf-load-more i { font-size: 18px; }
.mission-home-page .hf-load-more:hover { background: var(--line2); color: var(--text); }
/* ── 댓글 패널 ── */
.mission-home-page .hf-comments {
  border-top: 1px solid var(--line);
  padding: 12px 16px 14px;
  animation: cmtSlide .2s ease;
}
@keyframes cmtSlide {
  from { opacity: 0; transform: translateY(-6px); }
.mission-home-page to { opacity: 1; transform: translateY(0); }
}
.mission-home-page .cmt-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 12px; }
.mission-home-page .cmt-item { display: flex; gap: 9px; align-items: flex-start; }
.mission-home-page .cmt-avatar {
  width: 30px; height: 30px; border-radius: 9px;
  object-fit: cover; flex-shrink: 0;
}
.mission-home-page .cmt-bubble {
  background: var(--panel2); border: 1px solid var(--line);
  border-radius: 0 12px 12px 12px;
  padding: 8px 12px; flex: 1; min-width: 0;
}
.mission-home-page .cmt-name { font-size: .75rem; font-weight: 700; color: var(--accent); display: block; margin-bottom: 3px; }
.mission-home-page .cmt-text { font-size: .84rem; color: var(--text); line-height: 1.5; word-break: break-word; }
.mission-home-page .cmt-time { font-size: .68rem; color: var(--text3); margin-top: 4px; display: block; }

/* 입력 행 */
.mission-home-page .cmt-input-row { display: flex; gap: 9px; align-items: center; }
.mission-home-page .cmt-input-wrap {
  flex: 1; display: flex; align-items: center;
  background: var(--panel2); border: 1px solid var(--line2);
  border-radius: 12px; padding: 0 6px 0 12px;
  transition: border-color .15s, box-shadow .15s;
}
.mission-home-page .cmt-input-wrap:focus-within {
  border-color: var(--accent-border);
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.mission-home-page .cmt-input {
  flex: 1; background: none; border: none; outline: none;
  font-family: inherit; font-size: .84rem; color: var(--text);
  padding: 9px 0;
}
.mission-home-page .cmt-input::placeholder { color: var(--text3); }
.mission-home-page .cmt-send {
  width: 32px; height: 32px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text3); transition: all .15s; flex-shrink: 0;
}
.mission-home-page .cmt-send i { font-size: 17px; }
.mission-home-page .cmt-send:hover { background: var(--accent-soft); color: var(--accent); }
.mission-home-page .cmt-send.active { color: var(--accent); }

/* ═══════════════════════════════════════════════════
   전체 그룹 드로어
═══════════════════════════════════════════════════ */
/* 메인 목록에는 목록만: 닫힌 드로어·모달 완전 비노출 (ID로 최우선) */
#allMinistersDrawer:not(.show),
#memberSettingsModal:not(.show),
#applyModal:not(.show) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  position: fixed !important;
  left: -9999px !important;
  top: 0 !important;
  width: 0 !important;
  height: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  z-index: -1 !important;
}
#allMinistersDrawer.show,
#memberSettingsModal.show,
#applyModal.show {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 300 !important;
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

/* 드로어: 닫혀 있을 때 메인 목록에 전혀 노출되지 않음 */
.mission-home-page .drawer-backdrop:not(.show) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  position: fixed;
  left: -9999px;
  width: 0;
  height: 0;
  overflow: hidden;
}
.mission-home-page .drawer-backdrop {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  align-items: flex-end;
  justify-content: center;
}
.mission-home-page .drawer-backdrop.show { display: flex !important; visibility: visible; z-index: 300; animation: fadeIn .2s ease; }

.mission-home-page .drawer-sheet {
  width: 100%; max-width: 680px;
  background: var(--panel);
  border-radius: 28px 28px 0 0;
  padding: 12px 20px 32px;
  display: flex; flex-direction: column;
  max-height: 90vh;
  min-height: 0;
  overflow: hidden;
  animation: slideUp .24s cubic-bezier(.4,0,.2,1);
}
.mission-home-page .drawer-handle {
  width: 40px; height: 4px; border-radius: 2px;
  background: var(--line2); margin: 0 auto 16px;
  flex-shrink: 0;
}
.mission-home-page .drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 4px; flex-shrink: 0;
}
.mission-home-page .drawer-title {
  display: flex; align-items: center; gap: 7px;
  font-size: 1rem; font-weight: 800; color: var(--text);
}
.mission-home-page .drawer-title i { font-size: 20px; color: var(--accent); }
.mission-home-page .drawer-close {
  width: 34px; height: 34px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text3); transition: all .15s;
}
.mission-home-page .drawer-close i { font-size: 20px; }
.mission-home-page .drawer-close:hover { background: var(--chip-bg); color: var(--text); }

/* 드로어 스크롤 영역: 드로어가 열렸을 때만 적용 (메인 목록에는 영향 없음) */
.mission-home-page .drawer-backdrop.show .drawer-body {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding-bottom: 24px;
  scrollbar-width: thin;
  scrollbar-color: var(--scroll-track) transparent;
}
.mission-home-page .drawer-backdrop.show .drawer-body::-webkit-scrollbar { width: 4px; }
.mission-home-page .drawer-backdrop.show .drawer-body::-webkit-scrollbar-thumb { background: var(--scroll-track); border-radius: 2px; }
.mission-home-page .drawer-backdrop .drawer-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
  padding: 8px 2px 24px 4px;
}

.mission-home-page .d-card {
  border-radius: 14px; overflow: hidden;
  position: relative; cursor: pointer;
  aspect-ratio: 2/3;
  background: var(--panel2);
  box-shadow: var(--shadow);
  transition: transform .2s, box-shadow .2s;
}
.mission-home-page .d-card:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 16px 40px rgba(0,0,0,.4);
}
.mission-home-page .d-card img { width: 100%; height: 100%; object-fit: cover; }
.mission-home-page .d-card.filtered-out { display: none; }

/* ── 멤버 설정 바텀시트 ── */
.mission-home-page .ms-profile {
  display: flex; align-items: center; gap: 12px;
  padding: 4px 24px 16px;
  border-bottom: 1px solid var(--line);
}
.mission-home-page .ms-avatar {
  width: 46px; height: 46px; border-radius: 14px;
  object-fit: cover; flex-shrink: 0;
}
.mission-home-page .ms-info { flex: 1; min-width: 0; }
.mission-home-page .ms-name { font-size: 1rem; font-weight: 800; color: var(--text); }
.mission-home-page .ms-sub { font-size: .76rem; color: var(--accent); margin-top: 2px; font-weight: 600; }

.mission-home-page .ms-section-label {
  font-size: .75rem; font-weight: 700; color: var(--text3);
  padding: 14px 24px 6px; text-transform: uppercase; letter-spacing: .04em;
}
.mission-home-page .ms-row-toggle {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 10px 24px;
}
.mission-home-page .ms-row-left { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }
.mission-home-page .ms-icon-box {
  width: 38px; height: 38px; border-radius: 11px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.mission-home-page .ms-icon-box i { font-size: 20px; }
.mission-home-page .ms-icon-gray { background: var(--panel2); color: var(--text2); }
.mission-home-page .ms-icon-red { background: rgba(248,113,113,.15); color: var(--lv5); }
.mission-home-page .ms-row-title { font-size: .88rem; font-weight: 700; color: var(--text); }
.mission-home-page .ms-row-desc { font-size: .74rem; color: var(--text3); margin-top: 2px; }

/* 토글 스위치 */
.mission-home-page .ms-toggle-wrap { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.mission-home-page .ms-toggle-label { font-size: .82rem; font-weight: 700; color: var(--accent); }
.mission-home-page .ms-toggle { position: relative; width: 46px; height: 26px; }
.mission-home-page .ms-toggle input { opacity: 0; width: 0; height: 0; }
.mission-home-page .ms-toggle-track {
  position: absolute; inset: 0; border-radius: 13px;
  background: var(--line2); transition: background .2s;
  cursor: pointer;
}
.mission-home-page .ms-toggle-track::after {
  content: ''; position: absolute;
  top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: #fff; transition: transform .2s;
  box-shadow: 0 1px 4px rgba(0,0,0,.3);
}
.mission-home-page .ms-toggle input:checked + .ms-toggle-track { background: #22c55e; }
.mission-home-page .ms-toggle input:checked + .ms-toggle-track::after { transform: translateX(20px); }

/* 체크 항목 */
.mission-home-page .ms-check-rows { padding: 0 24px 8px; }
.mission-home-page .ms-check-row { padding: 0 24px 8px; display: flex; flex-direction: column; gap: 2px; }
.mission-home-page .ms-check-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0;
  border-top: 1px solid var(--line);
  font-size: .88rem; font-weight: 600; color: var(--text2);
  cursor: pointer;
}
.mission-home-page .ms-check-box {
  width: 24px; height: 24px; border-radius: 7px; flex-shrink: 0;
  background: var(--panel2); border: 1.5px solid var(--line2);
  display: flex; align-items: center; justify-content: center;
  transition: all .15s;
}
.mission-home-page .ms-check-box i { font-size: 15px; color: transparent; }
.mission-home-page .ms-check-box.checked { background: #22c55e; border-color: #22c55e; }
.mission-home-page .ms-check-box.checked i { color: #fff; }

/* 구분선 */
.mission-home-page .ms-divider { height: 6px; background: var(--bg2); margin: 8px 0; }

/* 위험 / 일반 행 */
.ms-danger-row, .ms-normal-row {
  width: 100%; display: flex; align-items: center; gap: 12px;
  padding: 12px 24px; text-align: left;
  transition: background .15s;
}
.mission-home-page .ms-danger-row:hover { background: rgba(248,113,113,.06); }
.mission-home-page .ms-normal-row:hover { background: var(--chip-bg); }
.mission-home-page .ms-danger-row span:not(.ms-chevron) { font-size: .92rem; font-weight: 700; color: var(--lv5); flex: 1; }
.mission-home-page .ms-normal-row span:not(.ms-chevron) { font-size: .92rem; font-weight: 600; color: var(--text2); flex: 1; }
.mission-home-page .ms-chevron { font-size: 18px !important; color: var(--text3); }

/* ── 모달: 닫혀 있을 때 메인 목록에 전혀 노출되지 않음 ── */
.mission-home-page .modal-backdrop:not(.show) {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
  position: fixed;
  left: -9999px;
  width: 0;
  height: 0;
  overflow: hidden;
}
.mission-home-page .modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
/* 그룹 등록 모달: 중앙 배치, 녹색 배경·흰색 글자 (테마 무관) */
.mission-home-page .modal-backdrop.modal-apply-fixed,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed {
  align-items: center !important;
  justify-content: center !important;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-sheet,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-sheet {
  width: 90%;
  max-width: 400px;
  background: #22c55e !important;
  background-color: #22c55e !important;
  color: #fff !important;
  border-radius: 20px !important;
  padding: 24px 20px calc(24px + env(safe-area-inset-bottom, 0)) !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4) !important;
  border: none !important;
  animation: missionModalPopIn .25s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes missionModalPopIn {
  from { transform: scale(0.92); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-handle,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-handle {
  background: rgba(255, 255, 255, 0.5) !important;
  margin-bottom: 16px;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-icon,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-icon {
  background: rgba(255, 255, 255, 0.25) !important;
  margin-bottom: 14px;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-icon i,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-icon i { color: #fff !important; }
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-title,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-title {
  color: #fff !important;
  font-size: 1.15rem;
  font-weight: 800;
  margin-bottom: 10px;
  text-align: center;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-desc,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-desc {
  color: rgba(255, 255, 255, 0.95) !important;
  font-size: .88rem;
  line-height: 1.7;
  text-align: center;
  margin-bottom: 20px;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-benefits,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-benefits {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 20px;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-benefit,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-benefit {
  background: rgba(255, 255, 255, 0.2) !important;
  border: 1px solid rgba(255, 255, 255, 0.35) !important;
  color: #fff !important;
  padding: 10px 12px;
  border-radius: 12px;
  font-size: .8rem;
  font-weight: 600;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-benefit i,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-benefit i { color: #fff !important; }
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-cta,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-cta {
  background: #fff !important;
  color: #16a34a !important;
  font-size: .95rem;
  font-weight: 800;
  padding: 15px;
  border-radius: 14px;
  margin-bottom: 10px;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: none;
  cursor: pointer;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-cta i,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-cta i { color: #16a34a !important; }
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-cta:hover,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-cta:hover { opacity: .92; }
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-cancel,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-cancel {
  color: rgba(255, 255, 255, 0.9) !important;
  background: transparent !important;
  border: none;
  padding: 10px 16px;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
}
.mission-home-page .modal-backdrop.modal-apply-fixed .modal-cancel:hover,
.mission-groups-list-wrap .modal-backdrop.modal-apply-fixed .modal-cancel:hover { color: #fff !important; }

.mission-home-page .modal-backdrop.show { display: flex !important; visibility: visible; animation: missionModalFadeIn .2s ease; }
@keyframes missionModalFadeIn { from { opacity: 0; } to { opacity: 1; } }
.mission-home-page .modal-sheet {
  width: 100%;
  max-width: 480px;
  background-color: var(--panel2);
  background: var(--panel2);
  border-radius: 28px 28px 0 0;
  padding: 20px 24px calc(24px + env(safe-area-inset-bottom, 0));
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.35);
  border: 1px solid var(--line2);
  border-bottom: none;
  animation: missionModalSlideUp .25s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes missionModalSlideUp {
  from { transform: translateY(60px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.mission-home-page .modal-handle {
  width: 40px; height: 4px; border-radius: 2px;
  background: var(--line2); margin-bottom: 20px;
}
.mission-home-page .modal-icon {
  width: 64px; height: 64px; border-radius: 20px;
  background: linear-gradient(135deg, var(--accent), var(--accent2, #10B981));
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.mission-home-page .modal-icon i { font-size: 32px; color: #fff; }
.mission-home-page .modal-title { font-size: 1.15rem; font-weight: 800; margin-bottom: 10px; text-align: center; color: var(--text); }
.mission-home-page .modal-desc { font-size: .88rem; color: var(--text2); line-height: 1.7; text-align: center; margin-bottom: 20px; }
.mission-home-page .modal-benefits {
  width: 100%; display: grid; grid-template-columns: 1fr 1fr;
  gap: 8px; margin-bottom: 22px;
}
.mission-home-page .modal-benefit {
  display: flex; align-items: center; gap: 7px;
  padding: 10px 12px; border-radius: 12px;
  background: var(--panel);
  border: 1px solid var(--line2);
  font-size: .8rem; font-weight: 600; color: var(--text);
}
.mission-home-page .modal-benefit i { font-size: 17px; color: var(--accent); }
.mission-home-page .modal-cta {
  width: 100%; padding: 15px; border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), var(--accent2, #10B981));
  color: #fff; font-size: .95rem; font-weight: 800;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-bottom: 10px; transition: opacity .15s;
  text-decoration: none;
  border: none;
  cursor: pointer;
}
.mission-home-page .modal-cta i { font-size: 20px; }
.mission-home-page .modal-cta:hover { opacity: .88; }
.mission-home-page .modal-cancel {
  font-size: .85rem; font-weight: 600; color: var(--text2);
  padding: 10px 16px; transition: color .13s;
  background: transparent; border: none; cursor: pointer;
}
.mission-home-page .modal-cancel:hover { color: var(--text); }

/* 내 활동 필터칩 */
.mission-home-page .my-act-filter {
  display: flex; gap: 6px;
  padding: 12px clamp(16px,3vw,40px) 4px;
  overflow-x: auto; scrollbar-width: none;
}
.mission-home-page .my-act-filter::-webkit-scrollbar { display: none; }
.mission-home-page .my-act-chip {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; gap: 4px;
  padding: 7px 14px; border-radius: 999px;
  font-size: .82rem; font-weight: 700; color: var(--text2);
  background: var(--chip-bg); border: 1px solid transparent;
  transition: all .15s; white-space: nowrap;
}
.mission-home-page .my-act-chip i { font-size: 15px; }
.mission-home-page .my-act-chip:hover { background: var(--line2); color: var(--text); }
.mission-home-page .my-act-chip.active { background: var(--chip-on-bg); color: var(--chip-on-cl); border-color: var(--chip-on-bd); }
.mission-home-page .act-item.hidden { display: none; }

/* 활동 항목 서브텍스트 */
.mission-home-page .ni-sub {
  font-size: .75rem; color: var(--text3);
  margin-top: 2px; margin-bottom: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}


/* ═══════════════════════════════════════════════════
   알림
═══════════════════════════════════════════════════ */
.mission-home-page .notif-wrap {
  padding: 12px clamp(16px, 3vw, 40px);
  max-width: 680px;
}
.mission-home-page .notif-item {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 14px 16px; border-radius: 14px; margin-bottom: 4px;
  transition: background .15s; cursor: pointer;
}
.mission-home-page .notif-item:hover { background: var(--chip-bg); }
.mission-home-page .notif-item.unread { background: rgba(79,142,247,.04); }
.mission-home-page .notif-item.unread:hover { background: rgba(79,142,247,.08); }
.mission-home-page .ni-icon {
  width: 42px; height: 42px; border-radius: 12px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.mission-home-page .ni-icon i { font-size: 20px; }
.mission-home-page .ni-gold { background: rgba(79,142,247,.12); color: var(--accent); }
.mission-home-page .ni-blue { background: rgba(74,123,247,.14); color: var(--lv2); }
.mission-home-page .ni-green { background: rgba(52,198,138,.14); color: var(--lv1); }
.mission-home-page .ni-red { background: rgba(240,90,126,.14); color: var(--lv5); }
.mission-home-page .ni-body { flex: 1; }
.mission-home-page .ni-text { font-size: .9rem; line-height: 1.5; }
.mission-home-page .ni-time { font-size: .75rem; color: var(--text3); margin-top: 3px; }
.mission-home-page .unread-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); flex-shrink: 0; margin-top: 8px;
}

/* ═══════════════════════════════════════════════════
   BOTTOM TAB BAR (모바일 only — Acts .jmp-acts-bottom-nav 와 동일: 검정 바·흰 라벨·#518cff 강조)
═══════════════════════════════════════════════════ */
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99900;
  height: calc(var(--tab-h) + var(--tab-safe));
  min-height: var(--tab-h);
  padding: 0;
  padding-bottom: var(--tab-safe);
  margin: 0;
  box-sizing: border-box;
  background: #000000 !important;
  background-color: #000000 !important;
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: none;
  display: flex;
  align-items: center;
  justify-content: space-around;
  flex-direction: row;
  gap: 2px;
  font-family: 'Pretendard Variable', Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  transition: transform .28s cubic-bezier(.4, 0, .2, 1);
  -webkit-tap-highlight-color: transparent;
}
/* Acts 사역자 목록과 동일: 아래로 스크롤 시 패널 밖으로 숨김 */
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav.hide-nav {
  transform: translateY(100%);
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  color: #ffffff !important;
  padding: 8px 4px 10px;
  margin: 0;
  border: none;
  background: none;
  background-color: transparent;
  cursor: pointer;
  font-family: inherit;
  line-height: 1.2;
  text-decoration: none;
  min-width: 0;
  appearance: none;
  transition: color .15s ease;
  position: relative;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn i,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn .jmp-acts-ri {
  font-size: 23px;
  line-height: 1;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn .jmp-acts-ri {
  font-style: normal;
  font-weight: normal;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "remixicon", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn .t-lbl {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: -0.02em;
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: center;
}
/* 테마 링크색이 a.tab-btn-link 내부를 덮는 경우 */
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn .t-lbl,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn > i,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn > .jmp-acts-ri {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active {
  color: #518cff !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active .t-lbl,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active > i,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active > .jmp-acts-ri {
  color: #518cff !important;
  -webkit-text-fill-color: #518cff !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.tab-btn-link {
  text-decoration: none !important;
}
@media (hover: hover) {
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:hover {
    color: #518cff !important;
  }
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:hover .t-lbl,
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:hover > i,
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:hover > .jmp-acts-ri {
    color: #518cff !important;
    -webkit-text-fill-color: #518cff !important;
  }
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active:hover,
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active:hover .t-lbl,
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active:hover > i,
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.active:hover > .jmp-acts-ri {
    color: #518cff !important;
    -webkit-text-fill-color: #518cff !important;
  }
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.tab-btn-link:hover .t-lbl,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.tab-btn-link:hover > i,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn.tab-btn-link:hover > .jmp-acts-ri {
  color: #518cff !important;
  -webkit-text-fill-color: #518cff !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:active {
  color: #3d7ae8 !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:active .t-lbl,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:active > i,
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-btn:active > .jmp-acts-ri {
  color: #3d7ae8 !important;
  -webkit-text-fill-color: #3d7ae8 !important;
}
.mission-home-page .bottom-tabs.jmp-acts-bottom-nav .tab-nb {
  position: absolute; top: 4px;
  width: 17px; height: 17px; border-radius: 50%;
  background: #F05A5A; border: 2px solid #000000;
  font-size: .58rem; font-weight: 700; color: #fff;
  display: flex; align-items: center; justify-content: center;
  right: calc(50% - 22px);
}

/* 데스크탑: 하단 탭 숨기고 헤더 네비 보이기 */
@media (min-width: 768px) {
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav { display: none !important; }
  .mission-home-page .header-nav { display: flex; }
  .mission-home-page .main { padding-bottom: 32px; }
}
@media (max-width: 767px) {
  .mission-home-page .header-nav { display: none; }
  .mission-home-page .bottom-tabs.jmp-acts-bottom-nav { isolation: isolate; }
}

/* ═══════════════════════════════════════════════════════════════
   Astra / HC Joyn — [mission_groups] 허브 전폭 (ACTS jmp-acts-public-page 정렬)
   숏코드가 블록 에디터에만 있을 때 대비: body:has(.mission-groups-list-wrap)
═══════════════════════════════════════════════════════════════ */
/* 임포트 HTML <style> 의 body { max-width } 등이 전역에 먹는 경우 보정 (jmp-hm-html-import 등) */
body.jmp-mission-groups-public-page,
body:has(#missionGroupsList),
body:has(.mission-groups-list-wrap) {
  max-width: none !important;
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: 0 !important;
}
body.jmp-mission-groups-public-page #content,
body.jmp-mission-groups-public-page .site-content,
body.jmp-mission-groups-public-page .entry-content,
body.jmp-mission-groups-public-page .content-area,
body.jmp-mission-groups-public-page #main,
body.jmp-mission-groups-public-page .site-main,
body.jmp-mission-groups-public-page main,
body.jmp-mission-groups-public-page #primary,
body.jmp-mission-groups-public-page .content,
body.jmp-mission-groups-public-page .site-inner,
body.jmp-mission-groups-public-page .page-content,
body:has(.mission-groups-list-wrap) #content,
body:has(.mission-groups-list-wrap) .site-content,
body:has(.mission-groups-list-wrap) .entry-content,
body:has(.mission-groups-list-wrap) .content-area,
body:has(.mission-groups-list-wrap) #main,
body:has(.mission-groups-list-wrap) .site-main,
body:has(.mission-groups-list-wrap) main,
body:has(.mission-groups-list-wrap) #primary,
body:has(.mission-groups-list-wrap) .content,
body:has(.mission-groups-list-wrap) .site-inner,
body:has(.mission-groups-list-wrap) .page-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body.jmp-mission-groups-public-page #content .ast-container,
body.jmp-mission-groups-public-page #content.content .ast-container,
body.jmp-mission-groups-public-page .site-content .ast-container,
body.jmp-mission-groups-public-page #content .content-area .ast-container,
body.jmp-mission-groups-public-page .site-content .content-area .ast-container,
body:has(.mission-groups-list-wrap) #content .ast-container,
body:has(.mission-groups-list-wrap) #content.content .ast-container,
body:has(.mission-groups-list-wrap) .site-content .ast-container,
body:has(.mission-groups-list-wrap) #content .content-area .ast-container,
body:has(.mission-groups-list-wrap) .site-content .content-area .ast-container {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
  width: 100%;
}
body.jmp-mission-groups-public-page #page,
body:has(.mission-groups-list-wrap) #page {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body.jmp-mission-groups-public-page .ast-separate-container,
body.jmp-mission-groups-public-page.ast-separate-container,
body:has(.mission-groups-list-wrap) .ast-separate-container,
body:has(.mission-groups-list-wrap).ast-separate-container {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body.jmp-mission-groups-public-page .site-header,
body.jmp-mission-groups-public-page header[role="banner"],
body.jmp-mission-groups-public-page #masthead,
body.jmp-mission-groups-public-page .header-wrap,
body.jmp-mission-groups-public-page .ast-header-wrap,
body:has(.mission-groups-list-wrap) .site-header,
body:has(.mission-groups-list-wrap) header[role="banner"],
body:has(.mission-groups-list-wrap) #masthead,
body:has(.mission-groups-list-wrap) .header-wrap,
body:has(.mission-groups-list-wrap) .ast-header-wrap {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}
body.jmp-mission-groups-public-page .mission-home-page .header,
body:has(.mission-groups-list-wrap) .mission-home-page .header,
body:has(#missionGroupsList) .mission-home-page .header {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* 상위 테마 래퍼 max-width — Acts acts-ministers-list (jmp-acts-ministers-list-page) 와 동일 계열 */
body.jmp-mission-groups-public-page #content,
body.jmp-mission-groups-public-page .site-content,
body.jmp-mission-groups-public-page .entry-content,
body.jmp-mission-groups-public-page #main,
body.jmp-mission-groups-public-page .site-main,
body:has(#missionGroupsList) #content,
body:has(#missionGroupsList) .site-content,
body:has(#missionGroupsList) .entry-content,
body:has(#missionGroupsList) #main,
body:has(#missionGroupsList) .site-main,
body:has(.mission-groups-list-wrap) #content,
body:has(.mission-groups-list-wrap) .site-content,
body:has(.mission-groups-list-wrap) .entry-content,
body:has(.mission-groups-list-wrap) #main,
body:has(.mission-groups-list-wrap) .site-main {
  max-width: 100% !important;
  width: 100%;
}
body.jmp-mission-groups-public-page .ast-plain-container #primary,
body.jmp-mission-groups-public-page .ast-no-sidebar #primary,
body:has(#missionGroupsList) .ast-plain-container #primary,
body:has(#missionGroupsList) .ast-no-sidebar #primary,
body:has(.mission-groups-list-wrap) .ast-plain-container #primary,
body:has(.mission-groups-list-wrap) .ast-no-sidebar #primary {
  max-width: 100% !important;
  width: 100%;
}
body.jmp-mission-groups-public-page .content-area,
body:has(#missionGroupsList) .content-area,
body:has(.mission-groups-list-wrap) .content-area {
  max-width: 100% !important;
}

/* :has(#missionGroupsList) — id가 템플릿 루트에 고정되어 있어 클래스만으로 매칭 실패 시에도 동작 */
body:has(#missionGroupsList) #content,
body:has(#missionGroupsList) .site-content,
body:has(#missionGroupsList) .entry-content,
body:has(#missionGroupsList) .content-area,
body:has(#missionGroupsList) #main,
body:has(#missionGroupsList) .site-main,
body:has(#missionGroupsList) main,
body:has(#missionGroupsList) #primary,
body:has(#missionGroupsList) .content,
body:has(#missionGroupsList) .site-inner,
body:has(#missionGroupsList) .page-content {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body:has(#missionGroupsList) #content .ast-container,
body:has(#missionGroupsList) #content.content .ast-container,
body:has(#missionGroupsList) .site-content .ast-container,
body:has(#missionGroupsList) #content .content-area .ast-container,
body:has(#missionGroupsList) .site-content .content-area .ast-container {
  padding-top: 0 !important;
  margin-top: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  max-width: 100% !important;
  width: 100%;
}
body:has(#missionGroupsList) #page {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body:has(#missionGroupsList) .ast-separate-container,
body:has(#missionGroupsList).ast-separate-container {
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body:has(#missionGroupsList) .site-header,
body:has(#missionGroupsList) header[role="banner"],
body:has(#missionGroupsList) #masthead,
body:has(#missionGroupsList) .ast-header-wrap {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}