/* ==========================
   0. ROOT & COMMON
========================== */
:root {
  --aid-green: #1b3b34;
  --muted: #6f7674;
  --line: #e7ebe9;
}

body.sub-insights {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* 공통 컨테이너 */
.ins-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 768px) {
  .ins-container {
    max-width: 95%;
    padding: 0 15px;
  }
}

/* ==========================
   1. HERO
========================== */
.ins-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 280px;
  background: linear-gradient(180deg, #f8fbf9 0%, #ffffff 100%);
  text-align: center;
}
.ins-hero-title {
  font-weight: 900;
  color: var(--aid-green);
  font-size: clamp(28px, 4vw, 44px);
  margin: 0;
}
.ins-hero-sub {
  color: #5d6966;
  margin-top: 10px;
}

/* ==========================
   2. TABS
========================== */
.ins-tabs {
  position: sticky;
  top: 0;
  z-index: 8;
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.ins-tablist {
  display: flex;
  gap: 18px;
  align-items: center;
  justify-content: center;
  height: 64px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.ins-tab {
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 700;
  color: var(--aid-green);
  user-select: none;
}
.ins-tab.active {
  background: #eef4f2;
  color: #0d201c;
}

/* ==========================
   3. SECTIONS
========================== */
.ins-section {
  padding: 64px 0;
}
.ins-head {
  margin-bottom: 18px;
  text-align: left;
}
.ins-title {
  font-weight: 900;
  color: var(--aid-green);
  margin: 0 0 6px;
}
.ins-sub {
  color: var(--muted);
  margin: 0;
}

/* ==========================
   4. PROJECTS (오버레이 카드)
========================== */
.aid-card-overlay {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.08);
  height: clamp(320px, 44vw, 560px);
  background: #000;
  margin-bottom: 60px;
}
.aid-card-media {
  position: absolute;
  inset: 0;
  margin: 0;
}
.aid-card-media > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* 패널 기본 (오른쪽) */
.aid-card-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: clamp(280px, 30vw, 480px);
  display: flex;
  align-items: stretch;
  background: linear-gradient(
    to left,
    rgba(0, 0, 0, 0.48) 0%,
    rgba(0, 0, 0, 0.28) 35%,
    rgba(0, 0, 0, 0) 100%
  );
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  color: #fff;
}
.aid-card-overlay.aid-left .aid-card-panel {
  left: 0;
  right: auto;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.48) 0%,
    rgba(0, 0, 0, 0.28) 35%,
    rgba(0, 0, 0, 0) 100%
  );
}
.aid-card-panel-inner {
  margin-left: auto;
  width: min(90%, 500px);
  height: 100%;
  padding: clamp(18px, 3.2vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  color: #fff;
}
.aid-card-panel .project-title {
  margin: 0;
  font-weight: 900;
  color: #fff;
}
.aid-card-panel .project-desc {
  margin: 0;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.92);
}
.aid-card-panel .project-tag,
.aid-card-panel .project-meta li {
  background: rgba(255, 255, 255, 0.9);
  color: #0e221e;
  border-radius: 999px;
  padding: 6px 10px;
  font-weight: 700;
}
.aid-card-panel .btn.btn-light {
  color: #0e221e;
}

.project-meta,
.aid-card-panel .project-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 6px 0 0;
  list-style: none;
}
.project-meta li,
.aid-card-panel .project-meta li {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  height: 36px;
  padding: 0 12px;
  border-radius: 999px;
}

.aid-card-panel .btn {
  align-self: flex-start;
  padding: 10px 16px;
  border-radius: 999px;
}

@media (max-width: 991.98px) {
  .aid-card-panel {
    left: 0;
    right: 0;
    width: 100%;
    top: auto;
    bottom: 0;
    height: 48%; /* 기존 52% → 살짝 줄임 */
  }
  .aid-card-panel-inner {
    width: 100%;
  }
}

/* ==========================
   5. BLOG & YOUTUBE (스플릿 카드)
========================== */
.blog-grid {
  display: grid;
  gap: 60px;
}
@media (max-width: 991.98px) {
  .blog-grid {
    gap: 36px;
  }
}

.blog-card {
  display: grid;
  grid-template-columns: minmax(340px, 1fr) clamp(320px, 34vw, 520px);
  height: clamp(380px, 40vw, 560px);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}
.blog-card.aid-left {
  grid-template-columns: clamp(320px, 34vw, 520px) minmax(340px, 1fr);
}

/* 이미지 */
.blog-card__media {
  grid-column: 1;
  margin: 0;
  position: relative;
}
.blog-card.aid-left .blog-card__media {
  grid-column: 2;
}
.blog-card__media > img,
.blog-card__media > .ratio {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.blog-card__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.12);
  pointer-events: none;
}

/* 텍스트 패널 */
.blog-card__panel {
  grid-column: 2;
  display: flex;
  align-items: stretch;
  background: rgba(14, 34, 30, 0.9); /* 딥그린 반투명 */
  color: #fff;
}
.blog-card.aid-left .blog-card__panel {
  grid-column: 1;
}
.blog-card__panel-inner {
  width: 100%;
  padding: clamp(18px, 3.2vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}

.blog-tag {
  display: inline-block;
  font-weight: 800;
  color: #0e221e;
  background: #fff;
  padding: 6px 10px;
  border-radius: 999px;
}
.blog-title {
  margin: 8px 0 6px;
  font-weight: 900;
  letter-spacing: -0.02em;
  color: #fff;
}
.blog-desc {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.7;
}
.blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0;
  margin: 10px 0 0;
  list-style: none;
}
.blog-meta li {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #fff;
  color: #0e221e;
  font-weight: 700;
  font-size: 0.92rem;
}
.blog-card__panel .btn {
  align-self: flex-start;
  padding: 10px 16px;
  border-radius: 999px;
}
.blog-card__panel-inner h3,
.blog-card__panel-inner p,
.blog-card__panel-inner li,
.blog-card__panel-inner small {
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.25);
}

/* 유튜브 iframe */
.blog-card__media .ratio {
  height: 100%;
}
.blog-card__media iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

/* 모바일 스택 */
@media (max-width: 991.98px) {
  .blog-card {
    grid-template-columns: 1fr;
    height: auto;
  }
  .blog-card__media,
  .blog-card__panel {
    grid-column: 1;
  }
  .blog-card__media {
    min-height: 46vw;
  }
}

/* ==========================
   6. FOOTER PUSH
========================== */
.site-footer {
  margin-top: auto;
}

/* === BLOG: 섹션 한정 강제 스타일 (우선순위↑) === */
#sec-blog .blog-grid {
  display: grid !important;
  gap: 60px;
}

#sec-blog .blog-card {
  display: grid;
  grid-template-columns: minmax(340px, 1fr) clamp(320px, 34vw, 520px);
  height: clamp(380px, 40vw, 560px);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}

/* 좌/우 반전 */
#sec-blog .blog-card.aid-left {
  grid-template-columns: clamp(320px, 34vw, 520px) minmax(340px, 1fr);
}

/* 미디어 셀 고정 */
#sec-blog .blog-card__media {
  grid-column: 1;
  position: relative;
  margin: 0;
}
#sec-blog .blog-card.aid-left .blog-card__media {
  grid-column: 2;
}
#sec-blog .blog-card__media > img,
#sec-blog .blog-card__media > .ratio {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* 텍스트 패널: 반드시 보이게 강제 */
#sec-blog .blog-card__panel {
  grid-column: 2;
  display: flex;
  align-items: stretch;
  background: rgba(14, 34, 30, 0.9) !important; /* ← 여기 핵심 */
  color: #fff !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
#sec-blog .blog-card.aid-left .blog-card__panel {
  grid-column: 1;
}

#sec-blog .blog-card__panel-inner {
  width: 100%;
  padding: clamp(18px, 3.2vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}

/* aid-left 전용 (짝수 nth-child는 제거) */
.blog-card.aid-left {
  grid-template-columns: clamp(320px, 34vw, 520px) minmax(340px, 1fr);
}
.blog-card.aid-left .blog-card__media {
  grid-column: 2;
}
.blog-card.aid-left .blog-card__panel {
  grid-column: 1;
}

/* === Fix: 블로그/유튜브 카드 텍스트가 패널 밖으로 나가는 문제 === */

/* 카드 자체는 그리드 셀을 꽉 채우도록 */
.blog-card {
  align-items: stretch;
}

/* 패널 내부 텍스트 영역 폭 제한 + 줄바꿈 강제 */
.blog-card__panel-inner {
  /* 폭을 너무 넓게 쓰지 않도록 고정 */
  width: 100%;
  max-width: 520px; /* ← 핵심 */
  box-sizing: border-box;
  margin-inline: clamp(12px, 2.4vw, 28px);
  overflow: hidden; /* 내부가 넘치면 잘라냄(스크롤 X) */
  word-break: keep-all; /* 한국어 자연 줄바꿈 */
  overflow-wrap: break-word; /* 긴 영문/URL 줄바꿈 */
}

/* 제목/본문도 안전 장치 */
.blog-title,
.blog-desc {
  word-break: keep-all;
  overflow-wrap: anywhere;
}

/* 이미지가 늦게 로드되어도 레이아웃이 무너지지 않도록 최소 높이 확보 */
.blog-card__media {
  min-height: 260px; /* 데스크탑 기준 안전선 */
}
@media (max-width: 991.98px) {
  .blog-card__media {
    min-height: 46vw; /* 모바일은 화면폭 비례 */
  }
}

/* 좌우 반전 케이스 보강: aid-left 시 컬럼 위치 확정 */
.blog-card.aid-left {
  grid-template-columns: clamp(320px, 34vw, 520px) minmax(340px, 1fr);
}
.blog-card.aid-left .blog-card__media {
  grid-column: 2;
}
.blog-card.aid-left .blog-card__panel {
  grid-column: 1;
}

/* 섹션 한정(혹시 상위 CSS 충돌 시) */
#sec-blog .blog-card__panel {
  background: rgba(14, 34, 30, 0.9) !important;
  color: #fff !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* 블로그 카드: 두 컬럼(이미지/패널)이 항상 같은 높이 */
.blog-card {
  display: grid;
  grid-template-columns: minmax(340px, 1fr) clamp(320px, 34vw, 520px);
  height: auto; /* 고정 높이 대신 auto */
  align-items: stretch; /* ← 핵심: 두 컬럼 높이 맞춤 */
}

/* 이미지와 패널 모두 부모 높이에 맞춤 */
.blog-card__media,
.blog-card__panel {
  display: flex;
  flex-direction: column;
}

.blog-card__media img,
.blog-card__media .ratio {
  flex: 1 1 auto;
  height: 100%;
  object-fit: cover;
}

/* 카드 최소 높이는 안전선만 */
.blog-card {
  min-height: 380px; /* 너무 납작해지지 않도록 */
}

/* ===== Blog section hard-fix: 두 셀을 항상 같은 1행에 고정 ===== */
#sec-blog .blog-grid {
  display: grid !important;
  gap: 60px;
}
@media (max-width: 991.98px) {
  #sec-blog .blog-grid {
    gap: 36px;
  }
}

#sec-blog .blog-card {
  display: grid !important;
  grid-template-columns: minmax(340px, 1fr) clamp(320px, 34vw, 520px) !important;
  grid-template-rows: 1fr !important; /* ← 1행 고정 */
  align-items: stretch !important; /* 높이 맞춤 */
  min-height: 400px; /* 안전선 */
  height: auto !important;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
}

/* 기본: 이미지 왼쪽(컬럼1), 패널 오른쪽(컬럼2) — 둘 다 행 1 */
#sec-blog .blog-card__media {
  grid-column: 1 !important;
  grid-row: 1 / 2 !important; /* ← 같은 행 */
  position: relative;
  margin: 0;
  min-height: 0;
  display: block;
}
#sec-blog .blog-card__panel {
  grid-column: 2 !important;
  grid-row: 1 / 2 !important; /* ← 같은 행 */
  display: flex;
  align-items: stretch;
  margin: 0;
  background: rgba(14, 34, 30, 0.9) !important;
  color: #fff !important;
}

/* 반전 카드: 텍스트 왼쪽, 이미지 오른쪽 */
#sec-blog .blog-card.aid-left .blog-card__media {
  grid-column: 2 !important;
}
#sec-blog .blog-card.aid-left .blog-card__panel {
  grid-column: 1 !important;
}

/* 미디어가 영역을 꽉 채우도록 */
#sec-blog .blog-card__media > img,
#sec-blog .blog-card__media > .ratio {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  display: block;
}
#sec-blog .blog-card__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.12);
  pointer-events: none;
}

/* 텍스트 패널 내부 기본 여백 */
#sec-blog .blog-card__panel-inner {
  width: 100%;
  padding: clamp(18px, 3.2vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}

/* 모바일은 단일 컬럼(이미지 위/텍스트 아래) */
@media (max-width: 991.98px) {
  #sec-blog .blog-card {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important; /* 이미지, 패널 각각 한 줄 */
    min-height: 0;
    height: auto !important;
  }
  #sec-blog .blog-card__media {
    grid-column: 1 !important;
    grid-row: auto;
  }
  #sec-blog .blog-card__panel {
    grid-column: 1 !important;
    grid-row: auto;
  }
  #sec-blog .blog-card__media {
    min-height: 46vw;
  }
}

/* 버튼 공통 */
.blog-card__panel .btn {
  display: block; /* 인라인 → 블록 */
  width: 100%; /* 패널 내부 폭 전체 */
  max-width: 240px; /* 원하는 최대 폭 (더 길게) */
  margin: 16px auto 0; /* 가운데 정렬 */
  text-align: center; /* 글자 가운데 */
  padding: 12px 20px; /* 버튼 키우기 */
  border-radius: 12px; /* 라운드 줄이기 (기존 999px → 12px) */
  font-weight: 700;
}

/* 패널 내부를 위(텍스트) / 아래(태그+버튼)로 분리 */
.blog-card__panel-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between; /* 위·아래로 벌려 놓기 */
}

/* 아래쪽 블록(태그+버튼)을 중앙 정렬 + 맨 아래로 */
.blog-card__panel-inner > div:last-child {
  display: flex;
  flex-direction: column;
  align-items: center; /* 수평 중앙 */
  gap: 12px;
  margin-top: auto; /* 남는 공간을 위로 밀어 버튼을 하단에 고정 */
}

/* 자세히 보기 버튼 공통 스타일 */
.blog-card__panel .btn {
  display: inline-block; /* block으로 늘리지 말고 */
  min-width: 180px; /* 가로 길이 확보 */
  padding: 11px 28px; /* 조금 더 길게 */
  border-radius: 10px; /* 라운드 축소 */
  font-weight: 600;
  align-self: center; /* 혹시 부모가 flex여도 중앙 정렬 유지 */
}

/* 태그 칩과 간격 맞추기(선택) */
.blog-meta {
  margin-bottom: 4px;
}

/* 패널 전체를 세로 flex로 → 위/아래 분리 */
.blog-card__panel-inner {
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between; /* 위/아래로 나누기 */
}

/* 하단 영역(태그+버튼) */
.blog-card__panel-inner > div:last-child {
  display: flex;
  flex-direction: column;
  align-items: center; /* ← 수평 중앙 */
  justify-content: flex-end;
  gap: 12px;
  margin-top: auto; /* 남는 공간 위로 밀기 */
  width: 100%; /* 부모 폭 따라가기 */
  text-align: center; /* 텍스트도 센터 */
}

/* 버튼 자체 스타일 */
.blog-card__panel .btn {
  min-width: 200px; /* 가로 길게 */
  padding: 12px 28px;
  border-radius: 10px; /* 라운드 축소 */
  font-weight: 600;
  text-align: center; /* 텍스트도 가운데 */
}

/* 버튼을 부모 안에서 정확히 중앙 정렬 */
.blog-card__panel .btn {
  min-width: 220px; /* 원하는 버튼 너비 */
  padding: 12px 28px;
  border-radius: 10px;
  font-weight: 600;
  display: block;
  margin: 0 auto; /* ← 좌우 자동 여백으로 정확히 가운데 */
  text-align: center;
}

/* 블로그 카드 텍스트 블록을 패널 안에서 '가운데 놓기' */
#sec-blog .blog-card__panel-inner {
  max-width: 680px; /* 텍스트 덩어리 최대 폭 */
  margin-left: auto; /* 좌우 여백 동일 */
  margin-right: auto;
  padding-left: clamp(18px, 3vw, 28px); /* 좌우 패딩 동일 */
  padding-right: clamp(18px, 3vw, 28px);
}

/* 큰 제목 줄바꿈 균형(지원 브라우저에서 가독성↑) */
#sec-blog .blog-title {
  text-wrap: balance; /* 크롬/사파리 등 최신 브라우저 */
}

/* 버튼 길게 + 라운드 축소 + 정확히 가운데 */
#sec-blog .blog-card__panel .btn {
  display: block;
  min-width: 240px; /* 더 길게 */
  padding: 12px 28px;
  border-radius: 10px; /* 라운드 줄이기 */
  margin: 12px auto 0; /* 가운데 정렬 */
}

/* 프로젝트 상세 보기 버튼 스타일 개선 */
.aid-card-panel .btn {
  display: block;
  min-width: 240px; /* 버튼을 더 길게 */
  padding: 12px 28px; /* 높이/폭 여유 */
  border-radius: 10px; /* 라운드 줄이기 */
  margin-top: 12px; /* 위 요소와 간격 */
  text-align: center; /* 텍스트 가운데 정렬 */
}

/* 프로젝트 태그 - 패널 가로 영역 전체 */
.aid-card-panel .project-tag {
  display: block;
  width: 100%; /* 패널 가로 전체 */
  text-align: center; /* 텍스트 가운데 */
  font-weight: 700;
  background: rgba(255, 255, 255, 0.9);
  color: #0e221e;
  border-radius: 12px; /* pill → 살짝 줄인 라운드 */
  padding: 10px 0; /* 위아래 여백만 */
  margin: 0 0 16px 0; /* 아래 공간 */
  font-size: 1rem;
}
/* ============================================
   FLUID TYPE for mobile (텍스트/칩/버튼만 조정)
   레이아웃/포지션은 그대로 유지
============================================ */
@media (max-width: 768px) {
  /* 히어로 · 섹션 타이포 */
  .ins-hero-title {
    font-size: clamp(22px, 6.5vw, 30px);
  }
  .ins-hero-sub {
    font-size: clamp(12px, 3.2vw, 14px);
  }
  .ins-title {
    font-size: clamp(20px, 5.2vw, 24px);
    line-height: 1.28;
  }
  .ins-sub {
    font-size: clamp(13px, 3.6vw, 15px);
    line-height: 1.7;
  }

  /* 카드 패널 내부 여백(넓으면 넉넉, 좁으면 컴팩트) */
  .aid-card-panel-inner,
  .blog-card__panel-inner {
    padding: clamp(14px, 4.2vw, 20px);
    gap: clamp(10px, 2.8vw, 14px);
  }

  /* 프로젝트 카드 텍스트 */
  .aid-card-panel .project-title {
    font-size: clamp(18px, 4.8vw, 22px);
    line-height: 1.3;
  }
  .aid-card-panel .project-desc {
    font-size: clamp(13px, 3.6vw, 16px);
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.86);
  }

  /* 배지/칩 */
  .project-meta li,
  .blog-meta li,
  .blog-tag {
    font-size: clamp(11px, 3.2vw, 13px);
    padding: clamp(5px, 1.6vw, 8px) clamp(8px, 2.4vw, 12px);
    height: auto;
  }

  /* 버튼(폭은 기존 스타일 유지, 텍스트/패딩만 유연) */
  .aid-card-panel .btn,
  .blog-card__panel .btn {
    font-size: clamp(13px, 3.6vw, 15px);
    padding: clamp(10px, 3.2vw, 12px) clamp(16px, 4vw, 20px);
    border-radius: 10px;
  }

  /* 블로그 카드 제목/본문 */
  .blog-title {
    font-size: clamp(18px, 4.8vw, 22px);
    line-height: 1.3;
    text-wrap: balance;
  }
  .blog-desc {
    font-size: clamp(13px, 3.6vw, 16px);
    line-height: 1.75;
  }
}

/* 초소형 폰(≤480px): 조금 더 압축 */
@media (max-width: 480px) {
  .ins-title {
    font-size: clamp(18px, 6vw, 22px);
  }
  .aid-card-panel .project-title,
  .blog-title {
    font-size: clamp(17px, 5.4vw, 20px);
  }
}
/* =========================================================
   MOBILE CARD VISIBILITY FIX (append at end)
   - 부모에 높이 보장, 자식 레이어 정렬
========================================================= */
@media (max-width: 768px) {
  /* 1) 부모(카드)에 확실한 높이 부여 */
  .aid-card-overlay {
    position: relative !important;
    min-height: 120vw !important; /* 텍스트가 많으면 130~140vw로 올려도 됨 */
    border-radius: 18px;
    overflow: hidden;
  }

  /* 2) 이미지 레이어 */
  .aid-card-media {
    position: absolute !important;
    inset: 0 !important;
    z-index: 1;
  }
  .aid-card-media > img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  /* 3) 패널 레이어(텍스트) — 전체를 덮되, 하단 정렬 */
  .aid-card-panel {
    position: absolute !important;
    inset: 0 !important; /* top/right/bottom/left = 0 */
    z-index: 2;
    display: flex;
    align-items: flex-end; /* 텍스트를 아래로 */
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.35) 0%,
      rgba(0, 0, 0, 0.55) 35%,
      rgba(0, 0, 0, 0.75) 100%
    ) !important;
    color: #fff !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .aid-card-panel-inner {
    width: 100%;
    padding: 18px 16px 22px !important; /* 하단 여백 조금 더 */
    margin: 0;
    gap: 12px;
  }

  /* 4) 텍스트만 살짝 압축 (레이아웃은 그대로) */
  .aid-card-panel .project-title {
    font-size: clamp(19px, 5.2vw, 23px);
    line-height: 1.28;
  }
  .aid-card-panel .project-desc {
    font-size: clamp(13px, 3.6vw, 15px);
    line-height: 1.7;
    color: rgba(255, 255, 255, 0.88);
  }
  .project-meta li {
    font-size: clamp(11px, 3.2vw, 13px);
    padding: 6px 10px;
    height: auto;
  }
  .aid-card-panel .btn {
    font-size: clamp(13px, 3.6vw, 15px);
    padding: 11px 18px;
    border-radius: 10px;
    max-width: 260px;
  }
}

/* 초소형 폰에서 텍스트가 더 길면 여유 확보 */
@media (max-width: 420px) {
  .aid-card-overlay {
    min-height: 130vw !important;
  } /* 필요시 140vw */
}
/* === MOBILE: 카드 높이 과확대 방지 (이미지 캡) === */
@media (max-width: 768px) {
  /* 카드 높이를 '최소–최대' 범위로 고정 */
  .aid-card-overlay {
    /* 최소는 내용 들어갈 여유, 최대는 화면 높이 내 */
    min-height: clamp(520px, 100svh - 96px, 120vw) !important;
    max-height: 100svh !important;
  }

  /* 이미지는 부모 높이에만 맞추고 더 키우지 않음 */
  .aid-card-media {
    position: absolute !important;
    inset: 0 !important;
  }
  .aid-card-media > img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 꽉 채우되 비율 유지 */
    object-position: center; /* 필요하면 'center right' 등으로 조정 */
  }

  /* 패널 내부 여백 살짝 압축(내용이 많은 카드 대비) */
  .aid-card-panel-inner {
    padding: 16px 16px 20px !important;
    gap: 10px;
  }
}
@media (max-width: 768px) {
  /* 1) 카드 높이 — 다시 줄임 */
  .aid-card-overlay {
    height: auto !important; /* 자동으로 내용에 맞게 */
    min-height: 420px !important; /* 너무 납작해지지 않게 기본선 */
    max-height: none !important; /* 더이상 강제 확대 안 함 */
  }

  /* 2) 이미지 — 전체를 덮되 세로 공간 제한 */
  .aid-card-media {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
  }
  .aid-card-media > img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 비율 유지하며 꽉 채움 */
    object-position: center; /* 중앙 기준 */
  }

  /* 3) 패널 — 이미지 안에 텍스트 전부 들어오게 */
  .aid-card-panel {
    position: absolute !important;
    inset: 0 !important;
    height: 100% !important;
    width: 100% !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-end; /* 텍스트를 하단에 */
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0.35) 0%,
      rgba(0, 0, 0, 0.65) 50%,
      rgba(0, 0, 0, 0.85) 100%
    ) !important;
  }

  .aid-card-panel-inner {
    padding: 16px;
    gap: 12px;
  }

  /* 4) 폰트 살짝 줄여서 꽉 맞추기 */
  .aid-card-panel .project-title {
    font-size: clamp(18px, 5vw, 22px);
    line-height: 1.3;
  }
  .aid-card-panel .project-desc {
    font-size: clamp(13px, 3.5vw, 15px);
    line-height: 1.6;
  }
  .project-meta li {
    font-size: 12px;
    padding: 5px 10px;
  }
  .aid-card-panel .btn {
    font-size: 13px;
    padding: 10px 18px;
    border-radius: 10px;
    max-width: 220px;
    margin: 12px auto 0;
  }
}
