

/* 섹션 배경 */
.project-section {
  padding: 80px 16px;
  background:#f7f7f7;
  color:#111;
  font-family: inherit;
}
.project-inner {
  max-width:1200px;
  margin:0 auto;
}

/* 섹션 제목 영역 */
.project-heading-kor {
  font-size:26px;
  font-weight:700;
  margin:0 0 4px;
}
.project-heading-eng {
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:#999;
  margin-bottom:30px;
}

/* 카드 레이아웃 */
.project-list {
  display:flex;
  flex-wrap:wrap;
  gap:24px;
}
.project-card {
  flex:1 1 calc(33.333% - 16px);
  min-width:260px;
  background:#fff;
  border-radius:0;
  box-shadow:0 0 0 1px rgba(0,0,0,0.04);
  padding:28px 26px 22px;
  box-sizing:border-box;
  transition:box-shadow .25s ease, transform .25s ease;
}
.project-card:hover{
  box-shadow:0 12px 25px rgba(0,0,0,0.08);
  transform:translateY(-4px);
}

/* 제목, 내용, 구분선 */
.project-title {
  font-size:18px;
  font-weight:600;
  line-height:1.5;
  margin:0 0 20px;
}
.project-line {
  border:none;
  border-top:1px solid #e1e1e1;
  margin:0 0 16px;
}
.project-desc {
  font-size:13px;
  line-height:1.7;
  color:#666;
  height:58px;          /* 2줄 정도만 보이도록 */
  overflow:hidden;
}

/* 하단 meta */
.project-footer {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-top:22px;
  font-size:12px;
  color:#999;
}
.project-footer a {
  text-decoration:none;
  font-weight:600;
  letter-spacing:0.05em;
  color:#333;
}
.project-footer a:hover {
  text-decoration:underline;
}

/* 반응형 */
@media (max-width: 900px){
  .project-card{
    flex:1 1 calc(50% - 12px);
  }
}
@media (max-width: 600px){
  .project-card{
    flex:1 1 100%;
  }
}