/* ============== WORKS PAGE ============== */
.page-works{background:var(--cream);color:var(--ink);}

.nav-links a.is-active{color:var(--accent);}

/* ----- HERO ----- */
.wk-hero{
  position:relative;min-height:100vh;padding:140px 32px 60px;
  display:flex;flex-direction:column;justify-content:space-between;
  overflow:hidden;
}
.wk-hero-grid{position:absolute;inset:0;display:grid;grid-template-columns:repeat(6,1fr);pointer-events:none;}
.wk-hero-grid span{border-right:1px solid var(--rule);}
.wk-hero-grid span:last-child{border-right:0;}
.wk-hero-top{display:flex;justify-content:space-between;align-items:flex-start;font-family:var(--mono);font-size:11px;letter-spacing:.06em;position:relative;z-index:1;}
.wk-eyebrow{display:flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid var(--rule);border-radius:99px;background:rgba(255,255,255,.4);backdrop-filter:blur(8px);}
.wk-eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px oklch(0.78 0.06 60 / .18);}
.wk-coord{color:var(--muted);}
.wk-coord em{font-family:var(--serif);}

.wk-title{
  font-family:var(--sans);font-weight:900;
  font-size:clamp(56px,13vw,220px);
  line-height:.88;letter-spacing:-.04em;
  text-transform:lowercase;margin:auto 0;position:relative;z-index:1;
}
.wk-title .line{display:block;overflow:hidden;}
.wk-title .word{display:inline-block;}
.wk-title .italic{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.02em;}

.wk-hero-bot{display:grid;grid-template-columns:1.5fr auto;gap:60px;align-items:flex-end;position:relative;z-index:1;}
.wk-lede{font-family:var(--serif);font-size:clamp(18px,1.8vw,26px);line-height:1.35;max-width:48ch;}
.wk-stats{display:flex;gap:30px;}
.wk-stats > div{display:flex;flex-direction:column;gap:6px;text-align:right;}
.wks-n{font-family:var(--sans);font-weight:900;font-size:clamp(48px,4.4vw,72px);line-height:.9;letter-spacing:-.03em;}
.wks-l{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;}

/* ----- FILTER BAR ----- */
.wk-filter{
  position:sticky;top:0;z-index:60;
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  padding:18px 32px;
  background:rgba(244,241,234,.7);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--rule);
}
.wkf-meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);}
.wkf-bar{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;}
.wkf-pill{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  border:1px solid var(--rule);background:transparent;
  padding:8px 14px;border-radius:99px;cursor:none;color:inherit;
  display:inline-flex;align-items:center;gap:8px;
  transition:background .35s, color .35s, border-color .35s, transform .35s;
}
.wkf-pill .wkf-c{font-size:9px;opacity:.55;}
.wkf-pill:hover{transform:translateY(-1px);border-color:var(--ink);}
.wkf-pill.is-active{background:var(--ink);color:var(--cream);border-color:var(--ink);}
.wkf-pill.is-active .wkf-c{opacity:.6;}
.wkf-toggle{display:flex;border:1px solid var(--rule);border-radius:99px;overflow:hidden;}
.wkv{font-family:var(--mono);font-size:11px;letter-spacing:.1em;background:transparent;border:0;padding:8px 14px;color:inherit;cursor:none;}
.wkv.on{background:var(--ink);color:var(--cream);}

/* ----- WORKS LIST (cinematic rows) ----- */
.wk-list{padding:0 32px 60px;}
.wk-row{
  display:grid;grid-template-columns:90px 1fr auto auto;align-items:center;gap:40px;
  padding:48px 0;border-bottom:1px solid var(--rule);
  position:relative;cursor:none;color:inherit;
  transition:padding .6s cubic-bezier(.7,0,.2,1), background .4s;
  isolation:isolate;
}
.wk-row::before{
  content:"";position:absolute;left:-32px;right:-32px;top:0;bottom:0;
  background:var(--ink);transform:scaleY(0);transform-origin:bottom;z-index:-1;
  transition:transform .55s cubic-bezier(.7,0,.2,1);
}
.wk-row:hover{padding-left:24px;color:var(--cream);}
.wk-row:hover::before{transform:scaleY(1);transform-origin:top;}

.wkr-num{font-family:var(--mono);font-size:11px;letter-spacing:.16em;opacity:.55;}
.wk-row:hover .wkr-num{opacity:.7;}

.wkr-title{
  font-family:var(--sans);font-weight:900;
  font-size:clamp(38px,5.4vw,96px);line-height:1;letter-spacing:-.03em;
  text-transform:lowercase;
  transition:transform .55s cubic-bezier(.7,0,.2,1), letter-spacing .55s;
}
.wkr-title em{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:-.01em;}
.wk-row:hover .wkr-title{transform:translateX(20px);}
.wkr-meta{display:flex;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--muted);}
.wk-row:hover .wkr-meta{color:rgba(244,241,234,.6);}

.wkr-thumb{
  width:140px;height:90px;position:relative;
  background:var(--c1);border-radius:4px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  transition:width .55s cubic-bezier(.7,0,.2,1), height .55s, transform .55s;
}
.wkr-thumb::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg, rgba(255,255,255,.04) 0 2px, transparent 2px 12px);}
.wk-row:hover .wkr-thumb{width:280px;height:160px;transform:translateX(-12px);}
.thumb-shape{background:var(--c2);}
.ts-circle{width:50%;aspect-ratio:1/1;border-radius:50%;}
.ts-bar{width:16%;height:62%;}
.ts-square{width:46%;aspect-ratio:1/1;}
.ts-arch{width:40%;height:62%;border-top-left-radius:999px;border-top-right-radius:999px;}
.ts-ring{width:48%;aspect-ratio:1/1;border-radius:50%;background:transparent;border:2px solid var(--c2);}
.ts-tri{width:0;height:0;background:transparent;border-left:40px solid transparent;border-right:40px solid transparent;border-bottom:64px solid var(--c2);}
.ts-tall{width:14%;height:78%;border-radius:99px;}
.ts-wave{
  width:60%;height:30%;background:transparent;border-top:2px solid var(--c2);border-bottom:2px solid var(--c2);
  position:relative;
}
.ts-col{width:8%;height:60%;background:var(--c2);box-shadow:14px 0 0 var(--c2), -14px 0 0 var(--c2);}
.ts-coin{width:50%;aspect-ratio:1/1;border-radius:50%;border:2px solid var(--c2);background:transparent;position:relative;}
.ts-coin::after{content:"";position:absolute;left:50%;top:50%;width:30%;height:30%;background:var(--c2);border-radius:50%;transform:translate(-50%,-50%);}
.ts-sun{width:46%;aspect-ratio:1/1;border-radius:50%;background:var(--c2);box-shadow:0 0 0 4px var(--c1), 0 0 0 5px var(--c2);}
.ts-clock{width:50%;aspect-ratio:1/1;border-radius:50%;border:2px solid var(--c2);background:transparent;position:relative;}
.ts-clock::before,.ts-clock::after{content:"";position:absolute;left:50%;top:50%;background:var(--c2);transform-origin:bottom;}
.ts-clock::before{width:2px;height:34%;transform:translate(-50%,-100%) rotate(35deg);}
.ts-clock::after{width:2px;height:24%;transform:translate(-50%,-100%) rotate(-90deg);}

.thumb-tag{position:absolute;left:10px;bottom:8px;font-family:var(--mono);font-size:9px;letter-spacing:.14em;color:rgba(244,241,234,.7);}

/* hide rows that don't match filter */
.wk-row.is-hidden{display:none;}

/* row entry animation hooks */
.wk-row .wkr-title, .wk-row .wkr-num, .wk-row .wkr-meta, .wk-row .wkr-thumb{will-change:transform,opacity,filter;}
.wk-row[data-revealed="0"] .wkr-title{opacity:0;transform:translateY(40px);filter:blur(14px);}
.wk-row[data-revealed="0"] .wkr-num,
.wk-row[data-revealed="0"] .wkr-meta{opacity:0;}
.wk-row[data-revealed="0"] .wkr-thumb{opacity:0;clip-path:inset(100% 0 0 0);}

/* ----- GRID VIEW (alternative) ----- */
.wk-list.is-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:24px 32px 80px;}
.wk-list.is-grid .wk-row{
  display:flex;flex-direction:column;padding:24px;border:1px solid var(--rule);border-bottom:1px solid var(--rule);border-radius:6px;gap:18px;
}
.wk-list.is-grid .wk-row::before{display:none;}
.wk-list.is-grid .wk-row:hover{padding-left:24px;background:var(--ink);color:var(--cream);}
.wk-list.is-grid .wkr-thumb{width:100%;height:200px;}
.wk-list.is-grid .wk-row:hover .wkr-thumb{width:100%;height:220px;transform:none;}
.wk-list.is-grid .wkr-title{font-size:clamp(28px,2.4vw,36px);}
.wk-list.is-grid .wkr-meta{font-size:10px;}

/* ----- END SECTION ----- */
.wk-end{padding:160px 32px 0;background:var(--ink);color:var(--cream);position:relative;}
.wke-meta{display:flex;gap:18px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:rgba(244,241,234,.55);margin-bottom:40px;}
.wke-title{font-family:var(--sans);font-weight:900;font-size:clamp(56px,9vw,160px);line-height:.9;letter-spacing:-.03em;text-transform:lowercase;text-align:left;}
.wke-title em{font-family:var(--serif);font-style:italic;font-weight:400;}
.wke-sub{margin-top:30px;font-family:var(--serif);font-size:22px;color:rgba(244,241,234,.7);max-width:36ch;}
.wk-end .marquee{margin-top:120px;}
.wk-end .footer{display:flex;justify-content:space-between;padding:30px 0 40px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:rgba(244,241,234,.5);}

/* ----- responsive ----- */
@media (max-width:900px){
  .wk-filter{grid-template-columns:1fr;}
  .wkf-meta{display:none;}
  .wkf-toggle{justify-self:flex-end;}
  .wk-hero-bot{grid-template-columns:1fr;gap:30px;}
  .wk-stats{justify-content:flex-start;}
  .wk-row{grid-template-columns:60px 1fr auto;gap:20px;padding:36px 0;}
  .wkr-meta{display:none;}
  .wkr-thumb{width:90px;height:60px;}
  .wk-row:hover .wkr-thumb{width:120px;height:80px;}
  .wk-list.is-grid{grid-template-columns:repeat(1,1fr);}
}

/* ============================================================
   T2ELVE — works page mobile + filter overlap fix
   ============================================================ */

/* Make the sticky filter sit BELOW the fixed nav, not under it */
.wk-filter{
  top: 64px;
  background: rgba(244,241,234,.92);
}
.wk-row::before{ left:-20px; right:-20px; }

@media (max-width:900px){
  .wk-filter{
    top: 56px;
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 12px 18px;
  }
  .wkf-meta{ display:none; }
  .wkf-bar{ justify-content:flex-start; }
  .wkf-toggle{ align-self:flex-end; }
  .wkf-pill{ font-size:10px; padding:6px 10px; }
}

@media (max-width:700px){
  .wk-hero{ padding:120px 20px 40px; }
  .wk-title{ font-size:clamp(48px,16vw,96px); }
  .wk-hero-bot{ grid-template-columns:1fr; gap:24px; }
  .wk-stats{ flex-wrap:wrap; gap:18px; }

  .wk-filter{ top:52px; padding:10px 16px; }
  .wkf-bar{ gap:4px; }
  .wkf-pill{ font-size:9px; letter-spacing:.06em; padding:5px 8px; }
  .wkf-toggle .wkv{ font-size:10px; padding:6px 10px; }

  .wk-list{ padding:0 18px 60px; }
  .wk-row{
    grid-template-columns: 36px 1fr auto;
    gap: 12px;
    padding: 22px 0;
    align-items: center;
  }
  .wk-row .wkr-meta{ display:none; }
  .wkr-num{ font-size:9px; letter-spacing:.12em; }
  .wkr-title{ font-size:22px; }
  .wkr-thumb{ width:72px; height:48px; }
  .wk-row:hover{ padding-left:0; }

  .wk-end{ padding:60px 20px; }
}
