/* ============================================================
   ORLANDO PIRATES FC — Squad slider (centrepiece)
   Typographic/crest player cards. Image slots, no fabricated faces.
   ============================================================ */

.squad-group { margin-bottom: clamp(3.5rem, 8vw, 6rem); }

.squad-group__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.75rem;
  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);
}

/* ---- SLIDER SHELL ---- */
.slider {
  position: relative;
  /* bleed to viewport edge on mobile so cards run off-screen */
  margin-inline: calc(var(--container-gutter) * -1);
  padding-inline: var(--container-gutter);
}

.slider__viewport {
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  cursor: grab;
  /* hide native scrollbar; custom progress below */
  padding-block: 1.5rem;
}
.slider__viewport::-webkit-scrollbar { display: none; }
.slider__viewport.is-dragging { cursor: grabbing; scroll-snap-type: none; }
.slider__viewport.is-dragging * { pointer-events: none; }

.slider__track {
  display: flex;
  gap: clamp(0.9rem, 2vw, 1.5rem);
  width: max-content;
  padding-right: var(--container-gutter);
}

/* ---- PLAYER CARD ---- */
.pcard {
  scroll-snap-align: start;
  flex: 0 0 auto;
  width: clamp(248px, 72vw, 300px);
  aspect-ratio: 3 / 4.2;
  position: relative;
  background:
    linear-gradient(180deg, var(--color-surface-1), var(--color-black));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transform: scale(0.94);
  opacity: 0.55;
  transition: transform var(--duration-slow) var(--ease-ghost),
              opacity var(--duration-slow) var(--ease-ghost),
              border-color var(--duration-base) var(--ease-ghost),
              box-shadow var(--duration-slow) var(--ease-ghost);
}
/* depth: the snapped/in-view card lifts forward */
.pcard.is-active {
  transform: scale(1);
  opacity: 1;
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-card);
}
.pcard:hover.is-active,
.pcard:focus-within.is-active {
  border-color: var(--color-border-gold);
  box-shadow: var(--shadow-card-lift), var(--shadow-gold-glow);
}

/* giant shirt number as background typographic anchor */
.pcard__no {
  position: absolute;
  top: -0.18em;
  right: -0.04em;
  font-family: var(--font-display);
  font-size: clamp(8rem, 22vw, 11rem);
  line-height: 1;
  color: var(--color-white-ghost);
  pointer-events: none;
  transition: color var(--duration-slow) var(--ease-ghost);
  z-index: 1;
}
.pcard.is-active:hover .pcard__no { color: rgba(212,184,74,0.16); }
.pcard__no--tbc {
  font-size: clamp(2rem, 6vw, 2.75rem);
  top: 0.6em;
  letter-spacing: var(--tracking-sub);
}

/* image slot — real headshot when sourced, else diagonal hatch + crest mask */
.pcard__media {
  position: relative;
  flex: 1 1 auto;
  min-height: 0;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.025) 0 2px, transparent 2px 12px);
  display: grid;
  place-items: center;
  z-index: 0;
}
/* skull placeholder mark — only shown when there is no photo */
.pcard__media::after {
  content: "";
  width: clamp(70px, 26%, 110px);
  aspect-ratio: 1;
  background: rgba(255,255,255,0.05);
  -webkit-mask: var(--skull-mask) center / contain no-repeat;
          mask: var(--skull-mask) center / contain no-repeat;
  transition: background var(--duration-slow) var(--ease-ghost);
}
.pcard.is-active:hover .pcard__media::after { background: rgba(255,255,255,0.09); }

/* a real headshot occupies the whole slot; suppress the hatch + skull */
.pcard--photo .pcard__media { background: var(--color-black); }
.pcard--photo .pcard__media::after { display: none; }

.pcard__photo {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 18%;
  z-index: 0;
  /* dark editorial default: near-monochrome, dimmed; lifts to colour in view */
  filter: grayscale(1) contrast(1.04) brightness(0.82);
  opacity: 0.78;
  transform: scale(1.02);
  transition: filter var(--duration-slow) var(--ease-ghost),
              opacity var(--duration-slow) var(--ease-ghost),
              transform var(--duration-slow) var(--ease-ghost);
}
.pcard.is-active .pcard__photo { opacity: 0.92; }
.pcard.is-active:hover .pcard__photo,
.pcard.is-active:focus-within .pcard__photo {
  filter: grayscale(0) contrast(1) brightness(1);
  opacity: 1;
  transform: scale(1.05);
}
/* scrim: knock back the bright studio backdrop top-left, sink the base to black */
.pcard__media::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(11,11,11,0.55) 0%, rgba(11,11,11,0) 32%),
    linear-gradient(to top, var(--color-black) 4%, rgba(11,11,11,0) 46%);
  opacity: 0;
  transition: opacity var(--duration-slow) var(--ease-ghost);
}
.pcard--photo .pcard__media::before { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
  .pcard__photo { transition: none; }
}

.pcard__pos {
  position: absolute;
  top: 1.1rem; left: 1.1rem;
  z-index: 2;
  font-family: var(--font-sub);
  font-size: var(--text-eyebrow);
  font-weight: 600;
  letter-spacing: var(--tracking-sub);
  text-transform: uppercase;
  color: var(--color-white);
  background: var(--color-scrim);
  border: 1px solid var(--color-border);
  padding: 0.3rem 0.6rem;
  border-radius: 2px;
}

/* nationality marker (non-SA gets a gold edge — scarce, marks the imports) */
.pcard__nat {
  position: absolute;
  top: 1.1rem; right: 1.1rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-family: var(--font-body);
  font-size: var(--text-small);
  color: var(--color-white-dim);
  background: var(--color-scrim);
  padding: 0.3rem 0.55rem;
  border-radius: 2px;
}
.pcard__nat[data-import="true"] { border: 1px solid var(--color-border-gold); }
.pcard__nat::before {
  content: "";
  width: 16px; height: 11px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border-strong);
}
.pcard__nat[data-import="true"]::before { border-color: var(--color-border-gold); }

/* meta block at base of card */
.pcard__body {
  position: relative;
  z-index: 2;
  padding: 1.1rem 1.2rem 1.3rem;
  background: linear-gradient(to top, var(--color-black) 60%, transparent);
}
.pcard__name {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 5vw, 1.9rem);
  line-height: 0.95;
  text-transform: uppercase;
  overflow-wrap: break-word;
  min-width: 0;
}
.pcard__name small {
  display: block;
  font-family: var(--font-sub);
  font-size: var(--text-eyebrow);
  letter-spacing: var(--tracking-sub);
  color: var(--color-ink-dim);
  margin-bottom: 0.2rem;
}

.pcard__stats {
  display: flex;
  gap: 1.25rem;
  margin-top: 1rem;
  padding-top: 0.9rem;
  border-top: 1px solid var(--color-border);
}
.pcard__stat { display: flex; flex-direction: column; gap: 0.1rem; }
.pcard__stat dt {
  font-family: var(--font-sub);
  font-size: 0.6875rem;
  letter-spacing: var(--tracking-sub);
  text-transform: uppercase;
  color: var(--color-ink-dim);
  margin: 0;
}
.pcard__stat dd {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.65rem;
  line-height: 1;
  color: var(--color-white);
}
.pcard__stat dd.is-empty { color: var(--color-ink-faint); font-size: 1.1rem; }
.pcard__stat--gold dd { color: var(--color-gold); }
.pcard__cs {
  margin-top: 0.85rem;
  font-size: var(--text-small);
  color: var(--color-ink-dim);
  line-height: 1.35;
}

/* ---- CONTROLS ---- */
.slider__nav {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.slider__btn {
  width: 46px; height: 46px;
  display: grid;
  place-items: center;
  background: transparent;
  border: 1px solid var(--color-border-strong);
  border-radius: 50%;
  color: var(--color-white);
  cursor: pointer;
  transition: border-color var(--duration-base) var(--ease-ghost),
              background var(--duration-base) var(--ease-ghost),
              transform var(--duration-base) var(--ease-ghost),
              opacity var(--duration-base) var(--ease-ghost);
}
.slider__btn:hover:not(:disabled) {
  border-color: var(--color-white);
  background: var(--color-white-ghost);
}
.slider__btn:active:not(:disabled) { transform: scale(0.92); }
.slider__btn:disabled { opacity: 0.25; cursor: not-allowed; }
.slider__btn:focus-visible {
  outline: 2px solid var(--color-gold-bright);
  outline-offset: 3px;
}
.slider__btn svg { width: 20px; height: 20px; }

/* progress rail */
.slider__progress {
  margin-top: 1.25rem;
  height: 2px;
  background: var(--color-border);
  position: relative;
  overflow: hidden;
}
.slider__progress-bar {
  position: absolute;
  left: 0; top: 0; height: 100%;
  width: 20%;
  background: var(--color-gold);
  transform-origin: left;
  transition: transform var(--duration-base) var(--ease-ghost),
              width var(--duration-base) var(--ease-ghost);
}

@media (min-width: 600px) {
  .pcard { width: 300px; }
}
