#loading-screen{
  position:fixed;inset:0;background:#0a0608;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  z-index:9999;gap:16px;transition:opacity .4s;
}
#loading-screen.hide{opacity:0;pointer-events:none;}
.loading-logo{font-family:'Barlow Condensed',sans-serif;font-size:52px;font-weight:900;
  color:#8b1a1a;letter-spacing:-2px;text-shadow:0 0 40px rgba(139,26,26,0.6);}
.loading-logo span{color:#c9922a;}
.loading-spinner{width:36px;height:36px;border:3px solid rgba(201,146,42,0.2);
  border-top-color:#c9922a;border-radius:50%;animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-msg{font-family:'Barlow',sans-serif;font-size:12px;color:#7a5a5e;letter-spacing:.5px;}
.sync-indicator{position:fixed;top:8px;right:8px;width:8px;height:8px;
  border-radius:50%;background:#22c55e;z-index:200;
  box-shadow:0 0 6px rgba(34,197,94,0.6);transition:background .3s;}
.sync-indicator.offline{background:#ef4444;box-shadow:0 0 6px rgba(239,68,68,0.6);}
.sync-indicator.syncing{background:#f59e0b;animation:pulse .8s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

:root{
  --bg:#0a0608;--s1:#110a0d;--s2:#1a1013;--s3:#231519;--s4:#2c1b1f;
  --border:#3d2228;--border2:#4d2a31;
  /* Magios: granate + dorado */
  --green:#c9922a;--gdim:rgba(201,146,42,0.15);--glow:rgba(201,146,42,0.3);
  --yellow:#e8b84b;--ydim:rgba(232,184,75,0.13);
  --red:#ef4444;--rdim:rgba(239,68,68,0.13);
  --blue:#c0855a;--bdim:rgba(192,133,90,0.13);
  --orange:#d4793a;--odim:rgba(212,121,58,0.13);
  --purple:#b56a7a;--pdim:rgba(181,106,122,0.13);
  --crimson:#8b1a1a;--cdim:rgba(139,26,26,0.2);--cglow:rgba(139,26,26,0.4);
  --text:#f5ece8;--muted:#7a5a5e;--muted2:#a88080;
  --fd:'Barlow Condensed',sans-serif;--fb:'Barlow',sans-serif;
  /* position colors */
  --c-arq:#e8b84b;--c-cen:#c0855a;--c-lat:#c0855a;
  --c-med:#c9922a;--c-ban:#b87333;--c-del:#8b1a1a;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;overflow:hidden;}
body{background:var(--bg);color:var(--text);font-family:var(--fb);
  display:flex;flex-direction:column;max-width:430px;margin:0 auto;position:relative;}

/* ── SCREENS ── */
.screen{display:none;flex-direction:column;height:100%;overflow:hidden;}
.screen.active{display:flex;}

/* ── LOGIN ── */
#login{
  background:radial-gradient(ellipse at 30% 20%,rgba(139,26,26,0.35) 0%,transparent 55%),
             radial-gradient(ellipse at 75% 85%,rgba(201,146,42,0.12) 0%,transparent 50%),
             var(--bg);
  align-items:center;justify-content:center;padding:28px 22px;overflow-y:auto;gap:0;
}
.login-logo{font-family:var(--fd);font-size:72px;font-weight:900;color:var(--crimson);
  letter-spacing:-2px;text-shadow:0 0 40px rgba(139,26,26,0.6),0 0 80px rgba(139,26,26,0.2);line-height:1;margin-bottom:0px;}
.login-logo span{color:var(--green);}
.login-club{font-size:11px;color:var(--muted2);letter-spacing:2.5px;text-transform:uppercase;margin-bottom:4px;}
.login-liga{font-size:10px;color:var(--muted);letter-spacing:1px;margin-bottom:24px;}
.login-escudo{width:120px;height:120px;margin:0 auto 10px;display:block;filter:drop-shadow(0 0 30px rgba(139,26,26,0.7)) drop-shadow(0 0 60px rgba(201,146,42,0.3));animation:logoFloat 3s ease-in-out infinite;}
@keyframes logoFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.login-title{font-family:var(--fd);font-size:20px;font-weight:700;color:var(--muted2);margin-bottom:14px;}
.login-widgets{width:100%;display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.login-widget{background:linear-gradient(135deg,rgba(139,26,26,0.18),rgba(201,146,42,0.08));border:1px solid var(--border);border-left:3px solid var(--green);border-radius:12px;padding:10px 12px;}
.login-widget-title{font-family:var(--fd);font-size:11px;color:var(--green);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;}
.login-widget-body{font-size:12px;color:var(--text);line-height:1.4;}
.login-widget-empty{color:var(--muted);font-style:italic;}
.login-widget .lw-line{display:flex;justify-content:space-between;gap:8px;font-size:11px;margin-top:2px;}
.login-widget .lw-line span:first-child{color:var(--text);}
.login-widget .lw-line span:last-child{color:var(--muted2);}
.role-cards{display:flex;flex-direction:column;gap:8px;width:100%;}
.role-card{background:linear-gradient(135deg,var(--s2),var(--s3));border:1px solid var(--border);border-radius:14px;
  padding:12px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;transition:all .2s;box-shadow:0 2px 10px rgba(0,0,0,0.2);}
.role-card:active{transform:scale(.97);}
.role-card.selected{border-color:var(--crimson);background:rgba(139,26,26,.12);box-shadow:0 0 20px rgba(139,26,26,0.2);}
.role-icon{font-size:22px;width:40px;height:40px;background:var(--s3);border-radius:10px;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.role-name{font-family:var(--fd);font-size:19px;font-weight:700;letter-spacing:.3px;}
.role-desc{font-size:11px;color:var(--muted);margin-top:1px;}
.player-select-wrap{width:100%;margin-top:9px;display:none;}
.pin-wrap{width:100%;margin-top:8px;display:none;}
.pin-wrap label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px;}
.btn-enter{width:100%;margin-top:16px;padding:14px;background:var(--crimson);color:#f5ece8;
  font-family:var(--fd);font-size:21px;font-weight:800;letter-spacing:.5px;
  border:none;border-radius:13px;cursor:pointer;box-shadow:0 4px 22px var(--cglow);}
.btn-enter:active{transform:scale(.97);}
.login-manual-link{margin-top:14px;width:100%;}
.login-manual-link a{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--s2),var(--s3));
  border:1px solid var(--border);border-radius:12px;
  padding:10px 16px;text-decoration:none;
  color:var(--muted2);font-family:var(--fb);font-size:12px;font-weight:500;letter-spacing:.4px;
  transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.login-manual-link a::before{content:"\1F4D6";font-size:15px;}
.login-manual-link a:active{transform:scale(.97);border-color:var(--green);color:var(--green);box-shadow:0 0 14px rgba(201,146,42,0.2);}

/* ── APP SHELL ── */
.app-header{background:linear-gradient(90deg,rgba(10,6,8,.98),rgba(17,10,13,.98));backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);padding:11px 15px;
  display:flex;align-items:center;justify-content:space-between;flex-shrink:0;z-index:50;
  box-shadow:0 2px 16px rgba(0,0,0,0.5);}
.app-logo{font-family:var(--fd);font-size:21px;font-weight:900;color:var(--green);letter-spacing:-.5px;}
.app-logo span{color:var(--crimson);}
.hdr-right{display:flex;align-items:center;gap:8px;}
.role-badge{padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;}
.rb-j{background:var(--bdim);color:var(--blue);}
.rb-dt{background:var(--ydim);color:var(--yellow);}
.rb-a{background:var(--rdim);color:var(--red);}
.rb-s{background:rgba(34,197,94,0.13);color:#22c55e;}
.rb-as{background:var(--cdim);color:var(--crimson);}
.logout-btn{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:3px;}

/* ── TABS ── */
.tabs{display:flex;flex-direction:column;background:var(--s1);border-bottom:1px solid var(--border);flex-shrink:0;}
.tabs-row{display:flex;}
.tabs-row + .tabs-row{border-top:1px solid var(--border);}
.tab{flex:1;background:none;border:none;color:var(--muted);padding:9px 3px 7px;
  font-family:var(--fb);font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;
  cursor:pointer;border-bottom:2px solid transparent;display:flex;flex-direction:column;align-items:center;gap:2px;transition:all .2s;}
.tab .ti{font-size:16px;}
.tab.active{color:var(--green);border-bottom-color:var(--green);}
.tab.active .ti{filter:drop-shadow(0 0 4px rgba(201,146,42,0.5));}

/* ── CALENDARIO ── */
.cal-wrap{background:var(--crimson);border:2px solid var(--green);border-radius:14px;padding:10px;color:var(--green);box-shadow:0 4px 18px rgba(139,26,26,0.45);}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.cal-title{font-family:var(--fd);font-size:22px;font-weight:900;color:var(--green);text-transform:capitalize;letter-spacing:.5px;}
.cal-nav{background:none;border:1px solid var(--green);color:var(--green);width:32px;height:32px;border-radius:8px;font-size:18px;font-weight:700;cursor:pointer;}
.cal-nav:active{transform:scale(.95);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-dows{margin-bottom:4px;}
.cal-dow{font-family:var(--fd);font-size:9px;font-weight:700;color:var(--green);text-align:center;padding:4px 0;letter-spacing:.5px;opacity:.85;}
.cal-dow-w{color:#f5d68a;}
.cal-cell{aspect-ratio:1/1;background:rgba(0,0,0,0.18);border:1px solid rgba(201,146,42,.35);border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;color:var(--green);font-family:var(--fd);font-weight:700;}
.cal-cell.cal-empty{background:transparent;border-color:transparent;}
.cal-day-num{font-size:14px;line-height:1;}
.cal-marks{display:flex;gap:1px;font-size:8px;margin-top:2px;min-height:10px;}
.cal-mk{font-size:9px;line-height:1;}
.cal-today{background:var(--green);color:var(--crimson);border-color:var(--green);box-shadow:0 0 8px rgba(201,146,42,0.5);}
.cal-today .cal-day-num{color:var(--crimson);}
.cal-leyenda{margin-top:8px;display:flex;justify-content:space-around;font-size:9px;color:var(--green);text-transform:uppercase;letter-spacing:.5px;opacity:.85;}

/* ── LIVE / EN VIVO ── */
.live-banner{background:linear-gradient(135deg,rgba(239,68,68,0.18),rgba(139,26,26,0.4));border:1px solid var(--red);border-radius:14px;padding:10px 12px;margin-bottom:12px;cursor:pointer;box-shadow:0 0 14px rgba(239,68,68,0.25);}
.live-banner:active{transform:scale(.99);}
.live-dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--red);box-shadow:0 0 8px var(--red);animation:livePulse 1.2s infinite;}
@keyframes livePulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.85);}}
.live-header{background:linear-gradient(135deg,var(--crimson),#6b1212);padding:14px 12px;display:flex;align-items:center;justify-content:space-between;color:#f5ece8;}
.live-team-name{font-family:var(--fd);font-size:13px;font-weight:700;letter-spacing:.5px;flex:1;text-align:center;}
.live-score{font-family:var(--fd);font-size:48px;font-weight:900;line-height:1;letter-spacing:-2px;flex:1;text-align:center;}
.live-chrono{background:#0a0608;padding:14px 12px;text-align:center;border-bottom:1px solid var(--border);}
.live-time{font-family:var(--fd);font-size:42px;font-weight:900;color:var(--green);line-height:1;letter-spacing:-1px;}
.live-fase{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px;}
.live-state-row{padding:10px 12px;display:flex;gap:8px;}
.live-state-row button{flex:1;padding:11px;border-radius:11px;font-family:var(--fd);font-size:15px;font-weight:800;cursor:pointer;border:none;}
.btn-state-go{background:linear-gradient(135deg,#22c55e,#16a34a);color:#0a0608;}
.btn-state-pause{background:linear-gradient(135deg,var(--yellow),#d4a045);color:#0a0608;}
.btn-state-end{background:linear-gradient(135deg,var(--crimson),#6b1212);color:#f5ece8;}
.live-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;}
.live-actions .live-btn-yel,.live-actions .live-btn-red,.live-actions .live-btn-sub{grid-column:span 2;}
.live-btn{padding:13px;border-radius:12px;font-family:var(--fd);font-size:15px;font-weight:800;cursor:pointer;border:1px solid;letter-spacing:.5px;}
.live-btn-mag{background:rgba(34,197,94,0.15);border-color:#22c55e;color:#22c55e;}
.live-btn-riv{background:var(--rdim);border-color:var(--red);color:var(--red);}
.live-btn-sub{background:var(--bdim);border-color:var(--blue);color:var(--blue);}
.live-btn-yel{background:rgba(232,184,75,0.15);border-color:var(--yellow);color:var(--yellow);}
.live-btn-red{background:var(--rdim);border-color:var(--red);color:var(--red);}

/* ── TABLA LIGA ── */
.tabla-liga{width:100%;border-collapse:collapse;font-size:11px;color:var(--text);}
.tabla-liga th{font-family:var(--fd);font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;padding:8px 5px;border-bottom:1px solid var(--border);background:var(--s2);text-align:center;white-space:nowrap;}
.tabla-liga th:nth-child(2){text-align:left;padding-left:10px;}
.tabla-liga td{padding:8px 5px;border-bottom:1px solid rgba(61,34,40,0.4);text-align:center;color:var(--muted2);white-space:nowrap;}
.tabla-liga td:first-child{font-family:var(--fd);font-weight:700;color:var(--muted);width:28px;}
.tabla-liga td:nth-child(2){padding-left:10px;text-align:left;color:var(--text);}
.tabla-liga tr:last-child td{border-bottom:none;}
.tabla-liga tr.tabla-magios td{background:rgba(139,26,26,0.35);color:#f5ece8;font-weight:800;font-size:12px;border-bottom:1px solid rgba(139,26,26,0.5);}
.tabla-liga tr.tabla-magios td:first-child{color:var(--green);}
.tabla-liga tr.tabla-magios td:nth-child(2){color:#f5ece8;}
.tabla-liga th.sortable{cursor:pointer;user-select:none;}
.tabla-liga th.sortable:hover{color:var(--green);}

/* ── CONTENT ── */
.content{flex:1;overflow-y:auto;overflow-x:hidden;}
.content::-webkit-scrollbar{width:2px;}
.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.page{display:none;padding:14px;animation:fu .2s ease;}
.page.active{display:block;}
@keyframes fu{from{opacity:0;transform:translateY(5px);}to{opacity:1;transform:translateY(0);}}

/* ── TYPOGRAPHY ── */
.pg-title{font-family:var(--fd);font-size:32px;font-weight:900;line-height:1;letter-spacing:-.5px;background:linear-gradient(135deg,var(--text),var(--muted2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.pg-sub{font-size:11px;color:var(--muted);margin-top:2px;margin-bottom:14px;}
.sec-label{font-family:var(--fd);font-size:13px;color:var(--muted);text-transform:uppercase;
  letter-spacing:1px;margin:14px 0 8px;border-bottom:1px solid var(--border);padding-bottom:5px;}

/* ── CARDS ── */
.card{background:linear-gradient(145deg,var(--s2),var(--s3));border:1px solid var(--border);border-radius:16px;padding:14px;margin-bottom:11px;box-shadow:0 2px 12px rgba(0,0,0,0.3);}
.card-sm{background:var(--s2);border:1px solid var(--border);border-radius:11px;padding:10px 13px;margin-bottom:7px;}
.card-title{font-family:var(--fd);font-size:19px;font-weight:700;margin-bottom:10px;}

/* ── PILLS ── */
.pill{padding:2px 7px;border-radius:4px;font-size:10px;font-weight:600;display:inline-block;}
.pg{background:var(--gdim);color:var(--green);}
.py{background:var(--ydim);color:var(--yellow);}
.pr{background:var(--rdim);color:var(--red);}
.pb{background:var(--bdim);color:var(--blue);}
.po{background:var(--odim);color:var(--orange);}
.pp{background:var(--pdim);color:var(--purple);}

/* ── STATS GRID ── */
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:12px;}
.stats-grid.cols3{grid-template-columns:1fr 1fr 1fr;}
.stats-grid.cols4{grid-template-columns:repeat(4,1fr);}
.stat-box{background:linear-gradient(145deg,var(--s2),var(--s3));border:1px solid var(--border);border-radius:13px;padding:12px 8px;text-align:center;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,0.2);}
.stat-box:active{border-color:var(--green);transform:scale(.97);}
.stat-val{font-family:var(--fd);font-size:32px;font-weight:800;line-height:1;color:var(--green);}
.stat-lbl{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-top:3px;}

/* ── PROFILE HERO ── */
.profile-hero{background:linear-gradient(135deg,rgba(139,26,26,0.15),var(--s3),var(--s2));
  border:1px solid var(--border);border-left:3px solid var(--crimson);border-radius:18px;padding:16px;margin-bottom:12px;box-shadow:0 4px 20px rgba(0,0,0,0.4);}
.ph-top{display:flex;gap:14px;align-items:flex-start;margin-bottom:12px;}
.ph-avatar-wrap{position:relative;flex-shrink:0;}
.ph-avatar{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:28px;font-weight:800;border:3px solid;overflow:hidden;cursor:pointer;}
.ph-avatar img{width:100%;height:100%;object-fit:cover;}
.ph-edit-btn{position:absolute;bottom:0;right:0;width:22px;height:22px;background:var(--green);
  border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;}
.ph-apodo{font-size:10px;color:var(--green);font-weight:700;text-transform:uppercase;letter-spacing:1px;}
.ph-name{font-family:var(--fd);font-size:22px;font-weight:800;line-height:1.1;}
.ph-sub{font-size:11px;color:var(--muted2);margin-top:1px;}
.ph-meta{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px;}
.ph-bottom{display:flex;gap:7px;}
.ph-stat{flex:1;background:var(--bg);border-radius:9px;padding:9px 6px;text-align:center;}
.ph-stat-val{font-family:var(--fd);font-size:22px;font-weight:700;color:var(--green);line-height:1;}
.ph-stat-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;margin-top:2px;}
.edit-btn{width:100%;margin-top:10px;padding:9px;background:var(--s3);
  border:1px solid var(--border2);border-radius:10px;color:var(--muted2);
  font-family:var(--fd);font-size:16px;font-weight:600;cursor:pointer;letter-spacing:.3px;}

/* ── NEXT MATCH BANNER ── */
.next-match{background:linear-gradient(135deg,rgba(139,26,26,.18),rgba(201,146,42,.06));
  border:1px solid rgba(139,26,26,.3);border-radius:15px;padding:13px;margin-bottom:12px;box-shadow:0 2px 12px rgba(139,26,26,0.15);}
.nm-label{font-size:9px;color:var(--yellow);text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:5px;}
.nm-rival{font-family:var(--fd);font-size:26px;font-weight:800;line-height:1;}
.nm-detail{font-size:11px;color:var(--muted);margin-top:3px;}
.nm-citacion{font-size:11px;color:var(--yellow);margin-top:2px;font-weight:600;}

/* ── FIXTURE CARD ── */
.fixture-card{background:linear-gradient(145deg,var(--s2),var(--s3));border:1px solid var(--border);border-radius:14px;
  padding:13px;margin-bottom:9px;transition:all .2s;border-left:3px solid var(--crimson);box-shadow:0 2px 10px rgba(0,0,0,0.25);}
.fixture-card:active{border-color:var(--green);transform:scale(.99);}
.fc-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.fc-fase{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.fc-rival{font-family:var(--fd);font-size:22px;font-weight:800;line-height:1;}
.fc-detail{font-size:11px;color:var(--muted2);margin-top:3px;}
.fc-citacion{font-size:10px;color:var(--yellow);margin-top:2px;font-weight:600;}
.fc-att{display:flex;gap:8px;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid var(--border);}
.att-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.att-bar-fill{height:100%;background:linear-gradient(90deg,var(--crimson),var(--green));border-radius:3px;}

/* ── MATCH RESULT CARD ── */
.match-card{background:linear-gradient(145deg,var(--s2),var(--s3));border:1px solid var(--border);border-radius:14px;
  padding:13px;margin-bottom:9px;cursor:pointer;transition:all .2s;box-shadow:0 2px 10px rgba(0,0,0,0.25);}
.match-card:active{transform:scale(.99);}
.mc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;}
.mc-fase{font-size:10px;color:var(--muted);text-transform:uppercase;}
.mc-score{display:flex;align-items:center;justify-content:center;gap:10px;margin:4px 0;}
.mc-team{font-size:13px;font-weight:600;flex:1;}
.mc-team.r{text-align:right;}
.mc-nums{font-family:var(--fd);font-size:42px;font-weight:900;display:flex;gap:5px;align-items:center;line-height:1;text-shadow:0 2px 8px rgba(0,0,0,0.3);}
.mc-sep{color:var(--muted);font-size:22px;}
.mc-meta{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap;}

/* ── CONFIRM ASISTENCIA ── */
.confirm-card{background:linear-gradient(135deg,rgba(34,197,94,.1),rgba(34,197,94,.03));
  border:1px solid rgba(34,197,94,.25);border-radius:18px;padding:15px;margin-bottom:12px;}
.confirm-btns{display:flex;gap:9px;margin-top:12px;}
.cbtn{flex:1;padding:13px;border-radius:11px;border:none;font-family:var(--fd);font-size:19px;font-weight:700;cursor:pointer;transition:all .2s;}
.cbtn:active{transform:scale(.96);}
.cbtn-yes{background:var(--green);color:#000;}
.cbtn-no{background:var(--s3);color:var(--red);border:1px solid rgba(239,68,68,.3);}
.chosen-yes{box-shadow:0 0 20px rgba(34,197,94,.4);}
.chosen-no{box-shadow:0 0 18px rgba(239,68,68,.3);}

/* ── PLANTEL TABLE ── */
.plantel-table{width:100%;border-collapse:collapse;}
.plantel-table th{font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;
  padding:6px 8px;border-bottom:1px solid var(--border);text-align:center;font-weight:600;}
.plantel-table th:first-child{text-align:left;}
.plantel-table td{padding:9px 8px;border-bottom:1px solid rgba(38,48,66,.6);text-align:center;font-size:12px;}
.plantel-table td:first-child{text-align:left;}
.plantel-table tr:last-child td{border-bottom:none;}
.pt-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;}
.pt-apodo{font-size:10px;color:var(--muted);}
.pt-score{font-family:var(--fd);font-size:17px;font-weight:700;}
.pt-pos-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;}

/* ── CUOTAS ── */
.cuota-player-card{background:var(--s2);border:1px solid var(--border);border-radius:14px;
  padding:13px;margin-bottom:9px;}
.cpc-top{display:flex;align-items:center;gap:11px;margin-bottom:10px;}
.cpc-info{flex:1;min-width:0;}
.cpc-name{font-size:14px;font-weight:600;}
.cpc-sub{font-size:11px;color:var(--muted);}
.cuotas-grid{display:flex;gap:5px;flex-wrap:wrap;}
.cuota-chip{width:34px;height:34px;border-radius:8px;border:1.5px solid;
  display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;}
.cuota-chip.paid{background:var(--gdim);border-color:var(--green);color:var(--green);}
.cuota-chip.pending{background:var(--s3);border-color:var(--border2);color:var(--muted);}
.cuota-chip.overdue{background:var(--rdim);border-color:var(--red);color:var(--red);}

/* ── FORMATION FIELD ── */
.field-wrap{border-radius:14px;overflow:hidden;margin-bottom:12px;}
.field-svg{width:100%;display:block;}
.pdot{cursor:pointer;}
.pdot:active{transform:scale(1.1);}

/* ── STARS / VOTE ── */
.vote-card{background:var(--s3);border:1px solid var(--border);border-radius:12px;
  padding:11px 13px;margin-bottom:8px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .2s;}
.vote-card.voted{border-color:var(--yellow);background:rgba(245,158,11,.08);}
.vote-card:active{transform:scale(.98);}

/* ── FORM ── */
.f-row{margin-bottom:10px;}
.f-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px;}
.f-input,.f-select,.f-textarea{width:100%;background:var(--s3);border:1px solid var(--border);
  border-radius:9px;padding:10px 12px;color:var(--text);font-family:var(--fb);font-size:13px;outline:none;transition:border-color .2s;}
.f-input:focus,.f-select:focus,.f-textarea:focus{border-color:var(--green);}
.f-select option{background:var(--s2);}
.f-textarea{resize:none;min-height:75px;}
.f-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.f-3col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}
.btn-row{display:flex;gap:7px;margin-top:13px;}
.btn-primary{flex:1;padding:12px;background:linear-gradient(135deg,var(--crimson),#6b1212);color:#f5ece8;
  font-family:var(--fd);font-size:19px;font-weight:800;border:none;border-radius:11px;cursor:pointer;box-shadow:0 3px 12px rgba(139,26,26,0.4);}
.btn-ghost{flex:1;padding:12px;background:var(--s3);color:var(--muted);
  font-family:var(--fd);font-size:19px;font-weight:700;border:1px solid var(--border);border-radius:11px;cursor:pointer;}
.btn-danger{flex:1;padding:12px;background:var(--rdim);color:var(--red);
  font-family:var(--fd);font-size:19px;font-weight:700;border:1px solid rgba(239,68,68,.3);border-radius:11px;cursor:pointer;}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);
  backdrop-filter:blur(7px);z-index:500;align-items:flex-end;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:linear-gradient(180deg,var(--s2),var(--s1));border:1px solid var(--border2);border-top:2px solid var(--crimson);border-radius:22px 22px 0 0;
  padding:18px 18px 40px;width:100%;max-width:430px;max-height:92vh;overflow-y:auto;
  animation:slideUp .28s cubic-bezier(.34,1.56,.64,1);position:relative;box-shadow:0 -4px 40px rgba(0,0,0,0.6);}
@keyframes slideUp{from{transform:translateY(100%);}to{transform:translateY(0);}}
.modal-handle{width:36px;height:4px;background:var(--border2);border-radius:2px;margin:0 auto 16px;}
.modal-close{position:absolute;top:15px;right:15px;background:var(--s3);border:none;color:var(--muted);
  width:28px;height:28px;border-radius:50%;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.modal-title{font-family:var(--fd);font-size:24px;font-weight:800;margin-bottom:3px;}
.modal-sub{font-size:11px;color:var(--muted);margin-bottom:16px;}

/* ── WELCOME ── */
.welcome-banner{background:linear-gradient(135deg,rgba(139,26,26,.18),rgba(201,146,42,.06));
  border:1px solid rgba(139,26,26,.3);border-radius:15px;padding:13px 15px;
  display:flex;align-items:center;gap:11px;margin-bottom:13px;box-shadow:0 2px 14px rgba(139,26,26,0.1);}

/* ── TOAST ── */
.toast{position:fixed;top:70px;left:50%;transform:translateX(-50%) translateY(-16px);
  background:var(--s3);border:1px solid var(--border2);border-radius:10px;
  padding:9px 18px;font-size:12px;font-weight:600;z-index:900;opacity:0;transition:all .25s;pointer-events:none;white-space:nowrap;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;}
.dot-g{background:var(--green);}.dot-y{background:var(--yellow);}.dot-r{background:var(--red);}
input[type="file"]{display:none;}

/* ── SEARCH ── */
.search{background:var(--s2);border:1px solid var(--border);border-radius:11px;
  padding:9px 13px;color:var(--text);font-family:var(--fb);font-size:13px;
  width:100%;outline:none;margin-bottom:11px;}
.search:focus{border-color:var(--green);}

.divider-row{display:flex;align-items:center;gap:8px;margin:12px 0 8px;}
.divider-row span{font-family:var(--fd);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;white-space:nowrap;}
.divider-row::before,.divider-row::after{content:'';flex:1;height:1px;background:var(--border);}
