/* ================================================================
 * 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; }

/* ── 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%; }

/* Ad placeholders */
.pn-ad{
  background:repeating-conic-gradient(#e8e4de 0% 25%,#f2ede8 0% 50%) 0 0/20px 20px;
  border-radius:6px;border:1px dashed #c8bfb2;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;color:var(--pn-secondary);font-size:11px;font-weight:600;
  letter-spacing:.5px;text-transform:uppercase;
}
.pn-ad svg{ opacity:.35; }
.pn-ad-sky{ width:160px;height:600px;position:sticky;top:20px; }
.pn-ad-halfpage{ width:300px;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-end;position:relative;
  min-height:260px;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:10px;
  font-family:"Lora",serif;font-size:120px;font-weight:600;
  color:var(--pn-third);opacity:.13;line-height:1;user-select:none;
}
.pn-hero-img{
  position:relative;z-index:1;width:190px;flex-shrink:0;align-self:flex-end;
}
.pn-hero-info{ position:relative;z-index:1;padding:28px 24px 28px 16px;flex:1; }
.pn-hero-country{ display:flex;align-items:center;gap:8px;margin-bottom:8px; }
.pn-hero-country span{
  font-size:12px;color:var(--pn-third);opacity:.8;
  letter-spacing:1px;text-transform:uppercase;
}
.pn-hero-name{
  font-family:"Lora",serif;font-size:42px;color:var(--pn-white);
  line-height:1.1;margin-bottom:6px;
}
.pn-hero-pos{
  font-size:13px;font-weight:600;color:var(--pn-third);
  letter-spacing:2px;text-transform:uppercase;margin-bottom:18px;
}
.pn-hero-meta{ display:flex;gap:20px;flex-wrap:wrap; }
.pn-hero-meta-item{ display:flex;flex-direction:column;gap:2px; }
.pn-hero-meta-key{
  font-size:10px;color:var(--pn-third);opacity:.6;
  text-transform:uppercase;letter-spacing:1px;
}
.pn-hero-meta-val{
  font-size:15px;font-weight:600;color:var(--pn-white);
  display:flex;align-items:center;gap:6px;
}

/* ── 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 */
.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;
}
.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{
  position:absolute;pointer-events:none;
  background:#483c32;color:#FBFCFF;
  padding:4px 8px;border-radius:4px;
  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 6px rgba(0,0,0,0.18);
  z-index:2;
}
.pn-aura-tooltip-val{ font-weight:600; }
.pn-aura-tooltip-date{ opacity:0.85; }
.pn-aura-revision{
  font-size:11px;color:var(--pn-secondary);text-align:center;margin-top:6px;
}

/* 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:hidden;
}
.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%;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 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 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; }

/* ── CAREER (full season) TABLE ── */
.pn-career-wrap{ width:100%;overflow-x:auto; }
.pn-career-table{ width:100%;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:20px;display:flex;align-items:center;justify-content:center;height:34px;
}
.pn-score-team.pn-score-winner{
  background:var(--pn-third);border-color:var(--pn-secondary);color:var(--pn-main);
}
.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:flex;width:100%;height:90px;max-width:728px;margin:0 auto 20px; }
}
@media(max-width:700px){
  .pn-hero{ flex-direction:column;min-height:auto; }
  .pn-hero-img{ width:130px;align-self:center;padding-top:20px; }
  .pn-hero-info{ padding:16px; }
  .pn-hero-name{ font-size:28px; }
  .pn-hero-number{ font-size:80px; }
  .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:flex;width:300px;height:250px;margin:20px auto; }
  .pn-nav ul{ padding:0 10px; }
  .pn-stats-strip{ gap:20px; }
  .pn-stats-strip-list{ gap:20px; }
}

/* ================================================================
 * 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); }

/* ── 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%;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; }
}
@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; }

/* 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:5px;
  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;
  font-size:10px;
  font-weight:700;
  padding:2px 6px;
  border-radius:8px;
  white-space:nowrap;
}
.pn-tr2-fee--permanent{ background:#f0ebe3;color:#826E5E; }
.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; }
}
