html, body {
  height: 100%;
  margin: 0;
}

body {
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;  /* ★ 메인이 남은 높이를 다 먹고, 푸터는 아래로 자동 배치 */
}

*{box-sizing:border-box}body{margin:0;font-family:Pretendard,system-ui,Segoe UI,Arial,sans-serif;line-height:1.55}
.wrap{max-width:960px;margin:0 auto;padding:16px}
header{border-bottom:1px solid #e5e7eb;background:#fafafa}
nav a{margin-right:12px;text-decoration:none;color:#2563eb}
nav a.right{float:right}
nav a:hover{text-decoration:underline}
.hero{padding:24px;background:#eef2ff;border:1px solid #c7d2fe;border-radius:12px;margin:12px 0}
.table{width:100%;border-collapse:collapse} .table th,.table td{border-bottom:1px solid #eee;padding:8px;text-align:left}
.field{display:flex;flex-direction:column;margin:8px 0} .field input,.field textarea{padding:8px;border:1px solid #ccc;border-radius:8px}
.btn{display:inline-block;padding:8px 12px;border:1px solid #2563eb;border-radius:10px;text-decoration:none}
.btn:hover{background:#2563eb;color:#fff}
.muted{color:#6b7280;font-size:12px}
.content{white-space:pre-wrap;padding:12px;border:1px solid #eee;border-radius:8px;background:#fff}

/* ===== Footer (PIPEASSET 레퍼런스 스타일) ===== */
.brand-footer {
  background: #f5f6f7;             /* 밝은 회색 배경 */
  padding: 24px 0 18px;
  border-top: 1px solid #e5e7eb;
  color: #6b7280;                  /* 전체 회색 톤 */
  margin-top: auto;                /* sticky footer */
}
.footer-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  font-size: 12px;
}
/* Footer grid 정렬 보정 */
.footer-info .row{
  display:grid;
  /* 레이블 고정폭 → 값 컬럼과 수직선 정렬 안정화 */
  grid-template-columns: 63px 1fr 1px 63px 1fr;
  column-gap: 14px;
  align-items:start;              /* 각 셀을 위쪽 기준으로 정렬 */
  min-height: 20px;               /* 행 최소 높이 */
}

.footer-info .cell{
  line-height: 1.6;               /* 줄간격 통일 */
}

.footer-info .cell.label{
  color:#8b949e;
  white-space:nowrap;             /* 라벨 줄바꿈 방지(정렬 유지) */
}

.footer-info .cell.value{
  color:#6b7280;
}

.footer-info .divider{
  width:1px;
  background:#dadde1;
  height: 71%; 
  align-self: center;
}

/* 긴 값(예: 주소)이 여러 줄일 때도 위쪽부터 시작하도록 */
.footer-info .row.top{
  align-items:start;
}

/* 우측 로고 */
.footer-logo {
  flex: 0 0 auto;
  display: flex;
  align-items: flex-start;         /* 상단 정렬 */
}
.footer-logo img {
  height: 60px;
}

/* 하단 카피라이트 */
.footer-bottom {
  margin-top: 16px;
}
.footer-bottom .copyright {
    font-size: 11px;
    letter-spacing: 0.08em;
    color: #9aa1aa;
    text-transform: uppercase;
    margin-top: 5px;
}

/* 링크 톤 다운 */
.muted-link {
  color: #6b7280;
  text-decoration: none;
}
.muted-link:hover {
  text-decoration: underline;
}

/* 반응형 처리 */
@media (max-width: 900px) {
  .footer-top {
    flex-direction: column;
    gap: 16px;
  }
  .footer-logo {
    justify-content: flex-end;     /* 모바일에서도 오른쪽 정렬 유지 */
  }
}

.footer-info .row.merged {
  grid-template-columns: 63px 1fr; /* ← 병합: 오른쪽 칸 삭제 */
}
.footer-info .row.merged .divider { display:none; } /* 분리선 제거 */

