/* ===================================================================
   MFAZA — PROJECTS INDEX layouts · set 3 (projects12–projects16)
   Self-contained, dark + gold + same fonts. After style.css.
   master-detail · horizontal panels · collage · v-accordion · numbers
   =================================================================== */
.py-hide{display:none!important}

/* ---------- A) MASTER–DETAIL SPLIT ---------- */
.py-md{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,72px);align-items:start}
.py-md__list{border-top:1px solid var(--line)}
.py-md__row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:18px 4px;
  border-bottom:1px solid var(--line);cursor:pointer;transition:padding .4s var(--ease),color .35s}
.py-md__row .t{font-family:var(--display);font-weight:200;font-size:clamp(18px,2vw,30px);text-transform:uppercase;line-height:1.05;transition:color .35s}
.py-md__row .c{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);flex:0 0 auto}
.py-md__row:hover .t,.py-md__row.active .t{color:var(--accent)}
.py-md__row.active{padding-left:12px}
.py-md__preview{position:sticky;top:100px}
.py-md__img{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--bg-2)}
.py-md__img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s var(--ease),transform 6s var(--ease);transform:scale(1.04)}
.py-md__img img.show{opacity:1;transform:scale(1)}
.py-md__info{margin-top:24px}
.py-md__info .code{font-family:var(--display);font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent)}
.py-md__info h3{font-family:var(--display);font-weight:200;font-size:clamp(24px,2.6vw,40px);text-transform:uppercase;margin:12px 0 14px;line-height:1.04}
.py-md__info .meta{display:flex;gap:22px;flex-wrap:wrap;font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
@media(max-width:900px){.py-md{grid-template-columns:1fr}.py-md__preview{display:none}.py-md__row{padding:22px 4px}}

/* ---------- B) HORIZONTAL SCROLL PANELS ---------- */
.py-hs-wrap{position:relative}
.py-hs{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:thin}
.py-hs::-webkit-scrollbar{height:3px}.py-hs::-webkit-scrollbar-thumb{background:var(--accent)}
.py-hs__panel{position:relative;flex:0 0 min(80vw,860px);height:72vh;overflow:hidden;scroll-snap-align:center;border-right:1px solid rgba(0,0,0,.4)}
.py-hs__panel img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%) brightness(.7);transition:transform 1.2s var(--ease),filter .7s}
.py-hs__panel:hover img{transform:scale(1.04);filter:grayscale(0) brightness(.88)}
.py-hs__panel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,17,17,.25),transparent 35%,rgba(17,17,17,.92));z-index:1}
.py-hs__b{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(28px,3vw,48px);width:100%}
.py-hs__b .num{font-family:var(--serif);font-size:clamp(40px,5vw,80px);color:transparent;-webkit-text-stroke:1px rgba(200,178,138,.6);line-height:.8;display:block;margin-bottom:14px}
.py-hs__b .code{font-family:var(--display);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent)}
.py-hs__b h3{font-family:var(--display);font-weight:200;font-size:clamp(24px,2.6vw,42px);text-transform:uppercase;margin:10px 0 8px;line-height:1.04}
.py-hs__b .loc{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.py-hs__panel a{position:absolute;inset:0;z-index:3}
.py-hs__hint{margin-top:20px;display:flex;align-items:center;gap:12px;font-family:var(--display);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.py-hs__hint .l{width:60px;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}

/* ---------- C) SCATTERED COLLAGE ---------- */
.py-col{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px);padding:10px}
.py-colcard{background:#171717;border:1px solid var(--line);padding:12px 12px 16px;transition:transform .55s var(--ease),box-shadow .55s,border-color .4s;will-change:transform}
.py-colcard:nth-child(3n+1){transform:rotate(-2.2deg)}
.py-colcard:nth-child(3n+2){transform:rotate(1.4deg)}
.py-colcard:nth-child(3n+3){transform:rotate(-0.8deg)}
.py-colcard:hover{transform:rotate(0) scale(1.03);z-index:2;box-shadow:0 30px 70px rgba(0,0,0,.5);border-color:var(--line-strong)}
.py-colimg{position:relative;overflow:hidden;aspect-ratio:4/3}
.py-colimg img{width:100%;height:100%;object-fit:cover;filter:grayscale(20%)}
.py-colcard .cap{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-top:14px}
.py-colcard h3{font-family:var(--display);font-weight:300;font-size:15px;text-transform:uppercase;line-height:1.1}
.py-colcard .code{font-family:var(--display);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}
.py-colcard a{position:absolute;inset:0;z-index:3}
.py-colcard{position:relative}
@media(max-width:900px){.py-col{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.py-col{grid-template-columns:1fr}.py-colcard,.py-colcard:nth-child(n){transform:none}}

/* ---------- D) VERTICAL EXPANDING ACCORDION ---------- */
.py-vacc{border-top:1px solid var(--line)}
.py-vrow{position:relative;overflow:hidden;border-bottom:1px solid var(--line);height:96px;transition:height .6s var(--ease)}
.py-vrow__bg{position:absolute;inset:0;z-index:0}
.py-vrow__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(30%) brightness(.4);opacity:0;transition:opacity .6s var(--ease),transform 6s var(--ease);transform:scale(1.06)}
.py-vrow__head{position:relative;z-index:2;height:96px;display:grid;grid-template-columns:80px 1fr auto auto;gap:24px;align-items:center;padding:0 6px;cursor:pointer}
.py-vrow__n{font-family:var(--display);font-size:13px;letter-spacing:.12em;color:var(--accent)}
.py-vrow__t{font-family:var(--display);font-weight:200;font-size:clamp(22px,2.8vw,42px);text-transform:uppercase;line-height:1;transition:color .35s}
.py-vrow__c{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.py-vrow__go{width:40px;height:40px;border:1px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--accent);transition:.4s var(--ease)}
.py-vrow.open{height:clamp(320px,40vw,460px)}
.py-vrow.open .py-vrow__bg img{opacity:1;transform:scale(1)}
.py-vrow.open .py-vrow__t{color:var(--text)}
.py-vrow.open .py-vrow__go{background:var(--accent);color:#111;border-color:var(--accent);transform:rotate(-45deg)}
.py-vrow__foot{position:absolute;left:0;bottom:0;z-index:2;padding:26px 6px;width:100%;display:flex;justify-content:space-between;gap:20px;
  opacity:0;transform:translateY(12px);transition:opacity .5s var(--ease) .15s,transform .5s var(--ease) .15s}
.py-vrow.open .py-vrow__foot{opacity:1;transform:none}
.py-vrow__foot .m{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.py-vrow__foot .m b{display:block;color:var(--text);margin-top:5px;font-weight:400}
@media(max-width:760px){.py-vrow__head{grid-template-columns:50px 1fr auto}.py-vrow__c{display:none}}

/* ---------- E) VALUE NUMBER GRID ---------- */
.py-num{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.py-numcell{position:relative;background:var(--bg);padding:clamp(30px,3vw,46px);min-height:300px;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}
.py-numcell__img{position:absolute;inset:0;z-index:0}
.py-numcell__img img{width:100%;height:100%;object-fit:cover;opacity:0;filter:grayscale(30%);transition:opacity .6s var(--ease),transform 6s var(--ease);transform:scale(1.06)}
.py-numcell:hover .py-numcell__img img{opacity:.22;transform:scale(1)}
.py-numcell>*{position:relative;z-index:1}
.py-numcell .top{display:flex;justify-content:space-between;font-family:var(--display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.py-numcell .val{font-family:var(--serif);font-size:clamp(40px,4.6vw,76px);line-height:.9;color:var(--text);margin:auto 0}
.py-numcell .val em{color:var(--accent);font-style:normal}
.py-numcell h3{font-family:var(--display);font-weight:300;font-size:clamp(17px,1.4vw,22px);text-transform:uppercase;line-height:1.1}
.py-numcell .loc{font-family:var(--display);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.py-numcell a{position:absolute;inset:0;z-index:3}
@media(max-width:980px){.py-num{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.py-num{grid-template-columns:1fr}}

/* ---------- F) FULL-WIDTH BANNER BANDS (replaces collage) ---------- */
.py-band{display:flex;flex-direction:column;gap:14px}
.py-bandrow{position:relative;height:clamp(220px,26vw,340px);overflow:hidden;background:var(--bg-2)}
.py-bandrow img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(30%) brightness(.55);transition:transform 1.2s var(--ease),filter .7s}
.py-bandrow:hover img{transform:scale(1.05);filter:grayscale(0) brightness(.78)}
.py-bandrow::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(17,17,17,.85),rgba(17,17,17,.2) 55%,rgba(17,17,17,.5));z-index:1}
.py-bandrow__in{position:relative;z-index:2;height:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:auto 1fr auto;gap:clamp(20px,4vw,60px);align-items:center}
.py-bandrow__n{font-family:var(--serif);font-size:clamp(40px,5vw,84px);color:transparent;-webkit-text-stroke:1px rgba(200,178,138,.6);line-height:1}
.py-bandrow__mid .code{font-family:var(--display);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent)}
.py-bandrow__mid h3{font-family:var(--display);font-weight:200;font-size:clamp(24px,3vw,48px);text-transform:uppercase;margin:10px 0 6px;line-height:1.02}
.py-bandrow__mid .loc{font-family:var(--display);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.py-bandrow__val{text-align:right;font-family:var(--display);font-size:clamp(14px,1.3vw,19px);color:var(--text)}
.py-bandrow__val span{display:block;font-family:var(--display);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.py-bandrow a{position:absolute;inset:0;z-index:3}
@media(max-width:760px){.py-bandrow__in{grid-template-columns:1fr}.py-bandrow__n,.py-bandrow__val{display:none}}

/* ---------- G) HOVER-REVEAL CARD GRID (replaces value grid) ---------- */
.py-rev{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.py-revcard{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.py-revcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(28%) brightness(.82);transition:transform 1.1s var(--ease),filter .6s}
.py-revcard:hover img{transform:scale(1.06);filter:grayscale(0) brightness(.7)}
.py-revcard__base{position:absolute;left:0;bottom:0;z-index:2;padding:26px;width:100%;background:linear-gradient(180deg,transparent,rgba(17,17,17,.9));transition:opacity .4s}
.py-revcard__base .code{font-family:var(--display);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent)}
.py-revcard__base h3{font-family:var(--display);font-weight:300;font-size:clamp(18px,1.5vw,23px);text-transform:uppercase;margin-top:8px;line-height:1.1}
.py-revcard:hover .py-revcard__base{opacity:0}
.py-revcard__over{position:absolute;inset:0;z-index:3;background:rgba(17,17,17,.9);backdrop-filter:blur(2px);
  padding:clamp(24px,2.4vw,36px);display:flex;flex-direction:column;justify-content:flex-end;
  opacity:0;transform:translateY(22px);transition:opacity .5s var(--ease),transform .55s var(--ease)}
.py-revcard:hover .py-revcard__over{opacity:1;transform:none}
.py-revcard__over .code{font-family:var(--display);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent)}
.py-revcard__over h3{font-family:var(--display);font-weight:200;font-size:clamp(20px,1.8vw,28px);text-transform:uppercase;margin:10px 0 14px;line-height:1.05}
.py-revcard__over p{color:var(--muted);font-size:13px;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.py-revcard__rows{display:flex;flex-direction:column;gap:0;margin-bottom:16px}
.py-revcard__rows .r{display:flex;justify-content:space-between;padding:8px 0;border-top:1px solid var(--line);font-family:var(--display);font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.py-revcard__rows .r span:first-child{color:var(--muted)}
.py-revcard a{position:absolute;inset:0;z-index:4}
@media(max-width:980px){.py-rev{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.py-rev{grid-template-columns:1fr}}
@media(hover:none){.py-revcard__over{position:static;opacity:1;transform:none;background:var(--bg-2);backdrop-filter:none}.py-revcard{aspect-ratio:auto}.py-revcard img{position:relative;height:240px}.py-revcard__base{display:none}}
