/* ── SALA DE PREMSA ── */
.premsa-grid{display:flex;flex-direction:column;gap:10px}
.noticia-card{background:var(--white);border-radius:var(--rl);border:1px solid var(--g200);overflow:hidden;transition:box-shadow .15s,border-color .15s}
.noticia-card:hover{border-color:var(--gold);box-shadow:0 4px 20px rgba(232,160,32,.12)}
.noticia-card.featured{border-left:4px solid var(--gold)}
.noticia-card.breaking{border-left:4px solid var(--red)}
.noticia-card.positive{border-left:4px solid var(--green)}
.noticia-inner{padding:14px 16px}
.noticia-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.noticia-tag{font-size:9px;font-weight:700;letter-spacing:1.5px;padding:3px 8px;border-radius:20px;text-transform:uppercase}
.tag-victoria{background:var(--green-lt);color:var(--green)}
.tag-porteria{background:var(--blue-lt);color:var(--blue)}
.tag-golejador{background:var(--gold-pale);color:#8a5a00}
.tag-ratxa{background:var(--amber-lt);color:var(--amber)}
.tag-lider{background:#f0e6ff;color:#6b21a8}
.tag-derrota{background:var(--red-lt);color:var(--red)}
.noticia-equip{font-size:10px;color:var(--g400);margin-left:auto;font-weight:500}
.noticia-titular{font-size:14px;font-weight:600;color:var(--navy);line-height:1.4;margin-bottom:6px}
.noticia-titular.xl{font-size:16px}
.noticia-entradeta{font-size:12px;color:var(--g600);line-height:1.5}
.noticia-footer{display:flex;align-items:center;gap:8px;padding:8px 16px;border-top:1px solid var(--g200);background:var(--g100)}
.noticia-data{font-size:10px;color:var(--g400)}
.ai-badge{display:flex;align-items:center;gap:4px;font-size:9px;color:var(--g400);font-weight:500;margin-left:auto}
.ai-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.gen-btn{background:var(--navy);color:var(--white);border:none;border-radius:var(--r);padding:10px 18px;font-size:12px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;font-family:var(--font-b);transition:background .15s}
.gen-btn:hover{background:var(--navy-mid)}
.gen-btn:disabled{background:var(--g400);cursor:not-allowed}
.gen-btn .spin{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.premsa-actions{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.loading-card{background:var(--white);border-radius:var(--rl);border:1px dashed var(--g200);padding:24px;text-align:center;color:var(--g400);font-size:13px}

/* ── LA PRÈVIA ── */
.previa-match{background:var(--white);border-radius:var(--rl);border:1px solid var(--g200);overflow:hidden;margin-bottom:10px}
.previa-hdr{background:var(--navy);padding:12px 16px;display:flex;align-items:center;gap:10px}
.previa-hdr-equip{font-family:var(--font-d);font-size:14px;color:var(--white);letter-spacing:1px;flex:1}
.previa-hdr-comp{font-size:10px;color:var(--gold-light)}
.previa-hdr-context{display:flex;gap:5px}
.ctx-chip{font-size:9px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.ctx-alta{background:#f0e6ff;color:#6b21a8}
.ctx-perm{background:var(--red-lt);color:var(--red)}
.ctx-ratxa{background:var(--green-lt);color:var(--green)}
.ctx-derbi{background:var(--gold-pale);color:#8a5a00}
.previa-body{padding:14px 16px}
.previa-teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;margin-bottom:12px}
.previa-team-local{text-align:right}
.previa-team-away{text-align:left}
.previa-tn{font-size:13px;font-weight:600;color:var(--navy)}
.previa-tn.our{color:var(--gold)}
.previa-stats-row{display:flex;gap:6px;margin-top:3px;justify-content:flex-end}
.previa-stats-row.away{justify-content:flex-start}
.pstat{font-size:9px;color:var(--g400)}
.previa-vs-box{background:var(--navy);color:var(--white);font-size:11px;font-weight:600;padding:6px 12px;border-radius:8px;text-align:center;white-space:nowrap}
.previa-ia{background:var(--g100);border-radius:var(--r);padding:12px 14px;font-size:12px;color:var(--g600);line-height:1.6;font-style:italic;border-left:3px solid var(--gold)}
.previa-ia.loading{color:var(--g400);animation:shimmer 1.5s infinite}
@keyframes shimmer{0%,100%{opacity:.5}50%{opacity:1}}
.previa-ia-hdr{font-size:10px;font-weight:600;color:var(--gold);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;display:flex;align-items:center;gap:6px;font-style:normal}
.gen-previa-btn{background:transparent;border:1px solid var(--gold);color:var(--gold);border-radius:var(--r);padding:6px 12px;font-size:11px;cursor:pointer;font-family:var(--font-b);transition:all .15s;margin-top:8px}
.gen-previa-btn:hover{background:var(--gold);color:var(--navy)}

/* ── SQUAD TABLE ── */
.squad-table{width:100%;border-collapse:collapse;font-size:12px;min-width:480px}
.squad-table th{padding:7px 10px;text-align:center;font-size:9px;font-weight:700;color:var(--g600);letter-spacing:1px;text-transform:uppercase;border-bottom:2px solid var(--g200);background:var(--g100);white-space:nowrap}
.squad-table th.col-name{text-align:left;padding-left:4px;min-width:160px}
.squad-table td{padding:9px 10px;text-align:center;border-bottom:1px solid var(--g200);color:var(--navy);white-space:nowrap}
.squad-table td.col-name{text-align:left;padding-left:4px;font-weight:500}
.squad-table tr:last-child td{border-bottom:none}
.squad-table tr.row-titular td{background:rgba(30,132,73,.04)}
.squad-table tr.row-top td{background:rgba(232,160,32,.06)}
.squad-table tr.row-top td.val-gold{color:var(--gold);font-weight:700}
.squad-table tr:hover td{background:var(--g100)}
.col-name{min-width:160px}
.dorsal{display:inline-block;width:22px;font-family:var(--font-d);font-size:14px;color:var(--g400);text-align:right;margin-right:8px}
.tit-badge{font-size:8px;font-weight:700;background:var(--green-lt);color:var(--green);padding:1px 5px;border-radius:10px;margin-left:4px}
.cap-badge{font-size:8px;font-weight:700;background:var(--red-lt);color:var(--red);padding:1px 5px;border-radius:10px;margin-left:4px}
.pos-tag{font-size:9px;font-weight:700;color:var(--g600);letter-spacing:.5px}
.pen-gols{font-size:10px;color:var(--g400)}
.val-gold{color:var(--gold);font-weight:600}
.val-red{color:var(--red);font-weight:500}
.val-yellow{color:#b45309;font-weight:500}
.val-red-card{color:var(--red);font-weight:700}
.val-green{color:var(--green);font-weight:500}
.squad-legend{display:flex;gap:14px;flex-wrap:wrap;font-size:10px;color:var(--g600);margin-top:10px;padding:8px 0}
.row-top-sample{background:rgba(232,160,32,.06);border-radius:4px;padding:1px 6px}
/* ── PORTERS TAB ── */
.porter-stat-chip{font-size:9px;font-weight:600;padding:2px 7px;border-radius:10px}
.chip-gold{background:var(--gold-pale);color:#8a5a00}
.chip-red{background:var(--red-lt);color:var(--red)}
.chip-blue{background:var(--blue-lt);color:var(--blue)}
.chip-gray{background:var(--g200);color:var(--g600)}
.zero-streak{font-size:10px;color:var(--green);font-weight:600;margin-top:4px}
/* ── ENTRENADORS ── */
.mister-card{background:var(--white);border-radius:var(--rl);border:1px solid var(--g200);padding:16px;display:flex;gap:14px;transition:border-color .15s,box-shadow .15s}
.mister-card:hover{border-color:var(--gold);box-shadow:0 4px 16px rgba(232,160,32,.12)}
.mister-rank-col{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;min-width:36px}
.mister-rank{font-family:var(--font-d);font-size:28px;color:var(--g200);line-height:1}
.mister-rank.top3{color:var(--gold)}
.mister-trophy{font-size:16px}
.mister-info{flex:1;min-width:0}
.mister-header{display:flex;align-items:center;gap:10px;margin-bottom:2px;flex-wrap:wrap}
.mister-name{font-size:15px;font-weight:600;color:var(--navy)}
.mister-equip-tag{background:var(--navy);color:var(--white);font-size:10px;font-weight:600;padding:2px 10px;border-radius:20px;letter-spacing:.5px}
.mister-comp{font-size:11px;color:var(--g400);margin-bottom:10px}
.mister-stats-row{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:10px}
.mister-stat{text-align:center;min-width:40px}
.mister-stat-val{font-family:var(--font-d);font-size:20px;color:var(--navy);line-height:1}
.mister-stat-val.gold{color:var(--gold)}
.mister-stat-val.green{color:var(--green)}
.mister-stat-val.red{color:var(--red)}
.mister-stat-lbl{font-size:9px;color:var(--g400);margin-top:1px}
.mister-forma{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.mf-label{font-size:9px;font-weight:600;color:var(--g600);letter-spacing:1px;text-transform:uppercase}
.mf-quote{font-size:11px;color:var(--g600);font-style:italic}
.mister-badge-row{display:flex;gap:6px;flex-wrap:wrap}
.mister-badge{font-size:9px;font-weight:600;padding:2px 8px;border-radius:20px}
.badge-leader{background:#f0e6ff;color:#6b21a8}
.badge-clean{background:var(--blue-lt);color:var(--blue)}
.badge-attack{background:var(--gold-pale);color:#8a5a00}
.badge-promo{background:var(--green-lt);color:var(--green)}
.squad-section-title{font-size:11px;font-weight:700;color:var(--g600);letter-spacing:1.5px;text-transform:uppercase;margin:16px 0 8px;padding-bottom:6px;border-bottom:2px solid var(--g200)}
.squad-section-title.gold{border-color:var(--gold);color:var(--gold)}

/* Goalkeeper featured card */
.gk-featured{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);border-radius:var(--rl);padding:16px;margin-bottom:14px;border:1px solid rgba(232,160,32,.3);display:flex;gap:14px;align-items:center}
.gk-av{width:56px;height:56px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:20px;color:var(--navy);flex-shrink:0}
.gk-info{flex:1}
.gk-name{font-size:15px;font-weight:600;color:var(--white);margin-bottom:2px}
.gk-role{font-size:11px;color:var(--gold-light);margin-bottom:8px}
.gk-stats{display:flex;gap:12px;flex-wrap:wrap}
.gk-stat{text-align:center}
.gk-stat-num{font-family:var(--font-d);font-size:20px;color:var(--white);line-height:1}
.gk-stat-num.clean{color:var(--gold)}
.gk-stat-lbl{font-size:9px;color:var(--g400);margin-top:1px}
.gk-shields{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}
.gk-shield-chip{background:rgba(232,160,32,.15);border:1px solid rgba(232,160,32,.3);color:var(--gold-light);font-size:9px;padding:2px 7px;border-radius:20px}

/* Player row */
.player-list{display:flex;flex-direction:column;gap:6px}
.player-row{background:var(--white);border-radius:var(--r);padding:10px 14px;display:flex;align-items:center;gap:12px;border:1px solid var(--g200);transition:border-color .15s}
.player-row:hover{border-color:var(--gold)}
.player-dorsal{font-family:var(--font-d);font-size:18px;color:var(--g200);width:26px;text-align:center;flex-shrink:0}
.player-av{width:34px;height:34px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--white);flex-shrink:0}
.player-av.gk{background:var(--gold);color:var(--navy)}
.player-av.captain{background:var(--red);position:relative}
.player-info{flex:1;min-width:0}
.player-name{font-size:13px;font-weight:500;color:var(--navy)}
.player-pos{font-size:10px;color:var(--g400);margin-top:1px}
.player-stats{display:flex;gap:10px;flex-shrink:0}
.pstat-item{text-align:center;min-width:28px}
.pstat-val{font-size:12px;font-weight:600;color:var(--navy)}
.pstat-val.gold{color:var(--gold)}
.pstat-val.red{color:var(--red)}
.pstat-val.green{color:var(--green)}
.pstat-val.blue{color:var(--blue)}
.pstat-lbl{font-size:8px;color:var(--g400);letter-spacing:.3px}
.conv-badge{font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px}
.conv-ok{background:var(--green-lt);color:var(--green)}
.conv-no{background:var(--g200);color:var(--g600)}
.conv-dub{background:var(--amber-lt);color:var(--amber)}

/* porteros section box */
.porters-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
@media(max-width:480px){.porters-grid{grid-template-columns:1fr}}
.porter-card{background:var(--white);border-radius:var(--r);border:1px solid var(--g200);overflow:hidden}
.porter-card-hdr{background:var(--navy);padding:8px 12px;display:flex;align-items:center;gap:8px}
.porter-card-av{width:32px;height:32px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--navy);flex-shrink:0}
.porter-card-name{font-size:12px;font-weight:500;color:var(--white);flex:1}
.porter-card-equip{font-size:10px;color:var(--gold-light)}
.porter-card-body{padding:10px 12px;display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.pcstat{text-align:center}
.pcstat-val{font-size:16px;font-weight:600;color:var(--navy);font-family:var(--font-d)}
.pcstat-val.zero{color:var(--gold)}
.pcstat-lbl{font-size:9px;color:var(--g400)}
.porter-card-foot{padding:6px 12px;background:var(--g100);border-top:1px solid var(--g200)}
.clean-dots{display:flex;gap:3px;flex-wrap:wrap}
.cd{width:8px;height:8px;border-radius:2px}
.cd-clean{background:var(--green)}
.cd-gol{background:var(--red)}
.cd-empty{background:var(--g200)}

/* convocatoria badge */
.conv-section{background:var(--g100);border-radius:var(--r);border:1px solid var(--g200);padding:12px 14px;margin-bottom:14px}
.conv-hdr{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.conv-title{font-size:12px;font-weight:600;color:var(--navy);flex:1}
.conv-date{font-size:10px;color:var(--g400)}
.conv-grid{display:flex;flex-wrap:wrap;gap:6px}
.conv-player{display:flex;align-items:center;gap:5px;background:var(--white);border:1px solid var(--g200);border-radius:var(--r);padding:4px 8px;font-size:11px;color:var(--navy)}
.conv-player.titlar{border-color:var(--green);background:var(--green-lt)}
.conv-player.suplent{border-color:var(--g200)}
.conv-player.baixa{border-color:var(--red-lt);background:var(--red-lt);color:var(--red);text-decoration:line-through;opacity:.6}


/** 2n **/

:root {
  /* ── PALETA OFICIAL CLUBAZO ── */
  --purple: #6C4CFF;
  --cyan:   #00D4FF;
  --teal:   #00E5D2;
  --blue:   #0099FF;
  --pink:   #FF4D7D;
  --amber:  #FFAE00;
  --white:  #FFFFFF;

  /* ── FONS FOSC ── */
  --bg:     #0A0E1A;
  --bg2:    #111827;
  --bg3:    #1C2333;
  --border: rgba(255,255,255,.08);
  --bord2:  rgba(255,255,255,.14);

  /* ── TEXT ── */
  --text:     #EEF1F8;
  --text-mid: rgba(238,241,248,.6);
  --text-dim: rgba(238,241,248,.35);

  /* ── ALIÀS SEMÀNTICS (mantenen compatibilitat de classes) ── */
  --navy:       var(--bg);
  --navy-mid:   var(--bg2);
  --navy-light: var(--bg3);
  --gold:       var(--amber);
  --gold-light: #ffd166;
  --gold-pale:  rgba(255,174,0,.12);
  --red:        var(--pink);
  --red-lt:     rgba(255,77,125,.12);
  --green:      var(--teal);
  --green-lt:   rgba(0,229,210,.12);
  --blue-lt:    rgba(0,153,255,.12);
  --amber-lt:   rgba(255,174,0,.12);
  --g100:       var(--bg2);
  --g200:       var(--border);
  --g400:       var(--text-dim);
  --g600:       var(--text-mid);

  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'DM Sans', sans-serif;
  --r: 10px; --rl: 16px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

body { font-family:var(--font-b); background:var(--bg); color:var(--text); min-height:100vh; }

::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--purple); border-radius:2px; }

/* ── HEADER ── */
.hdr { background:var(--bg2); border-bottom:1px solid var(--border); padding:0 20px; position:sticky; top:0; z-index:100; box-shadow:0 4px 24px rgba(0,0,0,.5); }
.hdr-inner { max-width:960px; margin:0 auto; display:flex; align-items:center; gap:14px; padding:12px 0; }
.shield { width:44px; height:44px; /*background:linear-gradient(135deg,var(--purple),var(--cyan)); border-radius:8px 8px 50% 50%;*/ display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.shield span { font-family:var(--font-d); font-size:15px; color:var(--white); letter-spacing:1px; }
.hdr-name { font-family:var(--font-d); font-size:20px; color:var(--white); letter-spacing:2px; line-height:1; }
.hdr-sub  { font-size:10px; color:var(--text-dim); letter-spacing:.8px; margin-top:2px; }
.hdr-season { text-decoration:none; background:linear-gradient(90deg,var(--purple),var(--blue)); color:var(--white); font-size:11px; font-weight:600; padding:3px 12px; border-radius:20px; margin-left:auto; flex-shrink:0; }

/* ── NAV ── */
.nav { background:var(--bg2); border-bottom:1px solid var(--border); overflow-x:auto; -webkit-overflow-scrolling:touch; }
.nav::-webkit-scrollbar { display:none; }
.nav-inner { max-width:960px; width:100%; margin:0 auto; display:flex; padding:0 12px; }
.nb { text-decoration:none; background:none; border:none; color:var(--text-dim); font-family:var(--font-d); font-size:13px; letter-spacing:1.5px; padding:13px 14px; cursor:pointer; white-space:nowrap; border-bottom:2px solid transparent; margin-bottom:-1px; transition:color .15s,border-color .15s; }
.nb:hover { color:var(--text); }
.nb.active { color:var(--cyan); border-bottom-color:var(--cyan); }

/* ── LAYOUT ── */
.main { max-width:960px; margin:0 auto; padding:20px 16px 60px; }
.tab { display:none; } .tab.active { display:block; }

/* ── JORNADA BANNER ── */
.jornada-banner { background:var(--bg2); border-radius:var(--rl); overflow:hidden; margin-bottom:18px; border:1px solid rgba(108,76,255,.2); }
.jornada-hdr { background:linear-gradient(90deg,var(--purple),var(--blue)); padding:10px 18px; display:flex; align-items:center; gap:10px; }
.jornada-hdr-title { font-family:var(--font-d); font-size:17px; color:var(--white); letter-spacing:1.5px; flex:1; }
.jornada-hdr-sub   { font-size:11px; color:rgba(255,255,255,.6); font-weight:500; }
.jornada-body { padding:16px 18px; display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:560px){ .jornada-body { grid-template-columns:1fr; } }
.jornada-col-title { font-size:10px; font-weight:600; color:var(--cyan); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:10px; }
.victory-item { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.victory-badge { background:var(--teal); color:var(--bg); font-family:var(--font-d); font-size:14px; letter-spacing:1px; padding:4px 10px; border-radius:6px; white-space:nowrap; min-width:52px; text-align:center; font-weight:700; }
.victory-info { flex:1; }
.victory-name { font-size:13px; font-weight:500; color:var(--white); line-height:1.2; }
.victory-cat  { font-size:11px; color:var(--text-dim); margin-top:1px; }
.scorer-jornada-item { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.sj-avatar { width:30px; height:30px; border-radius:50%; background:rgba(108,76,255,.2); border:1px solid rgba(108,76,255,.35); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--cyan); flex-shrink:0; }
.sj-info { flex:1; }
.sj-name { font-size:13px; font-weight:500; color:var(--white); line-height:1.2; }
.sj-detail { font-size:11px; color:var(--text-dim); margin-top:1px; }
.sj-gols { font-family:var(--font-d); font-size:20px; color:var(--amber); }

/* ── STATS ── */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-bottom:10px; }
@media(max-width:500px){ .stats-grid { grid-template-columns:repeat(2,1fr); } }
.stat-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:14px 10px; text-align:center; transition:border-color .2s; }
.stat-card:hover { border-color:var(--bord2); }
.stat-num { font-family:var(--font-d); font-size:30px; color:var(--white); line-height:1; }
.stat-num.gold { color:var(--amber); }
.stat-label { font-size:10px; color:var(--text-dim); margin-top:4px; font-weight:500; }

/* ── SECTION HDR ── */
.shdr { display:flex; align-items:center; gap:10px; margin:20px 0 10px; }
.shdr-line  { height:2px; background:linear-gradient(90deg,var(--purple),var(--cyan)); width:20px; flex-shrink:0; border-radius:1px; }
.shdr-title { font-size:10px; font-weight:600; color:var(--text-dim); letter-spacing:2px; text-transform:uppercase; }

/* ── TEAM CARDS ── */
.team-list { display:flex; flex-direction:column; }
.team-card { margin-bottom:8px; background:var(--bg2); border:1px solid var(--border); border-radius:var(--r); padding:12px 14px; display:flex; align-items:center; gap:12px; cursor:pointer; transition:border-color .15s,background .15s; }
.team-card:hover { border-color:rgba(108,76,255,.4); background:var(--bg3); }
.team-av { width:36px; height:36px; border-radius:7px; font-family:var(--font-d); font-size:12px; letter-spacing:.5px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--white); font-weight:600; }
.av-navy  { background:var(--purple); }
.av-mid   { background:rgba(108,76,255,.35); }
.av-gold  { background:var(--amber); color:var(--bg); }
.av-gray  { background:rgba(255,255,255,.1); }
.av-blue  { background:var(--blue); }
.av-green { background:var(--teal); color:var(--bg); }
.av-purple{ background:var(--purple); }
.team-info  { flex:1; min-width:0; }
.team-name  { font-size:13px; font-weight:500; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.team-liga  { font-size:11px; color:var(--text-dim); margin-top:1px; }
.pos-badge  { font-size:11px; font-weight:600; padding:3px 9px; border-radius:20px; white-space:nowrap; flex-shrink:0; }
.pos-top    { background:rgba(0,229,210,.12); color:var(--teal); }
.pos-mid    { background:rgba(255,255,255,.06); color:var(--text-mid); }
.pos-low    { background:rgba(255,77,125,.12); color:var(--pink); }
.pos-asc    { background:rgba(0,153,255,.12); color:var(--blue); }
.pos-prom   { background:rgba(255,174,0,.12); color:var(--amber); }
.team-arrow { color:var(--text-dim); font-size:14px; flex-shrink:0; }

/* ── MATCH CARDS ── */
.match-list { display:flex; flex-direction:column; gap:6px; }
.match-card { background:var(--bg2); border-radius:var(--r); border:1px solid var(--border); padding:11px 14px; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:8px; transition:border-color .15s; }
.match-card:hover { border-color:var(--bord2); }
.match-card.upcoming { border-left:2px solid var(--amber); }
.mh { text-align:right; } .ma { text-align:left; }
.mt-name     { font-size:12px; font-weight:500; color:var(--text); }
.mt-name.dim { color:var(--text-dim); font-weight:400; }
.mt-meta     { font-size:10px; color:var(--text-dim); margin-top:2px; }
.score-box { background:var(--bg3); color:var(--white); font-family:var(--font-d); font-size:17px; letter-spacing:2px; padding:7px 11px; border-radius:8px; text-align:center; min-width:62px; border:1px solid var(--border); }
.score-box.win  { background:rgba(0,229,210,.12); color:var(--teal);  border-color:rgba(0,229,210,.25); }
.score-box.loss { background:rgba(255,77,125,.10); color:var(--pink);  border-color:rgba(255,77,125,.22); }
.score-box.draw { background:rgba(255,174,0,.10);  color:var(--amber); border-color:rgba(255,174,0,.2); }
.score-box.upcoming { background:transparent; color:var(--text-mid); font-size:10px; font-weight:600; letter-spacing:.5px; line-height:1.5; font-family:var(--font-b); border:1px solid var(--border); }

/* ── FILTER TABS ── */
.ftabs { display:flex; gap:5px; margin-bottom:12px; flex-wrap:wrap; }
.ft { background:var(--bg2); border:1px solid var(--border); color:var(--text-dim); font-size:11px; font-weight:500; padding:5px 12px; border-radius:20px; cursor:pointer; transition:all .15s; font-family:var(--font-b); }
.ft:hover  { border-color:var(--bord2); color:var(--text); }
.ft.active { background:rgba(108,76,255,.15); border-color:rgba(108,76,255,.45); color:var(--cyan); }

/* ── CLASSIFICACIÓ ── */
.classif-wrap { background:var(--bg2); border-radius:var(--r); border:1px solid var(--border); overflow:hidden; margin-bottom:14px; }
.classif-hdr  { background:linear-gradient(90deg,var(--purple),var(--blue)); padding:9px 15px; display:flex; align-items:center; }
.classif-comp { font-family:var(--font-d); font-size:13px; color:var(--white); letter-spacing:1px; flex:1; }
.classif-sea  { font-size:10px; color:rgba(255,255,255,.55); }
.ct { width:100%; border-collapse:collapse; font-size:11px; }
.ct th { padding:7px 8px; text-align:center; font-size:9px; font-weight:700; color:var(--text-dim); letter-spacing:1px; text-transform:uppercase; border-bottom:1px solid var(--border); background:var(--bg3); }
.ct th:first-child,.ct th:nth-child(2) { text-align:left; padding-left:13px; }
.ct td { padding:9px 8px; text-align:center; border-bottom:1px solid var(--border); color:var(--text); }
.ct td:first-child  { padding-left:13px; color:var(--text-dim); font-size:10px; }
.ct td:nth-child(2) { text-align:left; font-weight:500; }
.ct tr:last-child td { border-bottom:none; }
.ct tr:hover td { background:var(--bg3); }
.ct tr.hl td { background:rgba(108,76,255,.07); }
.ct tr.hl td:nth-child(2) { color:var(--cyan); font-weight:600; }
.ct tr.asc-row  td:first-child { border-left:2px solid var(--blue); }
.ct tr.desc-row td:first-child { border-left:2px solid var(--pink); }
.ct tr.prom-row td:first-child { border-left:2px solid var(--amber); }
.pts-b { font-weight:700; font-size:12px; }
.form-d { display:flex; gap:2px; justify-content:center; }
.fd { width:9px; height:9px; border-radius:50%; }
.fd-w { background:var(--teal); } .fd-d { background:rgba(255,174,0,.5); } .fd-l { background:var(--pink); }
.classif-legend { display:flex; gap:14px; font-size:10px; color:var(--text-dim); padding:8px 13px; flex-wrap:wrap; border-top:1px solid var(--border); }
.leg-it { display:flex; align-items:center; gap:5px; }
.leg-bar { width:3px; height:12px; border-radius:1px; }

/* ── SCORERS / PORTERS ── */
.scorer-list { display:flex; flex-direction:column; gap:7px; }
.scorer-card { background:var(--bg2); border-radius:var(--r); border:1px solid var(--border); padding:12px 14px; display:flex; align-items:center; gap:12px; transition:border-color .15s; }
.scorer-card:hover { border-color:var(--bord2); }
.sc-rank     { font-family:var(--font-d); font-size:18px; color:rgba(255,255,255,.1); width:22px; text-align:center; flex-shrink:0; }
.sc-rank.top { color:var(--amber); }
.sc-av       { width:36px; height:36px; border-radius:50%; background:rgba(108,76,255,.15); border:1px solid rgba(108,76,255,.3); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--cyan); flex-shrink:0; }
.sc-av.gk    { background:rgba(255,174,0,.12); border-color:rgba(255,174,0,.3); color:var(--amber); }
.sc-info     { flex:1; min-width:0; }
.sc-name     { font-size:13px; font-weight:500; color:var(--text); }
.sc-team     { font-size:10px; color:var(--text-dim); margin-top:1px; }
.sc-cat-tag  { display:inline-block; background:rgba(108,76,255,.12); color:var(--cyan); font-size:9px; font-weight:700; padding:2px 7px; border-radius:10px; margin-top:3px; letter-spacing:.5px; }
.sc-bar-wrap { height:2px; background:var(--border); border-radius:1px; margin-top:7px; }
.sc-bar      { height:2px; border-radius:1px; background:linear-gradient(90deg,var(--purple),var(--cyan)); }
.sc-gols     { display:flex; flex-direction:column; align-items:flex-end; flex-shrink:0; gap:1px; }
.sc-num      { font-family:var(--font-d); font-size:22px; color:var(--white); line-height:1; }
.sc-lbl      { font-size:9px; color:var(--text-dim); font-weight:500; }

/* Stats extra goleadors */
.sc-stats { display:flex; gap:14px; flex-shrink:0; align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end; }
.sc-stat  { text-align:center; min-width:34px; }
@media (min-width:980px){
.nodesk{
	display:none;
}
}
@media (max-width:980px){
	.nodev{
		display:none;
	}
	.hdr-season{
		width: 3em;
	}
	.sc-stat-num,.sc-stat-lbl{
		text-align: right;
	}
div.sc-stat:first-child{ width:100%; }
.sc-stats {
	width: 9em;
	flex-shrink: 1;
  flex-wrap: wrap;
  justify-content: flex-end; }
}
.sc-stat-num { font-family:var(--font-d); font-size:20px; color:var(--white); line-height:1; }
.sc-stat-num.prin  { font-size:24px; }
.sc-stat-num.pen   { color:var(--amber); }
.sc-stat-num.avg   { color:var(--cyan); font-size:16px; }
.sc-stat-lbl { font-size:9px; color:var(--text-dim); font-weight:500; margin-top:2px; white-space:nowrap; }
.sc-divider  { width:1px; height:28px; background:var(--border); flex-shrink:0; }

/* ── SQUAD TABLES ── */
.squad-section-title { font-size:10px; font-weight:700; color:var(--text-dim); letter-spacing:1.5px; text-transform:uppercase; margin:16px 0 8px; padding-bottom:6px; border-bottom:1px solid var(--border); }
.squad-section-title.gold { border-color:var(--amber); color:var(--amber); }
.squad-table { width:100%; border-collapse:collapse; font-size:12px; min-width:480px; }
.squad-table th { padding:7px 10px; text-align:center; font-size:9px; font-weight:700; color:var(--text-dim); letter-spacing:1px; text-transform:uppercase; border-bottom:1px solid var(--border); background:var(--bg3); white-space:nowrap; }
.squad-table th.col-name { text-align:left; padding-left:4px; min-width:160px; }
.squad-table td { padding:9px 10px; text-align:center; border-bottom:1px solid var(--border); color:var(--text); white-space:nowrap; }
.squad-table td.col-name { text-align:left; padding-left:4px; font-weight:500; }
.squad-table tr:last-child td { border-bottom:none; }
.squad-table tr.row-titular td { background:rgba(0,229,210,.04); }
.squad-table tr.row-top td { background:rgba(255,174,0,.05); }
.squad-table tr.row-top td.val-gold { color:var(--amber); font-weight:700; }
.squad-table tr:hover td { background:var(--bg3); }
.col-name { min-width:160px; }
.dorsal   { display:inline-block; width:22px; font-family:var(--font-d); font-size:14px; color:var(--text-dim); text-align:right; margin-right:8px; }
.tit-badge { font-size:8px; font-weight:700; background:rgba(0,229,210,.12); color:var(--teal); padding:1px 5px; border-radius:10px; margin-left:4px; }
.cap-badge { font-size:8px; font-weight:700; background:rgba(255,77,125,.12); color:var(--pink); padding:1px 5px; border-radius:10px; margin-left:4px; }
.pos-tag { font-size:9px; font-weight:700; color:var(--text-dim); letter-spacing:.5px; }
.pen-gols { font-size:10px; color:var(--text-dim); }
.val-gold { color:var(--amber); font-weight:600; }
.val-red  { color:var(--pink); font-weight:500; }
.val-yellow { color:var(--amber); font-weight:500; }
.val-red-card { color:var(--pink); font-weight:700; }
.val-green { color:var(--teal); font-weight:500; }
.squad-legend { display:flex; gap:14px; flex-wrap:wrap; font-size:10px; color:var(--text-dim); margin-top:10px; padding:8px 0; }
.row-top-sample { background:rgba(255,174,0,.07); border-radius:4px; padding:1px 6px; }

/* ── PORTER CHIPS ── */
.porter-stat-chip { font-size:9px; font-weight:600; padding:2px 7px; border-radius:10px; }
.chip-gold { background:rgba(255,174,0,.12); color:var(--amber); }
.chip-red  { background:rgba(255,77,125,.10); color:var(--pink); }
.chip-blue { background:rgba(0,153,255,.10); color:var(--blue); }
.chip-gray { background:rgba(255,255,255,.06); color:var(--text-dim); }
.zero-streak { font-size:10px; color:var(--teal); font-weight:600; margin-top:4px; }

/* ── ENTRENADORS ── */
.mister-card { background:var(--bg2); border-radius:var(--rl); border:1px solid var(--border); padding:16px; display:flex; gap:14px; transition:border-color .15s,box-shadow .15s; }
.mister-card:hover { border-color:rgba(108,76,255,.4); box-shadow:0 4px 20px rgba(108,76,255,.07); }
.mister-rank-col { display:flex; flex-direction:column; align-items:center; gap:4px; flex-shrink:0; min-width:36px; }
.mister-rank { font-family:var(--font-d); font-size:28px; color:rgba(255,255,255,.1); line-height:1; }
.mister-rank.top3 { color:var(--amber); }
.mister-trophy { font-size:16px; }
.mister-info { flex:1; min-width:0; }
.mister-header { display:flex; align-items:center; gap:10px; margin-bottom:2px; flex-wrap:wrap; }
.mister-name { font-size:15px; font-weight:600; color:var(--text); }
.mister-equip-tag { background:rgba(108,76,255,.15); color:var(--cyan); font-size:10px; font-weight:600; padding:2px 10px; border-radius:20px; letter-spacing:.5px; }
.mister-comp { font-size:11px; color:var(--text-dim); margin-bottom:10px; }
.mister-stats-row { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:10px; }
.mister-stat { text-align:center; min-width:40px; }
.mister-stat-val { font-family:var(--font-d); font-size:20px; color:var(--white); line-height:1; }
.mister-stat-val.gold  { color:var(--amber); }
.mister-stat-val.green { color:var(--teal); }
.mister-stat-val.red   { color:var(--pink); }
.mister-stat-lbl { font-size:9px; color:var(--text-dim); margin-top:1px; }
.mister-forma { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:8px; }
.mf-label { font-size:9px; font-weight:600; color:var(--text-dim); letter-spacing:1px; text-transform:uppercase; }
.mf-quote { font-size:11px; color:var(--text-mid); font-style:italic; }
.mister-badge-row { display:flex; gap:6px; flex-wrap:wrap; }
.mister-badge { font-size:9px; font-weight:600; padding:2px 8px; border-radius:20px; }
.badge-leader { background:rgba(108,76,255,.15); color:var(--cyan); }
.badge-clean  { background:rgba(0,153,255,.10); color:var(--blue); }
.badge-attack { background:rgba(255,174,0,.12); color:var(--amber); }
.badge-promo  { background:rgba(0,229,210,.10); color:var(--teal); }

/* ── PRÈVIA ── */
.previa-match { background:var(--bg2); border-radius:var(--rl); border:1px solid var(--border); overflow:hidden; margin-bottom:10px; }
.previa-hdr   { background:var(--bg3); border-bottom:1px solid var(--border); padding:12px 16px; display:flex; align-items:center; gap:10px; }
.previa-hdr-equip { font-family:var(--font-d); font-size:14px; color:var(--white); letter-spacing:1px; flex:1; }
.previa-hdr-comp  { font-size:10px; color:var(--text-dim); }
.previa-hdr-context { display:flex; gap:5px; }
.ctx-chip  { font-size:9px; font-weight:700; padding:3px 8px; border-radius:20px; text-transform:uppercase; letter-spacing:.5px; }
.ctx-alta  { background:rgba(108,76,255,.15); color:var(--cyan); }
.ctx-perm  { background:rgba(255,77,125,.12); color:var(--pink); }
.ctx-ratxa { background:rgba(0,229,210,.10); color:var(--teal); }
.ctx-derbi { background:rgba(255,174,0,.12); color:var(--amber); }
.previa-body { padding:14px 16px; }
.previa-teams { display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:10px; margin-bottom:12px; }
.previa-team-local { text-align:right; }
.previa-team-away  { text-align:left; }
.previa-tn     { font-size:13px; font-weight:600; color:var(--text); }
.previa-tn.our { color:var(--cyan); }
.previa-stats-row { display:flex; gap:6px; margin-top:3px; justify-content:flex-end; }
.previa-stats-row.away { justify-content:flex-start; }
.pstat { font-size:9px; color:var(--text-dim); }
.previa-vs-box { background:rgba(108,76,255,.12); border:1px solid rgba(108,76,255,.25); color:var(--white); font-size:11px; font-weight:600; padding:6px 12px; border-radius:8px; text-align:center; white-space:nowrap; }
.previa-ia     { background:rgba(108,76,255,.05); border-radius:var(--r); padding:12px 14px; font-size:12px; color:var(--text-mid); line-height:1.6; font-style:italic; border-left:2px solid var(--purple); }
.previa-ia-hdr { font-size:10px; font-weight:600; color:var(--purple); letter-spacing:1px; text-transform:uppercase; margin-bottom:6px; display:flex; align-items:center; gap:6px; font-style:normal; }
.gen-previa-btn { background:transparent; border:1px solid rgba(108,76,255,.35); color:rgba(108,76,255,.8); border-radius:var(--r); padding:6px 12px; font-size:11px; cursor:pointer; font-family:var(--font-b); transition:all .15s; margin-top:8px; }
.gen-previa-btn:hover { background:rgba(108,76,255,.12); color:var(--cyan); border-color:var(--cyan); }

/* ── PREMSA ── */
.premsa-grid { display:flex; flex-direction:column; gap:10px; }
.noticia-card { background:var(--bg2); border-radius:var(--rl); border:1px solid var(--border); overflow:hidden; transition:border-color .15s; }
.noticia-card:hover { border-color:var(--bord2); }
.noticia-card.featured { border-left:3px solid var(--amber); }
.noticia-card.breaking  { border-left:3px solid var(--pink); }
.noticia-card.positive  { border-left:3px solid var(--teal); }
.noticia-inner     { padding:14px 16px; }
.noticia-top       { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
.noticia-tag       { font-size:9px; font-weight:700; letter-spacing:1.5px; padding:3px 8px; border-radius:20px; text-transform:uppercase; }
.tag-victoria  { background:rgba(0,229,210,.12); color:var(--teal); }
.tag-porteria  { background:rgba(0,153,255,.10); color:var(--blue); }
.tag-golejador { background:rgba(255,174,0,.12); color:var(--amber); }
.tag-ratxa     { background:rgba(108,76,255,.12); color:var(--cyan); }
.tag-lider     { background:rgba(108,76,255,.15); color:#b4a4ff; }
.tag-derrota   { background:rgba(255,77,125,.12); color:var(--pink); }
.noticia-equip     { font-size:12px;color: var(--text);margin-left:auto; font-weight:500; }
.noticia-titular   { font-size:14px; font-weight:600; color:var(--text); line-height:1.4; margin-bottom:6px; }
.noticia-titular.xl { font-size:16px; }
.noticia-entradeta  { font-size:12px; color:var(--text-mid); line-height:1.5; }
.noticia-footer    { display:flex; align-items:center; gap:8px; padding:8px 16px; border-top:1px solid var(--border); background:var(--bg3); }
.noticia-data      { font-size:10px; color:var(--text-dim); }
.ai-badge { display:flex; align-items:center; gap:4px; font-size:9px; color:var(--text-dim); font-weight:500; margin-left:auto; }
.ai-dot   { width:6px; height:6px; border-radius:50%; background:var(--teal); animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.gen-btn { background:linear-gradient(90deg,var(--purple),var(--blue)); color:var(--white); border:none; border-radius:var(--r); padding:10px 18px; font-size:12px; font-weight:500; cursor:pointer; display:flex; align-items:center; gap:8px; font-family:var(--font-b); transition:opacity .15s; }
.gen-btn:hover { opacity:.85; }
.gen-btn:disabled { opacity:.4; cursor:not-allowed; }
.gen-btn .spin { animation:spin 1s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }
.premsa-actions { display:flex; gap:8px; margin-bottom:16px; flex-wrap:wrap; }

/* ── ASCENS / DESCENS ── */
.promo-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:20px; }
@media(max-width:560px){ .promo-grid { grid-template-columns:1fr; } }
.promo-box { border-radius:var(--rl); overflow:hidden; border:1px solid var(--border); }
.promo-box-hdr { padding:10px 14px; display:flex; align-items:center; gap:8px; }
.promo-box-hdr.ascens { background:rgba(0,153,255,.08); border-bottom:1px solid rgba(0,153,255,.2); }
.promo-box-hdr.descens { background:rgba(255,77,125,.07); border-bottom:1px solid rgba(255,77,125,.18); }
.promo-box-hdr.prom    { background:rgba(255,174,0,.07); border-bottom:1px solid rgba(255,174,0,.18); }
.promo-icon { font-size:16px; }
.promo-box-title { font-size:12px; font-weight:600; flex:1; }
.promo-box-title.asc-color  { color:var(--blue); }
.promo-box-title.desc-color { color:var(--pink); }
.promo-box-title.prom-color { color:var(--amber); }
.promo-items { padding:10px 14px; background:var(--bg2); display:flex; flex-direction:column; gap:8px; }
.promo-item  { display:flex; align-items:center; gap:10px; }
.promo-av    { width:32px; height:32px; border-radius:6px; font-family:var(--font-d); font-size:11px; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--white); }
.promo-info  { flex:1; min-width:0; }
.promo-name  { font-size:12px; font-weight:500; color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.promo-liga  { font-size:10px; color:var(--text-dim); margin-top:1px; }
.promo-pos   { font-size:11px; font-weight:600; }
.promo-pos.asc  { color:var(--blue); }
.promo-pos.desc { color:var(--pink); }
.promo-pos.prom { color:var(--amber); }

/* ── INFO BOX ── */
.info-box { background:rgba(255,174,0,.06); border:1px solid rgba(255,174,0,.18); border-radius:var(--r); padding:12px 15px; font-size:12px; color:rgba(255,200,80,.9); margin-bottom:16px; }
.info-box strong { color:var(--amber); }

/* ── CALENDARI ── */
.cal-week { margin-bottom:18px; }
.cal-wlbl { font-size:10px; font-weight:600; color:var(--text-dim); letter-spacing:2px; text-transform:uppercase; margin-bottom:7px; padding-left:3px; }

/* ── FOOTER ── */
.footer { background:var(--bg2); border-top:1px solid var(--border); color:var(--text-dim); text-align:center; padding:18px; font-size:11px; }
.footer strong { color:var(--text-mid); }

/* ── MISC ── */
.plantilla-selector { display:flex; gap:6px; margin-bottom:14px; flex-wrap:wrap; }
@keyframes shimmer { 0%,100%{opacity:.5} 50%{opacity:1} }

@media(max-width:600px){
  .match-card { gap:5px; }
  .mt-name { font-size:11px; }
  .score-box { font-size:14px; padding:7px 8px; min-width:54px; }
}

/* JUSTES FASE 1 /  html v4 */

/* ── TEAM DETAIL PANEL ── */
.equip-panel {
  position:fixed; inset:0; z-index:200;
  background:var(--bg);
  display:none; flex-direction:column;
  overflow:hidden;
}
.equip-panel.open { display:flex; }

.equip-panel-hdr {
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:0 16px;
  flex-shrink:0;
}
.equip-panel-top {
  display:flex; align-items:center; gap:12px;
  padding:12px 0 10px;
}
.equip-panel-back {
  width:36px; height:36px; border-radius:50%;
  background:rgba(108,76,255,.12); border:1px solid rgba(108,76,255,.25);
  color:var(--cyan); font-size:20px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all .15s;
  font-family:var(--font-b); line-height:1;
}
.equip-panel-back:hover { background:rgba(108,76,255,.25); }
.equip-panel-av {
  width:44px; height:44px; border-radius:9px;
  font-family:var(--font-d); font-size:14px; letter-spacing:.5px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:var(--white); font-weight:600;
}
.equip-panel-info { flex:1; min-width:0; }
.equip-panel-name { font-size:16px; font-weight:600; color:var(--text); }
.equip-panel-liga { font-size:11px; color:var(--text-dim); margin-top:2px; }
.equip-panel-pos {
  font-size:11px; font-weight:600; padding:3px 10px;
  border-radius:20px; flex-shrink:0; white-space:nowrap;
}

/* Sub-nav dins el panel */
.equip-panel-nav {
  display:flex; gap:0; padding:0;
  border-top:1px solid var(--border);
}
.epnav-btn {
  background:none; border:none; color:var(--text-dim);
  font-family:var(--font-d); font-size:13px; letter-spacing:1.5px;
  padding:11px 16px; cursor:pointer; white-space:nowrap;
  border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:color .15s, border-color .15s;
}
.epnav-btn:hover { color:var(--text); }
.epnav-btn.active { color:var(--cyan); border-bottom-color:var(--cyan); }

/* Jornada navigator dins el panel */
.ep-jnav {
  display:flex; align-items:center; gap:12px;
  padding:12px 16px; border-bottom:1px solid var(--border);
  background:var(--bg2); flex-shrink:0;
}
.ep-jnav-btn {
  width:32px; height:32px; border-radius:50%;
  background:rgba(108,76,255,.1); border:1px solid rgba(108,76,255,.2);
  color:var(--cyan); font-size:18px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:all .15s; flex-shrink:0;
  font-family:var(--font-b); line-height:1;
}
.ep-jnav-btn:hover:not(:disabled) { background:rgba(108,76,255,.22); }
.ep-jnav-btn:disabled { opacity:.25; cursor:not-allowed; }
.ep-jnav-info { flex:1; text-align:center; }
.ep-jnav-num {
  font-family:var(--font-d); font-size:22px; color:var(--white);
  line-height:1; letter-spacing:2px;
}
.ep-jnav-date { font-size:10px; color:var(--text-dim); margin-top:2px; }

/* Cos scrollable */
.equip-panel-body {
  flex:1; overflow-y:auto; padding:16px;
}
.equip-panel-body::-webkit-scrollbar { width:3px; }
.equip-panel-body::-webkit-scrollbar-thumb { background:var(--purple); border-radius:2px; }

/* Sub-tabs */
.ep-tab { display:none; }
.ep-tab.active { display:block; }

/* Rivals amb link a club */
.match-club-link {
  display:inline-flex; align-items:center; gap:4px;
  font-size:9px; color:var(--purple); font-weight:600;
  cursor:pointer; letter-spacing:.5px; text-transform:uppercase;
  margin-top:2px; text-decoration:none;
  opacity:.8; transition:opacity .15s;
}
.match-club-link:hover { opacity:1; }

/* Animació */
.ep-fade { animation:epFade .2s ease both; }
@keyframes epFade { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.jornada-nav {
  display:flex; align-items:center; justify-content:space-between;
  background:var(--bg2); border-radius:var(--rl);
  border:1px solid rgba(108,76,255,.25);
  padding:16px 20px; margin-bottom:16px;
  position:relative; overflow:hidden;
}
.jornada-nav::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--purple),var(--cyan));
}
.jnav-btn {
  width:40px; height:40px; border-radius:50%;
  background:rgba(108,76,255,.12); border:1px solid rgba(108,76,255,.25);
  color:var(--cyan); font-size:22px; font-weight:300;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  transition:all .15s; flex-shrink:0; line-height:1;
  font-family:var(--font-b);
}
.jnav-btn:hover:not(:disabled) { background:rgba(108,76,255,.25); border-color:var(--cyan); }
.jnav-btn:disabled { opacity:.25; cursor:not-allowed; }
.jnav-center { text-align:center; flex:1; }
.jnav-label {
  font-size:9px; font-weight:700; letter-spacing:2.5px;
  color:var(--text-dim); text-transform:uppercase; margin-bottom:2px;
}
.jnav-num {
  font-family:var(--font-d); font-size:26px; color:var(--white);
  line-height:1; letter-spacing:2px;
}
.jnav-date { font-size:11px; color:var(--text-mid); margin-top:3px; }
.jornada-fade { animation:jFade .25s ease both; }
@keyframes jFade { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
.plantilla-selector { display:flex; gap:6px; margin-bottom:14px; flex-wrap:wrap; }
@keyframes shimmer { 0%,100%{opacity:.5} 50%{opacity:1} }

@media(max-width:600px){
  .match-card { gap:5px; }
  .mt-name { font-size:11px; }
  .score-box { font-size:14px; padding:7px 8px; min-width:54px; }
}

/* ── JORNADA BANNER ── */
.jornada-banner { background:var(--bg2); border-radius:var(--rl); overflow:hidden; margin-bottom:18px; border:1px solid rgba(108,76,255,.2); }
.jornada-hdr { background:linear-gradient(90deg,var(--purple),var(--blue)); padding:10px 18px; display:flex; align-items:center; gap:10px; }
.jornada-hdr-title { font-family:var(--font-d); font-size:17px; color:var(--white); letter-spacing:1.5px; flex:1; }
.jornada-hdr-sub   { font-size:11px; color:rgba(255,255,255,.6); font-weight:500; }
.jornada-body { padding:16px 18px; display:grid; grid-template-columns:1fr 1fr; gap:12px; }
@media(max-width:560px){ .jornada-body { grid-template-columns:1fr; } }
.jornada-col-title { font-size:10px; font-weight:600; color:var(--cyan); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:10px; }
.victory-item { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.victory-badge { background:var(--teal); color:var(--bg); font-family:var(--font-d); font-size:14px; letter-spacing:1px; padding:4px 10px; border-radius:6px; white-space:nowrap; min-width:52px; text-align:center; font-weight:700; }
.victory-info { flex:1; }
.victory-name { font-size:13px; font-weight:500; color:var(--white); line-height:1.2; }
.victory-cat  { font-size:11px; color:var(--text-dim); margin-top:1px; }
.scorer-jornada-item { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.sj-avatar { width:30px; height:30px; border-radius:50%; background:rgba(108,76,255,.2); border:1px solid rgba(108,76,255,.35); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:600; color:var(--cyan); flex-shrink:0; }
.sj-info { flex:1; }
.sj-name { font-size:13px; font-weight:500; color:var(--white); line-height:1.2; }
.sj-detail { font-size:11px; color:var(--text-dim); margin-top:1px; }
.sj-gols { font-family:var(--font-d); font-size:20px; color:var(--amber); }


.coach-row {
  background:var(--bg2);
  border:1px solid rgba(108,76,255,.2);
  border-radius:var(--r);
  padding:12px 14px;
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.coach-av {
  width:38px;height:38px;
  background:linear-gradient(135deg,var(--purple),var(--blue));
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:var(--white);
  flex-shrink:0;
}
.coach-info { flex:1;min-width:0; }
.coach-name { font-size:13px;font-weight:600;color:var(--text); }
.coach-role { font-size:10px;color:var(--text-dim);margin-top:1px; }
.coach-stats {
  display:flex;gap:14px;flex-shrink:0;flex-wrap:wrap;
}
.coach-stat { text-align:center;min-width:28px; }
.coach-stat-val { font-family:var(--font-d);font-size:18px;color:var(--white);line-height:1; }
.coach-stat-val.green { color:var(--teal); }
.coach-stat-val.amber { color:var(--amber); }
.coach-stat-val.red   { color:var(--pink); }
.coach-stat-lbl { font-size:9px;color:var(--text-dim);font-weight:500; }


/*** MARC ADDS **/
.jornada-body .list{ 
    max-height: 400px;
    overflow-y: auto;
}
.match-card .mh ,.match-card .ma {
    position: relative
}
.flag-local{
    position: absolute;
    
}
.match-card .ma .flag-local{
    right:0;
}
footer a{
	color: #8d8d8d;
  text-decoration: none;
}
.loader {
      width: 48px;
      height: 48px;
      border-radius: 50%;
      position: relative;
      animation: rotate 1s linear infinite
    }
    .loader::before {
      content: "";
      box-sizing: border-box;
      position: absolute;
      inset: 0px;
      border-radius: 50%;
      border: 5px solid #FFF;
      animation: prixClipFix 2s linear infinite ;
    }

    @keyframes rotate {
      100%   {transform: rotate(360deg)}
    }

    @keyframes prixClipFix {
        0%   {clip-path:polygon(50% 50%,0 0,0 0,0 0,0 0,0 0)}
        25%  {clip-path:polygon(50% 50%,0 0,100% 0,100% 0,100% 0,100% 0)}
        50%  {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,100% 100%,100% 100%)}
        75%  {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 100%)}
        100% {clip-path:polygon(50% 50%,0 0,100% 0,100% 100%,0 100%,0 0)}
    }
	
	.hidden{ display:none!important;}
        
        
.fields {
	display: flex;
	flex-wrap: wrap;
	gap: calc(var(--pad) * 0.5);
	flex-grow: 1;
}

/*XTRA*/
/* ============================================
   GENERAL & COMMON STYLES
   Variables, Base Styles, Layout & Utilities
   ============================================ */
:root {
  
  --purple: #6C4CFF;
  --cyan:   #00D4FF;
  --teal:   #00E5D2;
  --blue:   #0099FF;
  --pink:   #FF4D7D;
  --amber:  #FFAE00;
  --white:  #FFFFFF;

  /* ── FONS FOSC ── */
  --bg:     #0A0E1A;
  --bg2:    #111827;
  --bg3:    #1C2333;
  --border: rgba(255,255,255,.08);
  --bord2:  rgba(255,255,255,.14);

  /* ── TEXT ── */
  --text:     #EEF1F8;
  --text-mid: rgba(238,241,248,.6);
  --text-dim: rgba(238,241,248,.35);

  /* ── ALIÀS SEMÀNTICS (mantenen compatibilitat de classes) ── */
  --navy:       var(--bg);
  --navy-mid:   var(--bg2);
  --navy-light: var(--bg3);
  --gold:       var(--amber);
  --gold-light: #ffd166;
  --gold-pale:  rgba(255,174,0,.12);
  --red:        var(--pink);
  --red-lt:     rgba(255,77,125,.12);
  --green:      var(--teal);
  --green-lt:   rgba(0,229,210,.12);
  --blue-lt:    rgba(0,153,255,.12);
  --amber-lt:   rgba(255,174,0,.12);
  --g100:       var(--bg2);
  --g200:       var(--border);
  --g400:       var(--text-dim);
  --g600:       var(--text-mid);

  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'DM Sans', sans-serif;
  --r: 10px; --rl: 16px;

  
    /* Medidas de UI */
    --rad: 12px;                       /* Bordes redondeados modernos */
    --pad: 16px; 
    --padh: calc(var(--pad) * 0.5); 

    --bth: 42px;                       /* Altura de botones */
    --bthh: calc(var(--bth) * 0.5); 
    --icos: 48px; 

 
}


/* ============================================
   UTILITY CLASSES
   ============================================ */
.w {
	width: 100%;
}

.padb {
	padding-bottom: var(--pad);
}

.marb {
	margin-bottom: var(--pad);
}

.gap {
	gap: var(--pad);
}

.hidden {
	display: none !important;
}

.safe {
	max-width: var(--safes);
	margin: auto;
}

.rrow {
	display: flex;
}

.head {
	display: flex;
}
.head > .acc > .btn{ margin-left:var(--pad);}


/* ============================================
   LAYOUT STRUCTURES
   ============================================ */
.lay-center {
	display: flex;
	flex-direction: column;
	justify-items: center;
	align-items: center;
	width: 100%;
	
}

.lay-center > .lay-col {
	max-width: 280px;
        min-height: 70vh;
}

.lay-center .field {
	width: 100%;
}

.page-container{
	
	width:100%;
}

/* Grid and Layout Utilities */
.cols {
	display: flex;
}

div.col2 {
	display: flex;
	flex-direction: row;
	gap:2rem;
}

.col2 > * {
	width: 50%;
}

.col2 > .c1 {
	width: 25%;
}

.col2 > .c3 {
	width: 75%;
}

.col2 > .c4 {
	width: 100%;
}

/* ============================================
   FIELD & INPUT STYLES
   ============================================ */
.field {
	background: var(--color-second-line);
    border: 1px solid var(--color-fore3);
    border-radius: var(--rad);
    transition: all 0.3s ease;
	padding: var(--pad);
	padding-top: calc(var(--pad) * 0.25);
	padding-bottom: calc(var(--pad) * 0.25);
}

.field:has(:focus) {
	border-color: var(--color-dest2); /* Brillo violeta al pasar el cursor */
    box-shadow: 0 0 20px var(--color-accent-glow);
    transform: translateY(-2px);
}

.field.w {
	width: 100%;
}

.field input {
	display: block;
	color: var(--color-fore-dest);
	border: 0;
	background: transparent;
	font-size: 16px;
	font-weight: 400;
	padding-left: 0;
	outline: none;
	width: 100%;
	padding: calc(var(--pad) * 0.5 );
	padding-left:0;
}

.field label {
	display: block;
	color: var(--color-fore2);
	font-size: 11px;
  text-transform: uppercase;
}
.field a{ padding: 0;
  color: var(--color-fore2);
  text-decoration: none;
}
.field input:focus {
	outline: none;
	box-shadow: none;
}

.field.money {
	position: relative;
}

.field.money:before {
	content: "€";
	position: absolute;
	top: 2em;
	font-size: 14px;
}

.field.money input {
	margin-left: 0.75em;
}
input::placeholder{
	font-size:13px;display:none;opacity:0;
}
.thumb.imgfield img {
	width: 100%;
	height: 8em;
	object-fit: cover;
}

.thumb.imgfield .field {
	padding: 0;
	overflow: hidden;
}

.thumb.imgfield .text {
	max-width: 20em;
}

.thumb.imgfield input {
	padding: var(--pad);
}

.field.apt.box {
	margin-bottom: var(--pad);
}

.field.apt.box > label {
	color: var(--color-primary);
	margin-bottom: var(--pad);
	font-weight: 500;
}
.field:has(input[type="checkbox"]){
	padding-right:calc( var(--pad) * 3);
	position: relative;
}
.field input[type="checkbox"] {
	margin-left:auto;
	width:auto;
	position: absolute;
	top:1.5rem;
	right:1rem;
}


/* ============================================
   LIST & THUMB BASE STYLES
   ============================================ */
.thumb {
	display: inline-flex;
	gap: 1rem;
	text-decoration: none;
	align-items: center;
}

.acc {
	margin-left: auto;
}

.thumb > .text {
	display: flex;
	align-items: flex-start;
	font-weight: 500;
	flex-direction: column;
	justify-content: center;
	font-size: 16px;
	line-height: 1.3em;
}

.thumb >  .text .detail {
	font-weight: 300;
	display: block;
	font-size: 14px;
}

.thumb > .icon {
	width: var(--icos);
	height: var(--icos);
	border-radius: 50%;
	overflow: hidden;
	display: flex;
	align-items: center;
	background: var(--color-surface1);
	justify-content: center;
	flex-shrink: 0;
}
.thumb > .icon img{
	width:100%;
	height:100%;
	object-fit: cover;
}
.thumb.w {
	width: 100%;
	flex-wrap: nowrap;
	gap: 0;
}
.thumb > .acc{
	gap:var(--pad	);
}

.thumb.w .text {
	padding-left: 0;
}

.thumb.dest {
	color: var(--color-primary);
	background-color: var(--color-surface3);
	border-radius: calc(var(--rad) * 2);
	font-size: 14px;
	padding: calc(var(--pad) * 0.25);
}

.thumb.dest .acc {
	margin-right: 1em;
}

.thumb.dest .icon {
	background: transparent;
}

.thumb.dest > .icon i {
	font-size: 16px;
}

.thumb > .info {
	margin-left: auto;
	margin-right: auto;
}

.list > .thumb {
	align-items: center;
	padding-top: calc(var(--pad) * 0.5);
	padding-bottom: calc(var(--pad) * 0.5);
}

/* ============================================
   SIZE VARIANTS
   ============================================ */
.s {
	--icos: 2.5rem;
}

.s .thumb .text,
.select2-results .thumb .text {
	font-size: 14px;
}

.s .thumb .detail,
.select2-results .thumb .detail {
	font-size: 12px;
}

.xs {
	--icos: 2rem;
	font-size:10px;
}

.xs .thumb .icon {
	background-color: transparent;
}

.xs .thumb > .info {
	font-size: 11px;
}

.xs .thumb .text {
	font-size: 12px;
}

.xs .thumb .detail {
	font-size: 11px;
}
.nodet .thumb .detail {
	display:none;
}
.xs > .thumb {
	padding-top: calc(var(--pad) * 0.15);
	padding-bottom: calc(var(--pad) * 0.15);
}

.thumb.s,
.select2-results .thumb {
	--icos: 2rem;
}

/* ============================================
   INFO GRID
   ============================================ */
.info {
	display: grid;
	grid-template-columns: 50% 50%;
	grid-gap: 0.5em;
	flex-grow: 1;
}

.info .thumb .icon {
	background: transparent;
	font-size: 18px;
}

.info .thumb {
	gap: 0.5em;
}

.info .thumb .text {
	display: block;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}

.info a.thumb {
	color: var(--color-fore-box);
}
h2 > i {
	margin-right:var(--pad);
	opacity:0.5;
}
/* ============================================
   COMMON ELEMENTS
   ============================================ */
.dropdown {
	list-style: none;
}
.modal{
	position:fixed;
	top:0;
	bottom:0;
}
.modal-backdrop{
		position:fixed;
	top:0;
	bottom:0;
}
.dropdown-toggle {
	text-decoration: none;
}

.acc {
	display: flex;
	align-items: center;
}

.acc a {
	text-decoration: none;
	font-weight: 600;
	font-size: 16px;
}

.accmenu {
	min-width: var(--menuw);
}

ul.toolbar {
	list-style: none;
	padding: 0;
	margin: 0;
}

.toolbar {
	display: flex;
	width: 100%;
	gap: var(--pad);
	align-items: center;
	justify-content: space-evenly;
}

.toolbar .primary {
	margin-left: auto;
}

.list > * {
	border-bottom: 1px solid var(--color-surface1);
}

.list > *:last-child {
	border: 0;
}

.list {
	display: flex;
	flex-direction: column;
}

.list.col2 {
	flex-direction: row;
	flex-wrap: wrap;
}

/* ============================================
   FORM STRUCTURE
   ============================================ */
form {
	display: flex;
	flex-direction: column;
	gap: var(--pad);
}

.fields {
	display: flex;
	flex-wrap: wrap;
	gap: calc(var(--pad) * 0.5);
	flex-grow: 1;
}

.fields .field {
	flex-grow: 1;
}

.tab-content {
	max-width: 600px;
}

.form-control:focus{
	outline: 0;box-shadow: none;
}

/* ============================================
   UTILITY STYLES
   ============================================ */
.footer.center {
	justify-content: center;
	display: flex;
	align-items: center;
}

.modhead {
	flex-grow: 1;
	display: flex;
	align-items: center;
	padding-right: calc(var(--pad) * 2);
}

.modhead .kpi {
	gap: 0;
}

.modhead .kpi i {
	font-size: 20px;
}

.modhead .kpi .icon {
	background: transparent;
}

/* ============================================
   ICON CIRCLE
   ============================================ */
.ico-circ {
	display: inline-block;
	border: 3px solid var(--color-dest1);
	width: 1.1em;
	height: 1.1em;
	border-radius: 50%;
	vertical-align: central;
	margin-right: 0.5em;
}

.ico-circ.b {
	border-color: var(--color-dest2);
}

/* ============================================
   SEARCH STYLES
   ============================================ */
.search.dest .field {
	/*flex-direction: row;
	display: flex;
	align-items: center;*/
}

.search.dest .field label {
	white-space: nowrap;
}

/* ============================================
   RICH TEXT EDITOR
   ============================================ */
div.ql-toolbar.ql-snow {
	border: 0;
	padding-bottom: 0;
}

div.ql-container.ql-snow {
	border: 0;
}

.ql-editor {
	min-height: 10em;
}
:root{
    --color-fore2: #f2f2f2;
    
}
.modal-content{
    background-color:#333;
}
.btn{
    color: #fff;
  background-color: #0b5ed7;
  border-color: #0a58ca;

}