/* 콘텐츠 영역 메인(MFC001 등) 외 HTML 전용 스타일 · 공통 유틸·검색 필드·main 패딩 등은 common.css */

/* -------------------------------------------------------------------------- */
/* MFC002 · 검색 레이아웃(필드 컴포넌트는 common.css) */
/* -------------------------------------------------------------------------- */

.search-page > main > .page-inner-narrow {
  max-width: 560px;
  margin-inline: auto;
}

/* -------------------------------------------------------------------------- */
/* MFC003 · 검색 + 결과 (.search-page > main > .page-inner > .search-results) */
/* -------------------------------------------------------------------------- */

.search-page > main:has(.search-results),
.search-page.results > main {
  align-items: flex-start;
  justify-content: flex-start;
}

.search-page > main > .page-inner:has(.search-results),
.search-page.results > main > .page-inner {
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

.search-results {
  margin-top: 40px;
  width: 100%;
  text-align: left;
}

.search-results .search-results-list-wrap {
  width: 100%;
}

.search-results .search-results-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px 16px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}

.search-results .section-head-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.search-results .search-results-title {
  margin: 0;
  flex: 1 1 200px;
  min-width: 0;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.35px;
  line-height: 1.35;
  color: var(--text);
}

.search-results .ad-mark {
  display: inline-block;
  box-sizing: border-box;
  line-height: 1;
  font-size: 11px;
  font-weight: 300;
  letter-spacing: 0.02em;
  color: #b9bfc7;
  border: 1px solid var(--border-strong);
  border-radius: 4px;
  padding: 3px;
  margin-left: 6px;
  vertical-align: middle;
  text-decoration: none;
}

.search-results .ad-mark:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.search-results .section-more {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  white-space: nowrap;
}

.search-results .section-more:hover {
  color: var(--text-sub);
}

.search-results .control-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.search-results .control-box .control-btn {
  height: 24px;
  min-width: 24px;
  padding: 0 7px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background-color: var(--bg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px 14px;
  background-image: url('/assets/images/ic-chevron-left-black.svg');
  cursor: pointer;
  line-height: 0;
}

.search-results .control-box .control-btn:hover:not(:disabled) {
  background-color: var(--bg-sub);
  border-color: var(--border-strong);
}

.search-results .control-box .control-btn:focus-visible:not(:disabled) {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.search-results .control-box .swiper-nav-next {
  transform: rotate(180deg);
}

.search-results .chip-scroll {
  margin-bottom: 8px;
}

.search-results .filter-btn {
  flex: none;
  border: 1px solid var(--border);
  background: #fff;
  color: var(--text-sub);
  border-radius: 999px;
  min-height: 30px;
  padding: 0 12px;
  font-size: 14px;
  font-family: inherit;
  cursor: pointer;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease;
}

.search-results .filter-btn.is-active {
  background: var(--text);
  color: #fff;
  border-color: var(--text);
}

.search-results .filter-btn:hover:not(.is-active) {
  background-color: var(--bg-sub);
  border-color: var(--border-strong);
  color: var(--text-sub);
}

.search-results .filter-btn.is-active:hover {
  background-color: #1e293b;
  border-color: #1e293b;
}

.search-results .filter-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.search-results .list-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  row-gap: 16px;
  column-gap: 0;
  align-items: stretch;
}

.search-results .list-grid > .list-item {
  min-width: 0;
}

.search-results .list-item {
  box-sizing: border-box;
  background: transparent;
  border: 0;
  border-radius: 10px;
  padding: 10px 12px;
  display: flex;
  align-items: stretch;
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.search-results .list-item:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.search-results .list-left {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  width: 100%;
}

.search-results .list-avatar {
  height: 90px;
  width: auto;
  aspect-ratio: 1;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  border: 1px solid var(--border);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.search-results .list-text {
  min-width: 0;
  flex: 1 1 0;
}

.search-results .list-title {
  margin: 0 0 2px;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.search-results .list-text .c-rate {
  margin: 0 0 2px;
  font-size: 13px;
  font-weight: 700;
  color: #3b82f6;
}

.search-results .list-text .c-dot-line {
  font-size: 15px;
  color: var(--text-sub);
}

.search-results .list-desc {
  margin: 2px 0 0;
  color: var(--text-muted);
  max-width: 100%;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 15px;
}

@media (max-width: 640px) {
  .search-page-title {
    margin-bottom: 24px;
    font-size: 20px;
  }

  .search-recent {
    margin-top: 28px;
  }

  .search-results {
    margin-top: 28px;
  }

  .search-results .search-results-head {
    flex-direction: column;
    align-items: stretch;
  }

  .search-results .section-head-right {
    justify-content: space-between;
  }

  .search-results .search-results-title {
    font-size: 18px;
    flex: none;
  }

  .search-results .list-item {
    align-items: flex-start;
    padding: 0 4px 0 0;
    height: auto;
  }

  .search-results .list-left {
    align-items: flex-start;
  }

  .search-results .list-avatar {
    width: 80px;
    height: 80px;
  }

  .search-results .list-title {
    font-size: 14px;
  }

  .search-results .list-desc {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* -------------------------------------------------------------------------- */
/* MFC003 · FC 목록 (필터 + 카드 그리드) */
/* -------------------------------------------------------------------------- */

.fc-directory {
  width: 100%;
  padding-bottom: 48px;
}

.directory-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px 20px;
  margin-bottom: 28px;
}

.directory-filters {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  flex: 1 1 520px;
  min-width: 0;
}

.select-field {
  min-width: 0;
}

.fc-region-inline {
  display: block;
}

.directory-select {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  min-height: 48px;
  padding: 0 44px 0 16px;
  background-color: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%2394a3b8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' d='M2.5 4.25 6 7.75l3.5-3.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease;
}

.directory-select:hover {
  border-color: var(--border-strong);
}

.directory-select:focus {
  outline: none;
  border-color: var(--focus-border);
  box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.2);
}

button.directory-select,
a.directory-select {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 100%;
  text-align: left;
  overflow: hidden;
}

a.directory-select {
  text-decoration: none;
  color: inherit;
  box-sizing: border-box;
}

button.directory-select > span,
a.directory-select > span {
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fc-directory-sort {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}

.fc-sort-btn {
  display: inline;
  padding: 0;
  margin: 0;
  font: inherit;
  font-weight: 400;
  color: var(--text-muted);
  background: none;
  border: none;
  cursor: pointer;
  line-height: inherit;
}

.fc-sort-btn:hover {
  color: var(--text-sub);
}

.fc-sort-btn.is-active {
  font-weight: 700;
  color: var(--text);
}

.fc-sort-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.fc-profile-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 13px;
  align-items: stretch;
}

/* 메인 · 추천 FC 캐러셀 카드와 동일 톤 (main.css .card / .recommend-list 기준) */
.fc-profile-grid > .card {
  box-sizing: border-box;
  background-color: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  overflow: hidden;
  margin: 0;
  min-height: 0;
  height: 100%;
  display: flex;
  flex-direction: column;
}
.fc-profile-grid .card-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 16px 6px 14px;
}
.fc-profile-grid .card-link {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  color: inherit;
  text-decoration: none;
}
.fc-profile-grid .card-link:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 4px;
}
.fc-profile-grid .profile {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
  min-height: 0;
}
.fc-profile-grid .profile > div {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  min-height: 0;
}
.fc-profile-grid .profile-name {
  font-weight: 800;
  margin: 0 0 3px;
  text-align: center;
}
.fc-profile-grid .c-dot-line {
  text-align: left;
  margin: 2px 0 0;
  font-size: 14px;
  line-height: 1.35;
  align-self: center;
  width: max-content;
  max-width: 100%;
}
.fc-profile-grid .list-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  justify-content: center;
  align-self: stretch;
  max-width: 100%;
  margin-top: 6px;
  max-height: calc(22px + 2px + 22px);
  overflow: hidden;
}
.fc-profile-grid .list-tags span {
  border: 1px solid var(--border);
  border-radius: 5px;
  min-height: 22px;
  line-height: 20px;
  padding: 0 4px;
  font-size: 14px;
  color: var(--text-sub);
  display: inline-flex;
  align-items: center;
}
@media (max-width: 640px) {
  .directory-toolbar {
    flex-direction: column;
    align-items: stretch;
    margin-bottom: 10px;
  }

  .fc-directory {
    padding-bottom: 10px;
  }

  .fc-directory-sort {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    justify-content: flex-end;
  }

  .directory-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    flex-basis: 100%;
  }

  .fc-region-inline .fc-region-select {
    width: 100%;
  }

  .fc-profile-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  /* MFC003 · 모바일: 아바타 좌측 + 텍스트·태그 좌정렬 */
  .fc-profile-grid > .card {
    border-radius: 14px;
    min-width: 0;
  }

  .fc-profile-grid .card-body {
    padding: 16px 18px;
  }

  .fc-profile-grid .card-link {
    text-align: left;
    min-width: 0;
  }

  .fc-profile-grid .profile {
    flex-direction: row;
    align-items: flex-start;
    gap: 14px;
  }

  .fc-profile-grid .profile > div {
    flex: 1 1 0;
    min-width: 0;
    text-align: left;
    align-items: flex-start;
  }

  .fc-profile-grid .profile-name {
    text-align: left;
    font-size: 16px;
    margin: 0 0 4px;
  }

  .fc-profile-grid .c-rate {
    text-align: left;
  }

  .fc-profile-grid .c-dot-line {
    text-align: left;
    font-size: 13px;
    line-height: 1.45;
    align-self: flex-start;
    width: max-content;
    max-width: 100%;
  }

  .fc-profile-grid .list-tags {
    justify-content: flex-start;
    margin-top: 8px;
    gap: 6px;
    max-height: calc(22px + 6px + 22px);
  }

  /* 칩 스타일은 main.css .list-tags span — 그리드 모바일만 글자색 */
  .fc-profile-grid .list-tags span {
    color: var(--text-muted);
  }
}

/* -------------------------------------------------------------------------- */
/* MFC003_01 · FC 상세 */
/* -------------------------------------------------------------------------- */

/* FC 상세·상담 요청: main > .page-inner (폭은 아래) */

.detail-page > main > .page-inner > .section-title:first-child {
  margin-top: 0;
}

.detail-page > main > .page-inner > .section-title + p {
  margin: 0;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-sub);
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.fc-detail-card {
  box-sizing: border-box;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  padding: 30px;
}

.fc-detail-card .fc-detail-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 20px;
  margin-bottom: 28px;
}

.fc-detail-card .fc-detail-head > img {
  width: 96px;
  height: 96px;
  border-radius: 999px;
  object-fit: cover;
  border: 1px solid var(--border);
  flex-shrink: 0;
  background: #eef2f7;
}

.fc-detail-card .fc-detail-head .fc-detail-head-main {
  min-width: 0;
}

.fc-detail-card .fc-detail-head .fc-detail-head-main p {
  margin: 0 0 4px;
  font-size: 14px;
  line-height: 1.4;
  color: var(--text-muted);
}

.fc-detail-card .fc-detail-head .fc-detail-head-main h1 {
  margin: 0;
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: -0.02em;
  color: var(--text);
}

.fc-detail-card .fc-detail-head .fc-detail-head-main h1 > span {
  margin-left: 2px;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-sub);
}

.fc-detail-card .fc-detail-head .fc-detail-head-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}

.detail-capture-btn {
  padding: 8px 14px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-sub);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
}

.detail-capture-btn:hover {
  border-color: var(--border-strong);
  background: var(--bg-sub);
}

.fc-detail-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  color: var(--text-muted);
  background-color: var(--bg-sub);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
}

.fc-detail-icon-btn:hover {
  color: var(--text);
  background-color: var(--bg-elevated);
}

.fc-detail-icon-btn.c-bookmark-btn,
.fc-detail-icon-btn.detail-share-btn {
  background-repeat: no-repeat;
  background-position: center;
}

.fc-detail-icon-btn.c-bookmark-btn {
  background-size: 20px 20px;
  background-image: url('/assets/images/ic-detail-bookmark.svg');
}

.fc-detail-icon-btn.c-bookmark-btn[aria-pressed='true'] {
  background-image: url('/assets/images/ic-detail-bookmark-on.svg');
}

.fc-detail-icon-btn.detail-share-btn {
  background-size: 20px 20px;
  background-image: url('/assets/images/ic-detail-share.svg');
}

/* FC 상세 카드 · 요약 필드 (2열 자동 흐름) */
.fc-detail-card .fc-detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px 40px;
  margin-bottom: 28px;
}

.fc-detail-card .fc-detail-item {
  margin: 0;
}

.fc-detail-card .fc-detail-item > h3 {
  margin: 0 0 6px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: -0.01em;
}

.fc-detail-card .fc-detail-item > p {
  margin: 0;
  line-height: 1.55;
}

.fc-detail-card .fc-detail-item > p span {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 12px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--bg);
}

.fc-detail-cta-wrap {
  display: flex;
  justify-content: center;
  padding-top: 4px;
}

.fc-detail-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 320px;
  padding: 14px 24px;
  font-size: 16px;
  font-weight: 700;
  font-family: inherit;
  color: var(--bg);
  background: var(--primary);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  box-shadow: 0 1px 2px rgba(37, 99, 235, 0.25);
  text-decoration: none;
  box-sizing: border-box;
}

a.fc-detail-cta {
  text-align: center;
}

.fc-detail-cta:hover {
  background: var(--primary-hover);
}

.fc-detail-cta:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

/* FC 상세 · 경력 / 이력·인증 / 자기소개 (MFC003_01 등) */

.detail-page :is(.fc-detail-bio, .fc-detail-about) .section-title > span {
  font-size: 0.92em;
  font-weight: 600;
  color: var(--text-muted);
}

.detail-page .fc-detail-bio ul {
  margin: 0 0 24px;
  line-height: 1.65;
  color: var(--text-sub);
}

.detail-page .fc-detail-bio ul > li {
  margin-bottom: 6px;
}

.detail-page .fc-detail-certs-section .fc-detail-certs-block > p {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.5;
  font-weight: 400;
  color: var(--text-muted);
}

.detail-page .fc-detail-certs-section .fc-detail-certs {
  margin: 0;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg-sub);
}

.detail-page .fc-detail-certs-section .fc-detail-certs > li {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  line-height: 1.5;
  color: var(--text-sub);
}

.detail-page .fc-detail-certs-section .fc-detail-certs > li:last-child {
  border-bottom: none;
}

.detail-page .fc-detail-certs-section .fc-detail-certs > li > span {
  flex: 0 1 auto;
  min-width: 0;
}

.detail-page .fc-detail-certs-section .fc-detail-cert-dl {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background-color: var(--bg);
  background-image: url('/assets/images/ic-detail-download.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 16px 16px;
}

.detail-page .fc-detail-certs-section .fc-detail-cert-link {
  background-image: url('/assets/images/ic-detail-link-clip.svg');
}

.detail-page .fc-detail-certs-section .fc-detail-cert-dl:hover {
  border-color: var(--border-strong);
  background-color: var(--bg-elevated);
}

.detail-page .fc-detail-certs-section .fc-detail-cert-dl:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.detail-page .fc-detail-about > .section-title + p {
  margin: 0;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-sub);
  overflow-wrap: anywhere;
  word-break: keep-all;
}

/* MFC003_01 · FC 상세 · 주의사항(섹션 아닌 보조 박스) */
.detail-page .detail-notice-box {
  margin: 70px 0 0;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-sub);
}
.detail-page .detail-notice-title {
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 6px;
}
.detail-page .detail-notice-title::before {
  content: '';
  display: block;
  width: 18px;
  height: 18px;
  background: url('/assets/images/ic-notice.svg') no-repeat center / contain;
  flex: none;
}
.detail-page .detail-notice-box > p {
  margin: 0;
  padding-left: 8px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--text-sub);
  overflow-wrap: anywhere;
  word-break: keep-all;
}

/* 활동 이미지 캐러셀 · 슬라이드 비율 16:9 유지 */
.detail-page .fc-detail-story-images .fc-detail-story-swiper {
  width: 100%;
  overflow: hidden;
}
.detail-page .fc-detail-story-images .swiper-slide {
  height: auto;
}
.detail-page .fc-detail-story-images .swiper-slide .fc-story-trigger {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-sub);
}
.detail-page .fc-detail-story-images .swiper-slide .fc-story-trigger img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

/* MFC008_L05_L01 · 심의요청용 화면 미리보기 (공통 c-modal.lg 사용) */
.fc-delib-preview-inner {
  padding: 20px 18px 28px;
  box-sizing: border-box;
}

.fc-delib-preview-popup .fc-delib-preview-inner :is(.fc-detail-bio, .fc-detail-certs-section, .fc-detail-about) .section-title {
  font-size: 20px;
}

/* FC 상세 · 최근 후기 · 활동 스토리 */
.detail-page .control-box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  flex-shrink: 0;
}
.detail-page .control-box .control-btn,
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .control-btn {
  height: 24px;
  min-width: 24px;
  padding: 0 7px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background-color: var(--bg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 14px 14px;
  background-image: url('/assets/images/ic-chevron-left-black.svg');
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    background-color 0.2s ease;
}
.detail-page .control-box .control-btn:hover:not(:disabled),
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .control-btn:hover:not(:disabled) {
  background-color: var(--bg-sub);
  border-color: var(--border-strong);
}
.detail-page .control-box .control-btn:focus-visible:not(:disabled),
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .control-btn:focus-visible:not(:disabled) {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.detail-page .control-box .swiper-nav-next,
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper-nav-next {
  transform: rotate(180deg);
}

/* 슬라이더 이전·다음(control-btn): 끝 슬라이드 — 아이콘·테두리 흐림 (Swiper 번들보다 높은 특이도로 적용·번들이 link 뒤에 있어도 유지) */
.control-btn.swiper-nav-prev:disabled,
.control-btn.swiper-nav-next:disabled,
.control-btn.swiper-nav-prev.swiper-button-disabled,
.control-btn.swiper-nav-next.swiper-button-disabled {
  cursor: default;
  pointer-events: none;
  opacity: 0.38;
}

/* MFC003 모달 네비: Swiper 번들 기본 레이아웃·가상요소 문자만 무력화 */
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .control-btn {
  position: relative;
  inset: auto;
  margin: 0;
  flex-shrink: 0;
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
  color: transparent;
}
.c-modal:has(.story-detail-wrap) .story-detail-wrap > .control-btn::after {
  content: '';
  display: none;
}

/* 상세 후기: 플랫 리스트(패널 배경만), 항목은 구분선 — 클래스명은 메인과 동일 */
.detail-reviews-panel {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 25px 20px;
  box-sizing: border-box;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
}

/* 후기: 슬라이드 1장 = 후기 5개 묶음 · 터치 스크롤 없음(이전/다음 버튼만) */
.detail-reviews-swiper.swiper {
  overflow: hidden;
  width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

.detail-reviews-swiper .swiper-slide {
  box-sizing: border-box;
  height: auto;
  align-self: flex-start;
}

.detail-reviews-swiper .swiper-wrapper {
  align-items: flex-start;
}

.detail-page .detail-reviews-panel .swiper-slide > div {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.detail-reviews-panel .review-card {
  margin: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  border-bottom: 1px solid var(--border);
  padding: 18px 0;
  box-shadow: none;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 0;
  box-sizing: border-box;
}

.detail-reviews-panel .review-card:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.detail-reviews-panel .review-card:first-child {
  padding-top: 0;
}

.detail-reviews-panel .review-card:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.detail-reviews-panel .review-card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 10px;
  margin: 0 0 10px;
}

.detail-reviews-panel .review-card-meta .c-rate {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--primary);
  flex-shrink: 0;
}

.detail-reviews-panel .review-card-meta .review-author {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.35;
  color: var(--text-muted);
  flex-shrink: 0;
}

.detail-reviews-panel .review-card-meta .review-date {
  margin: 0 0 0 auto;
  font-size: 15px;
  line-height: 1.35;
  color: var(--text-sub);
  flex-shrink: 0;
}

.detail-reviews-panel .review-card h4 {
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 1.45;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.detail-reviews-panel .review-card-body {
  margin: 0;
  line-height: 1.65;
  color: var(--text-muted);
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.detail-page .detail-reviews .section-head > div:first-child {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px 12px;
  min-width: 0;
}

.detail-page .detail-reviews .section-head > div:first-child > p.c-rate .c-rate-star {
  color: #ffd910;
}

.detail-page .detail-reviews .section-head > div:first-child > p.review-count {
  margin: 0;
  color: var(--text-sub);
  font-weight: 600;
}

.fc-detail-story > header {
  margin-bottom: 18px;
}

.fc-detail-story .section-title {
  margin: 0;
}

/* 영상 스토리: 활동 이미지 캐러셀 1슬라이드(3열, gap 8px)와 동일한 폭 · 16:9 비율 */
/* 활동 이미지(.fc-detail-story-images)는 Swiper 구조라 적용 제외 */
.detail-page .fc-detail-story:not(.fc-detail-story-images) {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: 8px;
  row-gap: 12px;
}

.detail-page .fc-detail-story:not(.fc-detail-story-images) > .section-head {
  grid-column: 1 / -1;
}

.detail-page .fc-detail-story:not(.fc-detail-story-images) > div {
  position: relative;
  width: 100%;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-sub);
  aspect-ratio: 16 / 9;
  box-sizing: border-box;
}

.detail-page .fc-detail-story:not(.fc-detail-story-images) > div img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

/* 이미지 본문(활동 스토리 등): 컨테이너는 이미지 높이에 맞춰 자동 — 가로는 꽉 채우고 세로는 max-height로 제한해 가운데 표시 */
.c-modal:has(.story-detail-wrap) .story-detail-card > .body {
  width: 100%;
  max-height: min(70vh, 720px);
  padding: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
}

.c-modal:has(.story-detail-wrap) .story-detail-card > .body img {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(70vh, 720px);
  object-fit: contain;
}

/* 텍스트 후기(.story-detail-body) 내 인라인 이미지는 유연한 크기로 */
.c-modal:has(.story-detail-wrap) .story-detail-body img {
  display: block;
  max-width: 100%;
  height: auto;
  margin: 0 auto;
}

@media (max-width: 640px) {
  .fc-detail-card {
    padding: 20px 18px 22px;
  }

  .fc-detail-card .fc-detail-head {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .fc-detail-card .fc-detail-head .fc-detail-head-main {
    text-align: center;
    width: 100%;
  }

  .fc-detail-card .fc-detail-head .fc-detail-head-actions {
    display: none;
  }

  .fc-detail-card .fc-detail {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .fc-detail-cta {
    max-width: none;
  }

  .detail-reviews-panel {
    padding: 25px 20px;
  }
  .detail-reviews-panel .review-card {
    padding: 14px 0;
  }

  .detail-reviews-panel .review-card:last-child {
    padding-bottom: 0;
  }

  .detail-reviews-panel .review-card-body {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    overflow: hidden;
  }

  .detail-page .fc-detail-story:not(.fc-detail-story-images) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 6px;
  }

  .detail-page .fc-detail-story:not(.fc-detail-story-images) > div {
    border-radius: 8px;
  }
}

/* -------------------------------------------------------------------------- */
/* MFC007 · 회원가입 */
/* -------------------------------------------------------------------------- */

/* MFC003_01_L01/L02 · 후기·활동 상세 모달 (네비는 FC상세와 동일 .control-btn 규격) */
.c-modal:has(.story-detail-wrap) .c-modal-body {
  padding: 20px;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap {
  display: grid;
  grid-template-columns: 1fr auto auto;
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: 5px;
  row-gap: 12px;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper-nav-prev {
  grid-column: 2;
  grid-row: 1;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper-nav-next {
  grid-column: 3;
  grid-row: 1;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper.swiper {
  grid-column: 1 / -1;
  grid-row: 2;
  min-width: 0;
  width: 100%;
  overflow: hidden;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper .swiper-wrapper {
  align-items: flex-start;
}

.c-modal:has(.story-detail-wrap) .story-detail-wrap > .swiper .swiper-slide {
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  height: auto;
}

.c-modal:has(.story-detail-wrap) .story-detail-card {
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
  overflow: hidden;
}

.c-modal:has(.story-detail-wrap) .story-detail-card h3 {
  margin: 0;
  padding: 14px 16px;
  font-size: 18px;
  font-weight: 800;
  line-height: 1.45;
  letter-spacing: -0.01em;
  background: var(--bg-sub);
  border-bottom: 1px solid var(--border);
}

.c-modal:has(.story-detail-wrap) .story-detail-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
}

.c-modal:has(.story-detail-wrap) .story-detail-meta > p,
.c-modal:has(.story-detail-wrap) .story-detail-meta > time {
  margin: 0;
  font-size: 14px;
  color: var(--text-sub);
}

.c-modal:has(.story-detail-wrap) .story-detail-meta > p {
  display: inline-flex;
  align-items: center;
}

.c-modal:has(.story-detail-wrap) .story-detail-meta > time {
  margin-left: auto;
}

.c-modal:has(.story-detail-wrap) .story-detail-meta .c-rate {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}

.c-modal:has(.story-detail-wrap) .story-detail-meta .c-rate-star {
  color: #ffd910;
}

.c-modal:has(.story-detail-wrap) .story-detail-body {
  display: block;
  max-height: 300px;
  overflow-y: auto;
  padding: 14px 16px;
  box-sizing: border-box;
}

.c-modal:has(.story-detail-wrap) .story-detail-body p {
  margin: 0 0 13px;
  font-size: 15px;
  line-height: 1.62;
  color: var(--text-sub);
}

.c-modal:has(.story-detail-wrap) .story-detail-body p:last-child {
  margin-bottom: 0;
}

@media (max-width: 640px) {
  .c-modal:has(.story-detail-wrap) .c-modal-body {
    padding: 14px 10px 12px;
  }

  .c-modal:has(.story-detail-wrap) .story-detail-wrap {
    margin-left: 0;
    margin-right: 0;
    width: 100%;
  }

  .c-modal:has(.story-detail-wrap) .story-detail-card h3 {
    font-size: 16px;
  }

  .c-modal:has(.story-detail-wrap) .story-detail-meta > p,
  .c-modal:has(.story-detail-wrap) .story-detail-meta > time {
    font-size: 14px;
  }

  .c-modal:has(.story-detail-wrap) .story-detail-body {
    max-height: 52vh;
    padding: 12px 14px;
  }
}

/* 회원가입 유형 선택 (GNB · 중앙 팝업) */
.c-modal.signup-type .c-modal-panel {
  max-width: 380px;
}

.c-modal.signup-type .c-modal-head {
  border-bottom: none;
  padding-bottom: 10px;
}

.c-modal.signup-type .c-modal-body {
  padding: 4px 20px 20px;
}

/* 로그인 안내 팝업 공통 (MFC006_01_L03/L04/L05) */
.c-modal.notice-link .c-modal-head {
  border-bottom: none;
  padding-bottom: 8px;
}

.c-modal.notice-link .c-modal-body {
  padding: 24px 24px 30px;
  text-align: center;
}

.c-modal.notice-link .c-modal-body .modal-text {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: var(--text-sub);
}

.c-modal.notice-link .c-modal-foot {
  padding: 0 20px 20px;
  border-top: none;
}

.c-modal.notice-link .c-modal-foot > a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 15px 20px;
  font-size: 16px;
  font-weight: 700;
  color: var(--bg);
  text-align: center;
  text-decoration: none;
  background: var(--primary);
  border-radius: 12px;
  box-sizing: border-box;
  transition: background-color 0.2s ease;
}

.c-modal.notice-link .c-modal-foot > a:hover {
  background: var(--primary-hover);
}

.c-modal.notice-link .c-modal-foot > a:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

/* 심의필 절차 안내 (MFC008_L05 등) — notice-link와 분리된 단일 변형 */
.c-modal.deliberation-guide .c-modal-head {
  border-bottom: none;
  padding-bottom: 8px;
}

.c-modal.deliberation-guide .c-modal-foot {
  padding: 0 20px 20px;
  border-top: none;
}

.c-modal.deliberation-guide .c-modal-panel {
  max-width: 420px;
}

.c-modal.deliberation-guide .c-modal-body {
  padding: 8px 20px 16px;
  text-align: left;
}

.c-modal.deliberation-guide .c-modal-body > div {
  padding: 16px 18px;
  background: var(--bg-sub);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-sizing: border-box;
}

.c-modal.deliberation-guide .dash-list > li {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--text-sub);
}

.c-modal.deliberation-guide .dash-list > li strong {
  font-weight: 700;
  color: var(--text);
}

/* 이용약관 · 중앙 팝업 (MFC007_L01 등) */
.c-modal.terms .c-modal-panel {
  max-width: 480px;
  max-height: min(90vh, 560px);
}

.c-modal.terms .c-modal-body {
  padding: 30px;
}

.c-modal.terms .c-modal-body h3 {
  margin: 18px 0 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}

.c-modal.terms .c-modal-body h3:first-child {
  margin-top: 0;
}

.c-modal.terms .c-modal-body .modal-text {
  margin: 0 0 10px;
}

.c-modal.terms .c-modal-body ul {
  margin: 0 0 10px;
}

.c-modal.terms .c-modal-body li {
  margin: 0 0 10px;
}

.c-modal.terms .c-modal-body li:last-child {
  margin-bottom: 0;
}

.signup-type-options {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.signup-type-card {
  display: grid;
  grid-template-columns: 52px 1fr;
  column-gap: 16px;
  row-gap: 4px;
  align-items: start;
  width: 100%;
  margin: 0;
  padding: 18px 16px;
  text-align: left;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg);
  cursor: pointer;
  box-sizing: border-box;
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease;
}

.signup-type-card > span:first-of-type {
  grid-row: 1 / span 2;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  flex-shrink: 0;
}

.signup-type-card > span:first-of-type img {
  display: block;
  width: 26px;
  height: 26px;
}

.signup-type-card.individual > span:first-of-type {
  background: linear-gradient(155deg, #eff6ff 0%, #dbeafe 100%);
}

.signup-type-card.fc > span:first-of-type {
  background: linear-gradient(155deg, #f5f3ff 0%, #ede9fe 100%);
}

.signup-type-card strong {
  display: block;
  font-size: 18px;
  color: var(--text);
  margin: 0 0 6px;
  letter-spacing: -0.02em;
}

.signup-type-card p {
  color: var(--text-muted);
}

.signup-type-card:hover {
  background: #fafbff;
  border-color: var(--border-strong);
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.07);
}

.signup-type-card.individual:hover {
  border-color: #bfdbfe;
}

.signup-type-card.fc:hover {
  border-color: #ddd6fe;
}

.signup-type-card:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* MFC007_01_01 / MFC006_01_01_01 · 결과형 카드 공통 */

/* MFC007_01_01 · 회원가입 완료 */
.signup-done-inner {
  width: 100%;
  max-width: 400px;
  text-align: center;
  box-sizing: border-box;
}

.signup-done-inner > .signup-done-ico {
  margin: 0 0 22px;
  line-height: 0;
}

.signup-done-inner > .signup-done-ico img {
  display: inline-block;
  width: 72px;
  height: auto;
  vertical-align: top;
}

.signup-done-inner h1 {
  margin: 0 0 12px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: -0.03em;
  color: var(--text);
}

.signup-done-inner > p {
  margin: 0;
  font-size: 16px;
  line-height: 1.55;
  color: var(--text-sub);
}

/* FC 가입 완료 · 가입비 안내 (MFC008_01_01) — 폼·카드 톤과 맞춤 */
.signup-done-inner .fc-fee-promo {
  margin: 22px 0 0;
  padding: 22px 22px 24px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--bg-sub);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
  box-sizing: border-box;
  text-align: center;
}

.signup-done-inner .fc-fee-promo > p {
  margin: 0;
  line-height: 1.55;
  color: #475569;
}

.signup-done-inner .fc-fee-promo > p:first-child {
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--text-muted);
}

.signup-done-inner .fc-fee-promo > p + p {
  margin-top: 12px;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: #1e293b;
  font-variant-numeric: tabular-nums;
}

.signup-done-inner .fc-fee-promo s {
  font-weight: 400;
  color: var(--focus-border);
  text-decoration: line-through;
}

.signup-done-inner .fc-fee-promo-sep {
  margin: 0 0.2em;
  color: #cbd5e1;
  font-weight: 400;
  font-size: 0.95em;
}

.signup-done-inner .fc-fee-promo > p + p strong {
  font-weight: 700;
  font-size: 25px;
  color: var(--text);
  letter-spacing: -1px;
}

.signup-done-inner .fc-fee-promo-pill {
  display: inline-block;
  padding: 5px 12px 6px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--primary-hover);
  background: #eff6ff;
  vertical-align: 0.12em;
}

.signup-done-inner > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 32px;
  padding: 15px 24px;
  font-size: 16px;
  font-weight: 700;
  color: var(--bg);
  background: var(--primary);
  border-radius: 12px;
  text-decoration: none;
  box-sizing: border-box;
  transition: background-color 0.2s ease;
}

.signup-done-inner > a:hover {
  background: var(--primary-hover);
}

.signup-done-inner > a:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

@media (max-width: 640px) {
  .signup-done-inner h1 {
    font-size: 20px;
  }

  .signup-done-inner > p,
  .signup-done-inner > a {
    font-size: 14px;
  }

  .signup-done-inner .flow-result-card > :is(.flow-result-sub, p.flow-result-inquiry) {
    font-size: 12px;
  }

  .signup-done-inner .flow-result-card .flow-result-main {
    font-size: 16px;
  }

  .signup-done-inner .fc-fee-promo {
    padding: 18px 18px 20px;
  }

  .signup-done-inner .fc-fee-promo > p:first-child {
    font-size: 14px;
  }

  .signup-done-inner .fc-fee-promo > p + p {
    font-size: 16px;
  }

  .signup-done-inner .fc-fee-promo-pill {
    font-size: 13px;
    margin-left: 8px;
    padding: 4px 10px 5px;
  }
}

/* FC 회원가입 흐름 — layout: .layout-wrapper.form-page.signup-page (MFC008*, MFC005_L01_01) */
.signup-page main > form {
  margin: 0;
  padding: 0;
  background: var(--bg);
  border: none;
  border-radius: 0;
  box-shadow: none;
  box-sizing: border-box;
}
.signup-page .signup-step-lead {
  margin: 24px 0 30px 0;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  color: var(--text-sub);
}

/* 회원가입 · .c-tabs 기본은 common.css */

.signup-page .c-tabs {
  display: flex;
  margin-bottom: 18px;
  border: 1px solid #e5e7eb;
}

.signup-page .c-tabs > a {
  flex: 1;
  min-height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px 8px;
  font-size: 13px;
  font-weight: 500;
  color: #6b7280;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color 0.2s ease,
    color 0.2s ease;
}

.signup-page .c-tabs > a:hover {
  color: var(--text-sub);
  background: var(--bg-sub);
}

.signup-page .c-tabs > a[aria-current='page'] {
  color: var(--bg);
  background: #111827;
}

/* MFC008: 동의 블록 리드는 탭과 마진 상쇄 안 됨 → padding-top으로 타 단계와 동일 간격 */
.signup-page main > form > fieldset,
.signup-page main > form > .signup-agree {
  padding-top: 6px;
}

.signup-page main > form > fieldset > .signup-step-lead:first-child,
.signup-page main > form > .signup-agree > .signup-step-lead:first-child {
  margin-top: 0;
}

.signup-page main > form > p {
  margin: 8px 0 20px;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.5;
  color: var(--text);
}

.signup-page main > form > p span {
  color: var(--danger);
}

.signup-page .fc-profile-thumb {
  display: flex;
  justify-content: center;
  margin: 36px 0;
}

.signup-page .fc-profile-thumb > button {
  position: relative;
  width: 88px;
  height: 88px;
  padding: 0;
  border: none;
  border-radius: 50%;
  overflow: visible;
  background: var(--border);
  cursor: pointer;
}

.signup-page .fc-profile-thumb > button > img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  pointer-events: none;
}

.signup-page .fc-profile-thumb > button::after {
  content: '';
  position: absolute;
  right: 0px;
  bottom: 0px;
  z-index: 1;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid var(--border-strong);
  background-color: var(--bg);
  background-image: linear-gradient(var(--text-muted), var(--text-muted)), linear-gradient(var(--text-muted), var(--text-muted));
  background-size:
    10px 2px,
    2px 10px;
  background-position: center, center;
  background-repeat: no-repeat;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
  pointer-events: none;
}

.signup-page .fc-profile-thumb > button:hover::after,
.signup-page .fc-profile-thumb > button:focus-visible::after {
  border-color: var(--focus-border);
  background-color: var(--bg-sub);
  background-image: linear-gradient(var(--text-sub), var(--text-sub)), linear-gradient(var(--text-sub), var(--text-sub));
}

.signup-page main form > div > input + input {
  margin-top: 8px;
}

.signup-page .form-inline {
  display: flex;
  align-items: center;
  gap: 8px;
}

.signup-page .form-inline > * {
  flex: 1;
  min-width: 0;
}

.signup-page .form-inline:not(.time-range) > input:first-of-type {
  flex: 1.35 1 0;
  min-width: 7.5em;
}

.signup-page .time-range > span {
  flex: 0 0 auto;
  font-size: 15px;
  color: var(--text-muted);
}

.signup-page .file-upload .proof-mode {
  margin: 0 0 10px;
  padding: 0;
  border: none;
}

.signup-page .file-upload .proof-mode > legend {
  display: block;
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-sub);
}

.signup-page .file-upload .proof-mode > p {
  margin: 0px 0 8px;
  font-size: 14px;
  color: var(--text-muted);
}

.signup-page .file-upload .proof-mode > label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0 18px 8px 0;
  font-weight: 500;
  color: var(--text-sub);
  cursor: pointer;
}

.signup-page .file-upload .proof-mode > label:last-of-type {
  margin-right: 0;
}

.signup-page .file-upload .proof-panels {
  margin-top: 4px;
}

.signup-page .file-upload .proof-sets {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.signup-page .file-upload .proof-sets > div {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
}

.signup-page .file-upload .proof-sets > div > input {
  box-sizing: border-box;
  width: 100%;
  height: 50px;
  padding: 0 16px;
  line-height: 1.4;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-family: inherit;
}

.signup-page .file-upload .proof-sets > div > input::placeholder {
  color: var(--text-placeholder);
}

.signup-page .file-upload .proof-sets > div > input:focus {
  outline: none;
  border-color: var(--focus-border);
  box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.2);
}

.signup-page .file-upload .proof-sets > div > div,
.signup-page .file-upload > div {
  display: flex;
  align-items: center;
  gap: 8px;
}

.signup-page .file-upload .proof-sets > div > div > input[readonly],
.signup-page .file-upload > div > input[readonly] {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
  height: 50px;
  padding: 0 16px;
  line-height: 1.4;
  color: var(--text-muted);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: inherit;
  cursor: default;
}

.signup-page .file-upload .proof-sets > div > div > input[type='text']:not([readonly]) {
  flex: 1;
  min-width: 0;
  box-sizing: border-box;
  height: 50px;
  padding: 0 16px;
  line-height: 1.4;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  font-family: inherit;
}

.signup-page .file-upload .proof-sets > div > div > input[type='text']:not([readonly])::placeholder {
  color: var(--text-placeholder);
}

.signup-page .file-upload .proof-sets > div > div > input[type='text']:not([readonly]):focus {
  outline: none;
  border-color: var(--focus-border);
  box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.2);
}

.signup-page .file-upload .proof-sets input[name='proof_link_url'] {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.signup-page .file-upload .proof-sets > div > div > input[readonly]::placeholder,
.signup-page .file-upload > div > input[readonly]::placeholder {
  color: var(--text-placeholder);
}

.signup-page .file-upload .proof-sets > div > div > input[readonly]:focus,
.signup-page .file-upload > div > input[readonly]:focus {
  box-shadow: none;
  border-color: var(--border);
}

.signup-page .file-upload .proof-sets > div > div > button,
.signup-page .file-upload > div > button {
  flex: 0 0 auto;
  height: 50px;
  padding: 0 14px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  border: 1px solid var(--border-strong);
  border-radius: 8px;
  background: var(--bg);
}

.signup-page .file-upload > div > button {
  box-sizing: border-box;
  flex: 0 0 104px;
  width: 104px;
  min-width: 104px;
  white-space: nowrap;
}

.signup-page .form-box hr {
  margin: 24px 0;
  border: 0;
  border-top: 1px solid var(--border);
}

.signup-page .story-guide {
  margin-top: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-sub);
}

.signup-page .story-guide > p:first-of-type {
  margin: 0 0 8px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--text-muted);
}

.signup-page .story-guide > p:first-of-type strong {
  display: block;
  margin-bottom: 4px;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-sub);
  letter-spacing: -0.01em;
}

.signup-page .story-guide > ul {
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg-sub);
}

.signup-page .story-guide > ul li {
}

.signup-page .story-guide > ul li:last-child {
  margin-bottom: 0;
}

.signup-page .story-guide > p:last-of-type {
  color: var(--focus-border);
}

.signup-page .story-guide-emphasis {
  font-weight: 700;
  font-style: normal;
  color: var(--text);
}

/* MFC008_04 · 활동 스토리 이미지 썸네일 영역 */
.signup-page .fc-story-thumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

.signup-page .fc-story-thumb-main {
  box-sizing: border-box;
  width: 116px;
  height: 116px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.signup-page .fc-story-thumb-main > img {
  display: block;
  width: 48px;
  height: 48px;
  object-fit: contain;
  opacity: 0.88;
}

.signup-page .fc-story-thumb-add {
  box-sizing: border-box;
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #dbeafe;
  color: var(--primary);
  font-size: 22px;
  font-weight: 400;
  cursor: pointer;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.signup-page .fc-story-thumb-add:hover {
  background: #bfdbfe;
  color: var(--primary-hover);
}

.signup-page .fc-story-thumb-add:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

@media (max-width: 640px) {
  .signup-page .fc-story-thumb-main {
    width: 108px;
    height: 108px;
  }
}

/* -------------------------------------------------------------------------- */
/* MFC003_02 · 상담 요청 */
/* -------------------------------------------------------------------------- */

.consult-request {
  width: 100%;
  max-width: 500px;
  margin: 0 auto;
}

/* MFC005_L01_02 · 타이틀 + 승인 요청 현황(버튼형 링크, 공통 .btn.btn-line.btn-sm) 세로 배치 */
.consult-request > .section-head {
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}
.consult-request > .section-head .page-main-title {
  margin-bottom: 8px;
}
.consult-request > .section-head > .btn {
  align-self: flex-start;
}

.consult-request > .link-end {
  margin: 0 0 22px;
  text-align: right;
}

/* -------------------------------------------------------------------------- */
/* MFC005_L01_02_L02 · 승인 거부 사유 */
/* -------------------------------------------------------------------------- */

/* MFC005_L01_02_L02/L03/L04 · 거부 사유(.form-textarea) 본문 패딩 — L02·L04 readonly, L03 입력(높이 규칙은 :not([readonly])) */
.c-modal .c-modal-body:has(textarea.form-textarea) {
  padding: 16px 20px;
}

/* L03 상담 거부: 입력용 textarea만 높이·스크롤 보강 */
.c-modal .c-modal-body textarea.form-textarea:not([readonly]) {
  min-height: 140px;
  max-height: 220px;
  resize: vertical;
  box-sizing: border-box;
}

.consult-request-fc {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #f3f4f6;
}

.consult-request-fc > img {
  width: 90px;
  height: 90px;
  border-radius: 8px;
  object-fit: cover;
}

.consult-request-fc > div > h2 {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 700;
}

.consult-request-fc > div > p {
  margin: 0 0 4px;
  font-size: 15px;
  line-height: 1.45;
  color: var(--text-muted);
}

.consult-request-fc > div > p:last-child {
  margin-bottom: 0;
}

.consult-request-fc > div > p:nth-of-type(2) {
  font-size: 14px;
  color: var(--text-muted);
}

.consult-request-fc > div > p:nth-of-type(3) {
  color: var(--text-sub);
}

.consult-request form {
  margin-top: 16px;
}

/* 공통 날짜 선택기 — .consult-date 래퍼 + .consult-date-picker 패널 (페이지 스코프 없음) */
.consult-date {
  position: relative;
}

.consult-date > input {
  cursor: pointer;
}

.consult-date-picker {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 20;
  width: 100%;
  padding: 30px 20px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bg);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12);
  box-sizing: border-box;
}

.consult-date-picker-head {
  display: grid;
  grid-template-columns: 30px 1fr 30px;
  align-items: center;
  margin-bottom: 10px;
}

.consult-date-picker-head > strong {
  font-size: 15px;
  font-weight: 700;
  text-align: center;
  color: var(--text);
}

.consult-date-picker-nav {
  width: 30px;
  height: 30px;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff url('/assets/images/ic-chevron-left.svg') center / 14px 14px no-repeat;
}

.consult-date-picker-nav.next {
  transform: rotate(180deg);
}

.consult-date-picker-week,
.consult-date-picker-days {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 4px;
}

.consult-date-picker-week {
  margin: 0 0 4px;
}

.consult-date-picker-week > li {
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: var(--focus-border);
  line-height: 28px;
}

.consult-date-picker-day {
  height: 34px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.consult-date-picker-day.is-offset {
  color: #cbd5e1;
}

.consult-date-picker-day.is-today {
  border-color: #bfdbfe;
  color: var(--primary);
}

.consult-date-picker-day.is-selected {
  background: var(--primary);
  color: var(--bg);
}

.consult-request .consult-request-read {
  margin-bottom: 10px;
  padding: 20px 0 0;
}

.consult-request .consult-request-read p {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 10px;
  margin: 0 0 10px;
}

.consult-request .consult-request-read p:last-child {
  margin-bottom: 0;
}

.consult-request .consult-request-read p > span {
  font-weight: 600;
  color: var(--text-sub);
}

.consult-request .consult-request-read p > strong {
  font-weight: 700;
  color: #374151;
}

.consult-request .consult-request-edit {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  margin: 2px 0 14px;
  padding: 0 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  border: 1px solid var(--border-strong);
  border-radius: 7px;
  background: #fff;
  margin-left: auto;
}

.consult-request .consult-file-load-btn {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 52px;
  margin: 12px auto 0;
  padding: 0 18px;
  font-size: 16px;
  font-weight: 600;
  color: #1f2937;
  border: 1px solid var(--border-strong);
  border-radius: 11px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.08);
}

.consult-request .consult-file-load-btn::before {
  content: '';
  width: 14px;
  height: 14px;
  background: url('/assets/images/ic-detail-link-clip.svg') center / 14px 14px no-repeat;
  opacity: 0.8;
}

.consult-request .consult-file-load-btn:hover {
  border-color: #6b7280;
  background: var(--bg-sub);
}

.consult-request .consult-file-load-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.c-modal.sm:not(:has(.c-modal-head)) .c-modal-close {
  top: 12px;
  right: 12px;
}

.c-modal.sm .c-modal-body {
  padding: 54px 20px 14px;
  text-align: center;
}

.c-modal.sm .c-modal-body .modal-text {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: #3f4d63;
}

.c-modal.sm:not(:has(.c-modal-head)) .c-modal-foot {
  border-top: none;
  padding: 14px 20px 20px;
}

.c-modal.sm:not(:has(.c-modal-head)) .c-modal-btns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

@media (max-width: 640px) {
  .consult-request-fc {
    gap: 10px;
    padding: 12px;
    border-radius: 10px;
  }

  .consult-request-fc > img {
    width: 72px;
    height: 72px;
    border-radius: 8px;
  }

  .consult-request-fc > div > h2 {
    margin-bottom: 3px;
    font-size: 15px;
  }

  .consult-request-fc > div > p {
    margin-bottom: 3px;
    font-size: 13px;
    line-height: 1.4;
  }

  .consult-request-fc > div > p:nth-of-type(2) {
    font-size: 12px;
  }

  .consult-request .consult-file-load-btn {
    min-height: 40px;
    margin-top: 10px;
    font-size: 15px;
  }
}

.signup-page .file-upload > button {
  display: block;
  width: 24px;
  height: 24px;
  margin: 10px auto 0;
  border: none;
  border-radius: 50%;
  background: #dbeafe;
  color: var(--primary);
  font-size: 18px;
  line-height: 24px;
}

.signup-page .file-upload > button::before {
  content: '+';
}

@media (max-width: 640px) {
  .signup-page .c-tabs {
    overflow-x: auto;
  }

  .signup-page .c-tabs > a {
    flex: 0 0 auto;
    min-width: 96px;
    font-size: 13px;
  }

  .signup-page .signup-step-lead {
    margin-bottom: 14px;
  }
}

/* -------------------------------------------------------------------------- */
/* MFC006_01 · 로그인 */
/* -------------------------------------------------------------------------- */
.form-box .login-remember {
  margin: 6px 0 4px;
}
.form-box .login-remember label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 15px;
  font-weight: 500;
  color: var(--text-sub);
  cursor: pointer;
}

.form-page.account-find-page main .form-box {
  margin: 0;
  padding: 26px 22px 28px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 10px 40px -12px rgba(15, 23, 42, 0.08);
}
.form-box > .form-actions:last-of-type {
  margin-bottom: 0;
}
.form-box .login-or {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 22px 0;
  font-size: 13px;
  color: var(--text-sub);
}
.form-box .login-or::before,
.form-box .login-or::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.form-box .login-secondary {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  min-height: 52px;
  margin: 0;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--text);
  text-decoration: none;
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: 12px;
  cursor: pointer;
  font-family: inherit;
  transition:
    background-color 0.2s ease,
    border-color 0.2s ease;
}
.form-box .login-secondary:hover {
  background: var(--bg-sub);
  border-color: var(--focus-border);
}
.form-box .login-secondary:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.form-box .login-reset,
.form-page main .page-inner-narrow > .login-reset {
  margin: 20px 0 0;
  text-align: center;
  font-size: 14px;
  line-height: 1.5;
}
.form-box .login-reset a,
.form-page main .page-inner-narrow > .login-reset a {
  color: var(--text-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.form-box .login-reset a:hover,
.form-page main .page-inner-narrow > .login-reset a:hover {
  color: var(--text-sub);
}
.form-box .login-reset a:focus-visible,
.form-page main .page-inner-narrow > .login-reset a:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 4px;
}

/* MFC004_L01_02 · 내 증권 관리 */

.securities-page .securities-files {
  margin: 0;
}

.securities-page .securities-files > li + li {
  margin-top: 8px;
}

.securities-page .securities-row {
  position: relative;
}

.securities-page .securities-file {
  width: 100%;
  min-height: 44px;
  padding: 12px 44px 12px 42px;
  text-align: left;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.4;
  color: #374151;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: var(--bg-sub);
  background-image: url('/assets/images/ic-detail-download.svg');
  background-repeat: no-repeat;
  background-position: 14px center;
  background-size: 16px 16px;
  font-family: inherit;
  cursor: pointer;
  transition:
    border-color 0.2s ease,
    background-color 0.2s ease;
}

.securities-page .securities-file:hover {
  border-color: var(--border-strong);
  background-color: var(--bg-elevated);
}

.securities-page .securities-file.is-selected {
  border-color: #93c5fd;
  background-color: #eff6ff;
}

.securities-page .securities-file:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.securities-page .securities-remove {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background-color: transparent;
  background-image: url('/assets/images/ic-close.svg');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px 18px;
  cursor: pointer;
  z-index: 2;
}

.securities-page .securities-remove:hover {
  background-color: rgba(15, 23, 42, 0.06);
}

.securities-page .securities-remove:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.securities-page .securities-add-wrap {
  margin: 12px 0 0;
  text-align: center;
}

.securities-page .securities-add {
  width: 24px;
  height: 24px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: #dbeafe;
  color: var(--primary);
  font-size: 18px;
  line-height: 1;
  font-family: inherit;
  cursor: pointer;
}

.securities-page .securities-add::before {
  content: '+';
}

.securities-page .securities-add:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.securities-page .securities-submit {
  width: 100%;
  min-height: 52px;
  margin-top: 26px;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 700;
  color: var(--bg);
  background: var(--primary);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  font-family: inherit;
}

.securities-page .form-actions > .securities-submit {
  margin-top: 0;
}

.securities-page .securities-submit:hover {
  background: var(--primary-hover);
}

.securities-page .securities-submit:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* MFC004_L01_03 · 내 관심 FC */

.favorite-page .bookmark-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f3f4f6;
  font-size: 14px;
  font-weight: 600;
  color: #1f2937;
  box-sizing: border-box;
}

.favorite-page .bookmark-box > span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 16px;
}

.favorite-page .bookmark-box > span img {
  width: 18px;
  height: 18px;
}

.favorite-page .bookmark-box > strong {
  font-size: 14px;
  color: #374151;
}

.favorite-page .favorite-empty,
.consult-status-page .consult-empty {
  text-align: center;
  font-size: 14px;
  line-height: 1.65;
  letter-spacing: -0.01em;
}

.favorite-page .favorite-empty {
  margin: 12px 0 0;
  padding: 24px 16px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: var(--bg-sub);
  color: var(--text-sub);
}

.favorite-page .recommend-list-head {
  display: flex;
  justify-content: flex-end;
  margin: 16px 0 12px;
}

@media (max-width: 640px) {
  .favorite-page .page-inner {
    max-width: 100%;
  }
}

/* MFC004_L01_04 · 상담 현황 */
/* MFC005_L01_03 · 상담 신청 관리 — 검색 + 탭 + 목록(.fc-consult-mgmt · .consult-empty) */
.consult-status-page.fc-consult-mgmt .recommend-list-head {
  display: flex;
  justify-content: flex-end;
  margin: 12px 0 12px;
}

.consult-status-page .consult-search-form {
  margin: 0 0 18px;
}

.consult-status-page .consult-empty {
  margin: 16px 0 0;
  padding: 36px 12px;
  color: var(--focus-border);
}

.consult-status-page .consult-empty > p {
  margin: 0;
}

.consult-status-page .consult-empty > p + p {
  margin-top: 10px;
}

@media (max-width: 640px) {
  /* MFC004_L01_05 · 푸터 포함 페이지: main 최소높이로 생기는 하단 공백 제거 */
  .layout-wrapper.consult-status-page > main {
    min-height: auto;
  }
}

/* MFC005_L01_03 · 고객 연락처 — .fc-consult-mgmt 범위만 */
.consult-status-page.fc-consult-mgmt .recommend-list .profile {
  gap: 12px;
}

.consult-status-page.fc-consult-mgmt .consult-contact {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  font-weight: 500;
  color: var(--text-muted);
  word-break: break-all;
}

.consult-status-page.fc-consult-mgmt .recommend-list .profile-name {
  margin-top: 10px;
  margin-bottom: 6px;
}

.consult-status-page.fc-consult-mgmt .recommend-list .consult-contact + .consult-contact {
  margin-top: 4px;
}

.consult-status-page.fc-consult-mgmt .consult-card-hit {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
  text-align: inherit;
  text-decoration: none;
  box-sizing: border-box;
  cursor: pointer;
}

.consult-status-page.fc-consult-mgmt .consult-card-hit:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 8px;
}

.consult-status-page.fc-consult-mgmt .consult-card-hit:hover .profile-name {
  color: var(--primary);
}

.consult-status-page .page-inner {
  max-width: 1024px;
}

.consult-status-page .c-tabs {
  margin: 0 0 18px;
  border: 1px solid var(--border-strong);
}

.consult-status-page .c-tabs > button {
  height: 34px;
  padding: 0 14px;
  border: none;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-sub);
  font-family: inherit;
}

.consult-status-page .c-tabs > button[aria-selected='true'] {
  color: var(--text);
  background: var(--bg-sub);
}

/* 공통: Swiper Grid 모듈 없이 한 슬라이드 안 2×2 (DOM 순서 = 표시 순서) */
.swiper-page-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: 100%;
  min-width: 0;
  flex: 1 1 auto;
  align-self: stretch;
}

.favorite-page .recommend-list-swiper .swiper-slide {
  display: flex;
  flex-direction: column;
  align-self: flex-start;
}

/* 슬라이드별 카드 수가 다를 때(예: 4 vs 1) 짧은 슬라이드가 첫 슬라이드 높이로 늘어나 카드가 세로로 늘어나는 현상 방지 */
.favorite-page .recommend-list .swiper-wrapper {
  align-items: flex-start;
}

.favorite-page .recommend-list-swiper .swiper-slide > .swiper-page-grid {
  flex: 0 1 auto;
}

/* MFC005_L01_03 · Swiper 목록 — content 그리드와 충돌 방지 */
.consult-status-page.fc-consult-mgmt .recommend-list.swiper {
  display: block;
  margin-top: 0;
  overflow: hidden;
  touch-action: pan-x pinch-zoom;
  cursor: grab;
  user-select: none;
}

.consult-status-page.fc-consult-mgmt .recommend-list.swiper:active {
  cursor: grabbing;
}

.consult-status-page.fc-consult-mgmt .recommend-list-swiper .swiper-slide {
  display: flex;
  flex-direction: column;
  align-self: flex-start;
  height: auto;
  box-sizing: border-box;
}

.consult-status-page.fc-consult-mgmt .recommend-list .swiper-wrapper {
  align-items: flex-start;
}

.consult-status-page.fc-consult-mgmt .recommend-list-swiper .swiper-slide > .swiper-page-grid {
  flex: 0 1 auto;
}

.consult-status-page.fc-consult-mgmt .swiper-page-grid > .card {
  flex: 1 1 auto;
  max-width: 100%;
  min-width: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 212px;
  background-color: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.consult-status-page .recommend-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: 100%;
  margin-top: 12px;
  border-radius: 10px;
  box-sizing: border-box;
  cursor: default;
  user-select: auto;
  touch-action: auto;
  overflow: visible;
  align-items: stretch;
}

.consult-status-page .recommend-list > .card {
  min-width: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 212px;
  background-color: var(--bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.06);
  overflow: hidden;
}

.consult-status-page .recommend-list .card-body {
  position: relative;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.consult-status-page .recommend-list .card-link {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 10px;
  min-height: 0;
  width: 100%;
  box-sizing: border-box;
}

/* 버튼 없을 때도 일자가 태그 바로 아래에 오도록 — main의 .profile flex 성장 비활성화 */
.consult-status-page .recommend-list .card .profile {
  flex: 0 0 auto;
}

.consult-status-page .recommend-list .card .profile > div {
  flex: 0 0 auto;
  justify-content: flex-start;
}

.consult-status-page .recommend-list .date {
  margin: 4px 0 0;
  font-size: 13px;
  font-weight: 500;
  text-align: center;
  color: #6b7280;
}

/* 상담 상태 — 카드 왼쪽 상단 코너 뱃지 */
.consult-status-page .recommend-list .badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  margin: 0;
  max-width: calc(100% - 20px);
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  text-align: center;
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.consult-status-page .recommend-list .badge.pending {
  color: var(--primary-hover);
  background: #eff6ff;
  border: 1px solid #bfdbfe;
}

.consult-status-page .recommend-list .badge.done {
  color: #15803d;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
}

.consult-status-page .recommend-list .badge.reject {
  color: #dc2626;
  background: #fef2f2;
  border: 1px solid #fecaca;
}

.consult-status-page .recommend-list a.consult-status-action,
.consult-status-page .recommend-list .consult-status-action {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  min-height: 40px;
  margin-top: auto;
  padding: 0 12px;
  border: none;
  border-radius: 10px;
  background: var(--primary);
  color: var(--bg);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  text-decoration: none;
}

.consult-status-page .recommend-list .consult-status-action:disabled {
  background: #e5e7eb;
  color: var(--focus-border);
}

.consult-status-page .recommend-list a.consult-status-action:focus-visible,
.consult-status-page .recommend-list .consult-status-action:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.consult-status-page .recommend-list a.consult-status-action:hover {
  background: var(--primary-hover);
  color: var(--bg);
}

@media (max-width: 640px) {
  .consult-status-page .c-tabs {
    display: flex;
    width: 100%;
  }

  .consult-status-page .c-tabs > button {
    flex: 1;
    min-width: 0;
    font-size: 13px;
    padding: 0 8px;
  }

  .consult-status-page .recommend-list {
    grid-template-columns: 1fr;
  }
}

/* 폼 내 대시 목록 안내 — 회원 탈퇴(MFC004)·심의필(MFC005) 등 공통 */
.form-box > section.dash-notice {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid #e5e7eb;
}
.form-box > section.dash-notice > h2 {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}

/* MFC004_L01_01_01 · 회원 탈퇴 */
.form-page.withdraw-page .form-box > button[type='button'],
.form-page.withdraw-page .form-box > .form-actions > button[type='button'] {
  width: 100%;
  min-height: 52px;
  margin-top: 12px;
  padding: 14px 20px;
  font-size: 16px;
  font-weight: 700;
  color: var(--bg);
  background: var(--primary);
  border: none;
  border-radius: 12px;
}
.form-page.withdraw-page .form-box > button[type='submit'],
.form-page.withdraw-page .form-box > .form-actions > button[type='submit'] {
  margin-top: 8px;
}

.form-page.withdraw-page .form-box > .form-actions > button[type='button']:first-of-type {
  margin-top: 0;
}

/* 요약 카드 — 계정 찾기 등 div.flow-result-card */
.signup-done-inner .flow-result-card {
  margin-top: 28px;
  padding: 20px 20px 22px;
  text-align: center;
  background: linear-gradient(180deg, var(--bg-sub) 0%, var(--bg-elevated) 100%);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-sizing: border-box;
}

@media (max-width: 640px) {
  .signup-done-inner .flow-result-card {
    margin-top: 18px;
  }
}

.signup-done-inner .flow-result-card .flow-result-sub {
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 600;
  line-height: 1.45;
  letter-spacing: -0.02em;
  color: var(--text-muted);
}

.signup-done-inner .flow-result-card .flow-result-main {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  line-height: 1.45;
  color: var(--text);
}

.signup-done-inner:has(.flow-result-card) > a {
  margin-top: 28px;
}

.signup-done-inner .flow-result-card .warn {
  font-weight: 700;
  color: var(--danger);
}

.signup-done-inner .flow-result-card > p.flow-result-inquiry {
  margin: 20px 0 0;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  font-size: 14px;
  font-weight: 500;
  line-height: 1.55;
  color: var(--text-muted);
}

.signup-done-inner .flow-result-card > p.flow-result-inquiry a {
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
}

.signup-done-inner .flow-result-card > p.flow-result-inquiry a:hover {
  text-decoration: underline;
}

@media (max-width: 640px) {
  .signup-done-inner .flow-result-card .flow-result-sub,
  .signup-done-inner .flow-result-card > p.flow-result-inquiry {
    font-size: 14px;
  }

  .signup-done-inner .flow-result-card .flow-result-main {
    font-size: 16px;
  }
}

/* -------------------------------------------------------------------------- */
/* MFC005_L01_03_01 · 고객 상담 요청 상세 */
/* -------------------------------------------------------------------------- */

.consult-detail-page .consult-request .consult-request-read p {
  grid-template-columns: minmax(96px, 42%) minmax(0, 1fr);
  gap: 12px 18px;
  align-items: start;
}

.consult-detail-page .consult-request .consult-request-read p > span {
  line-height: 1.45;
  word-break: keep-all;
}

.consult-detail-page .consult-request .form-field > .form-textarea[readonly] {
  margin-top: 4px;
  background: #f0f4f8;
  border-color: var(--border);
  color: #374151;
}

.consult-detail-page .consult-detail-file-list {
  margin: 0;
}

.consult-detail-page .consult-detail-file-list > li + li {
  margin-top: 10px;
}

.consult-detail-page .consult-detail-file-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg-sub);
  color: var(--text);
  font-size: 14px;
  line-height: 1.4;
  text-decoration: none;
  box-sizing: border-box;
  word-break: break-all;
}

.consult-detail-page .consult-detail-file-link:hover {
  border-color: #cbd5e1;
  background: var(--bg-elevated);
}

.consult-detail-page .consult-detail-file-link:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.consult-detail-page .consult-detail-file-link img {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  opacity: 0.85;
}

.ad-mgmt-page .ad-mgmt-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 12px 16px;
  margin-bottom: 56px;
}

.ad-mgmt-page .ad-mgmt-head-spacer {
  min-width: 0;
  pointer-events: none;
}

.ad-mgmt-page .ad-mgmt-head .page-main-title {
  margin: 0;
  justify-self: center;
  text-align: center;
}

.ad-mgmt-page .ad-mgmt-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px 16px;
  flex-wrap: wrap;
  margin: 0 0 14px;
}

.ad-mgmt-page .ad-mgmt-head-actions {
  flex-shrink: 0;
  min-width: 0;
}

.ad-mgmt-page .ad-mgmt-updated {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 0;
  flex: 1 1 auto;
  min-width: 0;
  font-size: 13px;
  line-height: 1.4;
  color: #6b7280;
}

.ad-mgmt-page .ad-mgmt-updated-refresh {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 4px;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  flex-shrink: 0;
  vertical-align: middle;
}

.ad-mgmt-page .ad-mgmt-updated-refresh:hover .ad-mgmt-updated-ico {
  color: var(--text-muted);
}

.ad-mgmt-page .ad-mgmt-updated-refresh:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.ad-mgmt-page .ad-mgmt-updated-ico {
  display: inline-flex;
  color: var(--text-placeholder);
}

.ad-mgmt-page .ad-mgmt-table-wrap {
  overflow-x: auto;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: var(--bg);
  -webkit-overflow-scrolling: touch;
}

.ad-mgmt-page .ad-mgmt-table-wrap table {
  width: 100%;
  min-width: 520px;
  border-collapse: collapse;
  table-layout: fixed;
}

.ad-mgmt-page .ad-mgmt-table-wrap thead th {
  padding: 12px 10px;
  border-bottom: 1px solid #e5e7eb;
  background: #f9fafb;
  font-size: 14px;
  font-weight: 700;
  color: #374151;
  text-align: center;
  white-space: nowrap;
}

.ad-mgmt-page .ad-mgmt-table-wrap tbody td {
  padding: 14px 10px;
  border-bottom: 1px solid var(--bg-elevated);
  font-size: 14px;
  color: #1f2937;
  text-align: center;
  vertical-align: middle;
}

.ad-mgmt-page .ad-mgmt-table-wrap tbody td:first-child {
  font-weight: 500;
}

.ad-mgmt-page .ad-mgmt-table-wrap tbody td:nth-child(3),
.ad-mgmt-page .ad-mgmt-table-wrap tbody td:nth-child(4) {
  font-variant-numeric: tabular-nums;
  text-align: center;
}

.ad-mgmt-page .ad-mgmt-table-wrap tbody td:nth-child(5) {
  font-size: 13px;
  color: #4b5563;
  white-space: nowrap;
}

.ad-mgmt-page .ad-mgmt-table-wrap tbody tr:last-child td {
  border-bottom: 0;
}

.ad-mgmt-page .ad-status.on {
  font-weight: 600;
  color: var(--primary);
}

.ad-mgmt-page .ad-mgmt-table-wrap + .c-paging {
  margin-top: 20px;
  padding-bottom: 4px;
}

.ad-mgmt-page .ad-status.end {
  font-weight: 500;
  color: var(--text-placeholder);
}

@media (max-width: 480px) {
  .ad-mgmt-page .ad-mgmt-head {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .ad-mgmt-page .ad-mgmt-head-spacer {
    display: none;
  }

  .ad-mgmt-page .ad-mgmt-head .page-main-title {
    text-align: center;
  }

  .ad-mgmt-page .ad-mgmt-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .ad-mgmt-page .ad-mgmt-toolbar .ad-mgmt-head-actions .btn {
    width: 100%;
    justify-content: center;
  }
}

/* MFC005_L01_04_01 · 광고 신청 */
.fc-ad-apply-page .ad-apply-tabs-scroll {
  margin-bottom: 24px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.fc-ad-apply-page .ad-apply-tabs {
  width: 100%;
  min-width: min-content;
  margin-bottom: 0;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
}

.fc-ad-apply-page .ad-apply-tabs > button,
.fc-ad-apply-page .ad-apply-tabs > a {
  flex: 1 1 0;
  min-width: 0;
  min-height: 40px;
  padding: 8px 6px;
  border: none;
  border-right: 1px solid #e5e7eb;
  background: #f3f4f6;
  font-size: 11px;
  font-weight: 600;
  font-family: inherit;
  color: var(--text-placeholder);
  white-space: nowrap;
  text-decoration: none;
  box-sizing: border-box;
}

.fc-ad-apply-page .ad-apply-tabs > button:last-child,
.fc-ad-apply-page .ad-apply-tabs > a:last-child {
  border-right: none;
}

.fc-ad-apply-page .ad-apply-tabs > button[aria-selected='true'],
.fc-ad-apply-page .ad-apply-tabs > a[aria-selected='true'] {
  background: #111827;
  color: var(--bg);
}

.fc-ad-apply-page .directory-select .is-placeholder {
  color: var(--focus-border);
  font-weight: 400;
}

.fc-ad-apply-page .ad-apply-plan-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bg);
  box-sizing: border-box;
}

.fc-ad-apply-page .ad-apply-plan-row .c-radio {
  margin: 0;
  flex: 0 1 auto;
  min-width: 0;
  color: var(--text);
  font-weight: 500;
}

.fc-ad-apply-page .ad-apply-price {
  flex-shrink: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

@media (min-width: 400px) {
  .fc-ad-apply-page .ad-apply-tabs > button,
  .fc-ad-apply-page .ad-apply-tabs > a {
    padding: 10px 8px;
    font-size: 12px;
  }
}

@media (min-width: 640px) {
  .fc-ad-apply-page .ad-apply-tabs > button,
  .fc-ad-apply-page .ad-apply-tabs > a {
    font-size: 13px;
    padding: 10px 12px;
    min-height: 44px;
  }
}

.fc-ad-apply-page .form-field > .file-upload + .dash-list {
  margin-top: 12px;
}

.fc-ad-apply-page .form-field > .dash-list + .c-check {
  margin-top: 14px;
  margin-bottom: 20px;
}

.fc-ad-apply-page .form-field .c-check .warn {
  font-weight: 700;
  color: var(--danger);
}

/* 광고 신청 · 리뷰 선택 — MFC004_L01_05와 동일 후기 영역을 lg 모달에 표시 */
#popup-ad-review.c-modal.lg .c-modal-body {
  padding: 0 16px 4px;
  min-height: 0;
}

#popup-ad-review .detail-reviews > header {
  margin-top: 20px;
  margin-bottom: 10px;
}

#popup-ad-review .detail-reviews > header .section-head-right {
  margin-left: auto;
  flex-shrink: 0;
}

#popup-ad-review .detail-reviews-panel button.review-card.c-modal-option {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
  width: 100%;
  height: auto;
  min-height: 0;
  margin: 0;
  padding: 18px 16px 18px 40px;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  font: inherit;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

#popup-ad-review .detail-reviews-panel button.review-card.c-modal-option .c-modal-option-ico {
  position: absolute;
  top: 20px;
  left: 0;
  right: auto;
}

@media (max-width: 640px) {
  #popup-ad-review.c-modal.lg .c-modal-body {
    padding: 0 12px 4px;
  }

  #popup-ad-review .detail-reviews-panel button.review-card.c-modal-option {
    padding: 14px 0 14px 30px;
  }

  #popup-ad-review .detail-reviews-panel button.review-card.c-modal-option .c-modal-option-ico {
    top: 16px;
    left: 0;
  }

  #popup-ad-review .detail-reviews-panel .review-card-meta .c-rate,
  #popup-ad-review .detail-reviews-panel .review-card-meta .review-author,
  #popup-ad-review .detail-reviews-panel .review-card-meta .review-date {
    font-size: 14px;
  }

  #popup-ad-review .detail-reviews-panel .review-card h4 {
    margin-bottom: 6px;
    font-size: 16px;
  }

  #popup-ad-review .detail-reviews-panel .review-card-body {
    font-size: 14px;
    line-height: 1.58;
  }
}

/* 이용약관 전용 페이지 (MFC009) */
.layout-wrapper.terms-page .site-header > .header-mo > div > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin: -8px -8px -8px 0;
  color: var(--text-sub);
  text-decoration: none;
  border-radius: 8px;
}

.layout-wrapper.terms-page .terms-body {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 0 24px;
  line-height: 1.65;
  color: var(--text-sub);
}

.layout-wrapper.terms-page .terms-body > p {
  margin: 0 0 16px;
}

.layout-wrapper.terms-page .terms-body h3 {
  margin: 22px 0 10px;
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}

.layout-wrapper.terms-page .terms-body ul {
  margin: 0 0 12px;
  padding-left: 1.1em;
}

.layout-wrapper.terms-page .terms-body li {
  margin: 0 0 10px;
}

.layout-wrapper.terms-page .terms-body li:last-child {
  margin-bottom: 0;
}
