/* ============================================================
   project.css — Single project page
   Reuses .person-hero, .person-avatar-wrap, .person-hero-img
   from person.css. Add person.css before this file.
   ============================================================ */

/* ── Page ──────────────────────────────────────────────────── */
.project-single-page {
  min-height: calc(100vh - var(--nav-height));
  background: var(--footer-light, #f7f7f7);
  padding-bottom: 80px;
}

/* ── Hero overrides ────────────────────────────────────────── */
.project-hero {
  height: 260px;
}

/* ── Logo (reuses .person-avatar-wrap positioning) ─────────── */
.project-logo-wrap {
  display: flex;
  align-items: flex-end;

  max-width: 1200px;
  width: 100%;

  margin: -72px auto 0;
  padding: 0 80px;

  position: relative;
  z-index: 2;

  gap: 28px;
}

.project-page-logo {
  width: 144px;
  height: 144px;
  border-radius: 28px;
  object-fit: cover;
  border: 4px solid var(--footer-light, #f7f7f7);
  background: var(--color-blue-light); /* was #e8eef6 */
  flex-shrink: 0;
}

.project-single-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--color-black);
  margin: 0 0 8px;
  line-height: 1.2;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.project-single-header {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;

  min-height: 120px;
  padding-bottom: 8px;

  flex: 1;
  min-width: 0;
}

/* ── Content body ──────────────────────────────────────────── */
.project-single-body {
  max-width: 1200px;
  margin: 20px auto;
  padding: 0 80px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ── Block base ────────────────────────────────────────────── */
.project-block {
  background: var(--color-white);
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 16px;
  overflow: hidden;
}

/* ── Text block ────────────────────────────────────────────── */
.project-block--text {
  padding: 28px 32px;
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--color-black);
}

.project-block--text p          { margin: 0 0 1em; }
.project-block--text p:last-child { margin-bottom: 0; }
.project-block--text ul,
.project-block--text ol         { padding-left: 1.4em; margin: 0 0 1em; }
.project-block--text li         { margin-bottom: 0.4em; }
.project-block--text h2         { font-size: 1.15rem; font-weight: 700; margin: 1.4em 0 0.5em; }
.project-block--text h2:first-child { margin-top: 0; }
.project-block--text h3         { font-size: 1rem; font-weight: 700; margin: 1.2em 0 0.4em; }
.project-block--text a          { color: var(--color-accent-aaa); text-decoration: underline; } /* was #286499 — 7.2:1 ✓ AAA */
.project-block--text b          { font-weight: 700; }
.project-block--text i          { font-style: italic; }

/* ── Image block ───────────────────────────────────────────── */
.project-block--image {
  margin: 0;
}

.project-block--image-has-caption {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 1.3fr);
  grid-template-rows: 500px;
  align-items: stretch;
}

.project-block--image-reverse {
  grid-template-columns: minmax(260px, 1.3fr) minmax(0, 1fr);
}

.project-block--image-reverse img {
  order: 2;
}

.project-block--image-reverse figcaption {
  order: 1;
}

.project-block--image img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  display: block;
  object-fit: cover;
}

.project-block--image-has-caption img {
  min-height: 0;
}

.project-block--image figcaption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 28px 32px;
  font-size: 0.9rem;
  line-height: 1.65;
  color: var(--color-text-secondary);  /* was #999 — 7.1:1 ✓ AAA */
  border-left: 1px solid var(--color-border-light); /* was #f0f0f0 */
}

.project-block--image-reverse figcaption {
  border-left: none;
  border-right: 1px solid var(--color-border-light);
}

.project-block--image figcaption p { margin: 0 0 1em; }
.project-block--image figcaption p:last-child { margin-bottom: 0; }
.project-block--image figcaption h2,
.project-block--image figcaption h3 {
  font-size: 1rem;
  line-height: 1.35;
  font-weight: 700;
  color: var(--color-black);
  margin: 0 0 0.6em;
}
.project-block--image figcaption a {
  color: var(--color-accent-aaa);
  text-decoration: underline;
}

/* ── HTML embed block ──────────────────────────────────────── */
.project-block--embed {
  padding: 20px;
}

.project-block--embed iframe {
  width: 100%;
  aspect-ratio: 16/9;
  border: none;
  border-radius: 8px;
  display: block;
}

/* ── Link block — service-card style ───────────────────────── */
.project-block--link {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px 24px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.project-block--link:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(0,0,0,0.09);
}

.project-link-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--color-light-blue-bg);
}

.project-link-info {
  flex: 1;
  min-width: 0;
}

.project-link-desc {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-black);
  margin: 0 0 4px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.project-link-title {
  font-size: 0.78rem;
  color: var(--color-grey);
  line-height: 1.5;
  margin: 0;
}

.project-link-arrow {
  flex-shrink: 0;
  color: var(--color-grey);
  transition: color 0.2s, transform 0.2s;
}

.project-block--link:hover .project-link-arrow {
  color: var(--color-black);
  transform: translateX(3px);
}

/* ── Back link ─────────────────────────────────────────────── */
.project-single-back a {
  font-size: 0.85rem;
  color: var(--color-text-secondary); /* was #888 — 7.1:1 ✓ AAA */
  text-decoration: none;
  transition: color 0.2s;
}
.project-single-back a:hover { color: var(--color-black); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .project-single-header,
  .project-single-body {
    padding-left: 40px;
    padding-right: 40px;
  }
}

@media (max-width: 991px) and (min-width: 681px) {
  .project-block--image-has-caption {
    grid-template-rows: unset;
  }
  
  .project-block--image-has-caption {
      grid-template-columns: minmax(0, 1fr) minmax(260px, 1fr);
    }
    
    .project-block--image-reverse {
      grid-template-columns: minmax(260px, 1fr) minmax(0, 1fr);
    }
}

@media (max-width: 680px) {
    .project-hero {
        height: 135px;
    }

    .project-logo-wrap {
        padding-left: 16px;
        padding-right: 16px;

        gap: 5px;
        margin-top: -30px;

        align-items: center;
    }

    .project-page-logo {
        width: 88px;
        height: 88px;
        border-radius: 20px;
    }

    .project-single-header,
    .project-single-body {
        padding-left: 16px;
        padding-right: 16px;
    }

    .project-single-title {
        font-size: 1.4rem;
    }

    .project-block--text {
        padding: 20px 18px;
    }

    .project-block--image-has-caption,
    .project-block--image-reverse {
        display: block;
    }

    .project-block--image img,
    .project-block--image-reverse img {
        height: auto;
        min-height: 0;
        order: initial;
    }

    .project-block--image figcaption,
    .project-block--image-reverse figcaption {
        display: block;
        padding: 14px 18px;
        font-size: 0.8rem;
        border-left: none;
        border-right: none;
        border-top: 1px solid var(--color-border-light);
        order: initial;
    }

    .project-block--link {
        gap: 12px;
        padding: 18px;
    }

}

@media (max-width: 520px) {
  .project-logo-wrap {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .project-page-logo {
    margin-left: 12px;
  }

  .project-single-header {
    min-height: auto;
    padding-bottom: 0;
  }
}