/* Films section — modern collection navigation. Self-contained so it never
   collides with samo.css edits from other section worktrees; leans on the
   shared :root tokens (--fg, --muted, --ss-accent, --line, fonts) for harmony. */

.mv-page { max-width: var(--page-w, 880px); margin: 0 auto; }

.mv-head h1 { margin: 0.1em 0 0.15em; }
.mv-owner-badge { color: var(--ss-accent); }
.mv-counts { font-family: var(--font-mono); font-size: 12px; color: var(--muted); margin: 0 0 1.4em; }
.mv-empty { margin: 1.5em 0; }

/* ── Filter rail ───────────────────────────────────────────── */
.mv-filters { display: flex; flex-direction: column; gap: 8px; margin: 0 0 1.8em; }
.mv-search {
    font-family: var(--font-mono); font-size: 13px; color: var(--fg);
    padding: 7px 10px; border: 1px solid var(--line); border-radius: 7px;
    background: var(--bg-panel); max-width: 320px;
}
.mv-search:focus { outline: none; border-color: var(--ss-accent); }
.mv-chiprow { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.mv-chiplabel {
    font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--faint); width: 52px;
}
.mv-chip {
    font-family: var(--font-mono); font-size: 11px; color: var(--muted);
    padding: 3px 9px; border: 1px solid var(--line); border-radius: 999px;
    background: transparent; cursor: pointer; transition: all 0.12s ease;
}
.mv-chip:hover { color: var(--fg); border-color: var(--faint); }
.mv-chip[aria-pressed="true"], .mv-chip.is-on {
    color: var(--ss-accent); border-color: var(--ss-accent);
    background: var(--ss-accent-tint);
}
.mv-link { font-family: var(--font-mono); font-size: 12px; color: var(--ss-accent);
    background: none; border: none; cursor: pointer; padding: 0; text-decoration: underline; }
.mv-noresults { margin: 1em 0; }

/* ── Lanes + poster grid ───────────────────────────────────── */
.mv-lane { margin: 0 0 2.4em; }
.mv-lane.is-empty { display: none; }
.mv-lane-title {
    font-family: var(--font-display); font-size: 17px; font-weight: 600;
    display: flex; align-items: baseline; gap: 9px;
    padding-bottom: 6px; border-bottom: 1px solid var(--hairline); margin-bottom: 1em;
}
.mv-lane-count { font-family: var(--font-mono); font-size: 11px; color: var(--faint); }

.mv-grid {
    display: grid; gap: 16px 14px;
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
}

.mv-card { text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: 6px; }
.mv-card.is-hidden { display: none; }

.mv-poster {
    position: relative; aspect-ratio: 2 / 3; border-radius: 8px; overflow: hidden;
    background: var(--bg-panel); border: 1px solid var(--hairline);
    box-shadow: 0 1px 2px rgba(0,0,0,0.05); transition: transform 0.14s ease, box-shadow 0.14s ease;
}
.mv-card:hover .mv-poster { transform: translateY(-3px); box-shadow: 0 6px 16px rgba(0,0,0,0.14); }
.mv-poster-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mv-poster-blank {
    width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
    padding: 12px; text-align: center;
    background: linear-gradient(150deg,
        color-mix(in oklch, var(--samo-deep) 14%, var(--bg-panel)),
        var(--bg-panel));
}
.mv-poster-title { font-family: var(--font-display); font-size: 13px; line-height: 1.25; color: var(--muted); }

.mv-rating {
    position: absolute; top: 6px; right: 6px;
    font-family: var(--font-mono); font-size: 12px; font-weight: 600; color: #1a1206;
    background: var(--samo-sun); padding: 1px 6px; border-radius: 5px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
}
.mv-private {
    position: absolute; top: 6px; left: 6px; font-size: 10px; line-height: 1;
    color: var(--ss-accent); background: var(--bg-panel);
    padding: 3px; border-radius: 999px; border: 1px solid var(--ss-accent);
}

.mv-title { font-family: var(--font-display); font-size: 13.5px; line-height: 1.25; }
.mv-sub { font-family: var(--font-mono); font-size: 10.5px; color: var(--faint); line-height: 1.3; }
.mv-reviewed { color: var(--ss-accent); }

.mv-detail .dossier { color: var(--ss-accent); }
