/* projects-page.css — page-specific styles. Shared chrome (colours, nav, footer,
   fonts, buttons, animations) lives in site.css. */

/* NAV */
  .nav{position:fixed;top:0;left:0;right:0;z-index:40;background:rgba(251,253,251,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
/* PAGE HERO */
  .phero{position:relative;padding:150px 0 60px;overflow:hidden;background:#ffffff}
.phero .b{position:absolute;border-radius:50%;filter:blur(8px);z-index:0}
.phero .b1{width:340px;height:340px;background:radial-gradient(circle,rgba(255,210,74,.5),transparent 65%);top:-80px;right:-40px}
.phero .b2{width:300px;height:300px;background:radial-gradient(circle,rgba(63,158,208,.32),transparent 65%);bottom:-120px;left:-60px}
.phero .wrap{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-display);font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--yellow-deep);border-radius:2px}
.phero h1{font-size:clamp(2.3rem,5.4vw,3.7rem);line-height:1.08;color:var(--green-darker);font-weight:700;margin:16px 0 16px;max-width:16ch}
.phero p{color:var(--muted);font-size:1.08rem;line-height:1.7;max-width:60ch}
.phero-stats{display:flex;gap:38px;flex-wrap:wrap;margin-top:34px}
.phero-stats .st b{display:block;font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--green-darker);line-height:1}
.phero-stats .st span{font-size:.84rem;color:var(--muted);font-weight:500}
.phero-stats .st b .u{color:var(--yellow-deep)}
/* PROJECTS GRID */
  .pad{padding:64px 0;position:relative;z-index:1}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;
     box-shadow:0 30px 60px -46px rgba(18,46,35,.5);transition:transform .3s var(--ease),box-shadow .3s;opacity:0;transform:translateY(28px)}
.pcard.in{opacity:1;transform:none}
.pcard:hover{transform:translateY(-6px);box-shadow:0 50px 84px -44px rgba(18,46,35,.55)}
.pc-top{position:relative;height:152px;display:grid;place-items:center;overflow:hidden}
.pc-top::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 82% 8%,rgba(255,255,255,.42),transparent 55%)}
.pc-deco{position:absolute;border-radius:50%;background:rgba(255,255,255,.16);z-index:0}
.pc-deco.d1{width:120px;height:120px;top:-40px;left:-30px}
.pc-deco.d2{width:70px;height:70px;bottom:-22px;right:24px;background:rgba(255,255,255,.13)}
.emblem{width:62px;height:62px;stroke:#fff;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1;filter:drop-shadow(0 6px 12px rgba(0,0,0,.18))}
.pc-status{position:absolute;top:14px;left:14px;z-index:2;background:rgba(255,255,255,.94);color:var(--green-darker);font-size:.7rem;font-weight:700;letter-spacing:.05em;padding:5px 11px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;text-transform:uppercase}
.pc-status::before{content:"";width:7px;height:7px;border-radius:50%;background:#46a37a;box-shadow:0 0 0 3px rgba(70,163,122,.22)}
.pc-eu{position:absolute;top:14px;right:14px;z-index:2;background:rgba(20,40,30,.34);color:#fff;font-size:.64rem;font-weight:600;letter-spacing:.05em;padding:5px 10px;border-radius:999px;backdrop-filter:blur(3px)}
.pc-top:has(.pc-photo){height:200px;background:#f7faf9!important;border-bottom:1px solid var(--line)}
.pc-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:1;display:block;padding:18px}
.pc-top:has(.pc-photo) .emblem,.pc-top:has(.pc-photo) .pc-deco,.pc-top:has(.pc-photo)::after{display:none}
.pc-body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.pc-code{font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:var(--green-darker);letter-spacing:.01em}
.pc-sub{font-size:.78rem;font-weight:700;color:var(--c,#2C8067);text-transform:uppercase;letter-spacing:.08em;margin-top:5px}
.pc-desc{color:var(--muted);font-size:.93rem;line-height:1.62;margin:12px 0 16px;flex:1}
.pc-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:18px}
.pc-tag{font-size:.73rem;font-weight:600;color:var(--green-darker);background:var(--cream);border:1px solid var(--line);border-radius:999px;padding:5px 11px;display:inline-flex;align-items:center;gap:6px}
.pc-tag.dur{color:var(--yellow-deep);background:#fff7e2;border-color:#f3e3b3}
.pc-link{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--green);font-size:.92rem;margin-top:auto}
.pc-link svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.pc-link:hover svg{transform:translateX(4px)}
/* CTA band */
  .ctaband{margin:30px 0 80px}
.ctaband .inner{position:relative;overflow:hidden;border-radius:30px;padding:54px 48px;text-align:center;
     background:linear-gradient(135deg,var(--green-deep),var(--green));box-shadow:0 50px 90px -50px rgba(18,46,35,.7)}
.ctaband .inner::before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,74,.4),transparent 65%);top:-100px;right:-40px}
.ctaband .inner::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(124,198,232,.35),transparent 65%);bottom:-120px;left:-30px}
.ctaband h2{position:relative;z-index:1;color:#fff;font-size:clamp(1.7rem,3.6vw,2.5rem);font-weight:700;margin-bottom:12px}
.ctaband h2 .serif{color:var(--yellow)}
.ctaband p{position:relative;z-index:1;color:rgba(255,255,255,.86);max-width:54ch;margin:0 auto 26px;line-height:1.6}
.ctaband .btn{position:relative;z-index:1;display:inline-flex;align-items:center;gap:10px;background:var(--btn-yellow);color:var(--green-darker);font-weight:700;padding:15px 30px;border-radius:999px;font-size:1rem;box-shadow:0 18px 36px -16px rgba(0,0,0,.4)}
.ctaband .btn svg{width:19px;height:19px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* FOOTER */
  .foot{background:var(--green-darker);color:#cfe6da;padding:60px 0 28px}
@media(max-width:980px){
.proj-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
.proj-grid,.foot-grid{grid-template-columns:1fr}
.phero-stats{gap:24px}
}
@media(prefers-reduced-motion:reduce){
.pcard{opacity:1;transform:none}
}
