/* ULTRA PRO — Equipos (v1) */
.page-hero {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  background: radial-gradient(1200px 500px at 20% 0%, rgba(0,255,170,.12), transparent 55%),
              radial-gradient(900px 380px at 90% 10%, rgba(120,90,255,.14), transparent 50%),
              linear-gradient(135deg, rgba(10,12,18,1) 0%, rgba(18,20,30,1) 55%, rgba(12,14,22,1) 100%);
  border: 1px solid rgba(255,255,255,.08);
}
.page-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="800" height="400"><defs><pattern id="p" width="60" height="60" patternUnits="userSpaceOnUse"><path d="M0 0H60V60H0z" fill="none"/><path d="M0 30H60" stroke="rgba(255,255,255,0.05)" stroke-width="1"/><path d="M30 0V60" stroke="rgba(255,255,255,0.05)" stroke-width="1"/></pattern></defs><rect width="100%25" height="100%25" fill="url(%23p)"/></svg>');
  opacity:.45;
  pointer-events:none;
}
.page-hero .content{
  position:relative;
  z-index:1;
}
.kpi-card{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(8px);
}
.team-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(10,12,18,.55);
  backdrop-filter: blur(10px);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.team-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  border-color: rgba(255,255,255,.16);
}
.team-badge{
  font-size:.75rem;
  letter-spacing:.2px;
  border-radius:999px;
  padding:.25rem .55rem;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}
.team-logo{
  width:56px;
  height:56px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  display:flex;
  align-items:center;
  justify-content:center;
}
.team-logo img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.team-meta{
  font-size:.85rem;
  opacity:.85;
}
.formula{
  display:flex; gap:.35rem; flex-wrap:wrap;
}
.formula .pill{
  width:26px; height:26px;
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:.75rem;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
}
.section-title{
  font-weight:800;
  letter-spacing:.3px;
}
.table-soft{
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
}
.table-soft .table{
  margin-bottom:0;
}
.squad-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:.75rem;
}
@media (min-width: 992px){
  .squad-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}
.person-card{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background: rgba(10,12,18,.55);
  overflow:hidden;
}
.person-card .photo{
  width:100%;
  aspect-ratio: 4/3;
  background: rgba(255,255,255,.06);
}
.person-card img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.person-card .body{
  padding:.6rem .65rem .7rem;
}
.empty-state{
  border-radius:18px;
  border:1px dashed rgba(255,255,255,.18);
  background: rgba(255,255,255,.03);
  padding: 1.25rem;
}


/* Equipo: Nómina cards (mobile) */
.player-card{border-radius:16px;border:1px solid rgba(255,255,255,.08);background: rgba(10,12,18,.55);backdrop-filter: blur(10px);overflow:hidden;}
.player-card .head{display:flex;gap:.75rem;align-items:center;padding:.85rem;}
.player-card .head .fw-bold{font-size:1rem;}
.player-card .avatar{width:52px;height:52px;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background: rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.player-card .avatar img{width:100%;height:100%;object-fit:cover;}
.player-card .meta{font-size:.85rem;opacity:.85;}
.player-card .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;padding:0 .85rem .85rem;}
.player-card .mini{border-radius:12px;border:1px solid rgba(255,255,255,.08);background: rgba(255,255,255,.04);padding:.45rem .5rem;}
.player-card .mini .k{font-size:.72rem;opacity:.75;}
.player-card .mini .v{font-weight:800;}
/* Responsive fixes — Equipo (cards) */
.player-card .head{flex-wrap:nowrap;}
.player-card .head .flex-grow-1{min-width:0;}
.player-card .head .fw-bold{max-width:100%; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.player-card .head .meta{white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}

/* Better inner grid breakpoints */
@media (min-width: 576px){
  .player-card .grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (min-width: 768px){
  .player-card .grid{grid-template-columns:repeat(4,minmax(0,1fr));}
}

/* Reduce badge column squeeze */
.player-card .head .d-flex.flex-column{flex:0 0 auto;}

@media (max-width: 380px){.player-card .grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.5rem;padding:0 .85rem .85rem;}}

/* v2.2.3 ajuste — jugador cards responsive */
.player-card{height:100%;}
.player-card .head{align-items:flex-start;}
.player-card .head .fw-bold{font-size:1rem;}
.player-card .meta{margin-top:.15rem;}
@media (min-width: 576px){
  .player-card .head{padding:1rem;}
  .player-card .grid{padding:0 1rem 1rem;}
}


/* Hard responsive guardrails */
.player-card { min-width: 0; }
.player-card .head { align-items: flex-start; }
.player-card .head .d-flex.flex-column { margin-left: .25rem; }
@media (max-width: 420px){
  .player-card .head{gap:.6rem; padding:.75rem;}
  .player-card .avatar{width:46px;height:46px;border-radius:12px;}
  .player-card .head .fw-bold{font-size:.95rem;}
}

/* === FIX DEFINITIVO CARDS (MÓVIL) — evita que se vea aplastado === */
@media (max-width: 576px){
  .player-card .head{
    flex-wrap: wrap;
    align-items: flex-start;
  }
  /* columna derecha (dorsal/goles) baja y se vuelve fila */
  .player-card .head > .d-flex.flex-column,
  .player-card .head > .stats{
    width: 100%;
    flex-direction: row !important;
    justify-content: flex-end;
    align-items: center !important;
    gap: .4rem !important;
    margin-top: .4rem;
  }
  /* evita que meta se corte feo */
  .player-card .meta{
    white-space: normal;
    overflow: visible;
    text-overflow: unset;
  }
  .player-card .grid{
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: .55rem;
    padding: 0 .75rem .85rem;
  }
  .player-card .mini{
    padding: .5rem .6rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
  }
  .player-card .mini .k{ font-size: .70rem; }
  .player-card .mini .v{ font-size: .95rem; }
}

/* =========================================================
   FINAL MOBILE WRAP FIX — Jugadores cards (equipo)
   Objetivo: que NUNCA se aplaste el contenido en móviles.
   ========================================================= */
@media (max-width: 600px){
  .player-card{ overflow: hidden; }
  .player-card .head{
    display:flex;
    flex-wrap: wrap !important;
    align-items: flex-start !important;
    gap: .65rem !important;
  }
  .player-card .avatar{ flex: 0 0 auto; }
  .player-card .head .flex-grow-1{
    flex: 1 1 220px;
    min-width: 0;
  }
  /* Nombre y meta pueden ocupar 2 líneas si hace falta */
  .player-card .head .fw-bold{
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: unset !important;
    word-break: break-word;
    line-height: 1.15;
  }
  .player-card .meta{
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: unset !important;
    word-break: break-word;
  }

  /* Bloque de badges (dorsal/goles) siempre baja y se vuelve fila */
  .player-card .head > .stats,
  .player-card .head > .d-flex.flex-column{
    flex: 1 1 100%;
    width: 100%;
    flex-direction: row !important;
    justify-content: flex-end;
    align-items: center !important;
    gap: .45rem !important;
    margin-top: .15rem;
  }

  /* Grid interno estable */
  .player-card .grid{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
    gap: .55rem !important;
    padding: 0 .75rem .85rem !important;
  }
  .player-card .mini{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.5rem;
    padding: .52rem .6rem !important;
  }
  .player-card .mini .k{ font-size:.70rem; }
  .player-card .mini .v{ font-size:.95rem; }
}

/* =========================================================
   MOBILE MINI CARDS LOOK (Edad / Altura / etc) — como ejemplo
   ========================================================= */
@media (max-width: 600px){
  .player-card .mini{
    display:flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    padding: .55rem .7rem !important;
    gap: .15rem !important;
  }
  .player-card .mini .k{
    font-size: .72rem !important;
    opacity: .80 !important;
    line-height: 1.1 !important;
  }
  .player-card .mini .v{
    font-size: 1.15rem !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
    letter-spacing: .2px;
  }
}

/* Ajuste fino — mini-bloques móvil: texto un poco más pequeño */
@media (max-width: 600px){
  .player-card .mini .k{ font-size: .68rem !important; }
  .player-card .mini .v{ font-size: 1.05rem !important; }
}
