/*
 * COMSENSE — portfolio.css
 * Project cards/grid (block + shortcode + archive) and the single-project layout.
 * Tokens, buttons and section headers come from global.css.
 * ============================================================ */

/* ── PROJECT CARD GRID (block / shortcode / archive) ── */
.pf-feature{padding:120px 0;background:#fff}
.pf-feature .oh-wrap{margin-bottom:56px}
.pf-grid{display:grid;gap:24px}
.pf-cols-2{grid-template-columns:repeat(2,1fr)}
.pf-cols-3{grid-template-columns:repeat(3,1fr)}
.pf-cols-4{grid-template-columns:repeat(4,1fr)}

.pf-card{position:relative;overflow:hidden;display:block;text-decoration:none;border-radius:3px;aspect-ratio:4/3;background:var(--green-800);transition:transform .6s cubic-bezier(.2,.7,.2,1),box-shadow .6s}
.pf-card:hover{transform:translateY(-4px);box-shadow:0 30px 70px rgba(10,24,18,.26)}
.pf-card-media{position:absolute;inset:0;display:block}
.pf-card-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .5s;filter:saturate(.92)}
.pf-card:hover .pf-card-media img{transform:scale(1.07);filter:saturate(1.05)}
.pf-card-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:28px 26px;color:#fff;pointer-events:none;background:linear-gradient(180deg,rgba(10,24,18,0) 42%,rgba(10,24,18,.5) 72%,rgba(10,24,18,.9) 100%)}
.pf-card-name{font-family:var(--serif);font-size:1.3rem;font-weight:400;line-height:1.2;letter-spacing:-.005em;position:relative;padding-bottom:14px}
.pf-card-name::after{content:'';position:absolute;left:0;bottom:5px;width:26px;height:2px;background:var(--amber);transition:width .5s cubic-bezier(.2,.7,.2,1)}
.pf-card:hover .pf-card-name::after{width:58px}
.pf-card-sub{font-size:.74rem;color:rgba(255,255,255,.8);letter-spacing:.02em;line-height:1.4}
.pf-card-arrow{position:absolute;top:16px;right:16px;z-index:3;width:42px;height:42px;border-radius:50%;background:rgba(248,244,238,.14);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.28);display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7) rotate(-12deg);transition:opacity .45s,transform .45s,background .3s}
.pf-card-arrow svg{width:17px;height:17px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pf-card:hover .pf-card-arrow{opacity:1;transform:scale(1) rotate(0);background:var(--amber)}
.pf-card:hover .pf-card-arrow svg{stroke:var(--green-900)}
.pf-cta-wrap{margin-top:64px;text-align:center;display:flex;justify-content:center;gap:28px;flex-wrap:wrap}

/* ── ARCHIVE HERO (editorial, full-bleed) ── */
.pf-hero{position:relative;min-height:88vh;display:flex;align-items:center;overflow:hidden;background:var(--green-800)}
.pf-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;animation:pfHeroZoom 14s ease-out forwards}
@keyframes pfHeroZoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.pf-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,24,18,.55) 0%,rgba(10,24,18,.4) 45%,rgba(10,24,18,.8) 100%)}
.pf-hero-inner{position:relative;z-index:2;width:100%;max-width:var(--wrap);margin:0 auto;padding:0 44px;color:#fff}
.pf-hero-eyebrow{font-size:.72rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--amber);margin-bottom:22px;display:flex;align-items:center;gap:14px;opacity:0;animation:pfUp .9s .15s cubic-bezier(.2,.7,.2,1) forwards}
.pf-hero-eyebrow::before{content:'';width:34px;height:1px;background:var(--amber);opacity:.8}
.pf-hero h1{font-family:var(--serif);font-size:clamp(2.6rem,6vw,5rem);font-weight:300;line-height:1.04;letter-spacing:-.01em;max-width:14ch;margin-bottom:24px;opacity:0;animation:pfUp 1s .3s cubic-bezier(.2,.7,.2,1) forwards}
.pf-hero h1 em{font-style:italic;color:var(--amber);font-weight:400}
.pf-hero p{font-size:1.06rem;color:rgba(255,255,255,.82);line-height:1.8;max-width:600px;font-weight:300;opacity:0;animation:pfUp 1s .45s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes pfUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
.pf-hero-scroll{position:absolute;z-index:2;left:50%;bottom:34px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:9px;color:rgba(255,255,255,.85);text-decoration:none;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;opacity:0;animation:pfUp 1s .7s forwards}
.pf-hero-scroll svg{width:20px;height:20px;fill:none;stroke:var(--amber);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;animation:pfBob 1.8s ease-in-out infinite}
@keyframes pfBob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ── EDITORIAL ALTERNATING LIST ── */
.pf-editorial{padding:120px 0;background:#fff}
.pf-ed-item{display:grid;grid-template-columns:1.18fr 1fr;align-items:center;gap:72px;padding:0 0 110px}
.pf-ed-item:last-of-type{padding-bottom:0}
.pf-ed-item:nth-child(even) .pf-ed-media{order:2}
.pf-ed-item:nth-child(even) .pf-ed-text{order:1;padding-left:0;padding-right:14px;text-align:right}
.pf-ed-item:nth-child(even) .pf-ed-text .pf-ed-meta,
.pf-ed-item:nth-child(even) .pf-ed-text .pf-ed-link{margin-left:auto}
.pf-ed-item:nth-child(even) .pf-ed-title::after{margin-left:auto}

.pf-ed-media{position:relative;display:block;overflow:hidden;border-radius:4px;aspect-ratio:5/4;background:var(--green-800)}
.pf-ed-media img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.92);transition:transform 1.2s cubic-bezier(.2,.7,.2,1),filter .6s}
.pf-ed-media:hover img{transform:scale(1.06);filter:saturate(1.04)}
.pf-ed-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,24,18,0) 55%,rgba(10,24,18,.32) 100%);opacity:0;transition:opacity .5s}
.pf-ed-media:hover::after{opacity:1}
.pf-ed-view{position:absolute;z-index:2;left:50%;top:50%;transform:translate(-50%,-50%) scale(.86);display:inline-flex;align-items:center;gap:10px;padding:14px 26px;background:rgba(248,244,238,.92);color:var(--green-900);border-radius:40px;font-size:.74rem;font-weight:600;letter-spacing:.04em;opacity:0;transition:opacity .45s cubic-bezier(.2,.7,.2,1),transform .45s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.pf-ed-view svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.pf-ed-media:hover .pf-ed-view{opacity:1;transform:translate(-50%,-50%) scale(1)}

.pf-ed-index{font-size:.72rem;font-weight:600;letter-spacing:.26em;color:var(--amber);margin-bottom:18px}
.pf-ed-title{font-family:var(--serif);font-size:clamp(1.9rem,3.2vw,2.9rem);font-weight:300;line-height:1.08;letter-spacing:-.01em;color:var(--green-700);margin:0 0 6px}
.pf-ed-title a{color:inherit;text-decoration:none;transition:color .25s}
.pf-ed-title a:hover{color:var(--amber)}
.pf-ed-title::after{content:'';display:block;width:46px;height:2px;background:var(--amber);margin:20px 0 0}
.pf-ed-meta{font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-mut);margin-top:18px;max-width:34ch}
.pf-ed-exc{font-size:1rem;color:var(--text-2);line-height:1.8;font-weight:300;margin:18px 0 0;max-width:42ch}
.pf-ed-item:nth-child(even) .pf-ed-exc{margin-left:auto}
.pf-ed-link{display:inline-flex;align-items:center;gap:10px;margin-top:26px;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--green-700);text-decoration:none;transition:gap .3s,color .25s}
.pf-ed-link svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.pf-ed-link:hover{color:var(--amber);gap:16px}

/* scroll reveal */
.pf-ed-item.is-reveal{opacity:0;transform:translateY(40px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.pf-ed-item.is-reveal.in{opacity:1;transform:none}

.pf-ed-pagination{margin-top:30px;display:flex;justify-content:center}
.pf-ed-pagination ul{list-style:none;display:flex;gap:8px;margin:0;padding:0}
.pf-ed-pagination a,.pf-ed-pagination span{display:flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;border:1px solid var(--line-2);border-radius:4px;color:var(--green-700);text-decoration:none;font-size:.85rem;transition:background .2s,color .2s,border-color .2s}
.pf-ed-pagination a:hover{background:var(--green-700);color:#fff;border-color:var(--green-700)}
.pf-ed-pagination .current{background:var(--amber);color:var(--green-900);border-color:var(--amber);font-weight:600}
.pf-ed-empty{text-align:center;color:var(--text-mut);padding:40px 0}

/* ── SINGLE PROJECT (minimal · luxury · editorial) ── */

/* hero — framed editorial plate with overlaid title */
.pj-hero{position:relative;background:var(--cream);padding:26px 26px 0}
.pj-hero-media{position:relative;height:min(82vh,820px);border-radius:6px;overflow:hidden;background:var(--green-800);box-shadow:0 40px 90px -30px rgba(10,24,18,.5)}
.pj-hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform-origin:50% 50%;animation:pjKen 20s ease-out forwards}
@keyframes pjKen{from{transform:scale(1.1)}to{transform:scale(1)}}
.pj-hero-media::before{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,24,18,.42) 0%,rgba(10,24,18,0) 26%,rgba(10,24,18,0) 50%,rgba(10,24,18,.85) 100%)}

.pj-back{position:absolute;z-index:3;top:30px;left:34px;display:inline-flex;align-items:center;gap:9px;color:rgba(255,255,255,.92);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;padding:9px 16px 9px 13px;border:1px solid rgba(255,255,255,.32);border-radius:40px;backdrop-filter:blur(5px);background:rgba(10,24,18,.16);transition:background .25s,gap .3s,border-color .25s}
.pj-back svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.pj-back:hover{background:rgba(10,24,18,.4);border-color:rgba(255,255,255,.55);gap:12px}
.pj-back:hover svg{transform:translateX(-3px)}

.pj-hero-inner{position:absolute;z-index:2;left:0;right:0;bottom:0;max-width:var(--wrap);margin:0 auto;padding:0 52px 60px;color:#fff}
.pj-hero-eyebrow{display:flex;align-items:center;gap:13px;font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--amber);margin-bottom:20px;opacity:0;animation:pfUp .9s .25s cubic-bezier(.2,.7,.2,1) forwards}
.pj-hero-eyebrow i{width:26px;height:1px;background:var(--amber);opacity:.7;display:inline-block}
.pj-hero h1{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4.4rem);font-weight:300;line-height:1.04;letter-spacing:-.014em;margin:0 0 14px;max-width:18ch;opacity:0;animation:pfUp 1s .38s cubic-bezier(.2,.7,.2,1) forwards}
.pj-hero-sub{font-size:1.04rem;color:rgba(255,255,255,.82);font-weight:300;max-width:600px;opacity:0;animation:pfUp 1s .52s cubic-bezier(.2,.7,.2,1) forwards}

.pj-hero-scroll{position:absolute;z-index:3;left:50%;bottom:26px;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;color:rgba(255,255,255,.85);text-decoration:none;font-size:.64rem;letter-spacing:.24em;text-transform:uppercase;opacity:0;animation:pfUp 1s .7s forwards}
.pj-hero-scroll svg{width:19px;height:19px;fill:none;stroke:var(--amber);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;animation:pfBob 1.8s ease-in-out infinite}

/* body: story + details (left) · gallery rail (right) */
.pj-body{background:var(--cream);padding:100px 0}
.pj-layout{display:grid;grid-template-columns:1fr 340px;gap:72px;align-items:start}
.pj-layout--solo{grid-template-columns:minmax(0,820px);justify-content:center}

.pj-story{font-size:1.06rem;color:var(--text-2);line-height:1.95;font-weight:300}
.pj-story>p:first-of-type::first-letter{float:left;font-family:var(--serif);font-weight:400;color:var(--green-700);font-size:3.9rem;line-height:.82;padding:6px 15px 0 0}
.pj-story h2,.pj-story h3{font-family:var(--serif);color:var(--green-700);font-weight:400;line-height:1.25;letter-spacing:-.005em;margin:40px 0 13px}
.pj-story h2{font-size:1.75rem}.pj-story h3{font-size:1.3rem}
.pj-story h3{padding-top:14px;border-top:1px solid var(--line-2)}
.pj-story p{margin-bottom:20px}
.pj-story strong{color:var(--green-700);font-weight:600}
.pj-story ul{list-style:none;margin:10px 0 24px;padding:0}
.pj-story ul li{position:relative;padding-left:26px;margin-bottom:10px;line-height:1.6}
.pj-story ul li::before{content:'';position:absolute;left:0;top:12px;width:14px;height:1px;background:var(--amber)}

/* details (under the story, in the main column) */
.pj-details{margin-top:54px;padding-top:46px;border-top:1px solid var(--line-2);display:grid;grid-template-columns:1fr 1fr;gap:44px 56px}
.pj-details .pj-d-block:first-child{grid-column:1 / -1}
.pj-dlabel{font-size:.66rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--amber);margin-bottom:20px}
.pj-spec-list{margin:0}
.pj-spec{display:flex;justify-content:space-between;gap:24px;padding:14px 0;border-bottom:1px solid var(--line-3)}
.pj-spec:first-child{border-top:1px solid var(--line-3)}
.pj-spec dt{margin:0;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-mut)}
.pj-spec dd{margin:0;font-size:.95rem;color:var(--green-700);font-weight:500;text-align:right}
.pj-details .pj-hl{grid-column:1 / -1}
.pj-hl .pj-highlights{grid-template-columns:1fr 1fr;gap:13px 30px}
.pj-highlights{margin:0;list-style:none;padding:0;display:grid;gap:12px}
.pj-highlights li{position:relative;padding-left:29px;font-size:.93rem;color:var(--text-2);line-height:1.55}
.pj-highlights li::before{content:'';position:absolute;left:0;top:1px;width:19px;height:19px;border-radius:50%;background:var(--green-700);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}
.pj-details .pj-palette{grid-column:1 / -1}
.pj-palette-bar{display:flex;height:120px;border-radius:5px;overflow:hidden;box-shadow:0 16px 36px rgba(10,24,18,.16)}
.pj-band{flex:1;display:block;transition:flex .45s cubic-bezier(.2,.7,.2,1)}
.pj-palette-bar:hover .pj-band{flex:.78}
.pj-palette-bar .pj-band:hover{flex:1.6}
.pj-palette-names{display:flex;margin-top:11px}
.pj-palette-names span{flex:1;text-align:center;padding:0 6px;font-size:.72rem;letter-spacing:.02em;color:var(--text-mut);line-height:1.35}
.pj-d-cta{display:inline-flex;align-items:center;gap:11px;margin-top:48px;padding:16px 30px;background:var(--green-700);color:#fff;border-radius:4px;font-weight:600;font-size:.84rem;letter-spacing:.04em;text-decoration:none;transition:background .25s,gap .3s}
.pj-d-cta svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.pj-d-cta:hover{background:var(--green-800);gap:16px}

/* shared gallery item (rail + masonry) */
.pj-gal-item{position:relative;display:block;overflow:hidden;border-radius:3px;cursor:zoom-in;background:var(--cream-2);border:none;padding:0;width:100%}
.pj-gal-item img{width:100%;display:block;filter:saturate(.94);transition:transform .8s cubic-bezier(.2,.7,.2,1),filter .5s}
.pj-gal-item:hover img{transform:scale(1.05);filter:saturate(1.04)}
.pj-gal-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(10,24,18,.26);opacity:0;transition:opacity .35s}
.pj-gal-zoom svg{width:30px;height:30px;fill:none;stroke:#fff;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.pj-gal-item:hover .pj-gal-zoom{opacity:1}

/* side rail — five square thumbnails */
.pj-rail{position:sticky;top:96px}
.pj-rail .pj-dlabel{margin-bottom:16px}
.pj-rail-imgs{display:flex;flex-direction:column;gap:12px}
.pj-rail .pj-gal-item{aspect-ratio:1/1}
.pj-rail .pj-gal-item img{height:100%;object-fit:cover}

/* full gallery (asymmetric mosaic — varied sizes) */
.pj-gallery-full{background:var(--cream);padding:0 0 104px}
.pj-gallery-head{margin-bottom:26px}
.pj-masonry{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;grid-auto-flow:dense;gap:14px}
.pj-masonry .pj-gal-item{height:100%}
.pj-masonry .pj-gal-item img{height:100%;object-fit:cover}
.pj-masonry .pj-gal-item:nth-child(6n+1){grid-column:span 2;grid-row:span 2}
.pj-masonry .pj-gal-item:nth-child(6n+4){grid-column:span 2}
.pj-masonry .pj-gal-item:nth-child(6n+5){grid-row:span 2}

/* lightbox */
.pj-lb{position:fixed;inset:0;z-index:1000;background:rgba(10,24,18,.94);display:none;align-items:center;justify-content:center;padding:30px}
.pj-lb.open{display:flex}
.pj-lb img{max-width:94vw;max-height:90vh;object-fit:contain;border-radius:3px}
.pj-lb-close,.pj-lb-prev,.pj-lb-next{position:absolute;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.pj-lb-close:hover,.pj-lb-prev:hover,.pj-lb-next:hover{background:var(--amber);border-color:var(--amber);color:var(--green-900)}
.pj-lb-close{top:24px;right:24px}
.pj-lb-prev{left:24px;top:50%;margin-top:-24px}
.pj-lb-next{right:24px;top:50%;margin-top:-24px}
.pj-lb svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* related */
.pj-related{padding:104px 0;background:var(--cream);border-top:1px solid var(--line-2)}

/* ── RESPONSIVE ── */
@media(max-width:1040px){
  .pf-cols-3,.pf-cols-4{grid-template-columns:repeat(2,1fr)}
  .pj-layout,.pj-layout--solo{grid-template-columns:1fr;gap:56px;justify-content:stretch}
  .pj-rail{position:static}
  .pj-rail-imgs{flex-direction:row;flex-wrap:wrap}
  .pj-rail .pj-gal-item{flex:1 1 calc(33.333% - 11px)}
  .pj-masonry{grid-template-columns:repeat(3,1fr);grid-auto-rows:170px}
  .pf-editorial{padding:84px 0}
  .pf-ed-item{grid-template-columns:1fr;gap:30px;padding-bottom:74px}
  .pf-ed-item:nth-child(even) .pf-ed-media{order:0}
  .pf-ed-item:nth-child(even) .pf-ed-text{order:0;text-align:left;padding-right:0}
  .pf-ed-item:nth-child(even) .pf-ed-text .pf-ed-meta,
  .pf-ed-item:nth-child(even) .pf-ed-text .pf-ed-link,
  .pf-ed-item:nth-child(even) .pf-ed-exc{margin-left:0}
  .pf-ed-item:nth-child(even) .pf-ed-title::after{margin-left:0}
  .pf-ed-media{aspect-ratio:16/10}
}
@media(max-width:640px){
  .pf-feature{padding:70px 0}
  .pf-cols-2,.pf-cols-3,.pf-cols-4{grid-template-columns:1fr}
  .pj-hero{padding:14px 14px 0}
  .pj-hero-media{height:64vh}
  .pj-hero-inner{padding:0 22px 38px}
  .pj-back{top:18px;left:18px;font-size:.66rem;padding:8px 13px 8px 11px}
  .pj-hero-scroll{display:none}
  .pj-body{padding:60px 0}
  .pj-story{font-size:1.02rem}
  .pj-story>p:first-of-type::first-letter{font-size:3.2rem}
  .pj-details{grid-template-columns:1fr;gap:36px}
  .pj-details .pj-d-block:first-child{grid-column:auto}
  .pj-hl .pj-highlights{grid-template-columns:1fr}
  .pj-masonry{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px;gap:10px}
  .pf-hero{min-height:78vh}
  .pf-hero-inner{padding:0 20px}
  .pf-editorial{padding:60px 0}
  .pf-ed-item{padding-bottom:56px}
  .pf-ed-view{opacity:1;transform:translate(-50%,-50%) scale(1)}
}
@media(prefers-reduced-motion:reduce){
  .pf-hero img,.pf-hero-eyebrow,.pf-hero h1,.pf-hero p,.pf-hero-scroll,.pf-hero-scroll svg,
  .pj-hero-media img,.pj-hero-eyebrow,.pj-hero h1,.pj-hero-sub,.pj-hero-scroll,.pj-hero-scroll svg{animation:none;opacity:1}
  .pf-ed-item.is-reveal{opacity:1;transform:none;transition:none}
}
