/* =============================================================
   Section 5 · Media / Op-eds (Journalism)
   툭툭 놓은 기울어진 클리핑 카드 + 전체 리스트 토글
   ============================================================= */

.press {
  position: relative;
  background: var(--color-paper);
  padding: var(--space-24) 0;
}
.press__inner { max-width: var(--container); margin: 0 auto; padding: 0 var(--space-6); }

.press__head { margin: 0 0 var(--space-16); text-align: left; }
.press__label {
  font-size: var(--fs-small); font-weight: var(--fw-bold);
  letter-spacing: .18em; color: var(--color-coral-deep); margin-bottom: var(--space-3);
}
.press__title {
  font-size: clamp(1.7rem, 3.2vw, 2.6rem); font-weight: var(--fw-extra);
  line-height: 1.25; letter-spacing: var(--ls-tight); margin: 0; color: var(--color-ink);
}

/* ---------------- 클리핑 카드 그리드 ---------------- */
.press__grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--space-8) var(--space-6);
}

.clip { display: block; text-decoration: none; color: inherit; }
/* 폴라로이드/클리핑 — 살짝 기울임 (툭툭 놓은 느낌) */
.clip__inner {
  background: #fffdf7;
  padding: 12px 12px 16px;
  border-radius: 4px;
  box-shadow: 0 12px 26px rgba(40,40,30,.16), 0 2px 5px rgba(40,40,30,.10);
  transform: rotate(var(--rot, -2deg));
  transition: transform .35s cubic-bezier(.2,.8,.2,1), box-shadow .35s ease;
}
.clip:hover .clip__inner {
  transform: rotate(0deg) translateY(-6px) scale(1.02);
  box-shadow: 0 20px 40px rgba(40,40,30,.22);
}
/* 번갈아 기울이기 + 세로 엇갈림 */
.clip:nth-child(4n+1) .clip__inner { --rot: -3deg; }
.clip:nth-child(4n+2) .clip__inner { --rot:  2deg; }
.clip:nth-child(4n+3) .clip__inner { --rot: -1.5deg; }
.clip:nth-child(4n+4) .clip__inner { --rot:  3deg; }
.clip:nth-child(even) { margin-top: var(--space-8); }

/* 커버 */
.clip__cover {
  position: relative; aspect-ratio: 4 / 3; overflow: hidden;
  border-radius: 2px; background: var(--color-ink-soft);
}
.clip__cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* 매체명 클리핑 커버 (이미지 없을 때) */
.clip__cover--brand {
  display: grid; place-items: center; padding: var(--space-4);
  background: linear-gradient(135deg, rgba(233,255,112,.45), rgba(239,158,120,.25)), var(--color-paper-soft);
}
.clip__cover--brand.alt {
  background: linear-gradient(135deg, rgba(239,158,120,.40), rgba(233,255,112,.20)), var(--color-paper-soft);
}
.clip__masthead {
  font-size: 1.15rem; font-weight: var(--fw-extra); letter-spacing: -.01em;
  color: var(--color-ink); text-align: center; line-height: 1.2;
}

/* 타입 태그 / 재생 배지 */
.clip__type {
  position: absolute; top: 10px; left: 10px; z-index: 2;
  font-size: .68rem; font-weight: var(--fw-bold); letter-spacing: .08em;
  padding: 4px 9px; border-radius: var(--radius-pill);
  background: rgba(22,32,26,.82); color: var(--color-lime);
}
.clip__cover .play-badge {
  position: absolute; z-index: 2; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 50px; height: 50px; border-radius: 50%; background: #FF0000;
  display: grid; place-items: center; box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
.clip__cover .play-badge svg { width: 22px; height: 22px; color: #fff; margin-left: 3px; }

/* 캡션 */
.clip__cap { padding: var(--space-3) 4px 0; }
.clip__outlet {
  font-size: .72rem; font-weight: var(--fw-bold); letter-spacing: .04em;
  color: var(--color-coral-deep); margin-bottom: 4px;
}
.clip__name {
  font-size: .98rem; font-weight: var(--fw-semibold); color: var(--color-ink);
  line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

/* ---------------- 전체 리스트 토글 ---------------- */
.press__more { margin-top: var(--space-24); text-align: center; }
.press__toggle {
  display: inline-flex; align-items: center; gap: 8px;
  padding: var(--space-3) var(--space-8);
  font-size: .95rem; font-weight: var(--fw-semibold); font-family: inherit;
  color: var(--color-ink); background: #fff;
  border: 1.5px solid var(--color-line); border-radius: var(--radius-pill);
  cursor: pointer; transition: border-color .2s ease, background-color .2s ease;
}
.press__toggle:hover { border-color: var(--color-ink); background: var(--color-paper-soft); }
.press__toggle svg { width: 18px; height: 18px; transition: transform .3s ease; }
.press__toggle[aria-expanded="true"] svg { transform: rotate(180deg); }

.press__panel {
  overflow: hidden; max-height: 0;
  transition: max-height .55s cubic-bezier(.4,0,.2,1), opacity .4s ease;
  opacity: 0;
}
.press__panel.is-open { opacity: 1; }

.press__cats {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-8);
  padding: var(--space-12) 0 var(--space-4);
  text-align: left;
}
.press-cat__title {
  font-size: .8rem; font-weight: var(--fw-bold); letter-spacing: .12em;
  color: var(--color-ink); padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--color-lime); margin: 0 0 var(--space-4);
  display: inline-block;
}
.press-cat ul { list-style: none; margin: 0; padding: 0; }
.press-cat li {
  font-size: .92rem; line-height: 1.5; color: #3a4038;
  padding: 5px 0 5px 16px; position: relative;
}
.press-cat li::before {
  content: ""; position: absolute; left: 0; top: .8em;
  width: 5px; height: 5px; border-radius: 50%; background: var(--color-coral);
}
/* 언론보도는 길어서 2열 */
.press-cat--wide { grid-column: span 2; }
.press-cat--wide ul { columns: 2; column-gap: var(--space-8); }

/* ---------------- Responsive ---------------- */
@media (max-width: 920px) {
  .press__grid { grid-template-columns: repeat(2, 1fr); }
  .press { padding: var(--space-16) 0; }
}
@media (max-width: 560px) {
  .press__grid { grid-template-columns: 1fr; gap: var(--space-12); }
  .clip:nth-child(even) { margin-top: 0; }
  .press-cat--wide { grid-column: auto; }
  .press-cat--wide ul { columns: 1; }
}
