/* ================================================================
 * platform-new.css
 * Stylesheet for /new/* platform pages (player, team, …).
 * Self-contained: variables, layout, components and responsive.
 * ================================================================ */

:root {
  --pn-main:#483c32;
  --pn-secondary:#826E5E;
  --pn-third:#E1CA96;
  --pn-fourth:#e1ca9617;
  --pn-gray:#D0CCD0;
  --pn-green:#61FF7E;
  --pn-red:#ff6161;
  --pn-green-standings:#61ff7e66;
  --pn-red-standings:#ff61616e;
  --pn-white:#FBFCFF;
  --pn-bg:#f5f2ee;
}

/* Scope-only reset for /new pages */
body.platform-new,
body.platform-new *,
body.platform-new *::before,
body.platform-new *::after { box-sizing:border-box; }

body.platform-new {
  font-family:"Montserrat",sans-serif;
  background:var(--pn-bg);
  color:#1a1512;
  margin:0;
}
body.platform-new a { text-decoration:none; /* color:inherit — overrides cfc-header nav colors */ }
body.platform-new svg { overflow:visible; }

/* ── HEADER / NAV (under the global castolo brand bar) ── */
.pn-subheader{
  background:var(--pn-main);
  height:60px;
  display:flex;align-items:center;justify-content:center;
}
.pn-subheader .pn-logo{
  font-family:"Lora",serif;font-size:22px;color:var(--pn-third);letter-spacing:2px;
}
.pn-nav{ background:#eaede2; border-bottom:1px solid #d4d0c8; }
.pn-nav ul{
  max-width:1300px;margin:0 auto;display:flex;list-style:none;gap:4px;
  padding:0 20px;overflow-x:auto;white-space:nowrap;
}
.pn-nav ul li a{
  display:block;padding:10px 12px;font-size:13px;font-weight:600;
  text-transform:uppercase;letter-spacing:.5px;color:var(--pn-main);
}
.pn-nav ul li a:hover{ background:var(--pn-fourth); }

/* ── GRID ── */
.pn-grid{
  display:grid;grid-template-columns:160px 1fr 160px;gap:20px;
  max-width:1300px;margin:0 auto;padding:24px 10px;align-items:start;
}
.pn-central{ max-width:920px;width:100%;min-width:0; }

/* Ad placeholders */
.pn-ad{ display:block; }
.pn-ad-sky{ width:160px;min-height:600px;position:sticky;top:20px; }
.pn-ad-halfpage{ width:300px;min-height:600px;position:sticky;top:20px; }
.pn-ad-leaderboard{ display:none; }
.pn-ad-mrec{ display:none; }

/* Standings + 160x600 skyscraper sidebar */
.pn-comp-standings-row{
  display:grid;grid-template-columns:minmax(0,1fr) 160px;gap:16px;
  margin-bottom:24px;align-items:start;
}
.pn-comp-standings-main{ min-width:0; }
.pn-comp-standings-aside{ display:flex;justify-content:flex-end; }
@media(max-width:980px){
  .pn-comp-standings-row{ grid-template-columns:1fr; }
  .pn-comp-standings-aside{ display:none; }
}

/* ── HERO (player + team share most rules) ── */
.pn-hero{
  background:var(--pn-main);border-radius:12px;overflow:hidden;
  display:flex;align-items:flex-start;gap:16px;position:relative;
  padding:14px 20px;margin-bottom:20px;
}
.pn-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 80% at 20% 110%,#826E5E55 0%,transparent 70%),
    linear-gradient(135deg,#483c32 60%,#6b5444 100%);
}
.pn-hero-number{
  position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-family:"League Spartan","Lora",serif;font-size:72px;font-weight:600;
  color:rgba(232,201,122,0.08);line-height:1;user-select:none;pointer-events:none;
}
.pn-hero-img{ position:relative;z-index:1;flex-shrink:0; }
.pn-hero-photo{
  width:72px;height:72px;border-radius:10px;
  object-fit:cover;object-position:top center;
  border:2px solid rgba(232,201,122,0.25);display:block;
}
.pn-hero-photo--placeholder{
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,0.08);color:rgba(232,201,122,0.4);
}
.pn-hero-photo--placeholder svg{ width:36px;height:36px; }
.pn-hero-info{ position:relative;z-index:1;flex:1;min-width:0;padding:0; }
.pn-hero-country{ display:flex;align-items:center;gap:5px;margin-bottom:6px;min-width:0; }
.pn-hero-country img,
.pn-hero-country > svg{ width:23px;height:23px;object-fit:contain;flex-shrink:0; }
.pn-hero-country span,
.pn-hero-country-link{
  font-family:"Montserrat",sans-serif;font-size:14px;font-weight:600;
  line-height:23px;padding-top:3px;color:var(--pn-third);opacity:1;
  letter-spacing:.3px;text-transform:none;text-decoration:none;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}
.pn-hero-country-link:hover{ opacity:.85;text-decoration:none; }
.pn-hero-team{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:600;color:var(--pn-third);opacity:.75;
  letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;
  text-decoration:none;
}
a.pn-hero-team:hover{ opacity:1; }
.pn-hero-team-logo{
  width:18px;height:18px;object-fit:contain;flex-shrink:0;
}
.pn-hero-name{
  font-family:"League Spartan","Lora",serif;font-size:32px;color:var(--pn-white);
  line-height:1;margin-bottom:2px;overflow-wrap:break-word;
}
.pn-hero-pos{
  font-size:11px;font-weight:600;color:var(--pn-third);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:14px;
}
.pn-hero-meta{ display:flex;gap:16px;flex-wrap:wrap;align-items:flex-end;min-width:0; }
.pn-hero-meta-item{ display:flex;flex-direction:column;gap:2px;min-width:0; }
.pn-hero-meta-key{
  font-size:10px;color:var(--pn-third);opacity:.6;
  text-transform:uppercase;letter-spacing:1px;white-space:nowrap;
}
.pn-hero-meta-val{
  font-size:13px;font-weight:600;color:var(--pn-white);
  display:flex;align-items:center;gap:6px;min-height:23px;min-width:0;
}
.pn-hero-meta-link{ color:var(--pn-white);text-decoration:none;overflow-wrap:break-word;min-width:0; }
.pn-hero-meta-link:hover{ text-decoration:underline; }
.pn-flag{ font-size:16px;line-height:1;flex-shrink:0; }

/* ── STATS STRIP (a.k.a. "Temporada actual") ── */
.pn-stats-strip{
  background:var(--pn-white);border:1px solid #e0d8ce;border-radius:10px;
  padding:18px 24px;display:flex;align-items:center;margin-bottom:20px;overflow-x:auto;
}
.pn-stats-strip-label{
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;
  color:var(--pn-secondary);white-space:nowrap;
  padding-right:24px;border-right:1px solid var(--pn-third);margin-right:24px;
}
.pn-stats-strip-list{ display:flex;gap:32px; }
.pn-stats-strip-item{ display:flex;flex-direction:column;align-items:center;gap:2px; }
.pn-stats-strip-val{ font-family:"Lora",serif;font-size:28px;color:var(--pn-main); }
.pn-stats-strip-key{
  font-size:10px;font-weight:600;letter-spacing:1px;
  text-transform:uppercase;color:var(--pn-secondary);
}

/* ── SECTION TITLE ── */
.pn-section-title{
  font-family:"Lora",serif;font-size:20px;color:var(--pn-main);
  border-bottom:2px solid var(--pn-third);
  padding-bottom:8px;margin-bottom:16px;margin-top:28px;
}

/* ── HIGHLIGHTS ── */
.pn-highlights{ display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px; }
.pn-highlight{
  background:var(--pn-white);border:1px solid #e0d8ce;border-left:4px solid var(--pn-third);
  border-radius:0 8px 8px 0;padding:12px 16px;flex:1;min-width:130px;
}
.pn-highlight-val{
  font-family:"Lora",serif;font-size:28px;color:var(--pn-main);
  line-height:1;margin-bottom:4px;
}
.pn-highlight-key{
  font-size:11px;font-weight:600;color:var(--pn-secondary);
  text-transform:uppercase;letter-spacing:.5px;
}

/* ── 2-COLUMN ROW (aura + position) ── */
.pn-two-col-aura{
  display:grid;grid-template-columns:1fr 260px;gap:16px;margin-bottom:4px;
}
.pn-two-col{ display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px; }

/* ── PANEL ── */
.pn-panel{
  background:var(--pn-white);border-radius:10px;overflow:hidden;
  /* Single horizontal divider above the body; no vertical borders. */
  border-top:1px solid #e0d8ce;border-bottom:1px solid #e0d8ce;
}
.pn-panel-header{
  background:var(--pn-main);color:var(--pn-third);
  font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:10px 16px;
}
.pn-panel-body{ padding:16px; }
/* Aura chart legend (dual-line) */
.pn-aura-legend{
  display:flex;gap:14px;align-items:center;margin-bottom:10px;
}
.pn-aura-legend-item{
  display:inline-flex;align-items:center;gap:6px;
  font-family:Montserrat,sans-serif;font-size:11px;font-weight:600;
  color:var(--pn-secondary);letter-spacing:.3px;
}
.pn-aura-legend-item--secondary{ color:#826E5E;opacity:.85; }

/* Aura chart */
.pn-aura-meta{
  display:flex;justify-content:flex-end;margin-bottom:8px;
  gap:4px;flex-direction:column;align-items:flex-end;
}
.pn-aura-meta-split{
  flex-direction:row;align-items:flex-start;justify-content:space-between;gap:16px;
}
.pn-aura-meta-block{
  display:flex;flex-direction:column;gap:2px;line-height:1.1;flex:1;min-width:0;
}
.pn-aura-meta-block-right{ text-align:right;align-items:flex-end; }
.pn-aura-meta-label{ font-size:11px;color:var(--pn-secondary); }
.pn-aura-meta-val{
  font-family:"Lora",serif;font-size:20px;color:var(--pn-main);font-weight:600;
}
.pn-aura-meta-date{ font-size:11px;color:var(--pn-secondary); }
/* Legacy single-block names kept for any cached HTML still in production. */
.pn-aura-record-label{ font-size:11px;color:var(--pn-secondary); }
.pn-aura-record-val{
  font-family:"Lora",serif;font-size:20px;color:var(--pn-main);font-weight:600;
}
.pn-aura-record-date{ font-size:11px;color:var(--pn-secondary); }
.pn-aura-chart-wrap{ position:relative;width:100%; }
.pn-aura-track{ cursor:crosshair; }
.pn-aura-tooltip[hidden]{ display:none; }
.pn-aura-tooltip{
  position:absolute;pointer-events:none;
  background:#fff;color:#1a1a1a;
  padding:5px 10px;border-radius:6px;
  font-size:11px;font-family:Montserrat,sans-serif;
  display:flex;flex-direction:column;line-height:1.25;gap:1px;
  transform:translate(-50%,-110%);
  white-space:nowrap;
  box-shadow:0 2px 10px rgba(0,0,0,0.14);
  border:1px solid #e8e0d4;
  z-index:10;
}
.pn-aura-tip-row{ display:flex;align-items:baseline;gap:5px; }
.pn-aura-tip-row--date{ align-items:center;gap:4px;margin-bottom:3px;padding-bottom:3px;border-bottom:1px solid #e8e0d4; }
.pn-aura-tip-lbl{ font-size:9px;color:#888;letter-spacing:.3px;text-transform:uppercase;flex-shrink:0; }
.pn-aura-tooltip-crest{ display:block;width:13px;height:13px;min-width:13px;max-width:13px;object-fit:contain;flex-shrink:0;overflow:hidden; }
.pn-aura-tooltip-val{ font-weight:700;color:#1a1a1a; }
.pn-aura-tooltip-date{ font-weight:600;color:#444; }
.pn-aura-tooltip-aura{ font-weight:600;font-size:10px;color:#555; }
.pn-aura-revision{
  font-size:11px;color:#aaa;text-align:center;margin-top:6px;
}
.pn-aura-meta-label,.pn-aura-meta-date,
.pn-aura-record-label,.pn-aura-record-date{ color:#888; }

/* Position map */
.pn-pos-label{ font-size:13px;color:var(--pn-secondary);margin-bottom:4px; }
.pn-pos-name{ font-size:15px;font-weight:600;color:var(--pn-main);margin-bottom:14px; }
.pn-pitch-wrap{ display:flex;justify-content:center; }

/* ── SIMPLE TABLES (career-by-team / by-competition) ── */
.pn-mini-table-wrap{
  background:var(--pn-white);border:1px solid #e0d8ce;border-radius:10px;
  overflow-x:auto;min-width:0;
}
.pn-mini-table-header{
  background:var(--pn-main);color:var(--pn-third);
  font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:10px 14px;
}
.pn-mini-table{ width:100%;min-width:360px;border-collapse:collapse;font-size:13px; }
.pn-mini-table th{
  color:var(--pn-secondary);font-size:10px;font-weight:600;letter-spacing:.5px;
  text-transform:uppercase;padding:6px 10px;
  border-bottom:1px solid #e0d8ce;text-align:right;
}
.pn-mini-table th:first-child{ text-align:left; }
.pn-mini-table th:not(:first-child){ padding-left:4px;padding-right:6px; }
.pn-mini-table td{
  padding:7px 10px;border-bottom:1px solid #f0ebe3;
  text-align:right;vertical-align:middle;
}
.pn-mini-table td:first-child{ text-align:left; }
.pn-mini-table td:not(:first-child){ padding-left:4px;padding-right:6px; }
.pn-mini-table tr:last-child td{ border-bottom:none; }
.pn-mini-table tr:hover td{ background:var(--pn-fourth); }
.pn-entity-cell{ display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden; }
.pn-entity-cell > span,.pn-entity-cell > a{
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;
}

/* ── CAREER (full season) TABLE ── */
.pn-career-wrap{ width:100%;overflow-x:auto; }
.pn-career-table{ width:100%;min-width:600px;border-collapse:collapse;font-size:13px; }
.pn-career-table thead th{
  background:var(--pn-main);color:var(--pn-third);
  font-weight:600;letter-spacing:.4px;padding:9px 10px;
  text-align:left;white-space:nowrap;
}
.pn-career-table thead th:not(:first-child){ text-align:center; }
.pn-career-table tbody tr{ border-bottom:1px solid #e8e0d4;transition:background .15s; }
.pn-career-table tbody tr:hover{ background:var(--pn-fourth); }
.pn-career-table tbody td{ padding:8px 10px;white-space:nowrap;vertical-align:middle; }
/* Column-driven alignment so a rowspanned season cell doesn't shift the
   leading-text columns into the centered region. */
.pn-career-table tbody td.pn-col-season,
.pn-career-table tbody td.pn-col-team,
.pn-career-table tbody td.pn-col-comp{ text-align:left; }
.pn-career-table tbody td.pn-col-stat{ text-align:center; }
.pn-career-table tbody td.pn-season-label{
  font-weight:600;color:var(--pn-main);
  vertical-align:top;
  padding-top:10px;
}
.pn-career-table tbody tr.pn-season-group{ border-top:1px solid #d4ccbf; }
.pn-career-table tbody tr.pn-season-subtotal{
  background:#f7f1e8;color:var(--pn-secondary);font-style:italic;font-size:12px;
}
.pn-career-table tbody tr.pn-season-subtotal td.pn-col-comp{ text-align:right; }
.pn-career-table tbody tr.pn-totals-row{
  background:var(--pn-fourth);
  border-top:2px solid var(--pn-third);
  border-bottom:2px solid var(--pn-third);
}
.pn-career-table tbody tr.pn-totals-row td{ font-weight:600; }
.pn-season-entity{ display:flex;align-items:center;gap:6px; }

/* ── MATCH ROW (game widget) ── */
.pn-matches-list{ display:flex;flex-direction:column; }
.pn-match-row{
  background:var(--pn-white);border-bottom:1px solid var(--pn-third);
  padding:6px 0;transition:background .15s;
}
.pn-match-row:first-child{ border-top:1px solid var(--pn-third); }
.pn-match-row:hover{ background:var(--pn-fourth); }
.pn-game-widget{
  display:flex;justify-content:space-between;align-items:center;padding:0 4px;
}
.pn-gw-date{
  width:54px;flex-shrink:0;font-size:11px;line-height:1.4;
  color:var(--pn-secondary);padding-left:6px;
}
.pn-gw-comp-badge{
  width:34px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
}
.pn-gw-teams{
  flex:1;display:flex;align-items:center;justify-content:center;gap:4px;
}
.pn-gw-team{ display:flex;align-items:center;gap:5px;width:170px; }
.pn-gw-team.pn-gw-team-local{ justify-content:flex-end; }
.pn-gw-team.pn-gw-team-visitor{ justify-content:flex-start; }
.pn-gw-team .pn-team-name{
  font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;max-width:120px;text-shadow:1px 0 0 currentColor;
}
.pn-score-widget{ display:flex;margin:0 5px; }
.pn-score-team{
  padding:3px 0;border:1px solid #ccc;width:30px;text-align:center;
  font-weight:bold;background-color:var(--pn-white);text-shadow:1px 0 0 currentColor;
  font-size:18px;display:flex;align-items:center;justify-content:center;height:34px;
  font-variant-numeric: tabular-nums;
}
.pn-score-team.pn-score-winner{
  background:var(--pn-third);border-color:var(--pn-secondary);color:var(--pn-main);
}
/* Scores de 3 dígitos (100+): solo reducir fuente y letter-spacing */
.pn-score-widget--3d .pn-score-team{ font-size:14px;letter-spacing:-1px; }
.pn-gw-extra{
  width:168px;flex-shrink:0;display:flex;justify-content:flex-end;gap:10px;padding-right:8px;
}
.pn-mstat{ display:flex;flex-direction:column;align-items:center;gap:1px;min-width:26px; }
.pn-mstat-val{ font-weight:700;font-size:13px;color:var(--pn-main); }
.pn-mstat-key{
  font-size:9px;color:var(--pn-secondary);
  text-transform:uppercase;letter-spacing:.5px;
}

/* ── FOOTER ── */
.pn-footer{
  background:var(--pn-main);padding:24px 20px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:12px;margin-top:40px;
}
.pn-footer-brand{
  font-family:"Lora",serif;color:var(--pn-third);
  font-size:18px;letter-spacing:1px;
}
.pn-footer-links{ display:flex;gap:20px;flex-wrap:wrap; }
.pn-footer-links a{ color:var(--pn-third);font-size:12px;opacity:.7; }

/* ── RESPONSIVE ── */
@media(max-width:1200px){
  .pn-grid{ grid-template-columns:1fr 160px; }
  .pn-ad-left{ display:none; }
}
@media(max-width:960px){
  .pn-grid{ grid-template-columns:1fr; }
  .pn-ad-right{ display:none; }
  .pn-ad-leaderboard{ display:block;width:100%;max-width:728px;margin:0 auto 20px; }
}
@media(max-width:700px){
  .pn-grid{ padding-left:5px;padding-right:5px; }
  .pn-two-col-aura{ grid-template-columns:1fr; }
  .pn-two-col{ grid-template-columns:1fr; }
  .pn-gw-extra{ display:none; }
  .pn-gw-result-tag{ display:none; }
  .pn-gw-team{ width:100px; }
  .pn-gw-team .pn-team-name{ max-width:70px; }
  .pn-gw-date{ width:40px;font-size:10px; }
  .pn-ad-mrec{ display:block;width:300px;margin:20px auto; }
  .pn-nav ul{ padding:0 10px; }
  .pn-stats-strip{ gap:20px; }
  .pn-stats-strip-list{ gap:20px; }
  /* standings: hide Forma column — too wide for mobile */
  .pn-standings-table th:last-child,
  .pn-standings-table td:last-child{ display:none; }
}
@media(max-width:480px){
  /* hero */
  .pn-hero{ padding:14px 12px; }
  .pn-hero-photo{ width:53px;height:53px; }
  .pn-hero-photo--placeholder svg{ width:28px;height:28px; }
  .pn-hero-name{ font-size:22px; }
  .pn-hero-number{ font-size:52px; }
  .pn-hero-meta{ flex-wrap:wrap;gap:10px; }
  /* aura meta: reduce value size so two columns still fit on narrow screens */
  .pn-aura-meta-val,.pn-aura-record-val{ font-size:16px; }
  /* highlights */
  .pn-highlights{ display:grid;grid-template-columns:repeat(2,1fr); }
  .pn-highlight-val{ font-size:22px; }
  /* score boxes: shrink slightly on narrow phones */
  .pn-score-team{ width:26px;height:28px;font-size:16px; }
  /* standings: also hide GF/GC/DG (cols 7-9) to reduce required width */
  .pn-standings-table th:nth-child(7),
  .pn-standings-table td:nth-child(7),
  .pn-standings-table th:nth-child(8),
  .pn-standings-table td:nth-child(8),
  .pn-standings-table th:nth-child(9),
  .pn-standings-table td:nth-child(9){ display:none; }
  /* competition match row: drop the aside column */
  .pn-comp-match-aside{ display:none; }
  .pn-comp-match-row{
    grid-template-columns:48px 1fr auto 1fr;
    gap:4px;padding:6px 8px;
  }
  .pn-comp-match-home .pn-team-name,
  .pn-comp-match-away .pn-team-name{ max-width:72px;font-size:11px; }
}

/* ================================================================
 * TEAM-PAGE specific blocks (still under .platform-new scope).
 * ================================================================ */

/* ── TEAM HERO (variant: crest left, watermark, league badge over name) ── */
.pn-team-hero{
  background:var(--pn-main);border-radius:12px;overflow:hidden;
  display:flex;align-items:stretch;position:relative;
  min-height:220px;margin-bottom:20px;
}
.pn-team-hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 55% 90% at 10% 120%,#826E5E66 0%,transparent 65%),
    linear-gradient(135deg,#2d2218 0%,#483c32 50%,#6b5444 100%);
}
.pn-team-hero-watermark{
  position:absolute;right:-10px;bottom:-20px;
  font-family:"Lora",serif;font-size:130px;font-weight:600;
  color:var(--pn-third);opacity:.07;line-height:1;user-select:none;
  white-space:nowrap;pointer-events:none;
}
.pn-team-hero-crest{
  position:relative;z-index:1;width:180px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  padding:24px 0 24px 28px;
}
.pn-team-hero-info{
  position:relative;z-index:1;padding:28px 24px;flex:1;
  display:flex;flex-direction:column;justify-content:center;
}
.pn-team-hero-league{ display:flex;align-items:center;gap:8px;margin-bottom:10px; }
.pn-team-hero-league span{
  font-size:12px;color:var(--pn-third);opacity:.8;
  letter-spacing:1px;text-transform:uppercase;
}
.pn-team-hero-name{
  font-family:"Lora",serif;font-size:44px;color:var(--pn-white);
  line-height:1.05;margin-bottom:6px;
}
.pn-team-hero-sub{
  font-size:13px;font-weight:600;color:var(--pn-third);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:20px;
}
.pn-team-hero-meta{ display:flex;gap:22px;flex-wrap:wrap; }
/* re-use .pn-hero-meta-item / .pn-hero-meta-key / .pn-hero-meta-val */

/* ── STANDINGS + sidebar 2-col ── */
.pn-standings-next-row{ display:grid;grid-template-columns:1fr 280px;gap:16px;margin-bottom:4px; }

/* Standings table */
.pn-standings-table{ width:100%;border-collapse:collapse;font-size:13px; }
.pn-standings-table th,
.pn-standings-table td{ border-left:0;border-right:0; }
.pn-standings-table thead th{
  background:var(--pn-main);color:var(--pn-third);font-weight:600;
  padding:9px 10px;text-align:center;white-space:nowrap;letter-spacing:.4px;
}
.pn-standings-table thead th:nth-child(2){ text-align:left; }
.pn-standings-table tbody tr{ transition:background .15s; }
.pn-standings-table tbody tr:hover{ background:var(--pn-fourth); }
.pn-standings-table tbody tr.pn-row-highlight{
  background:var(--pn-fourth);border-left:3px solid var(--pn-third);
}
.pn-standings-table tbody tr.pn-row-highlight td{ font-weight:600; }
.pn-standings-table tbody td{ padding:7px 10px;text-align:center;vertical-align:middle; }
.pn-standings-table tbody td:nth-child(2){ text-align:left; }
.pn-team-cell{ display:flex;align-items:center;gap:8px; }
.pn-form-cell{ display:flex;gap:4px;justify-content:flex-end;align-items:center; }
.pn-form-pill{
  width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  border:2px solid transparent;overflow:hidden;
  font-size:9px;font-weight:700;color:#fff;
  flex-shrink:0;
}
.pn-form-pill img{
  width:14px;height:14px;object-fit:contain;display:block;
}
/* Win = green border + tinted background; loss = red; draw = amber. */
.pn-form-w{ background:rgba(39,174,96,.15);border-color:#27ae60; }
.pn-form-d{ background:rgba(243,156,18,.18);border-color:#f39c12; }
.pn-form-l{ background:rgba(231,76,60,.15);border-color:#e74c3c; }
/* Upcoming match — gray, separated from the played 5 by a small gap. */
.pn-form-next{ background:rgba(149,165,166,.18);border-color:#95a5a6;margin-left:6px; }

/* Next match panel body */
.pn-next-match{
  display:flex;flex-direction:column;align-items:center;
  gap:12px;padding:20px 16px;
}
.pn-next-match-comp{
  font-size:11px;color:var(--pn-secondary);
  text-transform:uppercase;letter-spacing:1px;
}
.pn-next-match-teams{
  display:flex;align-items:center;gap:16px;width:100%;justify-content:center;
}
.pn-next-match-team{ display:flex;flex-direction:column;align-items:center;gap:6px; }
.pn-next-match-team span{ font-size:11px;font-weight:600; }
.pn-next-match-vs{
  font-family:"Lora",serif;font-size:22px;color:var(--pn-secondary);font-weight:600;
}
.pn-next-match-when{
  background:var(--pn-fourth);border:1px solid var(--pn-third);border-radius:6px;
  padding:8px 14px;text-align:center;width:100%;
}
.pn-next-match-when-date{ font-size:13px;font-weight:700;color:var(--pn-main); }
.pn-next-match-when-time{ font-size:12px;color:var(--pn-secondary); }

/* ── TEAM matches (played + upcoming) ── */
.pn-team-matches{
  display:flex;flex-direction:column;gap:18px;margin-bottom:24px;
}
.pn-team-matches-block{ display:flex;flex-direction:column; }
.pn-team-matches-bar{
  background:var(--pn-main);color:var(--pn-third);
  padding:8px 14px;font-family:"Lora",serif;font-size:13px;font-weight:600;
  letter-spacing:.5px;border-radius:8px 8px 0 0;
  display:flex;align-items:center;gap:8px;
}
.pn-team-matches .pn-comp-matches{ margin-bottom:0; }
@media(max-width:700px){
  .pn-team-matches-bar{ font-size:12px;padding:6px 12px; }
}

/* Team aura mini panel */
.pn-team-aura{ padding:12px 14px; }
.pn-team-aura-head{
  display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:6px;
}
.pn-team-aura-key{
  font-size:10px;color:var(--pn-secondary);
  text-transform:uppercase;letter-spacing:.5px;
}
.pn-team-aura-val{
  font-family:"Lora",serif;font-size:22px;color:var(--pn-main);font-weight:600;
}
.pn-team-aura-record{ text-align:right; }
.pn-team-aura-record-val{ font-size:13px;font-weight:700;color:var(--pn-main); }

/* ── PLAYER LINKS widget ── */
.pn-links{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;
}
.pn-links-col{
  background:var(--pn-white);border:1px solid #e0d8ce;border-radius:10px;overflow:hidden;
}
.pn-links-header{
  background:var(--pn-main);color:var(--pn-third);
  font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  padding:9px 14px;
}
.pn-links-list{ list-style:none;margin:0;padding:0; }
.pn-links-row{
  display:grid;grid-template-columns:22px 32px 1fr auto auto;
  align-items:center;gap:8px 12px;
  padding:7px 14px;border-bottom:1px solid #f0ebe4;
}
.pn-links-row:last-child{ border-bottom:none; }
.pn-links-rank{
  font-size:11px;font-weight:700;color:var(--pn-secondary);opacity:.5;text-align:center;
}
.pn-links-avatar{
  width:32px;height:32px;border-radius:50%;object-fit:cover;object-position:top center;
  border:1px solid #e0d8ce;display:block;flex-shrink:0;
}
.pn-links-avatar--ph{
  background:#e8e0d6;
}
.pn-links-name-wrap{
  display:flex;flex-direction:column;gap:1px;min-width:0;
}
.pn-links-name{
  font-size:13px;font-weight:500;color:var(--pn-main);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;
}
.pn-links-aura{
  font-size:10px;font-weight:600;color:var(--pn-secondary);opacity:.65;
  white-space:nowrap;letter-spacing:.2px;
}
.pn-links-link{
  color:var(--pn-main);text-decoration:none;
}
.pn-links-link:hover{ text-decoration:underline; }
.pn-links-apps{
  font-size:13px;font-weight:700;color:var(--pn-main);
  font-family:"Lora",serif;white-space:nowrap;
}

/* ── FORMATION pitch (horizontal) ── */
.pn-formation-full{ margin-bottom:16px; }
.pn-formation-wrap{ display:flex;justify-content:center; }
.pn-formation-svg{ width:100%;max-width:700px;display:block; }

/* ── SQUAD cards ── */
.pn-squad-group-label{
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--pn-secondary);padding:14px 0 8px;
  border-bottom:1px solid #e8e0d4;margin-bottom:10px;
}
.pn-squad-group-wrap{ padding:0 14px; }
.pn-squad-cards{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:10px;
  padding:0 14px 14px;
}

.pn-squad-card{
  background:var(--pn-white);border:1px solid #ede8e0;border-radius:8px;
  display:flex;flex-direction:column;align-items:stretch;gap:0;padding:0;
  transition:background .15s,transform .15s,box-shadow .15s;
  cursor:pointer;overflow:hidden;
  border-left:3px solid var(--pn-third);
}
.pn-squad-card:hover{
  background:var(--pn-fourth);transform:translateY(-1px);
  box-shadow:0 2px 6px rgba(72,60,50,.08);
}
.pn-squad-card.pn-squad-card-featured{
  background:var(--pn-fourth);border-left:3px solid #1a4a8a;
}

/* Top row of the card: dorsal · avatar · name+meta. Each card stacks
   header → stats → aura vertically inside the grid cell. */
.pn-sc-header{
  display:flex;align-items:stretch;gap:0;
  border-bottom:1px solid #ede8e0;
}

/* Avatar with dorsal badge anchored bottom-right. The dorsal is a chip, not
   a full-height block, so the card stays compact in the grid. */
.pn-sc-avatar{
  position:relative;
  width:56px;height:56px;border-radius:50%;
  margin:8px 10px 8px 12px;flex-shrink:0;overflow:visible;
  background:#e8e4de;
  display:flex;align-items:center;justify-content:center;
}
.pn-sc-avatar img{ width:100%;height:100%;object-fit:cover;border-radius:50%;display:block; }
.pn-sc-avatar svg{ width:40px;height:40px; }
.pn-sc-dorsal{
  position:absolute;bottom:2px;right:2px;
  background:var(--pn-main);color:var(--pn-third);
  font-family:inherit;font-size:10px;font-weight:700;
  padding:2px 6px;border-radius:999px;line-height:1;
  letter-spacing:.3px;
}
.pn-squad-card-featured .pn-sc-dorsal{ background:#1a4a8a; }

.pn-sc-info{ flex:1;min-width:0;padding:8px 10px 8px 4px; }
.pn-sc-name{
  font-size:14px;font-weight:700;color:#1a1512;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-bottom:3px;
  display:flex;align-items:center;gap:6px;
}
.pn-sc-name span{ overflow:hidden;text-overflow:ellipsis;min-width:0; }
/* Country flag inline before the name. Small, fixed size, doesn't push the
   name to wrap. */
.pn-sc-flag{
  width:16px;height:16px;object-fit:cover;flex-shrink:0;
  border-radius:50%;
}
.pn-squad-card-featured .pn-sc-name{ color:var(--pn-main); }
.pn-sc-meta{ display:flex;align-items:center;gap:6px;flex-wrap:wrap; }
.pn-sc-pos{
  font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px;
  letter-spacing:.5px;text-transform:uppercase;
}
.pn-sc-pos-por{ background:#fff3cd;color:#856404;border:1px solid #ffc107; }
.pn-sc-pos-def{ background:#cfe2ff;color:#084298;border:1px solid #9ec5fe; }
.pn-sc-pos-mid{ background:#d1e7dd;color:#0a3622;border:1px solid #a3cfbb; }
.pn-sc-pos-fwd{ background:#f8d7da;color:#842029;border:1px solid #f1aeb5; }
.pn-sc-nat{ display:flex;align-items:center;gap:4px;font-size:11px;color:var(--pn-secondary); }
.pn-sc-age{ font-size:11px;color:var(--pn-secondary); }

/* Stats row: equal-width 6-col grid (PJ MIN G A AM R). The two card stats
   that map to disciplinary cards (AM=amarilla, R=roja) get a colored value
   so you can scan a card and spot the booking count without reading labels. */
.pn-sc-stats{
  display:grid;
  grid-template-columns:repeat(6, 1fr);
  border-bottom:1px solid #ede8e0;
}
.pn-sc-stat{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:1px;padding:6px 2px;border-right:1px solid #ede8e0;
}
.pn-sc-stat:last-child{ border-right:0; }
.pn-sc-stat-val{
  font-family:"Lora",serif;font-size:15px;font-weight:600;color:var(--pn-main);line-height:1;
}
.pn-sc-stat-key{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--pn-secondary);
}
.pn-sc-stat-yc .pn-sc-stat-key{ color:#caa700; }
.pn-sc-stat-rc .pn-sc-stat-key{ color:#c0392b; }
.pn-sc-stat-yc .pn-sc-stat-val,
.pn-sc-stat-rc .pn-sc-stat-val{ color:var(--pn-main); }

/* Aura row: label · bar · value. Bar fills proportionally to the team's top
   aura, so you can see at a glance which players carry the squad's value. */
.pn-sc-aura{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  gap:8px;padding:6px 10px;
}
.pn-sc-aura-val{ font-size:12px;font-weight:700;color:var(--pn-main);text-align:right; }
.pn-squad-card-featured .pn-sc-aura-val{ font-weight:700; }
/* Track lleno (gradiente) representa de 0 al prime del jugador. El tick
   marca dónde está el valor actual respecto a su prime. Si el jugador está
   en su prime, el tick va al final. */
.pn-sc-aura-bar-wrap{
  position:relative;
  height:6px;
  background:linear-gradient(90deg,#e6dfd2 0%,#826E5E 50%,#E1CA96 100%);
  border-radius:3px;
  overflow:visible;
}
.pn-sc-aura-bar{ display:none; }
.pn-sc-aura-tick{
  position:absolute;
  top:50%;
  width:10px;height:10px;
  background:var(--pn-main);
  border:2px solid var(--pn-white);
  border-radius:50%;
  transform:translate(-50%,-50%);
  box-shadow:0 1px 2px rgba(0,0,0,.25);
  pointer-events:none;
}
.pn-sc-aura-prime{
  font-size:10px;font-weight:600;color:var(--pn-secondary);margin-left:1px;
}
.pn-sc-aura-key{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--pn-secondary);
}

/* ── Result badge (used by match row when in "result" mode) ── */
.pn-gw-result-tag{
  width:52px;flex-shrink:0;
  display:flex;align-items:center;justify-content:flex-end;padding-right:8px;
}
.pn-result-badge{
  font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;letter-spacing:.5px;
}
.pn-result-w{ background:var(--pn-green-standings);color:#1a6b30; }
.pn-result-d{ background:#e8e8e8;color:#555; }
.pn-result-l{ background:var(--pn-red-standings);color:#8b1c1c; }

/* ── Career flat table (one row per season-competition) ── */
.pn-career-flat{ width:100%;min-width:420px;border-collapse:collapse;font-size:13px; }
.pn-career-flat thead th{
  background:var(--pn-main);color:var(--pn-third);font-weight:600;
  letter-spacing:.4px;padding:9px 10px;text-align:center;white-space:nowrap;
}
.pn-career-flat thead th:first-child{ text-align:left; }
.pn-career-flat tbody tr{ border-bottom:1px solid #e8e0d4;transition:background .15s; }
.pn-career-flat tbody tr:hover{ background:var(--pn-fourth); }
.pn-career-flat tbody td{
  padding:8px 10px;white-space:nowrap;vertical-align:middle;text-align:center;
}
.pn-career-flat tbody td:first-child{ text-align:left; }
.pn-career-flat tbody tr.pn-totals-row{
  background:var(--pn-fourth);
  border-top:2px solid var(--pn-third);
  border-bottom:2px solid var(--pn-third);
}
.pn-career-flat tbody tr.pn-totals-row td{ font-weight:600; }

/* Responsive overrides for team-only blocks */
@media(max-width:700px){
  .pn-team-hero{ flex-direction:column;min-height:auto; }
  .pn-team-hero-crest{ width:100%;padding:24px 0 8px;justify-content:center; }
  .pn-team-hero-info{ padding:0 20px 24px; }
  .pn-team-hero-name{ font-size:30px; }
  .pn-team-hero-watermark{ font-size:80px; }
  .pn-standings-next-row{ grid-template-columns:1fr; }
  .pn-links{ grid-template-columns:1fr; }
}
@media(max-width:600px){
  .pn-squad-cards{ grid-template-columns:1fr;padding:0 10px 10px; }
  .pn-squad-group-wrap{ padding:0 10px; }
  .pn-sc-stat{ padding:5px 1px; }
  .pn-sc-stat-val{ font-size:14px; }
  .pn-sc-aura-val{ font-size:11px; }
}

/* ================================================================
 * COMPETITION-PAGE specific blocks (still under .platform-new scope).
 * ================================================================ */

/* ── Clean white competition header ── */
.pn-comp-header{
  background:var(--pn-white);border:1px solid #e0d8ce;border-radius:10px;
  padding:18px 22px;margin-bottom:18px;
  display:flex;align-items:center;gap:18px;
}
.pn-comp-header-logo{
  width:64px;height:64px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.pn-comp-header-text{ display:flex;flex-direction:column;gap:2px; }
.pn-comp-header-name{
  font-family:"Lora",serif;font-size:30px;color:var(--pn-main);
  line-height:1.05;margin:0;
}
.pn-comp-header-season{
  font-size:12px;color:var(--pn-secondary);
  letter-spacing:.5px;font-weight:500;
}
/* Season selector — same look-and-feel as the static .pn-comp-header-season
   label, but a clickable pill with a chevron. */
.pn-comp-header-season-select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  font-family:inherit;font-size:12px;font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;
  color:var(--pn-main);background:#f7f1e8;
  border:1px solid #e0d8ce;border-radius:999px;
  padding:4px 26px 4px 12px;margin-top:2px;
  cursor:pointer;line-height:1.4;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'><path d='M1 1.5l5 5 5-5' fill='none' stroke='%23483c32' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 10px center;background-size:9px;
  transition:background-color .15s ease,border-color .15s ease;
}
.pn-comp-header-season-select:hover{ background-color:#f0e7d8;border-color:#d4c8b9; }
.pn-comp-header-season-select:focus{ outline:none;border-color:var(--pn-accent,#E1CA96);box-shadow:0 0 0 2px rgba(225,202,150,0.3); }

/* Group tabs (multi-group leagues like Primera Federación). Pill strip under
   the title — same family as the season pill but each tab is a link. */
.pn-comp-header-groups{
  display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;
}
.pn-comp-header-group{
  font-family:inherit;font-size:12px;font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;
  color:var(--pn-main);background:#f7f1e8;
  border:1px solid #e0d8ce;border-radius:999px;
  padding:4px 12px;line-height:1.4;
  text-decoration:none;
  transition:background-color .15s ease,border-color .15s ease;
}
.pn-comp-header-group:hover{ background-color:#f0e7d8;border-color:#d4c8b9; }
.pn-comp-header-group.is-current{
  background:var(--pn-main);color:var(--pn-white);border-color:var(--pn-main);
}

/* Competition cell becomes a link when we have data for that comp/season —
   inherits the badge+name layout but underlines on hover. */
.pn-season-entity-link{
  display:inline-flex;align-items:center;gap:6px;
  color:inherit;text-decoration:none;
}
.pn-season-entity-link:hover{ text-decoration:underline;text-decoration-color:var(--pn-accent,#E1CA96); }

/* ── Round navigator (3-tab dark bar) ── */
.pn-round-bar{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:stretch;
  background:var(--pn-main);border-radius:8px;overflow:hidden;
  margin-bottom:0;
}
.pn-round-tab{
  display:flex;align-items:center;gap:8px;
  padding:12px 16px;color:var(--pn-third);
  font:600 12px/1 "Montserrat",sans-serif;letter-spacing:1px;
  text-transform:uppercase;text-decoration:none;
  transition:background .15s,color .15s;
}
.pn-round-tab.pn-round-tab-side{
  color:#fff;opacity:.85;
}
.pn-round-tab.pn-round-tab-side:hover{
  opacity:1;
}
/* Prev: flush to the left edge. Next: flush to the right edge. */
.pn-round-bar > .pn-round-tab-side:first-child{
  justify-content:flex-start;
}
.pn-round-bar > .pn-round-tab-side:last-child{
  justify-content:flex-end;
}
.pn-round-tab.pn-round-tab-current{
  justify-content:center;
  font:600 14px/1 "Lora",serif;letter-spacing:1.5px;
  color:var(--pn-third);text-transform:uppercase;
  white-space:nowrap;
}
.pn-round-tab.pn-round-tab-disabled{
  opacity:.18;cursor:default;
}
.pn-round-tab .pn-round-arrow{
  font-size:18px;font-weight:400;
  display:inline-flex;align-items:center;line-height:1;
}

/* ── Match rows inside a round ── */
.pn-comp-matches{
  background:var(--pn-white);border:1px solid #e0d8ce;border-top:0;
  border-radius:0 0 8px 8px;overflow:hidden;
  margin-bottom:24px;
}
.pn-comp-match-link{ text-decoration:none;color:inherit;display:block; }
.pn-comp-match-link + .pn-comp-match-link .pn-comp-match-row{
  border-top:1px solid var(--pn-third);
}
/* Separador entre el header de torneo (round-bar / fh-round-bar) y la
   primera fila de partidos. Sin esto la primera fila se adhiere visualmente
   a la franja superior y rompe la rejilla de separadores. */
.pn-comp-matches > .pn-comp-match-link:first-child .pn-comp-match-row{
  border-top:1px solid var(--pn-third);
}
.pn-comp-match-row{
  display:grid;
  /* date | home | score | away | aside (mirrors date width to keep the
     home/score/away cluster centered). */
  grid-template-columns:90px 1fr auto 1fr 90px;
  align-items:center;gap:12px;
  padding:6px 14px;
  transition:background .15s;
}
.pn-comp-match-aside{
  display:flex;align-items:center;justify-content:flex-end;
  font-size:11px;color:var(--pn-secondary);font-weight:600;
  white-space:nowrap;
}
/* Two-leg tie connector: pair the ida + vuelta with a subtle left rail and
   a small "Ida"/"Vuelta" label tucked above the date. */
.pn-comp-match-link--tie .pn-comp-match-row{
  border-left:3px solid #d1c4a3;
  padding-left:10px;
}
.pn-comp-match-link--ida .pn-comp-match-row{
  /* No bottom border so the next row visually joins. */
  border-bottom:0;
}
.pn-comp-match-link--ida + .pn-comp-match-link--vuelta .pn-comp-match-row{
  /* Tighten the vertical gap inside the pair. */
  border-top:0;
}
.pn-comp-match-leg{
  display:inline-block;font-size:9px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:#a08753;line-height:1;margin-bottom:2px;
}
.pn-comp-match-agg{
  font-size:11px;color:var(--pn-main);font-weight:500;
}
.pn-comp-match-agg strong{ color:var(--pn-main);font-weight:700; }
.pn-comp-match-center{
  display:flex;align-items:center;justify-content:center;
}
.pn-comp-match-link:hover .pn-comp-match-row{ background:var(--pn-fourth); }
.pn-comp-match-date{
  display:flex;flex-direction:column;gap:1px;
  font-size:11px;color:var(--pn-secondary);font-weight:600;
  white-space:nowrap;
}
.pn-comp-match-date-day{ font-size:12px;color:var(--pn-main); }
.pn-comp-match-date-time{ color:var(--pn-secondary); }
.pn-comp-match-home{
  display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;
}
.pn-comp-match-away{
  display:flex;align-items:center;justify-content:flex-start;gap:8px;min-width:0;
}
.pn-comp-match-home .pn-team-name,
.pn-comp-match-away .pn-team-name{
  font-size:13px;font-weight:600;color:var(--pn-main);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:160px;
}
.pn-comp-match-score{ margin:0; }
.pn-comp-match-kickoff{
  font-family:"Lora",serif;font-size:16px;color:var(--pn-main);font-weight:600;
  padding:3px 12px;min-width:62px;text-align:center;
}

/* ── Standings table — position-circle zones ── */
/* The position cell is the first <td>; shrink it so the team column gets the
   width it deserves. The circle is rendered as a span inside it. */
.pn-standings-table thead th:first-child,
.pn-standings-table tbody td:first-child{
  width:36px;padding-left:6px;padding-right:6px;
}
/* Stat columns (PJ, G, E, P, GF, GC, DG = cols 4..10) — narrow + monospace tabular feel. */
.pn-standings-table thead th:nth-child(n+3):nth-child(-n+10),
.pn-standings-table tbody td:nth-child(n+3):nth-child(-n+10){
  width:30px;padding-left:2px;padding-right:2px;font-variant-numeric:tabular-nums;
}
.pn-standings-table thead th:last-child,
.pn-standings-table tbody td:last-child{
  /* Form column — 5 played pills + gap + next-match pill. */
  width:180px;padding-left:8px;padding-right:8px;
}
.pn-pos-circle{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:50%;
  font-weight:700;font-size:12px;color:var(--pn-main);
  background:transparent;
  line-height:1;
}
/* UEFA-style colours: Champions (blue), Europa (orange),
   Conference (teal). Generic promotion/playoff (green/yellow). Relegation (red). */
.pn-pos-circle--champions {
  background:#1f6feb;color:#fff;
}
.pn-pos-circle--promotion {
  background:#27ae60;color:#fff;
}
.pn-pos-circle--europa {
  background:#f97316;color:#fff;
}
.pn-pos-circle--conference {
  background:#0d9488;color:#fff;
}
.pn-pos-circle--playoff {
  background:#e1ca56;color:#1a1a1a;
}
.pn-pos-circle--relegation {
  background:#e74c3c;color:#fff;
}

.pn-standings-legend{
  list-style:none;margin:12px 0 0;padding:0;
  display:flex;flex-wrap:wrap;gap:14px;
  font-size:12px;color:var(--pn-secondary);
}
.pn-standings-legend li{
  display:inline-flex;align-items:center;gap:6px;
}
.pn-standings-legend .pn-pos-circle{
  width:14px;height:14px;font-size:0;
}
.pn-standings-legend-label{ color:var(--pn-main); }

/* ── Top players (Goleadores / Asistentes) — 2-col panel grid ── */
.pn-top-players-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;
}
.pn-top-players-list{
  list-style:none;margin:0;padding:0;
}
.pn-top-players-row{
  display:flex;align-items:center;gap:12px;
  padding:8px 14px;border-bottom:1px solid #f0ebe3;
}
.pn-top-players-row:last-child{ border-bottom:0; }
.pn-top-players-rank{
  width:22px;color:var(--pn-secondary);font-weight:700;text-align:center;flex-shrink:0;
  font-family:"Lora",serif;font-size:14px;
}
.pn-top-players-info{ flex:1;display:flex;flex-direction:column;gap:1px;min-width:0; }
.pn-top-players-name{
  font-size:13px;font-weight:600;color:var(--pn-main);
  text-decoration:none;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pn-top-players-name:hover{ color:var(--pn-secondary); }
.pn-top-players-team{
  display:flex;align-items:center;gap:4px;
  font-size:11px;color:var(--pn-secondary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pn-top-players-value{
  font-family:"Lora",serif;font-size:18px;color:var(--pn-main);font-weight:600;
  margin-left:auto;flex-shrink:0;
}

/* ── Responsive overrides ── */
@media(max-width:760px){
  .pn-comp-header{ padding:14px 16px; }
  .pn-comp-header-name{ font-size:22px; }
  .pn-comp-match-row{
    grid-template-columns:60px 1fr auto 1fr 60px;gap:6px;padding:6px 8px;
  }
  .pn-comp-match-home .pn-team-name,
  .pn-comp-match-away .pn-team-name{ max-width:90px;font-size:12px; }
  .pn-comp-match-date{ font-size:10px; }
  .pn-top-players-grid{ grid-template-columns:1fr; }
  .pn-round-tab{ padding:10px 8px;font-size:11px;letter-spacing:.5px; }
  .pn-round-tab.pn-round-tab-current{ font-size:12px; }
}

/* ── PALMARÉS ──
   Vitrina de trofeos: cabinet oscuro cálido con borde dorado interior y
   medallas en relieve. Cada tarjeta es una medalla (logo del torneo en
   disco dorado) + count en Lora monumental + nombre grabado en mayúsculas.
   Pensado para mirarse, no para hojearse: el contraste con el resto del
   layout cream/marrón le da su momento.                                  */
.pn-palmares{
  position:relative;margin:28px 0 24px;border-radius:14px;overflow:hidden;
  background:
    radial-gradient(ellipse 55% 65% at 50% 0%, rgba(225,202,150,.18) 0%, transparent 65%),
    radial-gradient(ellipse 60% 80% at 50% 110%, rgba(0,0,0,.45) 0%, transparent 60%),
    linear-gradient(135deg,#2a221d 0%,#3c322a 45%,#4a3d33 100%);
  box-shadow:
    inset 0 1px 0 rgba(225,202,150,.22),
    inset 0 -1px 0 rgba(0,0,0,.35),
    0 18px 40px -22px rgba(0,0,0,.45);
}
/* Grano cálido — manchitas doradas dispersas para que no se vea plano. */
.pn-palmares::before{
  content:'';position:absolute;inset:0;pointer-events:none;opacity:.55;
  background-image:
    radial-gradient(circle at 14% 22%, rgba(225,202,150,.05) 0 1px, transparent 2px),
    radial-gradient(circle at 71% 64%, rgba(225,202,150,.04) 0 1px, transparent 2px),
    radial-gradient(circle at 42% 89%, rgba(225,202,150,.04) 0 1px, transparent 2px),
    radial-gradient(circle at 88% 12%, rgba(225,202,150,.05) 0 1px, transparent 2px);
  background-size:11px 11px,17px 17px,9px 9px,13px 13px;
  mix-blend-mode:screen;
}
/* Marco dorado interior — fina línea doble por sombras. */
.pn-palmares::after{
  content:'';position:absolute;inset:10px;border-radius:8px;pointer-events:none;
  border:1px solid rgba(225,202,150,.16);
  box-shadow:inset 0 0 0 4px rgba(0,0,0,.0), 0 0 0 1px rgba(0,0,0,.25);
}
.pn-palmares-frame{ position:relative;z-index:1;padding:26px 22px 28px; }

/* Cabecera: regla — diamante — TÍTULO — diamante — regla */
.pn-palmares-head{
  display:flex;align-items:center;gap:18px;margin:0 0 22px;
}
.pn-palmares-rule{
  flex:1;height:1px;
  background:linear-gradient(90deg,transparent,rgba(225,202,150,.4),transparent);
}
.pn-palmares-titleblock{
  display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.pn-palmares-mark{
  width:6px;height:6px;background:#E1CA96;
  transform:rotate(45deg);
  box-shadow:0 0 0 1px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,.4);
}
.pn-palmares-title{
  font-family:"Lora",serif;font-size:28px;font-weight:600;letter-spacing:.5px;
  color:#f0d99f;margin:0;line-height:1;
  text-shadow:0 1px 0 rgba(0,0,0,.35);
}

/* Rejilla de medallas — tarjetas de ancho fijo, centradas, no estiran cuando
   solo hay 1-2 trofeos. */
.pn-palmares-grid{
  display:grid;grid-template-columns:repeat(auto-fill,170px);
  gap:6px 4px;justify-content:center;
}
.pn-palmares-card{
  position:relative;display:flex;flex-direction:column;align-items:center;
  gap:10px;padding:18px 10px 18px;border-radius:10px;
  text-decoration:none;color:inherit;
  background:linear-gradient(180deg,rgba(225,202,150,0) 0%,rgba(225,202,150,.04) 100%);
  transition:transform .25s ease,background .25s ease;
}
.pn-palmares-card::before{
  /* Halo dorado tenue al pasar por encima — separa la tarjeta del cabinet. */
  content:'';position:absolute;inset:6px;border-radius:8px;
  background:radial-gradient(ellipse at 50% 30%,rgba(225,202,150,.08) 0%,transparent 70%);
  opacity:0;transition:opacity .3s ease;pointer-events:none;
}
.pn-palmares-card:hover{ transform:translateY(-3px); }
.pn-palmares-card:hover::before{ opacity:1; }

/* Medalla: disco dorado con sombras de relieve y un brillo angular. */
.pn-palmares-medal{ position:relative;width:64px;height:64px; }
.pn-palmares-medal-disc{
  position:relative;width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 35% 28%,#fbe8b6 0%,#e6c478 30%,#b9923f 70%,#7d5e1f 100%);
  box-shadow:
    inset 0 -3px 6px rgba(0,0,0,.4),
    inset 0 2px 3px rgba(255,236,196,.55),
    0 6px 14px rgba(0,0,0,.45),
    0 0 0 2px rgba(225,202,150,.18);
  transition:transform .35s cubic-bezier(.2,.8,.3,1),box-shadow .35s ease;
}
.pn-palmares-medal-disc::after{
  /* Brillo en arco superior izquierdo */
  content:'';position:absolute;top:7px;left:9px;width:24px;height:9px;
  background:linear-gradient(135deg,rgba(255,255,255,.6),rgba(255,255,255,0));
  border-radius:50%;filter:blur(.4px);pointer-events:none;
}
.pn-palmares-medal-disc img{
  position:relative;width:38px;height:38px;object-fit:contain;
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.35));
}
.pn-palmares-card:hover .pn-palmares-medal-disc{
  transform:scale(1.06) rotate(-3deg);
  box-shadow:
    inset 0 -3px 6px rgba(0,0,0,.4),
    inset 0 2px 3px rgba(255,236,196,.6),
    0 10px 22px rgba(0,0,0,.55),
    0 0 0 2px rgba(225,202,150,.36);
}

/* Count "N×" — Lora grande, número en champagne, ×  en cursiva más pequeña. */
.pn-palmares-count{
  display:flex;align-items:baseline;gap:1px;
  font-family:"Lora",serif;color:#f0d99f;line-height:1;
  text-shadow:0 1px 0 rgba(0,0,0,.4);
}
.pn-palmares-count-num{
  font-size:42px;font-weight:600;letter-spacing:-1px;
}
.pn-palmares-count-x{
  font-size:17px;font-style:italic;opacity:.65;
  margin-left:2px;align-self:flex-end;padding-bottom:6px;
}

/* Nombre del torneo grabado — small caps con subrayado animado. */
.pn-palmares-name{
  position:relative;max-width:100%;padding:0 4px 8px;
  text-align:center;font-size:11px;font-weight:600;
  letter-spacing:1.6px;text-transform:uppercase;color:#d8c9aa;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.pn-palmares-name::after{
  content:'';position:absolute;left:50%;bottom:0;
  width:0;height:1px;background:rgba(225,202,150,.7);
  transform:translateX(-50%);transition:width .35s ease;
}
.pn-palmares-card:hover .pn-palmares-name::after{ width:50%; }

/* Responsive: en móviles bajamos paddings y tamaño del count. */
@media(max-width:760px){
  .pn-palmares-frame{ padding:22px 14px 24px; }
  .pn-palmares-title{ font-size:22px; }
  .pn-palmares-rule{ flex:0 1 32px; }
  .pn-palmares-grid{ grid-template-columns:repeat(auto-fill,140px); }
  .pn-palmares-card{ padding:14px 8px; }
  .pn-palmares-medal,.pn-palmares-medal-disc{ width:54px;height:54px; }
  .pn-palmares-medal-disc img{ width:32px;height:32px; }
  .pn-palmares-count-num{ font-size:34px; }
  .pn-palmares-name{ font-size:10px;letter-spacing:1.3px; }
}

/* ──────────────────────────────────────────────────────────────
   COMPETITION SUB-NAVIGATION
   ────────────────────────────────────────────────────────────── */
.pn-comp-subnav{
  display:flex;
  gap:0;
  border-bottom:2px solid var(--border-color,#e8e0cc);
  margin-bottom:24px;
}
.pn-comp-subnav-item{
  padding:10px 18px;
  font-size:13px;
  font-weight:600;
  color:var(--secondary-color,#8c7b5e);
  text-decoration:none;
  border-bottom:2px solid transparent;
  margin-bottom:-2px;
  transition:color .15s,border-color .15s;
  letter-spacing:.3px;
  text-transform:uppercase;
}
.pn-comp-subnav-item:hover{
  color:var(--primary-color,#1a1a1a);
}
.pn-comp-subnav-item.is-active{
  color:var(--accent-gold,#c9a84c);
  border-bottom-color:var(--accent-gold,#c9a84c);
}

/* ──────────────────────────────────────────────────────────────
   TRANSFERS PAGE
   ────────────────────────────────────────────────────────────── */

/* ── v2: per-team 3-column layout ── */
.pn-tr2-wrap{
  margin-top:4px;
  display:flex;
  flex-direction:column;
  gap:16px;
}
.pn-transfers-empty{
  padding:40px 0;
  text-align:center;
  color:var(--pn-secondary,#826E5E);
  font-size:14px;
}

/* Team card */
.pn-tr2-team{
  background:#fff;
  border:1px solid var(--border-color,#e8e0cc);
  border-radius:10px;
  overflow:hidden;
}
.pn-tr2-team-header{
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 16px;
  background:var(--section-bg,#f9f6ef);
  border-bottom:1px solid var(--border-color,#e8e0cc);
}
.pn-tr2-shield{
  object-fit:contain;
  flex-shrink:0;
}
.pn-tr2-team-name{
  font-size:14px;
  font-weight:700;
  color:#1a1512;
  text-decoration:none;
  flex:1;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.pn-tr2-team-name:hover{ text-decoration:underline; }

/* Economic balance in team header */
.pn-tr2-balance{
  display:flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
}
.pn-tr2-balance-out{
  font-size:11px;
  font-weight:600;
  color:#c5221f;
}
.pn-tr2-balance-in{
  font-size:11px;
  font-weight:600;
  color:#137333;
}
.pn-tr2-balance-net{
  font-size:11px;
  font-weight:700;
  padding:2px 8px;
  border-radius:10px;
}
.pn-tr2-balance-net--pos{ background:#e6f4ea;color:#137333; }
.pn-tr2-balance-net--neg{ background:#fce8e6;color:#c5221f; }

/* 3-column grid */
.pn-tr2-cols{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
}
.pn-tr2-col{
  min-width:0;
  border-right:1px solid var(--border-color,#e8e0cc);
}
.pn-tr2-col:last-child{ border-right:none; }

/* Column header */
.pn-tr2-col-head{
  display:flex;
  align-items:center;
  gap:7px;
  padding:9px 12px 8px;
  border-bottom:1px solid var(--border-color,#e8e0cc);
}
.pn-tr2-col-label{
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.6px;
}
.pn-tr2-col-label--arrivals{ color:#137333; }
.pn-tr2-col-label--departures{ color:#c5221f; }
.pn-tr2-col-label--rumours{ color:#1a73e8; }
.pn-tr2-col-count{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:18px;
  height:18px;
  padding:0 5px;
  border-radius:9px;
  font-size:10px;
  font-weight:700;
  background:var(--pn-fourth,#e1ca9617);
  color:var(--pn-secondary,#826E5E);
}

/* Column empty state */
.pn-tr2-col-empty{
  padding:20px 12px;
  font-size:12px;
  color:var(--pn-secondary,#826E5E);
  text-align:center;
}

/* Player row inside a column */
.pn-tr2-player{
  display:flex;
  align-items:flex-start;
  gap:8px;
  padding:9px 12px;
  border-bottom:1px solid var(--border-color,#e8e0cc);
}
.pn-tr2-player:last-child{ border-bottom:none; }

.pn-tr2-avatar{
  width:30px;
  height:30px;
  border-radius:50%;
  object-fit:cover;
  flex-shrink:0;
  background:var(--section-bg,#f9f6ef);
  border:1px solid var(--border-color,#e8e0cc);
}
.pn-tr2-avatar--empty{
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--pn-secondary,#826E5E);
}

.pn-tr2-player-body{
  min-width:0;
  flex:1;
}
.pn-tr2-player-top{
  display:flex;
  align-items:center;
  gap:4px;
  margin-bottom:3px;
}
.pn-tr2-player-name{
  font-size:12px;
  font-weight:700;
  color:#1a1512;
  text-decoration:none;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-width:0;
  flex:1;
}
.pn-tr2-player-name:hover{ text-decoration:underline; }
.pn-tr2-flag{
  flex-shrink:0;
  border-radius:1px;
}
.pn-tr2-player-bottom{
  display:flex;
  align-items:center;
  gap:5px;
  min-width:0;
}
.pn-tr2-club-img{
  flex-shrink:0;
  object-fit:contain;
}
.pn-tr2-club-name{
  font-size:11px;
  color:var(--pn-secondary,#826E5E);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  flex:1;
  min-width:0;
}
.pn-tr2-fee{
  flex-shrink:0;
  margin-left:auto;
  font-size:10px;
  font-weight:700;
  padding:2px 6px;
  border-radius:8px;
  white-space:nowrap;
}
.pn-tr2-fee--permanent{ background:#f0ebe3;color:#483c32; }
.pn-tr2-fee--loan{ background:#e8f0fe;color:#1a73e8; }
.pn-tr2-fee--free{ background:#e6f4ea;color:#137333; }
.pn-tr2-fee--loan_end{ background:#fce8e6;color:#c5221f; }

/* ── Responsive ── */
@media(max-width:640px){
  .pn-tr2-cols{
    grid-template-columns:1fr;
  }
  .pn-tr2-col{
    border-right:none;
    border-bottom:1px solid var(--border-color,#e8e0cc);
  }
  .pn-tr2-col:last-child{ border-bottom:none; }
  .pn-comp-subnav-item{ padding:8px 12px;font-size:12px; }
}

/* ── Rankings page ────────────────────────────────────────────────── */
.pn-rankings-subtitle{
  font-size:13px;
  color:var(--pn-secondary);
  margin:-8px 0 16px;
  letter-spacing:.4px;
}
.pn-rankings-updated{
  font-size:11px;
  color:var(--pn-secondary);
  text-align:right;
  margin:8px 0 24px;
  opacity:.7;
}

/* ── League rankings tabs ─────────────────────────────────────────────── */
.pn-league-tabs-wrap{ margin-bottom:24px; }

.pn-league-tabs-nav{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-bottom:16px;
}

.pn-league-tab{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  border:1.5px solid #d9cfbf;
  border-radius:20px;
  background:#fff;
  color:var(--pn-secondary);
  font-family:"Montserrat",sans-serif;
  font-size:12px;font-weight:600;letter-spacing:.3px;
  cursor:pointer;
  transition:background .15s,border-color .15s,color .15s;
  white-space:nowrap;
}
.pn-league-tab:hover{
  border-color:var(--pn-third);
  color:var(--pn-main);
}
.pn-league-tab--active{
  background:var(--pn-main);
  border-color:var(--pn-main);
  color:#fff;
}
.pn-league-tab--active:hover{
  background:var(--pn-secondary);
  border-color:var(--pn-secondary);
  color:#fff;
}
.pn-league-tab-icon{
  width:20px;height:14px;flex-shrink:0;
  border-radius:2px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.pn-league-tab-icon img{
  width:20px;height:14px;
  object-fit:cover;display:block;
}

.pn-league-tab-panel--hidden{ display:none; }

/* ── Search dropdown ─────────────────────────────────────────────────────── */
.bwai-search-wrap{position:relative;display:flex;align-items:center;}
.bwai-search-results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;min-width:260px;
  background:#fff;border:1px solid #e0e0e0;border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,.13);
  max-height:70vh;overflow-y:auto;z-index:9999;
  padding:4px 0;
}
.bwai-search-results[hidden]{display:none;}
.bwai-search-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;color:#111;text-decoration:none;
  transition:background .1s;
}
.bwai-search-item:hover,.bwai-search-item--active{background:var(--bwai-search-hl,#e7edf7);box-shadow:inset 3px 0 0 var(--bwai-search-accent,#1a3c6e);}
.bwai-search-thumb{
  width:32px;height:32px;flex-shrink:0;border-radius:4px;
  background:#f0f0f0 center/cover no-repeat;
}
.bwai-search-thumb--empty{background:#e8e8e8;}
.bwai-search-meta{display:flex;flex-direction:column;gap:2px;min-width:0;}
.bwai-search-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.bwai-search-name b{font-weight:700;}
.bwai-search-type{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:#888;}
.bwai-search-empty{padding:12px;font-size:13px;color:#888;text-align:center;}

/* ── byTeam / byComp: 50/50 desktop, stacked mobile ────────────────────────── */
.pn-mini-tables-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:24px;}
.pn-mini-tables-row .pn-mini-table-wrap{flex:1 1 calc(50% - 8px);min-width:260px;max-width:100%;}
@media(max-width:640px){.pn-mini-tables-row .pn-mini-table-wrap{flex:1 1 100%;}}

/* ── PLAYER LINKS — equipo + aura ── */
.pn-links-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
}
.pn-links-team {
  font-size: 10px;
  color: #1a1a1a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}
.pn-links-retired {
  color: #888;
}
.pn-links-aura {
  font-size: 10px;
  font-weight: 700;
  color: var(--pn-main);
  white-space: nowrap;
  letter-spacing: .2px;
  flex-shrink: 0;
}
.pn-links-aura--prime {
  color: #b07030;
}

/* ── PLAYER LINKS — team crest + aura badge ── */
.pn-links-team-link {
  display: inline-flex; align-items: center; gap: 4px;
  text-decoration: none; color: inherit;
}
a.pn-links-team-link:hover .pn-links-team { text-decoration: underline; }
.pn-links-team-crest {
  width: 14px; height: 14px; object-fit: contain; flex-shrink: 0;
}
.pn-links-aura-badge {
  display: inline-flex; align-items: baseline; gap: 3px;
  white-space: nowrap; text-align: right;
}
.pn-links-aura-label {
  font-size: 8px; font-weight: 700; letter-spacing: .8px;
  text-transform: uppercase; color: #6b6560;
}
.pn-links-aura-val {
  font-size: 12px; font-weight: 800; color: #1a1510;
}
.pn-links-aura-prime {
  font-size: 9px; color: #6b6560;
}
.pn-links-aura-week-diff {
  font-size: 10px; font-weight: 700;
}
.pn-links-aura-up   { color: #16a34a; }
.pn-links-aura-down { color: #dc2626; }

/* ── TEAM SHIELDS (shared: castolofc + hooperstats home) ── */
.fh-team-shields{
  display:flex;flex-wrap:wrap;gap:2px;
  margin-left:auto;padding:6px 10px 6px 0;justify-content:flex-end;
}
.fh-team-shield{
  display:inline-flex;flex-direction:column;align-items:center;justify-content:flex-end;
  width:24px;background:transparent;text-decoration:none;
  color:#5a4a36;font-size:9px;font-weight:700;
}
.fh-team-shield img{
  width:22px;height:22px;object-fit:contain;
  transition:transform .12s,filter .12s;transform-origin:center bottom;
}
.fh-team-shield:hover img{ transform:scale(1.15); }
.fh-team-shield::before{
  content:'';width:10px;height:3px;border-radius:4px;margin-bottom:3px;background:transparent;
}
.fh-team-shield--champions::before  { background:#2e6abf; }
.fh-team-shield--europa::before     { background:#f49542; }
.fh-team-shield--conference::before { background:#2ecc71; }
.fh-team-shield--playoff::before    { background:#8c4ad1; }
.fh-team-shield--promotion::before  { background:#1e8449; }
.fh-team-shield--relegation::before { background:#c0392b; }
.fh-team-shield--eliminated::before { background:#aaa; }
.fh-team-shield--eliminated img     { filter:grayscale(1) opacity(.55); }
.fh-team-shield--eliminated:hover img { filter:grayscale(.4) opacity(.8); }
