/*
 * 판례 브리프 상세 페이지 공통 스타일 (precedents/{slug}.html)
 *
 * 이 파일은 precedents 하위 모든 단일 판례형 상세 페이지가 공유합니다.
 * 디자인 토큰은 인덱스 페이지(precedents/index.html)와 일치시켜 패밀리 일관성을 유지.
 * 색상 변경 시 인덱스도 함께 검토 필요.
 */

* { margin: 0; padding: 0; box-sizing: border-box; }
:root {
  --primary: #256D85;
  --primary-dark: #183B56;
  --accent: #9A6B2F;
  --bg: #F7FAFC;
  --border: #DDE7EE;
  --text: #1A2332;
  --text-sub: #586B7A;
}
body { font-family: 'Noto Sans KR', sans-serif; background: var(--bg); color: var(--text); }
.article-wrap { max-width: 760px; margin: 0 auto; padding: 54px 24px 92px; }
.breadcrumb { color: #7A8B99; font-size: 13px; margin-bottom: 26px; }
.breadcrumb a { color: var(--primary); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.post-tag {
  display: inline-flex;
  align-items: center;
  min-height: 25px;
  border-radius: 999px;
  background: #E7F3F6;
  color: var(--primary);
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 700;
  margin-bottom: 16px;
}
h1 { font-size: 31px; font-weight: 700; line-height: 1.42; color: var(--primary-dark); margin-bottom: 12px; }
.post-meta { display: flex; flex-wrap: wrap; gap: 14px; color: #7A8B99; font-size: 13px; margin-bottom: 34px; }

/* 사건 메타 박스 — 사건번호·법원·선고일자 등 판례 고정 정보
   데스크톱: dt(라벨) 90px 고정 + dd(값) 1fr — 2쌍을 한 행에 배치 (총 4트랙)
   모바일: dt 78px + dd 1fr — 1쌍씩 한 행에 배치
   .full 모디파이어가 붙은 행은 데스크톱에서도 풀너비 (참조조문/참조판례처럼 긴 텍스트용) */
.case-meta {
  display: grid;
  grid-template-columns: 90px 1fr 90px 1fr;
  column-gap: 16px;
  row-gap: 9px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px 18px;
  margin: 4px 0 28px;
  font-size: 13.5px;
  line-height: 1.7;
}
.case-meta dt { color: #7A8B99; font-weight: 600; }
.case-meta dd { color: var(--text); word-break: keep-all; }
/* 긴 텍스트 행 — 한 줄 전체를 dt + dd 한 쌍이 사용 (참조조문/판례용) */
.case-meta dt.full { grid-column: 1 / 2; }
.case-meta dd.full { grid-column: 2 / -1; }

.summary-box {
  background: #fff;
  border: 1px solid var(--border);
  border-left: 4px solid var(--primary);
  border-radius: 0 8px 8px 0;
  padding: 20px 22px;
  margin: 0 0 36px;
}
.summary-box p { color: #374151; font-size: 14px; line-height: 1.85; margin: 0; }
.article-body h2 {
  color: var(--primary-dark);
  font-size: 20px;
  font-weight: 700;
  margin: 42px 0 14px;
  padding-left: 12px;
  border-left: 4px solid var(--primary);
}
.article-body h3 { color: var(--text); font-size: 16px; font-weight: 700; margin: 25px 0 9px; }
.article-body p { color: #374151; font-size: 15px; line-height: 1.9; margin-bottom: 15px; }
.article-body ul, .article-body ol { padding-left: 22px; margin-bottom: 16px; }
.article-body li { color: #374151; font-size: 15px; line-height: 1.85; margin-bottom: 4px; }
.case-table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
  border: 1px solid var(--border);
  margin: 18px 0 26px;
  font-size: 14px;
}
.case-table th, .case-table td { border: 1px solid var(--border); padding: 12px 14px; text-align: left; vertical-align: top; line-height: 1.75; }
.case-table th { width: 138px; background: #F1F6F8; color: var(--primary-dark); font-weight: 700; }
.practice-list {
  display: grid;
  gap: 10px;
  margin: 18px 0 24px;
}
.practice-list div {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 15px 16px;
  color: #374151;
  font-size: 14px;
  line-height: 1.8;
}
.notice {
  background: #FFF8EB;
  border: 1px solid #E7D3A8;
  border-radius: 8px;
  padding: 16px 18px;
  margin: 26px 0;
  color: #54412A;
  font-size: 13.5px;
  line-height: 1.85;
}

/* 출처 박스 — law.go.kr OPEN API 가이드라인상 표기 의무 */
.source-box {
  margin-top: 28px;
  padding: 14px 16px;
  background: #F1F6F8;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.7;
}
.source-box a { color: var(--primary); text-decoration: none; font-weight: 700; }
.source-box a:hover { text-decoration: underline; }

.post-nav { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 54px; }
.post-nav a {
  flex: 1;
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px 18px;
  color: var(--primary);
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
}
footer { border-top: 1px solid var(--border); }
@media (max-width: 768px) {
  .article-wrap { padding: 36px 18px 76px; }
  h1 { font-size: 24px; }
  .article-body h2 { font-size: 18px; margin-top: 34px; }
  .article-body p, .article-body li { font-size: 14.5px; }
  .case-table th, .case-table td { display: block; width: 100%; }
  .case-table th { border-bottom: 0; }
  /* 모바일에서는 dt 폭을 좁히고 1쌍씩 한 행에 배치 — .full 행도 동일 그리드 사용 */
  .case-meta {
    grid-template-columns: 78px 1fr;
    column-gap: 12px;
    row-gap: 7px;
  }
  .case-meta dt.full { grid-column: 1; }
  .case-meta dd.full { grid-column: 2; }
}
