*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
:root{
  --bg:#e8e4ef;
  --sh-dark:#c4c0cb;
  --sh-light:#ffffff;
  --accent:#F5A623;
  --accent-dk:#d4881a;
  --acc-sh1:#c8880e;
  --acc-sh2:#ffd07a;
  --lila:#9C7FC0;
  --lila-dk:#7a5fa0;
  --text:#3a2e4a;
  --text-soft:#7a6e88;
  --text-xs:#b0a8bc;
  --card-r:20px;
  --radius:14px;
  --neu-up:8px 8px 22px var(--sh-dark),-8px -8px 22px var(--sh-light);
  --neu-in:inset 4px 4px 10px var(--sh-dark),inset -4px -4px 10px var(--sh-light);
  --sidebar-w:240px
}
body{background:var(--bg);color:var(--text);font-family:'Inter',Arial,sans-serif;font-size:15px;line-height:1.5;min-height:100vh}

/* ─── NAV ─── */
#nav{
  background:var(--bg);padding:0 24px;height:64px;
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  box-shadow:0 4px 16px var(--sh-dark);position:sticky;top:0;z-index:200
}
.nav-logo-wrap{display:flex;align-items:center;gap:12px}
.nav-logo-img{height:44px;width:auto;filter:drop-shadow(0 2px 6px rgba(156,127,192,.35))}
.nav-titulo{font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text)}
.nav-titulo span{display:block;font-size:10px;font-weight:500;color:var(--lila);letter-spacing:1px}
.nav-info{display:flex;align-items:center;gap:10px}

/* Badge usuario — solo nombre, sin "(rol)" */
.nav-user-badge{
  background:var(--bg);box-shadow:var(--neu-up);border-radius:50px;
  padding:7px 20px;font-size:13px;font-weight:700;color:var(--text);
  display:flex;align-items:center;gap:8px
}
.rol-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;flex-shrink:0}
.nav-user-badge.admin .rol-dot{background:var(--lila)}
#nav .btn-nav-salir{
  background:none;border:none;padding:8px 18px;border-radius:50px;
  font-size:13px;font-weight:600;font-family:inherit;color:var(--text-soft);
  cursor:pointer;box-shadow:var(--neu-up);transition:all .2s
}
#nav .btn-nav-salir:hover{color:var(--accent-dk)}

/* ─── LAYOUT ─── */
#app-layout{display:flex;min-height:calc(100vh - 64px)}

/* ─── SIDEBAR (solo admin) ─── */
#sidebar{
  width:var(--sidebar-w);flex-shrink:0;background:var(--bg);
  box-shadow:4px 0 18px var(--sh-dark);padding:24px 14px;
  display:flex;flex-direction:column;gap:6px;
  position:sticky;top:64px;height:calc(100vh - 64px);overflow-y:auto
}
.sb-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--text-xs);padding:0 10px;
  margin-top:10px;margin-bottom:2px
}
.sb-label:first-child{margin-top:0}
.sb-btn{
  display:flex;align-items:center;gap:10px;padding:12px 14px;border:none;
  border-radius:var(--radius);font-size:13px;font-weight:600;font-family:inherit;
  color:var(--text-soft);background:var(--bg);cursor:pointer;
  box-shadow:var(--neu-up);transition:all .2s;text-align:left;width:100%
}
.sb-btn:hover{color:var(--text);transform:translateX(2px);box-shadow:5px 5px 16px var(--sh-dark),-5px -5px 16px var(--sh-light)}
.sb-btn.on-acc{background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;box-shadow:4px 4px 12px var(--acc-sh1),-2px -2px 8px var(--acc-sh2)}
.sb-btn.on-lila{background:linear-gradient(135deg,var(--lila),var(--lila-dk));color:#fff;box-shadow:4px 4px 12px rgba(122,95,160,.4)}
.sb-icon{font-size:16px;flex-shrink:0}

/* ─── MAIN ─── */
#main{flex:1;padding:28px 24px;overflow-x:hidden}

/* ─── SECCIONES ─── */
.sec{background:var(--bg);border-radius:var(--card-r);box-shadow:var(--neu-up);padding:24px;margin-bottom:24px}
.sec h2{
  font-size:15px;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--text);padding-bottom:14px;margin-bottom:20px;border-bottom:2px solid;
  border-image:linear-gradient(90deg,var(--accent),var(--lila)) 1
}

/* ─── BOTONES ─── */
.acc{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
button{font-family:inherit;cursor:pointer}
.btn-app{
  display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border:none;
  border-radius:50px;font-size:13px;font-weight:700;font-family:inherit;
  letter-spacing:.6px;text-transform:uppercase;cursor:pointer;
  background:var(--accent);color:#fff;
  box-shadow:4px 4px 12px var(--acc-sh1),-2px -2px 8px var(--acc-sh2);transition:all .2s
}
.btn-app:hover{background:var(--accent-dk);color:#fff;transform:translateY(-1px)}
.btn-app:active{transform:scale(.97);box-shadow:inset 3px 3px 8px var(--acc-sh1)}
.btn-sec{
  display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border:none;
  border-radius:50px;font-size:13px;font-weight:700;font-family:inherit;
  letter-spacing:.6px;text-transform:uppercase;cursor:pointer;
  background:var(--bg);color:var(--lila);box-shadow:var(--neu-up);transition:all .2s
}
.btn-sec:hover{color:var(--lila-dk);transform:translateY(-1px)}
.btn-sec:active{box-shadow:var(--neu-in);transform:scale(.97)}
.btn-sm{padding:6px 14px!important;font-size:11px!important;letter-spacing:.4px!important}
.btn-del{background:var(--bg)!important;color:#c0392b!important;box-shadow:var(--neu-up)!important;display:inline-flex!important;align-items:center!important;gap:6px!important;border:none!important;border-radius:50px!important;font-size:13px!important;font-weight:700!important;font-family:inherit!important;letter-spacing:.6px!important;text-transform:uppercase!important;cursor:pointer!important;transition:all .2s!important}
.btn-del:hover{color:#922b21!important;transform:translateY(-1px)!important}
.btn-obs{background:var(--bg)!important;color:#1a7a1a!important;box-shadow:var(--neu-up)!important;display:inline-flex!important;align-items:center!important;gap:6px!important;border:none!important;border-radius:50px!important;font-size:13px!important;font-weight:700!important;font-family:inherit!important;letter-spacing:.6px!important;text-transform:uppercase!important;cursor:pointer!important;transition:all .2s!important}
.btn-obs:hover{color:#0d5c0d!important;transform:translateY(-1px)!important}

/* ─── GRID BLOQUES ─── */
.grid-bloques{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:18px}
.tarjeta-bloque{
  background:var(--bg);border-radius:var(--card-r);box-shadow:var(--neu-up);
  padding:24px 16px;cursor:pointer;text-align:center;transition:all .22s;
  position:relative;overflow:hidden
}
.tarjeta-bloque::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--accent),var(--lila));
  border-radius:var(--card-r) var(--card-r) 0 0
}
.tarjeta-bloque:hover{box-shadow:10px 10px 28px var(--sh-dark),-10px -10px 28px var(--sh-light);transform:translateY(-3px)}
.tarjeta-bloque:active{box-shadow:var(--neu-in);transform:scale(.97)}
.bloque-num{
  font-size:40px;font-weight:900;line-height:1;
  background:linear-gradient(135deg,var(--accent),var(--lila));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px
}
.tarjeta-bloque h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:6px}
.tarjeta-bloque p{font-size:12px;color:var(--text-soft)}

/* ─── TABLAS ─── */
.tabla-scroll{overflow-x:auto;border-radius:var(--radius)}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
thead th{
  background:linear-gradient(135deg,var(--lila),var(--lila-dk));color:#fff;
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;
  padding:12px 14px;text-align:left
}
thead th:first-child{border-radius:var(--radius) 0 0 0}
thead th:last-child{border-radius:0 var(--radius) 0 0}
tbody td{padding:11px 14px;color:var(--text);border-bottom:1px solid rgba(196,192,203,.35);vertical-align:middle;background:var(--bg)}
tbody tr:last-child td{border-bottom:none}
tbody tr:last-child td:first-child{border-radius:0 0 0 var(--radius)}
tbody tr:last-child td:last-child{border-radius:0 0 var(--radius) 0}
tbody tr:hover td{background:rgba(245,166,35,.06)}
tbody tr:nth-child(even) td{background:rgba(196,192,203,.1)}
tbody tr:nth-child(even):hover td{background:rgba(245,166,35,.08)}

/* Badges jueces */
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:28px;height:24px;border-radius:8px;font-size:11px;font-weight:700;margin-right:3px;
  background:var(--bg);color:var(--text-xs);
  box-shadow:3px 3px 7px var(--sh-dark),-3px -3px 7px var(--sh-light)
}
.badge.done{background:linear-gradient(135deg,var(--lila),var(--lila-dk));color:#fff;box-shadow:2px 2px 6px rgba(122,95,160,.4)}
.badge.mine{background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;box-shadow:2px 2px 6px rgba(200,136,14,.4)}
.td-acc{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

/* ─── RÚBRICA + PROMEDIO LIVE ─── */
.rubrica-tabla input[type=number]{
  width:94px;padding:8px 10px;border:none;border-radius:10px;font-size:15px;
  font-weight:600;font-family:inherit;text-align:center;color:var(--text);
  background:var(--bg);box-shadow:var(--neu-in);outline:none;transition:box-shadow .2s;
  -moz-appearance:textfield
}
.rubrica-tabla input[type=number]:focus{box-shadow:inset 4px 4px 10px var(--sh-dark),inset -4px -4px 10px var(--sh-light),0 0 0 2.5px var(--accent)}
.rubrica-tabla input::-webkit-outer-spin-button,.rubrica-tabla input::-webkit-inner-spin-button{-webkit-appearance:none}

/* Card grande del promedio en vivo */
.live-card{
  background:linear-gradient(135deg,var(--accent),var(--accent-dk));
  border-radius:var(--card-r);padding:24px 28px;
  box-shadow:6px 6px 20px var(--acc-sh1),-3px -3px 12px var(--acc-sh2);
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  margin-bottom:0
}
.live-card-left .live-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.75);margin-bottom:4px}
.live-card-left .live-num{font-size:56px;font-weight:900;color:#fff;line-height:1;letter-spacing:-2px}
.live-card-left .live-sub{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px}
.live-card-right{text-align:right}
.live-prog-label{font-size:11px;color:rgba(255,255,255,.7);margin-bottom:6px}
.live-prog-bar{width:120px;height:8px;border-radius:50px;background:rgba(255,255,255,.25);overflow:hidden}
.live-prog-fill{height:100%;border-radius:50px;background:#fff;transition:width .3s}

/* Info grupo tabla compacta */
.tabla-info{width:auto;min-width:100%}
.tabla-info th{background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;font-size:11px;text-transform:uppercase;letter-spacing:.8px;padding:8px 14px;white-space:nowrap}
.tabla-info td{font-weight:600;padding:8px 16px;background:var(--bg);border-bottom:1px solid rgba(196,192,203,.3)}
.tabla-info tr:last-child td{border-bottom:none}
.tabla-info th:first-child{border-radius:var(--radius) 0 0 0}
.tabla-info tr:last-child th{border-radius:0 0 0 var(--radius)}
.tabla-info tr:last-child td{border-radius:0 0 var(--radius) 0}

/* ─── VISTA DETALLE (J1/J2/J3 + total) ─── */
.eval-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px;margin-bottom:20px}
.eval-juez-card{
  background:var(--bg);border-radius:var(--card-r);box-shadow:var(--neu-up);
  padding:22px 18px;text-align:center;position:relative;overflow:hidden
}
.eval-juez-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--lila),var(--accent))}
.eval-juez-card.pend::before{background:var(--sh-dark)}
.ej-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-soft);margin-bottom:10px}
.ej-score{
  font-size:38px;font-weight:900;line-height:1;
  background:linear-gradient(135deg,var(--lila),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.ej-score.pend{font-size:18px;background:none;-webkit-text-fill-color:var(--text-xs);color:var(--text-xs);font-weight:500}
.eval-total-card{
  background:linear-gradient(135deg,var(--lila),var(--lila-dk));
  border-radius:var(--card-r);padding:22px 28px;text-align:center;
  box-shadow:6px 6px 18px rgba(122,95,160,.4),-3px -3px 10px var(--sh-light)
}
.et-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,.75);margin-bottom:4px}
.et-num{font-size:52px;font-weight:900;color:#fff;line-height:1;letter-spacing:-2px}
.et-sub{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px}

/* ─── RANKING con calificaciones ─── */
.tabla-ranking thead th{background:linear-gradient(135deg,var(--accent),var(--accent-dk))}
.medalla{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;font-size:16px}
.m1{background:linear-gradient(135deg,#FFD700,#FFA500);color:#fff;box-shadow:0 2px 8px rgba(255,165,0,.5)}
.m2{background:linear-gradient(135deg,#C0C0C0,#888);color:#fff;box-shadow:0 2px 8px rgba(136,136,136,.4)}
.m3{background:linear-gradient(135deg,#CD7F32,#a05a1e);color:#fff;box-shadow:0 2px 8px rgba(160,90,30,.4)}
.mn{background:var(--bg);color:var(--text-soft);box-shadow:2px 2px 6px var(--sh-dark),-2px -2px 6px var(--sh-light);font-size:12px;font-weight:700}
.chip-final{
  display:inline-block;padding:5px 14px;border-radius:50px;font-size:14px;font-weight:800;
  background:linear-gradient(135deg,var(--accent),var(--accent-dk));color:#fff;
  box-shadow:2px 2px 6px rgba(200,136,14,.35)
}
.chip-j{
  display:inline-block;padding:3px 10px;border-radius:50px;font-size:12px;font-weight:700;
  background:var(--bg);color:var(--lila);
  box-shadow:2px 2px 6px var(--sh-dark),-2px -2px 6px var(--sh-light);margin-right:3px
}
.chip-j.pend{color:var(--text-xs)}

/* ─── FORMULARIOS ─── */
.campo{margin-bottom:18px;display:flex;flex-direction:column;gap:6px}
.campo label{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--lila)}
.campo input,.campo select{
  padding:12px 16px;border:none;border-radius:var(--radius);font-size:14px;
  font-family:inherit;color:var(--text);background:var(--bg);box-shadow:var(--neu-in);
  outline:none;transition:box-shadow .2s;width:100%;-webkit-appearance:none;appearance:none
}
.campo input:focus,.campo select:focus{box-shadow:inset 4px 4px 10px var(--sh-dark),inset -4px -4px 10px var(--sh-light),0 0 0 2.5px var(--accent)}
.form-grupo{max-width:500px}

/* ─── ESTADOS ─── */
.loading-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}
.spinner{width:40px;height:40px;border-radius:50%;border:3px solid var(--sh-dark);border-top-color:var(--accent);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:48px 20px;color:var(--text-soft)}
.empty-state .ei{font-size:48px;margin-bottom:12px;opacity:.5}
.empty-state p{font-size:14px;margin-bottom:20px}

/* Toast */
#msg{
  display:none;position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--bg);color:var(--text);padding:12px 28px;font-size:14px;font-weight:600;
  z-index:9999;border-radius:50px;box-shadow:var(--neu-up);white-space:nowrap;border-left:4px solid var(--accent)
}
#msg.error{border-left-color:#c0392b;color:#c0392b}

/* ─── LOGIN (sin cambios) ─── */
body.login-page{background:var(--bg);min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-main{width:100%;padding:20px;display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{display:flex;flex-direction:row;width:100%;max-width:860px;min-height:520px;border-radius:30px;overflow:hidden;box-shadow:14px 14px 36px var(--sh-dark),-14px -14px 36px var(--sh-light);border-top:5px solid var(--accent)}
.login-left{flex:1.1;background:linear-gradient(145deg,#ddd8e8 0%,#e8e4ef 50%,#d8d2e2 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 36px;position:relative;box-shadow:inset -6px 0 16px rgba(196,192,203,.5)}
.login-left::before{content:'★ ★ ★';position:absolute;top:24px;font-size:11px;color:var(--accent);opacity:.3;letter-spacing:8px}
.login-left::after{content:'★ ★ ★';position:absolute;bottom:24px;font-size:11px;color:var(--lila);opacity:.25;letter-spacing:8px}
.login-logo{width:100%;max-width:320px;height:auto;object-fit:contain;filter:drop-shadow(0 12px 30px rgba(156,127,192,.4)) drop-shadow(0 4px 10px rgba(245,166,35,.25));animation:float 4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.login-tagline{margin-top:22px;font-size:12px;color:var(--text-soft);text-align:center;letter-spacing:1.2px;text-transform:uppercase}
.login-right{flex:1;display:flex;flex-direction:column;justify-content:center;padding:52px 44px;background:var(--bg)}
.login-title{font-size:30px;font-weight:800;color:var(--text);text-align:center;margin-bottom:6px;letter-spacing:2px;text-transform:uppercase}
.login-sub{font-size:13px;color:var(--text-soft);text-align:center;margin-bottom:34px}
.login-req{display:none}
.login-campo{margin-bottom:20px;position:relative}
.login-campo label{display:block;font-size:11px;font-weight:700;color:var(--lila);margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}
.login-input{width:100%;padding:15px 18px;border:none;border-radius:14px;font-size:14px;font-family:inherit;color:var(--text);outline:none;background:var(--bg);box-shadow:inset 4px 4px 10px var(--sh-dark),inset -4px -4px 10px var(--sh-light);transition:box-shadow .2s}
.login-input:focus{box-shadow:inset 5px 5px 12px var(--sh-dark),inset -5px -5px 12px var(--sh-light),0 0 0 2.5px var(--accent)}
.login-input::placeholder{color:var(--text-xs);font-size:13px}
.login-pass-wrap{position:relative}
.login-pass-wrap .login-input{padding-right:50px}
.login-eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-soft);padding:4px;display:flex;align-items:center}
.login-eye:hover{color:var(--lila);background:none}
.login-error{color:#c0392b;font-size:13px;text-align:center;margin-bottom:8px;min-height:18px}
.login-btn-primary{width:100%;padding:16px;margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:50px;font-size:15px;font-weight:800;font-family:inherit;cursor:pointer;letter-spacing:2px;text-transform:uppercase;box-shadow:5px 5px 16px var(--acc-sh1),-3px -3px 10px var(--acc-sh2);transition:all .2s}
.login-btn-primary:hover{background:var(--accent-dk);color:#fff}
.login-btn-primary:active{transform:scale(.97)}

/* ─── RESPONSIVE ─── */
@media(max-width:680px){
  .login-card{flex-direction:column;max-width:400px;min-height:unset;border-radius:26px}
  .login-left{padding:36px 24px 28px;box-shadow:none}
  .login-left::before,.login-left::after{display:none}
  .login-logo{max-width:200px;animation:none}
  .login-right{padding:28px 24px 36px}
  .login-title{font-size:24px}
}
@media(max-width:768px){
  #sidebar{display:none!important}
  #main{padding:16px 12px}
  .sec{padding:16px}
  .rubrica-tabla input[type=number]{width:74px}
  table{font-size:12px}
  thead th,tbody td{padding:8px 8px}
  .grid-bloques{grid-template-columns:repeat(2,1fr);gap:12px}
  .eval-grid{grid-template-columns:1fr 1fr}
  .live-card{flex-direction:column;text-align:center}
  .live-card-right{text-align:center}
  .live-prog-bar{margin:0 auto}
}
