/* ============================================================
   GAMEBOY 콘텐츠 허브 — 구조 + 다크 스킨 (gch-base.css)
   · 전역 redesign-chrome.css 의 --gb-* 토큰 사용(사이트 전역 로드되어 항상 resolve).
   · 시각 미세조정/라이트 전환은 자식테마 redesign-hub.css 가 뒤에서 덮음.
   · 스코프 = body.gch-hub-page (라우터가 항상 부착).
   ============================================================ */

.gch-hub-page {
  --gch-radius: 16px;
  --gch-chzzk: #00ffa3;
  --gch-soop: #3a8cff;
  --gch-yt: #ff4e45;
  --gch-cat-recruit: var(--gb-pur);
  --gch-cat-team: var(--gb-cyan);
  --gch-cat-sicham: var(--gb-amber);
  --gch-cat-promo: var(--gb-pink);
  --gch-soft: #d98a8a;
}

/* ── 래퍼: 사이드바 + 본문 ── */
body.gch-hub-page .gch-wrap {
  max-width: 1200px;
  margin: 22px auto 60px;
  padding: 0 16px;
  display: flex;
  gap: 22px;
  align-items: flex-start;
  font-family: 'Pretendard', 'Pretendard Variable', -apple-system, BlinkMacSystemFont,
    'Apple SD Gothic Neo', 'Noto Sans KR', system-ui, sans-serif;
  color: var(--gb-txt);
}
body.gch-hub-page .gch-content { flex: 1 1 auto; min-width: 0; }
body.gch-hub-page .gch-content a { text-decoration: none; }

/* ── 좌측 사이드바 ── */
body.gch-hub-page .gch-sidebar {
  flex: 0 0 220px;
  position: sticky;
  top: 80px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
body.gch-hub-page .gch-nav {
  background: var(--gb-bg2);
  border: 1px solid var(--gb-line);
  border-radius: var(--gch-radius);
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
body.gch-hub-page .gch-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 13px; border-radius: 11px;
  color: var(--gb-txt2); font-weight: 600; font-size: 14px;
  transition: background .15s, color .15s;
}
body.gch-hub-page .gch-nav-item:hover { background: var(--gb-bg3); color: var(--gb-txt); }
body.gch-hub-page .gch-nav-item.is-active { background: rgba(146,41,247,.16); color: #c4b9ff; font-weight: 800; }
body.gch-hub-page .gch-nav-ic { font-size: 16px; width: 20px; text-align: center; }
body.gch-hub-page .gch-side-write {
  display: block; text-align: center;
  padding: 13px; border-radius: 12px;
  background: var(--gb-pink); color: #fff; font-weight: 800; font-size: 14px;
  transition: filter .15s;
}
body.gch-hub-page .gch-side-write:hover { filter: brightness(1.08); }

/* ── 상단바 ── */
body.gch-hub-page .gch-topbar {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px; margin-bottom: 18px;
}
body.gch-hub-page .gch-h1 { font-size: 26px; font-weight: 900; color: var(--gb-txt); margin: 0 0 4px; line-height: 1.2; }
body.gch-hub-page .gch-sub { font-size: 13px; color: var(--gb-mut); margin: 0; }

/* ── 버튼 ── */
body.gch-hub-page .gch-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 11px 18px; border-radius: 11px;
  font-weight: 800; font-size: 14px; cursor: pointer;
  border: 1px solid var(--gb-line2); background: var(--gb-bg2); color: var(--gb-txt);
  transition: filter .15s, background .15s, border-color .15s;
}
body.gch-hub-page .gch-btn:hover { border-color: var(--gb-pur); }
body.gch-hub-page .gch-btn-primary { background: var(--gb-pink); border-color: transparent; color: #fff; }
body.gch-hub-page .gch-btn-primary:hover { filter: brightness(1.08); border-color: transparent; }
body.gch-hub-page .gch-btn-sub { background: var(--gb-pur); border-color: transparent; color: #fff; }
body.gch-hub-page .gch-write-cta { flex: 0 0 auto; white-space: nowrap; }

/* ── 플랫폼 탭 ── */
body.gch-hub-page .gch-platform-tabs {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px;
  border-bottom: 1px solid var(--gb-line); padding-bottom: 12px;
}
body.gch-hub-page .gch-ptab {
  padding: 8px 18px; border-radius: 999px; font-weight: 800; font-size: 13px;
  background: var(--gb-bg2); border: 1px solid var(--gb-line2); color: var(--gb-txt2);
  transition: background .15s, color .15s, border-color .15s;
}
body.gch-hub-page .gch-ptab:hover { color: var(--gb-txt); border-color: var(--gb-line3); }
body.gch-hub-page .gch-ptab.is-active { background: var(--gb-pur); border-color: transparent; color: #fff; }
body.gch-hub-page .gch-ptab-chzzk.is-active { background: var(--gch-chzzk); color: #06281c; }
body.gch-hub-page .gch-ptab-soop.is-active { background: var(--gch-soop); color: #fff; }
body.gch-hub-page .gch-ptab-youtube.is-active { background: var(--gch-yt); color: #fff; }

/* ── 분야 칩 ── */
body.gch-hub-page .gch-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
body.gch-hub-page .gch-chip {
  padding: 6px 15px; border-radius: 999px; font-weight: 700; font-size: 13px;
  background: var(--gb-bg2); border: 1px solid var(--gb-line2); color: var(--gb-txt2);
  transition: background .15s, color .15s, border-color .15s;
}
body.gch-hub-page .gch-chip:hover { color: var(--gb-txt); border-color: var(--gb-line3); }
body.gch-hub-page .gch-chip.is-active { background: var(--gb-txt); color: var(--gb-bg); border-color: transparent; }
body.gch-hub-page .gch-chip-recruit.is-active { background: var(--gch-cat-recruit); color: #fff; }
body.gch-hub-page .gch-chip-team.is-active { background: var(--gch-cat-team); color: #062a30; }
body.gch-hub-page .gch-chip-sicham.is-active { background: var(--gch-cat-sicham); color: #2a1c03; }
body.gch-hub-page .gch-chip-promo.is-active { background: var(--gch-cat-promo); color: #fff; }

/* ── 태그바 ── */
body.gch-hub-page .gch-tagbar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 16px; }
body.gch-hub-page .gch-tagf {
  padding: 4px 11px; border-radius: 8px; font-weight: 600; font-size: 12px;
  background: transparent; border: 1px solid var(--gb-line2); color: var(--gb-mut);
  transition: color .15s, border-color .15s;
}
body.gch-hub-page .gch-tagf:hover { color: var(--gb-txt2); border-color: var(--gb-line3); }
body.gch-hub-page .gch-tagf.is-active { color: #c4b9ff; border-color: var(--gb-pur); background: rgba(146,41,247,.1); }

/* ── 툴바 ── */
body.gch-hub-page .gch-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 14px;
}
body.gch-hub-page .gch-search { display: flex; align-items: center; flex: 1 1 260px; max-width: 360px; position: relative; }
body.gch-hub-page .gch-search-in {
  width: 100%; padding: 10px 40px 10px 14px; border-radius: 11px;
  background: var(--gb-bg3); border: 1px solid var(--gb-line2); color: var(--gb-txt); font-size: 13px;
}
body.gch-hub-page .gch-search-in:focus { outline: none; border-color: var(--gb-pur); }
body.gch-hub-page .gch-search-btn {
  position: absolute; right: 6px; background: transparent; border: none;
  color: var(--gb-mut); cursor: pointer; font-size: 15px; padding: 4px 6px;
}
body.gch-hub-page .gch-toolbar-right { display: flex; align-items: center; gap: 10px; }
body.gch-hub-page .gch-sort { display: flex; gap: 4px; }
body.gch-hub-page .gch-sort-o { padding: 7px 12px; border-radius: 9px; font-size: 12px; font-weight: 700; color: var(--gb-mut); }
body.gch-hub-page .gch-sort-o:hover { color: var(--gb-txt2); }
body.gch-hub-page .gch-sort-o.is-active { color: var(--gb-txt); background: var(--gb-bg3); }
body.gch-hub-page .gch-view-toggle { display: flex; gap: 2px; background: var(--gb-bg3); border-radius: 9px; padding: 3px; }
body.gch-hub-page .gch-vt { padding: 5px 10px; border-radius: 7px; color: var(--gb-mut); font-size: 14px; }
body.gch-hub-page .gch-vt.is-active { background: var(--gb-pur); color: #fff; }

/* ── 결과 메타 ── */
body.gch-hub-page .gch-resmeta { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
body.gch-hub-page .gch-rescount { font-size: 13px; color: var(--gb-mut); font-weight: 600; }
body.gch-hub-page .gch-reset { font-size: 12px; color: var(--gch-soft); font-weight: 700; }

/* ── 카드 그리드 ── */
body.gch-hub-page .gch-grid {
  display: grid; gap: 14px;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}
body.gch-hub-page .gch-grid[data-view="list"] { grid-template-columns: 1fr; }

/* ── 카드 ── */
body.gch-hub-page .gch-card {
  display: flex; flex-direction: column; gap: 9px;
  background: var(--gb-bg2); border: 1px solid var(--gb-line);
  border-radius: var(--gch-radius); padding: 15px 16px;
  transition: border-color .15s, transform .15s;
}
body.gch-hub-page .gch-card:hover { border-color: var(--gb-pur); transform: translateY(-2px); }
body.gch-hub-page .gch-card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
body.gch-hub-page .gch-card-badges { display: flex; gap: 5px; flex-wrap: wrap; }
body.gch-hub-page .gch-badge { font-size: 10px; font-weight: 800; padding: 3px 8px; border-radius: 999px; letter-spacing: .02em; }
body.gch-hub-page .gch-badge-new { background: var(--gch-cat-promo); color: #fff; }
body.gch-hub-page .gch-badge-soon { background: rgba(217,138,138,.18); color: var(--gch-soft); }
body.gch-hub-page .gch-badge-date { background: rgba(27,189,138,.15); color: var(--gb-green); }
body.gch-hub-page .gch-badge-closed { background: var(--gb-bg4); color: var(--gb-mut); }
body.gch-hub-page .gch-card-views { font-size: 11px; color: var(--gb-mut2); white-space: nowrap; }
body.gch-hub-page .gch-card-title {
  font-size: 15px; font-weight: 800; color: var(--gb-txt); margin: 0; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
body.gch-hub-page .gch-card-pills { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
body.gch-hub-page .gch-pill { font-size: 11px; font-weight: 800; padding: 3px 9px; border-radius: 7px; }
body.gch-hub-page .gch-pill-open { background: rgba(27,189,138,.15); color: var(--gb-green); }
body.gch-hub-page .gch-pill-closed { background: var(--gb-bg4); color: var(--gb-mut); }
body.gch-hub-page .gch-card-cat { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 7px; background: var(--gb-bg3); color: var(--gb-txt2); }
body.gch-hub-page .gch-card-cat.gch-cat-recruit { color: #c4b9ff; }
body.gch-hub-page .gch-card-cat.gch-cat-team { color: var(--gch-cat-team); }
body.gch-hub-page .gch-card-cat.gch-cat-sicham { color: var(--gch-cat-sicham); }
body.gch-hub-page .gch-card-cat.gch-cat-promo { color: var(--gch-cat-promo); }
body.gch-hub-page .gch-card-plat-tag { font-size: 11px; font-weight: 700; color: var(--gb-mut); }
body.gch-hub-page .gch-card.gch-plat-chzzk .gch-card-plat-tag { color: var(--gch-chzzk); }
body.gch-hub-page .gch-card.gch-plat-soop .gch-card-plat-tag { color: var(--gch-soop); }
body.gch-hub-page .gch-card.gch-plat-youtube .gch-card-plat-tag { color: var(--gch-yt); }
body.gch-hub-page .gch-card-tags { display: flex; gap: 6px; flex-wrap: wrap; }
body.gch-hub-page .gch-tag-mini { font-size: 11px; color: var(--gb-mut); }
body.gch-hub-page .gch-card-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  margin-top: 2px; padding-top: 9px; border-top: 1px solid var(--gb-line);
}
body.gch-hub-page .gch-card-author { display: flex; align-items: center; gap: 7px; min-width: 0; }
body.gch-hub-page .gch-avatar { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; background: var(--gb-bg3); }
body.gch-hub-page .gch-author-name { font-size: 12px; color: var(--gb-txt2); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
body.gch-hub-page .gch-card-cap { font-size: 11px; color: var(--gb-mut); white-space: nowrap; }

/* ── 리스트 뷰: 카드를 가로형으로 ── */
body.gch-hub-page .gch-grid[data-view="list"] .gch-card {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: "top top" "title views" "pills pills" "foot foot";
  align-items: center;
}
body.gch-hub-page .gch-grid[data-view="list"] .gch-card-tags { display: none; }

/* ── 페이지네이션 ── */
body.gch-hub-page .gch-pagination { display: flex; gap: 6px; justify-content: center; align-items: center; margin: 28px 0 0; flex-wrap: wrap; }
body.gch-hub-page .gch-pg { padding: 7px 12px; border-radius: 9px; font-size: 13px; font-weight: 700; color: var(--gb-txt2); background: var(--gb-bg2); border: 1px solid var(--gb-line2); }
body.gch-hub-page .gch-pg:hover { border-color: var(--gb-pur); color: var(--gb-txt); }
body.gch-hub-page .gch-pg.is-active { background: var(--gb-pur); color: #fff; border-color: transparent; }
body.gch-hub-page .gch-pg-gap { color: var(--gb-mut2); padding: 0 2px; }

/* ── 빈 상태 ── */
body.gch-hub-page .gch-empty { text-align: center; padding: 60px 20px; }
body.gch-hub-page .gch-empty-ic { font-size: 46px; margin-bottom: 12px; }
body.gch-hub-page .gch-empty-t { font-size: 18px; font-weight: 800; color: var(--gb-txt); margin: 0 0 6px; }
body.gch-hub-page .gch-empty-s { font-size: 14px; color: var(--gb-mut); margin: 0 0 20px; }

/* ============================================================
   상세 페이지
   ============================================================ */
body.gch-hub-page .gch-back { display: inline-block; margin-bottom: 14px; font-size: 13px; color: var(--gb-mut); font-weight: 600; }
body.gch-hub-page .gch-back:hover { color: var(--gb-txt2); }
body.gch-hub-page .gch-detail {
  background: var(--gb-bg2); border: 1px solid var(--gb-line);
  border-radius: var(--gch-radius); padding: 24px 26px;
}
body.gch-hub-page .gch-detail-head .gch-card-badges { margin-bottom: 12px; }
body.gch-hub-page .gch-detail-plat { font-size: 11px; font-weight: 800; padding: 3px 9px; border-radius: 7px; background: var(--gb-bg3); color: var(--gb-mut); }
body.gch-hub-page .gch-detail-plat.gch-plat-chzzk { color: var(--gch-chzzk); }
body.gch-hub-page .gch-detail-plat.gch-plat-soop { color: var(--gch-soop); }
body.gch-hub-page .gch-detail-plat.gch-plat-youtube { color: var(--gch-yt); }
body.gch-hub-page .gch-detail-title { font-size: 23px; font-weight: 900; color: var(--gb-txt); margin: 0 0 14px; line-height: 1.35; }
body.gch-hub-page .gch-detail-author { display: flex; align-items: center; gap: 9px; }
body.gch-hub-page .gch-detail-author .gch-avatar { width: 32px; height: 32px; }
body.gch-hub-page .gch-detail-author .gch-author-name { font-size: 14px; color: var(--gb-txt); font-weight: 700; }
body.gch-hub-page a.gch-author-name:hover { color: #c4b9ff; }
body.gch-hub-page .gch-detail-date { font-size: 12px; color: var(--gb-mut2); margin-left: auto; }
body.gch-hub-page .gch-detail-meta { display: flex; flex-wrap: wrap; gap: 14px; margin: 18px 0; padding: 14px 0; border-top: 1px solid var(--gb-line); border-bottom: 1px solid var(--gb-line); }
body.gch-hub-page .gch-meta-i { font-size: 13px; color: var(--gb-txt2); font-weight: 600; }
body.gch-hub-page .gch-detail-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
body.gch-hub-page .gch-detail-tags .gch-tag-mini { font-size: 12px; color: var(--gb-mut); padding: 3px 9px; border-radius: 7px; background: var(--gb-bg3); }
body.gch-hub-page .gch-detail-tags .gch-tag-mini:hover { color: #c4b9ff; }
body.gch-hub-page .gch-detail-body { font-size: 15px; line-height: 1.8; color: var(--gb-txt2); word-break: break-word; margin-bottom: 22px; }
body.gch-hub-page .gch-body-link { color: #c4b9ff; text-decoration: underline; word-break: break-all; }
body.gch-hub-page .gch-embed-yt { display: block; position: relative; width: 100%; max-width: 640px; aspect-ratio: 16/9; margin: 14px 0; }
body.gch-hub-page .gch-embed-yt iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; border-radius: 12px; }

/* ── 신청/연락 존 ── */
body.gch-hub-page .gch-applybox { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; padding: 18px 0 4px; }
body.gch-hub-page .gch-applybox .gch-btn-primary { padding: 13px 26px; font-size: 15px; }
body.gch-hub-page .gch-owner-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
body.gch-hub-page .gch-owner-tag { font-size: 13px; font-weight: 700; color: var(--gb-amber); }
body.gch-hub-page .gch-applied-state { font-size: 14px; font-weight: 700; color: var(--gb-mut); }
body.gch-hub-page .gch-myapp { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
body.gch-hub-page .gch-as-pending { color: var(--gb-amber); }
body.gch-hub-page .gch-as-ok { color: var(--gb-green); }
body.gch-hub-page .gch-as-no { color: var(--gch-soft); }
body.gch-hub-page .gch-as-cancel { color: var(--gb-mut2); }

/* ── 신청자 패널 ── */
body.gch-hub-page .gch-applicants { margin-top: 26px; padding-top: 22px; border-top: 1px solid var(--gb-line); }
body.gch-hub-page .gch-applicants-h { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
body.gch-hub-page .gch-applicants-h h2 { font-size: 17px; font-weight: 800; color: var(--gb-txt); margin: 0; }
body.gch-hub-page .gch-app-counts { font-size: 12px; color: var(--gb-mut); }
body.gch-hub-page .gch-app-empty { font-size: 14px; color: var(--gb-mut); padding: 16px 0; }
body.gch-hub-page .gch-app-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
body.gch-hub-page .gch-app-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; background: var(--gb-bg3); border: 1px solid var(--gb-line); border-radius: 12px; padding: 13px 15px; }
body.gch-hub-page .gch-app-name { font-size: 14px; font-weight: 700; color: var(--gb-txt); }
body.gch-hub-page .gch-app-status { font-size: 11px; font-weight: 700; margin-left: 8px; }
body.gch-hub-page .gch-app-msg { font-size: 13px; color: var(--gb-txt2); margin: 6px 0 0; line-height: 1.6; }
body.gch-hub-page .gch-app-contact { font-size: 12px; color: var(--gb-mut); margin: 4px 0 0; }
body.gch-hub-page .gch-app-act { display: flex; gap: 6px; flex: 0 0 auto; }
body.gch-hub-page .gch-app-act .gch-btn { padding: 7px 14px; font-size: 13px; }
body.gch-hub-page .gch-resp-no { background: transparent; border-color: var(--gch-soft); color: var(--gch-soft); }
body.gch-hub-page .gch-resp-no:hover { background: rgba(217,138,138,.12); border-color: var(--gch-soft); }

/* ============================================================
   작성/수정 폼
   ============================================================ */
body.gch-hub-page .gch-write { max-width: 720px; }
body.gch-hub-page .gch-write-form { background: var(--gb-bg2); border: 1px solid var(--gb-line); border-radius: var(--gch-radius); padding: 24px 26px; margin-top: 14px; }
body.gch-hub-page .gch-field { margin-bottom: 20px; }
body.gch-hub-page .gch-field-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
body.gch-hub-page .gch-fl { display: block; font-size: 13px; font-weight: 700; color: var(--gb-txt); margin-bottom: 8px; }
body.gch-hub-page .gch-req { color: var(--gch-cat-promo); }
body.gch-hub-page .gch-in, body.gch-hub-page .gch-ta {
  width: 100%; box-sizing: border-box; padding: 11px 14px; border-radius: 11px;
  background: var(--gb-bg3); border: 1px solid var(--gb-line2); color: var(--gb-txt);
  font-size: 14px; font-family: inherit;
}
body.gch-hub-page .gch-in:focus, body.gch-hub-page .gch-ta:focus { outline: none; border-color: var(--gb-pur); }
body.gch-hub-page .gch-ta { resize: vertical; line-height: 1.6; }
body.gch-hub-page .gch-radios { display: flex; flex-wrap: wrap; gap: 8px; }
body.gch-hub-page .gch-radio {
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  padding: 9px 15px; border-radius: 10px; font-size: 13px; font-weight: 600;
  background: var(--gb-bg3); border: 1px solid var(--gb-line2); color: var(--gb-txt2);
}
body.gch-hub-page .gch-radio input { accent-color: var(--gb-pur); margin: 0; }
body.gch-hub-page .gch-radio.is-on { border-color: var(--gb-pur); color: var(--gb-txt); background: rgba(146,41,247,.1); }
body.gch-hub-page .gch-tag-suggest { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
body.gch-hub-page .gch-tag-add { font-size: 12px; padding: 4px 11px; border-radius: 8px; background: transparent; border: 1px solid var(--gb-line2); color: var(--gb-mut); cursor: pointer; }
body.gch-hub-page .gch-tag-add:hover { color: #c4b9ff; border-color: var(--gb-pur); }
body.gch-hub-page .gch-fhint { font-size: 12px; color: var(--gb-mut); margin: 8px 0 0; }
body.gch-hub-page .gch-fhint a { color: #c4b9ff; }
body.gch-hub-page .gch-write-actions { display: flex; align-items: center; gap: 14px; margin-top: 6px; }
body.gch-hub-page .gch-form-msg { font-size: 13px; color: var(--gb-mut); margin: 0; }
body.gch-hub-page .gch-form-msg.is-err { color: var(--gch-soft); }

/* ============================================================
   신청 모달
   ============================================================ */
body.gch-hub-page .gch-modal { position: fixed; inset: 0; z-index: 99999; display: flex; align-items: center; justify-content: center; }
body.gch-hub-page .gch-modal[hidden] { display: none; }
body.gch-hub-page .gch-modal-bg { position: absolute; inset: 0; background: rgba(0,0,0,.6); backdrop-filter: blur(2px); }
body.gch-hub-page .gch-modal-box { position: relative; width: 92%; max-width: 460px; background: var(--gb-bg2); border: 1px solid var(--gb-line2); border-radius: 16px; padding: 24px; box-shadow: 0 20px 60px rgba(0,0,0,.5); }
body.gch-hub-page .gch-modal-x { position: absolute; top: 14px; right: 14px; background: transparent; border: none; color: var(--gb-mut); font-size: 16px; cursor: pointer; }
body.gch-hub-page .gch-modal-t { font-size: 18px; font-weight: 800; color: var(--gb-txt); margin: 0 0 6px; }
body.gch-hub-page .gch-modal-s { font-size: 13px; color: var(--gb-mut); margin: 0 0 18px; }
body.gch-hub-page .gch-modal-s strong { color: var(--gb-txt2); }
body.gch-hub-page .gch-modal-box .gch-fl { margin-top: 12px; }
body.gch-hub-page .gch-modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }

/* ============================================================
   내 글·신청
   ============================================================ */
body.gch-hub-page .gch-mine-sec { margin-bottom: 28px; }
body.gch-hub-page .gch-mine-h { font-size: 17px; font-weight: 800; color: var(--gb-txt); margin: 0 0 14px; }
body.gch-hub-page .gch-mine-n { font-size: 13px; color: var(--gb-pur); margin-left: 4px; }
body.gch-hub-page .gch-mine-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
body.gch-hub-page .gch-mine-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; background: var(--gb-bg2); border: 1px solid var(--gb-line); border-radius: 12px; padding: 13px 16px; }
body.gch-hub-page .gch-mine-title { font-size: 14px; font-weight: 700; color: var(--gb-txt); flex: 1 1 240px; min-width: 0; }
body.gch-hub-page .gch-mine-title:hover { color: #c4b9ff; }
body.gch-hub-page .gch-mine-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
body.gch-hub-page .gch-mine-apps { font-size: 12px; color: var(--gb-mut); }
body.gch-hub-page .gch-mine-by { font-size: 12px; color: var(--gb-mut2); }
body.gch-hub-page .gch-mine-act { display: flex; gap: 6px; flex: 0 0 auto; }
body.gch-hub-page .gch-mine-act .gch-btn { padding: 6px 12px; font-size: 12px; }

/* ── 반응형 ── */
@media (max-width: 880px) {
  body.gch-hub-page .gch-wrap { flex-direction: column; gap: 16px; }
  body.gch-hub-page .gch-sidebar { flex: 1 1 auto; width: 100%; position: static; flex-direction: row; flex-wrap: wrap; }
  body.gch-hub-page .gch-nav { flex-direction: row; flex-wrap: wrap; flex: 1 1 auto; }
  body.gch-hub-page .gch-nav-item { flex: 1 1 auto; justify-content: center; }
  body.gch-hub-page .gch-side-write { flex: 0 0 auto; }
}
@media (max-width: 560px) {
  body.gch-hub-page .gch-topbar { flex-direction: column; align-items: stretch; }
  body.gch-hub-page .gch-write-cta { width: 100%; justify-content: center; }
  body.gch-hub-page .gch-grid { grid-template-columns: 1fr 1fr; }
  body.gch-hub-page .gch-nav-item span:not(.gch-nav-ic) { display: none; }
  body.gch-hub-page .gch-field-2col { grid-template-columns: 1fr; }
  body.gch-hub-page .gch-detail { padding: 18px 16px; }
  body.gch-hub-page .gch-write-form { padding: 18px 16px; }
}
