/* ============================================================
 * pages/project.css — /project/{slug} 전용
 * ============================================================ */

.project__header-inner { max-width: 880px; }

.project__crumbs {
  font-size: var(--fs-xs); color: var(--text-muted);
  letter-spacing: var(--ls-wide); text-transform: uppercase;
  display: inline-flex; gap: var(--space-2); align-items: center;
  margin-bottom: var(--space-4);
}
.project__crumbs a { color: var(--text-secondary); text-decoration: none; }
.project__crumbs a:hover { color: var(--text-primary); }

.project__title {
  font-size: var(--fs-5xl); font-weight: var(--fw-black);
  letter-spacing: var(--ls-tight); line-height: var(--lh-tight);
  margin-bottom: var(--space-3);
}
.project__subtitle {
  font-size: var(--fs-lg); color: var(--text-secondary);
  line-height: var(--lh-relaxed); margin-bottom: var(--space-5);
  max-width: 60ch;
}
.project__meta {
  display: flex; flex-wrap: wrap; gap: var(--space-4);
  align-items: center; margin-bottom: var(--space-6);
  font-size: var(--fs-sm);
}
.project__meta-item { color: var(--text-secondary); }
.project__meta-label {
  display: inline-block; margin-right: var(--space-2);
  color: var(--text-muted); text-transform: uppercase;
  letter-spacing: var(--ls-wide); font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
}
.project__cta { display: flex; gap: var(--space-3); flex-wrap: wrap; }

.project__cover {
  margin: 0 auto;
  max-width: var(--container-max);
  padding-inline: var(--container-pad);
}
.project__cover img {
  width: 100%; height: auto; display: block;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
  box-shadow: var(--shadow-lg);
}

.project__video-wrap {
  margin: 0 auto;
  max-width: var(--container-max);
  padding-inline: var(--container-pad);
  padding-block: var(--space-2);
}
.project__video {
  width: 100%; aspect-ratio: 16/9;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
  display: block; background: #000;
}

.project__content-inner {
  display: grid; gap: var(--space-7);
  grid-template-columns: minmax(0, 1fr) 280px;
}
@media (max-width: 880px) {
  .project__content-inner { grid-template-columns: 1fr; }
}

.project__lede {
  font-size: var(--fs-lg); color: var(--text-primary);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
}
.project__paragraph {
  font-size: var(--fs-md); color: var(--text-secondary);
  line-height: var(--lh-relaxed); margin-bottom: var(--space-4);
}
.project__paragraph--muted { color: var(--text-muted); font-style: italic; }

.project__side { align-self: start; position: sticky; top: 88px; }
.project__side-heading {
  font-size: var(--fs-sm); text-transform: uppercase;
  letter-spacing: var(--ls-widest); font-weight: var(--fw-bold);
  color: var(--text-muted); margin-bottom: var(--space-4);
}
.project__side-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-block: var(--space-2);
  border-top: 1px solid var(--border-subtle);
  font-size: var(--fs-sm);
}
.project__side-row:first-of-type { border-top: 0; }
.project__side-label { color: var(--text-muted); text-transform: uppercase; letter-spacing: var(--ls-wide); font-size: var(--fs-xs); }
.project__side-value { color: var(--text-primary); font-weight: var(--fw-semi); text-align: right; }

.project__gallery-heading {
  font-size: var(--fs-xl); font-weight: var(--fw-bold);
  margin-bottom: var(--space-5);
}
.project__gallery {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--space-3);
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
}
.project__gallery-link {
  display: block; aspect-ratio: 4 / 3;
  border-radius: var(--radius-md); overflow: hidden;
  border: 1px solid var(--border-default);
  background: var(--color-bg-deep);
  transition: border-color var(--dur-fast) var(--ease), transform var(--dur-base) var(--ease);
}
.project__gallery-link:hover {
  border-color: rgba(255, 255, 255, 0.18);
  transform: translateY(-2px);
}
.project__gallery-link img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}

.project__back-inner { display: flex; justify-content: flex-start; }

/* ── Quill HTML 출력 스타일 ─────────────────────────────── */
.project__body-html { line-height: 1.75; color: var(--text-secondary); }
.project__body-html p { margin-bottom: 1em; }
.project__body-html h2 { font-size: var(--fs-2xl); font-weight: var(--fw-bold); color: var(--text-primary); margin: 1.5em 0 .5em; }
.project__body-html h3 { font-size: var(--fs-xl);  font-weight: var(--fw-bold); color: var(--text-primary); margin: 1.2em 0 .4em; }
.project__body-html a  { color: rgba(255,255,255,.7); text-decoration: underline; text-underline-offset: 3px; }
.project__body-html a:hover { color: #fff; }
.project__body-html img { max-width: 100%; border-radius: 0; margin: 0; display: block; vertical-align: bottom; }
/* 이미지 포함 p */
.project__body-html p:has(img) { margin: 0 !important; padding: 0 !important; line-height: 0 !important; font-size: 0 !important; overflow: hidden; }
.project__body-html p:has(img) img { display: block; width: 100%; vertical-align: bottom; }
/* 이미지 앞뒤 빈 p (Quill이 <p><br></p> 삽입) */
.project__body-html p:has(img) + p,
.project__body-html p:has(img) ~ p:has(img),
.project__body-html p + p:has(img) { margin-top: 0 !important; }
.project__body-html p:has(br:only-child) + p:has(img),
.project__body-html p:has(img) + p:has(br:only-child) { margin: 0 !important; line-height: 0 !important; font-size: 0 !important; }
.project__body-html iframe { max-width: 100%; width: 100%; aspect-ratio: 16/9; border-radius: var(--radius-md); margin: 1em 0; border: 0; }
.project__body-html blockquote { border-left: 2px solid rgba(255,255,255,.18); padding-left: 1em; color: var(--text-muted); font-style: italic; margin: 1em 0; }
.project__body-html pre { background: rgba(0,0,0,.35); border-radius: var(--radius-sm); padding: 1em; overflow-x: auto; font-family: var(--font-mono); font-size: var(--fs-sm); }
.project__body-html code { background: rgba(255,255,255,.06); border-radius: 4px; padding: 2px 6px; font-family: var(--font-mono); font-size: .9em; }
.project__body-html ul, .project__body-html ol { padding-left: 1.5em; margin-bottom: 1em; }
.project__body-html li { margin-bottom: .35em; }
