:root{--verde:#1a7a3c;--verde-cl:#23a352;--dorado:#c9a227;--rojo:#c0392b;--azul:#1a56a0;--gris:#f4f5f7;--borde:#e0e0e0;--texto:#1a1a1a;--texto-cl:#555;--shadow:0 2px 8px rgba(0,0,0,.08);--radius:12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,sans-serif;background:#f0f2f5;color:var(--texto)}nav{background:linear-gradient(135deg,#0d5c2a,#1a7a3c);color:#fff;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px #0003}.nav-logo{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:.5rem}.nav-links{display:flex;gap:.25rem;align-items:center}.nav-link{color:#ffffffd9;text-decoration:none;padding:.4rem .8rem;border-radius:6px;font-size:.9rem;transition:all .2s}.nav-link:hover,.nav-link.active{background:#ffffff26;color:#fff}.nav-link.registro{background:var(--dorado);color:#000;font-weight:600}.nav-user{font-size:.85rem;opacity:.9;padding:0 .5rem}.btn-logout{background:#ffffff26;color:#fff;border:none;padding:.35rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem}main{max-width:1100px;margin:0 auto;padding:1.5rem 1rem}.filtros{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.filtro-btn{padding:.4rem 1rem;border:2px solid var(--borde);background:#fff;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .2s}.filtro-btn.activo{background:var(--verde);color:#fff;border-color:var(--verde)}.partidos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem}.partido-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);border:1px solid var(--borde);transition:transform .2s,box-shadow .2s}.partido-card.finalizado{border-left:4px solid var(--verde)}.partido-fase{font-size:.7rem;text-transform:uppercase;font-weight:600;color:var(--texto-cl);letter-spacing:.05em;margin-bottom:.3rem}.partido-fecha{font-size:.8rem;color:var(--texto-cl);margin-bottom:.75rem}.partido-equipos{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.75rem}.equipo{display:flex;align-items:center;gap:.4rem;flex:1}.equipo-derecha{flex-direction:row-reverse;text-align:right}.bandera{font-size:1.4rem}.bandera-img{width:32px;height:24px;object-fit:cover;border-radius:3px;box-shadow:0 1px 2px #0003;flex-shrink:0}.nombre-equipo{font-size:.8rem;font-weight:600;line-height:1.15;word-break:break-word}.marcador-center{text-align:center;min-width:60px}.resultado-final{font-size:1.5rem;font-weight:800;color:var(--verde)}.vs{font-size:.9rem;color:var(--texto-cl);font-weight:600}.estadio{font-size:.75rem;color:var(--texto-cl);margin-bottom:.75rem}.prediccion-form{border-top:1px solid var(--borde);padding-top:.75rem}.pred-label{font-size:.78rem;font-weight:600;color:var(--texto-cl);margin-bottom:.4rem}.pred-inputs{display:flex;align-items:center;gap:.5rem}.pred-input{width:52px;text-align:center;padding:.4rem;border:2px solid var(--borde);border-radius:8px;font-size:1rem;font-weight:700}.pred-input:focus{outline:none;border-color:var(--verde)}.pred-sep{font-size:1.2rem;font-weight:700;color:var(--texto-cl)}.btn-guardar{margin-left:auto;background:var(--verde);color:#fff;border:none;border-radius:8px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer}.btn-guardar:disabled{opacity:.5}.pred-msg{font-size:.8rem;margin-top:.4rem}.pred-msg.ok{color:var(--verde)}.pred-msg.error{color:var(--rojo)}.prediccion-resultado{border-top:1px solid var(--borde);padding-top:.75rem;display:flex;align-items:center;justify-content:space-between}.pred-mostrar{font-size:.85rem;color:var(--texto-cl)}.badge{font-size:.78rem;font-weight:700;padding:.25rem .6rem;border-radius:20px}.badge-exacto{background:#d4edda;color:#155724}.badge-tendencia{background:#fff3cd;color:#856404}.badge-fallo{background:#f8d7da;color:#721c24}.sin-prediccion{border-top:1px solid var(--borde);padding-top:.75rem;font-size:.8rem;color:#aaa}.tabla-header{text-align:center;margin-bottom:1.5rem}.tabla-header h1{font-size:1.8rem;font-weight:800;color:var(--verde)}.tabla-sub{color:var(--texto-cl);font-size:.9rem;margin-top:.25rem}.tabla-wrapper{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.tabla-liga{width:100%;border-collapse:collapse}.tabla-liga thead{background:var(--verde);color:#fff}.tabla-liga th{padding:.85rem 1rem;text-align:center;font-size:.85rem;font-weight:600}.col-nombre{text-align:left!important}.col-pos{width:50px}.col-pts{color:var(--dorado)}.tabla-liga td{padding:.75rem 1rem;text-align:center;font-size:.9rem;border-bottom:1px solid var(--borde)}.tabla-liga tbody tr:hover{background:var(--gris)}.fila-yo{background:#e8f5e9!important;font-weight:600}.badge-yo{background:var(--verde);color:#fff;font-size:.65rem;padding:.1rem .4rem;border-radius:10px;margin-left:.4rem}.col-pts strong{font-size:1.05rem;color:var(--verde)}.leyenda{display:flex;gap:1.5rem;justify-content:center;margin-top:1rem;font-size:.82rem;color:var(--texto-cl)}.auth-page{display:flex;justify-content:center;padding:2rem 1rem;min-height:70vh}.auth-card{background:#fff;border-radius:var(--radius);padding:2rem;width:100%;max-width:500px;box-shadow:0 4px 24px #0000001a}.auth-logo{text-align:center;font-size:1.1rem;font-weight:700;color:var(--verde);margin-bottom:1rem}.auth-card h2{text-align:center;font-size:1.5rem;margin-bottom:.25rem}.auth-sub{text-align:center;color:var(--texto-cl);font-size:.9rem;margin-bottom:1.5rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group label{font-size:.85rem;font-weight:600}.form-group input{padding:.6rem .9rem;border:2px solid var(--borde);border-radius:8px;font-size:.95rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--verde)}.field-error{font-size:.78rem;color:var(--rojo)}.field-hint{font-size:.76rem;color:var(--texto-cl)}.error-box{background:#fde8e8;color:var(--rojo);padding:.75rem;border-radius:8px;font-size:.9rem;margin-bottom:.5rem}.btn-primary{background:var(--verde);color:#fff;border:none;border-radius:10px;padding:.75rem;font-size:1rem;font-weight:700;cursor:pointer;margin-top:.5rem}.btn-primary:disabled{opacity:.6}.auth-footer{text-align:center;font-size:.85rem;color:var(--texto-cl);margin-top:1rem}.auth-footer a{color:var(--verde);font-weight:600;text-decoration:none}.exito{text-align:center}.exito-icon{font-size:3rem;margin-bottom:1rem}.serial-group{background:linear-gradient(135deg,#f0fdf4,#e8f5e9);border:2px solid #a5d6a7;border-radius:10px;padding:1rem;margin-bottom:.5rem}.serial-group label{color:var(--verde);font-size:.95rem}.form-divider{text-align:center;font-size:.78rem;font-weight:600;color:var(--texto-cl);letter-spacing:.05em;text-transform:uppercase;border-top:1px solid var(--borde);padding-top:.75rem;margin-top:.25rem}.input-error{border-color:var(--rojo)!important}.reset-pasos{display:flex;justify-content:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--borde)}.reset-paso{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex:1}.paso-circulo{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;background:var(--borde);color:var(--texto-cl);transition:all .3s}.reset-paso.activo .paso-circulo{background:var(--verde);color:#fff}.reset-paso.completo .paso-circulo{background:#23a352;color:#fff}.reset-paso span{font-size:.72rem;color:var(--texto-cl)}.input-codigo{font-size:1.8rem!important;letter-spacing:.5rem;text-align:center;font-weight:800!important;padding:.75rem!important}.reenvio-container{text-align:center;margin-top:.75rem}.reenvio-timer{font-size:.85rem;color:var(--texto-cl)}.btn-link{background:none;border:none;color:var(--verde);cursor:pointer;font-size:.85rem;text-decoration:underline;padding:0}.mt-sm{margin-top:.5rem;display:block}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.admin-header h1{font-size:1.5rem;font-weight:800}.btn-sync{background:var(--azul);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-weight:600}.sync-msg{background:#d4edda;color:#155724;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem}.admin-tabla{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.admin-partidos{width:100%;border-collapse:collapse;font-size:.9rem}.admin-partidos th{padding:.75rem;text-align:left;background:var(--gris);font-size:.8rem;font-weight:700;text-transform:uppercase}.admin-partidos td{padding:.75rem;border-bottom:1px solid var(--borde)}.resultado-inputs{display:flex;align-items:center;gap:.5rem}.input-gol{width:48px;text-align:center;padding:.3rem;border:2px solid var(--borde);border-radius:6px;font-weight:700;font-size:1rem}.btn-sm{padding:.35rem .75rem;border:none;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600}.btn-sorteo{background:var(--dorado);color:#000}.row-finalizado td{background:#f9fffe}.badge-estado{padding:.25rem .6rem;border-radius:12px;font-size:.78rem;font-weight:600}.badge-estado.finalizado{background:#d4edda;color:#155724}.badge-estado.pendiente{background:#fff3cd;color:#856404}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.modal-sorteo{background:#fff;border-radius:var(--radius);padding:2rem;width:90%;max-width:650px;max-height:85vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-sorteo h2{margin-bottom:1rem}.tabla-participantes{width:100%;border-collapse:collapse;font-size:.88rem;margin-bottom:1rem}.tabla-participantes th{padding:.5rem;background:var(--gris);text-align:left}.tabla-participantes td{padding:.5rem;border-bottom:1px solid var(--borde)}.row-ganador td{background:#fffde7;font-weight:600}.sorteo-action{display:flex;gap:.75rem;margin:1rem 0}.input-premio{flex:1;padding:.6rem .9rem;border:2px solid var(--borde);border-radius:8px}.ganador-box{text-align:center;background:linear-gradient(135deg,#fffde7,#fff9c4);border-radius:12px;padding:1.5rem;margin:1rem 0}.ganador-emoji{font-size:2.5rem;margin-bottom:.5rem}.btn-cerrar{width:100%;padding:.6rem;background:var(--gris);border:none;border-radius:8px;cursor:pointer;font-weight:600;margin-top:.5rem}.loading{text-align:center;padding:3rem;color:var(--texto-cl)}@media (max-width:640px){.form-row{grid-template-columns:1fr}.nav-links{gap:0}.nav-link{padding:.35rem .5rem;font-size:.8rem}.leyenda{flex-direction:column;align-items:center}}.premio-cfg{display:flex;align-items:center;gap:.4rem}.premio-check{display:flex;align-items:center;gap:.25rem;font-size:.82rem;cursor:pointer}.input-num-premios{width:48px;text-align:center;padding:.3rem;border:2px solid var(--borde);border-radius:6px;font-weight:700}.sorteo-cantidad{display:flex;align-items:center;gap:.4rem;font-size:.85rem}.tombola{text-align:center;background:linear-gradient(135deg,#1a7a3c,#23a352);border-radius:12px;padding:2rem;margin:1rem 0;color:#fff}.tombola-label{font-size:1rem;font-weight:600;margin-bottom:.5rem;opacity:.9}.tombola-nombre{font-size:2rem;font-weight:800;min-height:2.5rem;letter-spacing:.02em;animation:pulso .3s infinite alternate}@keyframes pulso{0%{transform:scale(1)}to{transform:scale(1.05)}}.ganadores-box{text-align:center;background:linear-gradient(135deg,#fffde7,#fff9c4);border-radius:12px;padding:1.5rem;margin:1rem 0}.ganador-item{font-size:1.1rem;padding:.5rem;border-bottom:1px solid rgba(0,0,0,.08)}.ganador-item span{color:var(--texto-cl);font-size:.9rem;margin-left:.5rem}.aviso-privado{background:#fff3cd;color:#856404;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.88rem;border:1px solid #ffeaa7}.link-tel{color:var(--verde);text-decoration:none;font-weight:600}.link-tel:hover{text-decoration:underline}
