/* ── 18. 폼 박스 (인증·수정 페이지용) ───────────────────── */
.form-box {
  background: #fff;
  border: 1px solid var(--color-gray-200);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
  max-width: 480px;
  margin: 0 auto;
}
.form-box-wide { max-width: 600px; }

/* ── 폼 박스: 좁은 폰에서 패딩 축소 ────────────────────────── */
@media (max-width: 479px) {
  .form-box { padding: var(--space-5); border-radius: var(--radius-lg); }
  .form-box-wide { padding: var(--space-5); }
}

/* ══════════════════════════════════════════════════════════
   28. 소셜 로그인 버튼 (카카오·네이버) — 인증 화면 전용
   ── 카카오/네이버 색은 각 사 공식 브랜드 색이라 식별성·신뢰를
      위해 네이비/골드 토큰의 예외로 그대로 사용. 나머지(여백·
      radius·높이·타이포)는 기존 .btn 토큰과 일관.
   ══════════════════════════════════════════════════════════ */

/* 구분선: "또는 SNS 계정으로 로그인" */
.social-divider {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: var(--space-6) 0;
  color: var(--color-gray-400);
  font-size: var(--font-size-sm);
  font-weight: 600;
}
.social-divider::before,
.social-divider::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--color-gray-200);
}

/* 소셜 버튼 묶음 */
.social-buttons {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

/* 공통 소셜 버튼 — 카카오/네이버 공식 가이드 준수.
   높이 48px, radius 12px(카카오 규정), 전체폭, 인라인 SVG 로고 + 라벨. */
.btn-social {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  min-height: 48px;
  padding: 0 var(--space-5);
  border: none;
  border-radius: 12px;            /* 카카오 공식 가이드: 모서리 radius 12px */
  font-size: var(--font-size-base);
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: filter 0.15s, box-shadow 0.15s, transform 0.05s;
}
.btn-social:hover { text-decoration: none; filter: brightness(0.96); }
.btn-social:active { transform: translateY(1px); }
.btn-social:focus-visible {
  outline: 2px solid var(--color-primary-500);
  outline-offset: 2px;
}

/* 좌측 공식 로고 SVG — 비율·색 보존(변형 금지). 라벨 왼쪽에 배치. */
.btn-social .social-mark {
  flex: 0 0 auto;
  display: block;
}

/* 카카오 — 공식 노랑 #FEE500 / 라벨 #000 opacity 85%.
   말풍선 심볼은 인라인 SVG(#000000)로 형태·비율·색 보존. */
.btn-kakao {
  background: #FEE500;
  color: rgba(0, 0, 0, 0.85);
}
.btn-kakao:hover { filter: brightness(0.97); }

/* 네이버 — 공식 그린(Naver Green) #03C75A / 라벨 #fff.
   N 로고는 인라인 SVG(#ffffff)로 가로세로 비율 보존. */
.btn-naver {
  background: #03C75A;
  color: #ffffff;
}
.btn-naver:hover { filter: brightness(0.95); }

/* 데스크탑·모바일 모두 폼 너비에 맞춘 전체폭(.btn-social width:100%).
   form-box 가 480/540px 폭이라 자연히 폼 너비에 정렬됨. */
@media (max-width: 480px) {
  .btn-social { min-height: 48px; }   /* 터치타깃 ≥44px 보장 */
  .social-divider { margin: var(--space-5) 0; }
}

/* ── reduced-motion 무시 정책: C·D·G 모든 추가 모션 항상 재생 (정지 규칙 제거) ── */

/* ════════════════════════════════════════════════════════
   29. 정책 문서 페이지 (개인정보처리방침 등)
   ════════════════════════════════════════════════════════ */
.policy-doc { text-align: left; }
.policy-section { margin-top: var(--space-8); }
.policy-section h2 {
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-primary-800);
  padding-bottom: var(--space-2);
  margin-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-gray-100);
}
.policy-section p { color: var(--color-gray-700); line-height: 1.75; margin-bottom: var(--space-3); }
.policy-section ul { margin: 0 0 var(--space-3) 1.1em; padding: 0; }
.policy-section li { color: var(--color-gray-700); line-height: 1.7; margin-bottom: var(--space-1); list-style: disc; }
.policy-section a { color: var(--color-primary-600); text-decoration: underline; }

/* 푸터 개인정보처리방침 링크 */
.footer-policy-link {
  color: var(--color-gray-200);
  text-decoration: underline;
  font-weight: 600;
}
.footer-policy-link:hover { color: #fff; }

/* 소셜 로그인 안내 문구 (네이버 검수 진행 중 등) — 연한 골드 톤, 브랜드 일관 */
.social-notice {
  margin-top: var(--space-3);
  padding: 10px 14px;
  background: #fff8e6;
  border: 1px solid #ffe39e;
  border-radius: 10px;
  color: var(--color-gray-700);
  font-size: 0.8rem;
  line-height: 1.55;
  text-align: center;
}
.social-notice b { color: var(--color-primary-800); font-weight: 700; }
