.project-hero { padding: 86px 0; }
.project-hero-grid { display: grid; grid-template-columns: minmax(0, .92fr) minmax(340px, 1.08fr); gap: 46px; align-items: center; }
.project-hero-image { margin: 0; border-radius: 32px; overflow: hidden; box-shadow: 0 30px 80px rgba(0,0,0,.34); background: #2a211b; }
.project-hero-image img { width: 100%; aspect-ratio: 4/3; object-fit: cover; }
.project-summary-grid { display: grid; grid-template-columns: minmax(0, 1fr) 380px; gap: 28px; align-items: start; }
.project-story { background: #fff; }
.project-content { font-size: 1.06rem; }
.project-content p { margin-top: 0; }
.project-challenge-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 18px; margin-top: 26px; }
.project-challenge-grid > div { border: 1px solid rgba(138,91,61,.18); border-radius: 20px; padding: 20px; background: #fffaf4; }
.project-details dl { display: grid; gap: 12px; }
.project-details dt { border-top: 1px solid rgba(0,0,0,.08); padding-top: 12px; }
.project-details dt:first-child { border-top: 0; padding-top: 0; }
.project-gallery { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 16px; margin-top: 28px; }
.project-gallery a { display: block; border-radius: 24px; overflow: hidden; background: #ddd; min-height: 180px; box-shadow: 0 14px 40px rgba(0,0,0,.08); }
.project-gallery a:first-child { grid-row: span 2; }
.project-gallery span, .project-gallery img { display: block; width: 100%; height: 100%; }
.project-gallery img { object-fit: cover; aspect-ratio: 4/3; transition: transform .3s ease; }
.project-gallery a:hover img { transform: scale(1.04); }
.project-card-meta { font-size: .92rem; color: var(--muted); border-top: 1px solid rgba(0,0,0,.08); padding-top: 12px; }
.project-cta-section .quote-card .btn { margin-top: 12px; }
.gallery-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,.88); display: grid; place-items: center; z-index: 9999; padding: 24px; }
.gallery-lightbox[hidden] { display: none; }
.gallery-lightbox img { max-width: min(1100px, 94vw); max-height: 86vh; border-radius: 18px; box-shadow: 0 30px 100px rgba(0,0,0,.5); }
.gallery-lightbox button { position: fixed; top: 18px; right: 18px; border: 0; border-radius: 999px; background: #fff; color: #111; padding: 10px 14px; font-weight: 900; cursor: pointer; }
@media (max-width: 980px) {
  .project-hero-grid, .project-summary-grid { grid-template-columns: 1fr; }
  .project-gallery { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .project-gallery a:first-child { grid-row: auto; }
}
@media (max-width: 640px) {
  .project-gallery, .project-challenge-grid { grid-template-columns: 1fr; }
}
