/* ============================================================
   AVC — Listado de Proyectos (cartera)
   Depende de avc.css.
   ============================================================ */

.plist-hero { padding-top: clamp(140px, 20vh, 230px); }
.plist-hero__top { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.plist-hero h1 { margin-top: 22px; }
.plist-hero .lead { margin-top: 26px; max-width: 52ch; }
.plist-hero__count { font-family: var(--mono); font-size: .72rem; letter-spacing: .18em; text-transform: uppercase; color: var(--t-soft); white-space: nowrap; }
.plist-hero__count b { color: var(--navy); font-size: 2.4em; font-weight: 500; display: block; letter-spacing: -.02em; }

/* Filtro */
.plist-filter {
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
  margin-top: clamp(40px, 6vh, 70px);
  padding: 16px 0; border-top: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark);
  position: sticky; top: 54px; background: var(--paper); z-index: 30;
}
.fpill {
  font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  padding: 9px 17px; border: 1px solid var(--line-dark); border-radius: 100px; color: var(--t-mid);
  display: inline-flex; align-items: center; gap: 9px;
  transition: background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease);
}
.fpill .c { color: var(--t-soft); }
.fpill:hover { border-color: var(--t-mid); color: var(--t-strong); }
.fpill.is-active { background: var(--ink); border-color: var(--ink); color: var(--paper); }
.fpill.is-active .c { color: var(--accent); }

/* Grid */
.plist__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(18px, 2.6vw, 38px); padding-block: clamp(44px, 7vh, 90px); }
.pcard { display: flex; flex-direction: column; }
.pcard.is-hidden { display: none; }
.pcard--featured { grid-column: 1 / -1; }

.pcard__media { position: relative; overflow: hidden; aspect-ratio: 3/4; background: var(--ink-2); }
.pcard--featured .pcard__media { aspect-ratio: 16/8; }
.pcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s var(--ease); filter: brightness(.92) saturate(.82); }
.pcard:hover .pcard__media img { transform: scale(1.045); }
.pcard__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(4,8,16,.16) 0%, rgba(4,8,16,0) 34%, rgba(4,8,16,.66) 100%); }

.pcard__idx { position: absolute; top: 16px; left: 16px; z-index: 2; font-family: var(--mono); font-size: .68rem; letter-spacing: .18em; color: rgba(255,255,255,.85); }
.pcard__badge { position: absolute; top: 14px; right: 14px; z-index: 2;
  font-family: var(--mono); font-size: .58rem; letter-spacing: .16em; text-transform: uppercase; color: #fff;
  padding: 7px 12px; border: 1px solid rgba(255,255,255,.28); border-radius: 100px;
  display: inline-flex; align-items: center; gap: 8px; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.pcard__badge .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.pcard__badge--done .dot { background: rgba(255,255,255,.6); }

.pcard__over { position: absolute; left: 22px; right: 22px; bottom: 20px; z-index: 2; color: #fff; }
.pcard__name { font-size: clamp(1.6rem, 3vw, 2.8rem); font-weight: 540; letter-spacing: -.03em; line-height: .98; }
.pcard--featured .pcard__name { font-size: clamp(2.2rem, 5vw, 4.4rem); }
.pcard__loc { font-family: var(--mono); font-size: .66rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.78); margin-top: 10px; }

.pcard__foot { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 18px 2px 0; border-top: 1px solid var(--line-dark); margin-top: 16px; }
.pcard__meta { display: flex; gap: 22px; flex-wrap: wrap; }
.pcard__meta .k { font-family: var(--mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--t-soft); }
.pcard__meta .k b { color: var(--t-strong); font-weight: 400; }
.pcard__go { font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; display: inline-flex; align-items: center; gap: 9px; color: var(--t-mid); white-space: nowrap; transition: color .3s var(--ease), gap .3s var(--ease); }
.pcard:hover .pcard__go { color: var(--navy); gap: 14px; }
.pcard__go.is-soon { color: var(--t-soft); }
.pcard:hover .pcard__go.is-soon { color: var(--t-soft); gap: 9px; }

.plist__empty { display: none; padding: 60px 0; font-family: var(--mono); font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; color: var(--t-soft); text-align: center; }

@media (max-width: 860px) {
  .plist__grid { grid-template-columns: 1fr; }
  .pcard--featured .pcard__media { aspect-ratio: 4/3; }
}
