/* ============================================================
   NACRUDI — Projects page styles (builds on homepage.css)
   ============================================================ */

/* page intro */
.page-intro{background:var(--brand-deep);color:#fff;position:relative;overflow:hidden;}
.page-intro::before{content:"";position:absolute;inset:0;background:var(--topo) no-repeat right -120px top -140px/760px;opacity:.14;pointer-events:none;}
.page-intro .container{position:relative;z-index:1;padding:clamp(110px,14vw,160px) 0 clamp(56px,7vw,84px);}
.page-intro .eyebrow{color:#bfe3dd;}
.page-intro h1{color:#fff;font-size:clamp(48px,8vw,104px);line-height:.95;margin:18px 0 0;}
.page-intro .lead{color:rgba(255,255,255,.86);max-width:620px;margin-top:24px;}
.crumbs{display:flex;gap:10px;align-items:center;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:6px;}
.crumbs a:hover{color:#fff;}
.crumbs .sep{opacity:.5;}

/* partnership band */
.partnership{padding:clamp(48px,6vw,84px) 0;background:var(--paper-2);border-bottom:1px solid var(--line);}
.partnership-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(32px,5vw,64px);align-items:center;}
.partnership-photo{margin:0;border-radius:16px;overflow:hidden;background:var(--fill);box-shadow:0 24px 60px -34px rgba(0,0,0,.5);}
.partnership-photo img{width:100%;height:100%;max-height:560px;object-fit:cover;display:block;}
.partnership-body{display:flex;flex-direction:column;gap:18px;}
.partnership-body p{color:var(--ink-soft);line-height:1.65;}
.partnership-credit{font-size:15px;color:var(--ink);border-left:3px solid var(--gold);padding-left:16px;}
@media (max-width:820px){.partnership-grid{grid-template-columns:1fr;}}

/* project block */
.project{padding:clamp(64px,8vw,110px) 0;border-bottom:1px solid var(--line);}
.project:nth-child(even){background:var(--paper-2);}
.project-grid{display:grid;grid-template-columns:340px 1fr;gap:clamp(36px,5vw,68px);align-items:start;}

/* left meta rail */
.project-aside{position:sticky;top:100px;display:flex;flex-direction:column;gap:24px;}
.project-tag{align-self:flex-start;font-family:var(--display);font-size:15px;letter-spacing:.06em;text-transform:uppercase;color:var(--brand-deep);background:var(--brand-soft);border-radius:999px;padding:7px 16px;}
.project-aside h2{font-size:clamp(30px,3.6vw,46px);}
.project-desc{color:var(--ink-soft);font-size:16px;line-height:1.6;}
.facts{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-2);margin-top:4px;}
.fact{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--line-2);}
.fact .k{font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);font-weight:700;}
.fact .v{font-size:15px;font-weight:700;text-align:right;color:var(--ink);}
.fact .v.accent{color:var(--brand);}
.status-pill{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;color:var(--brand-deep);}
.status-pill .d{width:9px;height:9px;border-radius:50%;background:var(--brand);box-shadow:0 0 0 4px var(--brand-soft);}

/* beneficiary card */
.beneficiary{display:flex;gap:16px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px;}
.beneficiary img{width:74px;height:74px;border-radius:50%;object-fit:cover;flex:0 0 auto;border:2px solid var(--brand-soft);}
.beneficiary .who b{font-family:var(--serif);font-size:18px;display:block;}
.beneficiary .who span{font-size:13px;color:var(--ink-soft);}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:150px;gap:14px;}
.gallery figure{margin:0;overflow:hidden;border-radius:12px;background:var(--fill);position:relative;cursor:zoom-in;}
.gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.gallery figure:hover img{transform:scale(1.05);}
.gallery .g-lg{grid-column:span 4;grid-row:span 2;}
.gallery .g-tall{grid-column:span 2;grid-row:span 2;}
.gallery .g-wide{grid-column:span 4;grid-row:span 1;}
.gallery .g-sm{grid-column:span 2;grid-row:span 1;}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 14px 10px;font-size:12px;color:#fff;
  background:linear-gradient(transparent,rgba(8,32,29,.7));opacity:0;transition:opacity .25s;}
.gallery figure:hover figcaption{opacity:1;}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:9500;background:rgba(8,20,18,.92);display:none;align-items:center;justify-content:center;padding:32px;cursor:zoom-out;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);}
.lightbox .lb-close{position:absolute;top:22px;right:26px;width:46px;height:46px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.lightbox .lb-close:hover{background:rgba(255,255,255,.12);}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:1.5px solid rgba(255,255,255,.4);background:transparent;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.lightbox .lb-nav:hover{background:rgba(255,255,255,.12);}
.lightbox .lb-prev{left:24px;}
.lightbox .lb-next{right:24px;}
.lightbox .lb-count{position:absolute;bottom:24px;left:0;right:0;text-align:center;color:rgba(255,255,255,.7);font-size:13px;letter-spacing:.1em;}

@media (max-width:900px){
  .project-grid{grid-template-columns:1fr;}
  .project-aside{position:static;}
  .gallery .g-lg{grid-column:span 6;}
  .gallery .g-tall{grid-column:span 3;}
  .gallery .g-wide{grid-column:span 6;}
  .gallery .g-sm{grid-column:span 3;}
}
@media (max-width:560px){
  /* galleries become swipeable carousels on phones */
  .gallery{
    display:flex;overflow-x:auto;gap:12px;
    grid-auto-rows:initial;
    scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
    padding-bottom:12px;margin-bottom:-4px;
    scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;
  }
  .gallery::-webkit-scrollbar{height:5px;}
  .gallery::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:99px;}
  .gallery figure{
    flex:0 0 84%;scroll-snap-align:center;height:260px;
    grid-column:auto !important;grid-row:auto !important;
  }
  .gallery figcaption{opacity:1;}
}
