/* ============================================================
   ORLANDO PIRATES FC — Squad grid
   Mirrors the coaches page exactly: a clean responsive grid of
   editorial cards (portrait → position → name → nationality chip),
   grouped by line. Same type, spacing, borders, hover and portrait
   treatment as .coach in styles.css. No slider, no giant number,
   no hatch — the shirt number is a small tidy meta detail.
   ============================================================ */

.squad-group { margin-bottom: clamp(3rem, 7vw, 5rem); }

.squad-group__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 1rem;
}
.squad-group__title {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  text-transform: uppercase;
  line-height: 1;
}
.squad-group__count {
  font-family: var(--font-sub);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-sub);
  text-transform: uppercase;
  color: var(--color-ink-dim);
}

/* ---- GRID (identical pattern to .coach-grid) ---- */
.squad-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 240px), 1fr));
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
}

/* ---- PLAYER CARD (mirror of .coach) ---- */
.pcard {
  position: relative;
  background: var(--color-pitch);
  padding: clamp(1.5rem, 3vw, 2rem);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: background var(--duration-base) var(--ease-ghost);
}
.pcard:hover { background: var(--color-surface-1); }

/* portrait slot — mirror of .coach__portrait + --photo */
.pcard__portrait {
  aspect-ratio: 4 / 5;
  width: 100%;
  margin-bottom: auto;
  background:
    repeating-linear-gradient(135deg, var(--color-surface-2) 0 2px, transparent 2px 10px),
    var(--color-surface-1);
  border: 1px solid var(--color-border);
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
}
/* crest mark shown only when there is no photo */
.pcard__portrait::after {
  content: "";
  width: 56px; height: 56px;
  background: var(--crest-mark) center / contain no-repeat;
  opacity: 0.4;
}
.pcard__portrait--photo {
  background: var(--color-black);
  border-color: var(--color-border);
}
.pcard__portrait--photo::after { display: none; }
.pcard__portrait-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 14%;
  /* identical to coach treatment: bright, clear */
  filter: grayscale(0.1) contrast(1.03) brightness(1.03);
  transition: filter var(--duration-slow) var(--ease-ghost),
              transform var(--duration-slow) var(--ease-ghost);
}
.pcard:hover .pcard__portrait-img {
  filter: grayscale(0) contrast(1.02) brightness(1.04);
  transform: scale(1.03);
}
/* light bottom scrim to anchor the studio backdrop into the card */
.pcard__portrait--photo::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(to top, rgba(11,11,11,0.55) 0%, rgba(11,11,11,0.12) 12%, rgba(11,11,11,0) 30%);
}
@media (prefers-reduced-motion: reduce) {
  .pcard__portrait-img { transition: none; }
}

/* role = position line (mirror of .coach__role), with shirt no. as tidy meta */
.pcard__role {
  font-family: var(--font-sub);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-sub);
  text-transform: uppercase;
  color: var(--color-ink-dim);
  margin-top: 1.5rem;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
}
.pcard__no {
  font-family: var(--font-sub);
  color: var(--color-ink-faint);
  letter-spacing: var(--tracking-sub);
  flex: none;
}

/* name (mirror of .coach__name) */
.pcard__name {
  font-family: var(--font-display);
  font-size: var(--text-h3);
  text-transform: uppercase;
  margin-top: 0.35rem;
  line-height: 1;
  overflow-wrap: break-word;
  min-width: 0;
}

/* nationality chip (mirror of .coach__nat) */
.pcard__nat {
  margin-top: 0.6rem;
  font-size: var(--text-small);
  color: var(--color-white-dim);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.pcard__nat::before {
  content: "";
  width: 20px; height: 13px;
  border: 1px solid var(--color-border-strong);
  background-color: var(--color-surface-2);
  background-image: var(--flag, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  flex: none;
}
.pcard__nat[data-flag="za"]::before { --flag: url("assets/flags/za.svg"); }
.pcard__nat[data-flag="na"]::before { --flag: url("assets/flags/na.svg"); }
.pcard__nat[data-flag="ml"]::before { --flag: url("assets/flags/ml.svg"); }
.pcard__nat[data-flag="nz"]::before { --flag: url("assets/flags/nz.svg"); }
.pcard__nat[data-flag="zw"]::before { --flag: url("assets/flags/zw.svg"); }
.pcard__nat[data-flag="ma"]::before { --flag: url("assets/flags/ma.svg"); }
.pcard__nat[data-flag="tn"]::before { --flag: url("assets/flags/tn.svg"); }
/* imports get a scarce gold edge on the flag chip */
.pcard__nat[data-import="true"]::before { border-color: var(--color-border-gold); }
