/* =====================================================================
   ART IS EVERYTHING — sub-page layouts (All Films index, Collection)
   Loaded alongside film.css (tokens, Bootzy @font-face, .fnav, .footer).
   ===================================================================== */

main { background: var(--paper); }

/* ----------------------- page header ----------------------------- */
.phead { background: var(--black); color: var(--paper-on-black); padding: clamp(7rem, 16vh, 12rem) var(--pad) clamp(3rem, 7vh, 6rem); }
.phead__inner { max-width: var(--maxw); margin: 0 auto; }
.phead .rule { border-color: var(--line-on-black); }
.phead .rule > span { color: var(--paper-on-black); }
.phead .rule > span:first-child { color: var(--muted-on-black); }
.phead .rule > span:last-child { margin-left: auto; color: var(--muted-on-black); }
.phead__title { font-family: "Bootzy", sans-serif; text-transform: uppercase; font-weight: 400; line-height: 0.9; letter-spacing: -0.01em; font-size: clamp(3.2rem, 12vw, 12rem); margin: clamp(1.4rem, 3.5vh, 2.6rem) 0 0; }
.phead__intro { margin-top: clamp(1.2rem, 3vh, 2rem); max-width: 44ch; font-size: clamp(1.05rem, 1.7vw, 1.5rem); line-height: 1.4; color: var(--paper-on-black); }

/* filter row (visual; All + mediums) */
.filters { margin-top: clamp(1.8rem, 4vh, 3rem); display: flex; flex-wrap: wrap; gap: 0.5rem 0.5rem; }
.filters a { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; padding: 0.55rem 1rem; border: 1px solid var(--line-on-black); border-radius: 100px; color: var(--muted-on-black); transition: color 0.3s var(--ease), border-color 0.3s var(--ease); }
.filters a:hover, .filters a[aria-current="true"] { color: var(--black); background: var(--paper-on-black); border-color: var(--paper-on-black); }

/* ------------------------- films grid ---------------------------- */
.fgrid { max-width: var(--maxw); margin: 0 auto; padding: clamp(2.5rem, 6vh, 5rem) var(--pad) clamp(4rem, 9vh, 8rem);
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: clamp(1.5rem, 3vw, 3rem) clamp(1.2rem, 2.4vw, 2.2rem); }
.fcard { display: block; color: var(--ink); }
.fcard__still { position: relative; aspect-ratio: 4 / 3; overflow: hidden; background: var(--paper-2); }
.fcard__still::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(135deg, rgba(0,0,0,0.05) 0 2px, transparent 2px 10px); z-index: 1; }
.fcard__still img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.8s var(--ease); }
.fcard:hover .fcard__still img { transform: scale(1.05); }
.fcard__num { position: absolute; left: 1rem; top: 0.9rem; z-index: 2; font-size: 0.72rem; font-weight: 600; letter-spacing: 0.16em; color: rgba(255,255,255,0.85); }
.fcard__play { position: absolute; right: 1rem; bottom: 0.9rem; z-index: 2; width: 44px; height: 44px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,0.9); display: grid; place-items: center; transition: background 0.4s var(--ease); }
.fcard__play svg { width: 32%; margin-left: 8%; fill: #fff; transition: fill 0.4s var(--ease); }
.fcard:hover .fcard__play { background: #fff; }
.fcard:hover .fcard__play svg { fill: #111; }
.fcard__name { font-family: "Bootzy", sans-serif; text-transform: uppercase; font-weight: 400; line-height: 0.92; font-size: clamp(1.7rem, 2.6vw, 2.4rem); margin-top: 1.1rem; }
.fcard__meta { margin-top: 0.5rem; font-size: 0.74rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.fcard__bio { margin-top: 0.7rem; font-size: 0.95rem; line-height: 1.5; color: var(--muted); max-width: 38ch; }

/* ----------------------- collection grid ------------------------- */
.phead--paper { background: var(--paper); color: var(--ink); border-bottom: 1px solid var(--line); }
.phead--paper .rule { border-color: var(--line); }
.phead--paper .rule > span { color: var(--ink); }
.phead--paper .rule > span:first-child { color: var(--muted); }
.phead--paper .phead__intro { color: var(--ink); }

.cgrid { max-width: var(--maxw); margin: 0 auto; padding: clamp(3rem, 7vh, 6rem) var(--pad) clamp(4rem, 9vh, 8rem);
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: clamp(2rem, 4vw, 4rem) clamp(1.2rem, 2.4vw, 2.2rem); }
.citem__img { position: relative; aspect-ratio: 4 / 5; overflow: hidden; background: var(--paper-2); }
.citem__img::before { content: ""; position: absolute; inset: 0; background: repeating-linear-gradient(135deg, rgba(0,0,0,0.04) 0 2px, transparent 2px 12px); }
.citem__img[data-label]::after { content: attr(data-label); position: absolute; left: 1rem; bottom: 0.9rem; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.82); }
.citem__tag { position: absolute; right: 1rem; top: 0.9rem; font-size: 0.66rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink); background: var(--paper); padding: 0.3rem 0.6rem; }
.citem__name { font-family: "Bootzy", sans-serif; text-transform: uppercase; font-weight: 400; line-height: 0.95; font-size: clamp(1.5rem, 2.2vw, 2rem); margin-top: 1.1rem; }
.citem__tie { margin-top: 0.45rem; font-size: 0.74rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.citem__row { margin-top: 0.7rem; display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--line-soft); padding-top: 0.7rem; }
.citem__meta { font-size: 0.9rem; color: var(--muted); }
.citem__price { font-size: 0.82rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; }

@media (max-width: 620px) {
  .fgrid { grid-template-columns: 1fr; }
}

/* placeholder tones — kept last so they win over .fcard__still / .citem__img bg */
.tone1 { background: linear-gradient(150deg, #9aa07e, #565a44); }
.tone2 { background: linear-gradient(150deg, #c8bca8, #8a7d68); }
.tone3 { background: linear-gradient(150deg, #5f6f80, #34404e); }
.tone4 { background: linear-gradient(150deg, #c9bfb2, #847868); }
.tone5 { background: linear-gradient(150deg, #9a5f50, #5c372e); }
.tone6 { background: linear-gradient(150deg, #7a6f86, #463f52); }
