*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#08080f;--card:#0f0f1a;--cyan:#00d4ff;--red:#ef4444;--green:#34d399;--text:#f0f0f8;--mute:rgba(255,255,255,.5);--border:rgba(255,255,255,.08)}
html,body{min-height:100vh;background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;-webkit-font-smoothing:antialiased}

/* ── Topnav ─────────────────────────────────────────── */
.topnav{position:sticky;top:0;z-index:50;height:54px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 18px;background:rgba(8,8,15,.96);backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.topnav-back{display:flex;align-items:center;gap:6px;font-size:.84rem;font-weight:500;color:var(--mute);text-decoration:none;padding:7px 13px;border-radius:8px;border:1px solid var(--border);transition:all .15s}
.topnav-back:hover{color:#fff;border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.04)}
.topnav-logo{font-size:1.05rem;letter-spacing:-.01em;color:#fff;display:flex;align-items:center;gap:8px}
.topnav-tag{font-size:.62rem;font-weight:700;color:var(--cyan);background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);padding:2px 8px;border-radius:20px;letter-spacing:.08em}
.topnav-user{display:flex;align-items:center;gap:10px;font-size:.78rem;color:rgba(255,255,255,.55)}
.user-name{display:flex;align-items:center;gap:6px}
.admin-pill{font-size:.6rem;font-weight:700;color:var(--cyan);background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.28);padding:1px 7px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}
.logout-btn{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--mute);background:rgba(255,255,255,.04);border:1px solid var(--border);text-decoration:none;transition:all .15s}
.logout-btn:hover{color:var(--red);border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.05)}

/* ── Page ───────────────────────────────────────────── */
.page{max-width:880px;margin:0 auto;padding:28px 20px 80px}
.page-hdr{margin-bottom:24px}
.hdr-back{display:inline-flex;align-items:center;gap:4px;color:var(--mute);text-decoration:none;font-size:.78rem;font-weight:500;margin-bottom:8px}
.hdr-back:hover{color:#fff}
.page-hdr h1{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;letter-spacing:.03em;color:#fff;line-height:1}
.page-hdr p{font-size:.85rem;color:var(--mute);margin-top:6px}

/* ── Login ──────────────────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, rgba(0,212,255,.12) 0%, transparent 65%),
    var(--bg);}
.login-card{width:100%;max-width:380px;background:#0d0d18;border:1px solid var(--border);border-radius:24px;padding:32px 28px;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.login-logo{text-align:center;font-family:'Bebas Neue',sans-serif;font-size:2.4rem;letter-spacing:.04em;color:#fff;line-height:1;margin-bottom:6px}
.login-sub{font-family:'Inter',sans-serif;font-size:.74rem;font-weight:500;color:var(--mute);text-transform:uppercase;letter-spacing:.12em;margin-top:6px;margin-bottom:24px}
.login-form{display:flex;flex-direction:column;gap:14px}
.login-field{display:flex;flex-direction:column;gap:5px}
.login-field span{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--mute)}
.login-field input{background:#16162a;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;font-size:.95rem;color:#fff;outline:none;font-family:'Inter',sans-serif;transition:border-color .15s}
.login-field input:focus{border-color:rgba(0,212,255,.55);box-shadow:0 0 0 3px rgba(0,212,255,.07)}
.login-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--cyan);color:#000;font-weight:700;font-size:.95rem;padding:13px;border:none;border-radius:12px;cursor:pointer;font-family:'Inter',sans-serif;margin-top:6px;transition:transform .12s}
.login-btn:hover{transform:translateY(-1px)}
.login-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:10px 14px;border-radius:10px;font-size:.82rem}

/* ── Empty / Alert ──────────────────────────────────── */
.empty-state{text-align:center;padding:50px 20px;border:1.5px dashed var(--border);border-radius:16px}
.empty-title{font-size:.95rem;font-weight:600;color:rgba(255,255,255,.45);margin-bottom:4px}
.empty-sub{font-size:.78rem;color:rgba(255,255,255,.22)}
.alert{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.3);color:#fcd34d;padding:14px 18px;border-radius:14px;font-size:.85rem;margin-bottom:24px}
.info-pill{display:inline-block;background:rgba(0,212,255,.06);border:1px solid rgba(0,212,255,.25);color:#67e8f9;padding:8px 14px;border-radius:20px;font-size:.78rem;margin-bottom:24px}
.info-pill code{background:rgba(0,212,255,.12);padding:1px 6px;border-radius:4px;font-family:'JetBrains Mono',monospace;font-size:.74rem}

/* ── Error banner ───────────────────────────────────── */
.error-banner{display:flex;align-items:flex-start;gap:12px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.35);color:#fca5a5;padding:14px 18px;border-radius:14px;font-size:.85rem;margin-bottom:24px}
.error-banner svg{flex-shrink:0;color:#ef4444;margin-top:2px}
.err-body{flex:1;min-width:0}
.err-title{font-weight:700;color:#f87171;font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.err-msg{color:#fca5a5;line-height:1.4;word-break:break-word}
.err-time{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:rgba(252,165,165,.5);margin-top:4px}

/* ── Cam pill ───────────────────────────────────────── */
.cam-pill{font-size:.66rem;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.04em;text-transform:uppercase}
.cam-pill.ok{background:rgba(52,211,153,.1);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.cam-pill.offline{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.4);animation:blink .9s ease-in-out infinite}

/* ── Live (canchas grabando) ────────────────────────── */
.live-section{margin-bottom:32px}
.live-hdr{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.live-hdr h2{font-family:'Bebas Neue',sans-serif;font-size:1.3rem;letter-spacing:.04em;color:#fff;font-weight:400}
.live-pulse{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 10px rgba(239,68,68,.8);animation:blink .7s ease-in-out infinite;flex-shrink:0}
.live-count{font-family:'JetBrains Mono',monospace;font-size:.7rem;font-weight:700;color:var(--red);background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);padding:2px 9px;border-radius:20px;letter-spacing:.04em}
.live-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.live-card{display:flex;flex-direction:column;gap:6px;padding:14px 16px;background:linear-gradient(135deg,rgba(239,68,68,.06) 0%,rgba(15,15,26,.6) 100%);border:1.5px solid rgba(239,68,68,.28);border-radius:14px;color:#fff;text-decoration:none;transition:all .18s}
.live-card:hover{border-color:rgba(239,68,68,.55);transform:translateY(-2px);box-shadow:0 8px 24px rgba(239,68,68,.12)}
.live-top{display:flex;align-items:center;gap:7px;font-family:'JetBrains Mono',monospace;font-size:.85rem;font-weight:700}
.live-top .rec-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 8px rgba(239,68,68,.7);animation:blink .7s infinite;flex-shrink:0}
.live-time{color:var(--red)}
.live-sep,.live-tot{color:rgba(255,255,255,.35)}
.live-name{font-size:.95rem;font-weight:700;color:#fff;margin-top:2px}
.live-club{font-size:.72rem;color:var(--mute)}

/* ── Clubs grid ─────────────────────────────────────── */
.clubs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.club-card,.cancha-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;text-decoration:none;color:#fff;transition:all .18s}
.club-card:hover,.cancha-card:hover{border-color:rgba(0,212,255,.3);background:rgba(0,212,255,.03);transform:translateY(-2px)}
.club-icon,.cancha-ico{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.05);border:1px solid var(--border);font-size:1.5rem;flex-shrink:0}
.club-info,.cancha-info{flex:1;min-width:0}
.club-name,.cancha-name{font-size:.95rem;font-weight:700;color:#fff;margin-bottom:3px}
.club-meta,.cancha-meta{font-size:.74rem;color:var(--mute)}
.club-arrow{color:rgba(255,255,255,.25);flex-shrink:0}

/* ── Canchas grid ───────────────────────────────────── */
.canchas-grid{display:flex;flex-direction:column;gap:10px}

/* ── Cancha page (REC panel) ────────────────────────── */
.rec-page{max-width:680px}
.sec-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--mute);margin-bottom:12px}

.dur-section{margin-bottom:32px}
.dur-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.dur-btn{display:flex;flex-direction:column;align-items:center;gap:1px;padding:14px 8px;background:var(--card);border:1.5px solid var(--border);border-radius:14px;color:rgba(255,255,255,.6);cursor:pointer;font-family:'Inter',sans-serif;transition:all .15s}
.dur-btn:hover:not(:disabled){border-color:rgba(0,212,255,.3);color:#fff}
.dur-btn.sel{background:rgba(0,212,255,.1);border-color:var(--cyan);color:var(--cyan)}
.dur-btn:disabled{opacity:.35;cursor:not-allowed}
.dur-num{font-family:'Bebas Neue',sans-serif;font-size:1.7rem;letter-spacing:.03em;line-height:1}
.dur-lbl{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}

/* ── REC button ─────────────────────────────────────── */
.rec-section{display:flex;flex-direction:column;align-items:center;gap:18px;padding:36px 20px;background:linear-gradient(180deg,rgba(15,15,26,.5) 0%,rgba(15,15,26,0) 100%);border:1.5px solid var(--border);border-radius:24px;margin-bottom:24px}
.rec-state{display:flex;align-items:center;gap:9px;font-size:.78rem;font-weight:600;color:var(--mute);text-transform:uppercase;letter-spacing:.08em}
.rec-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.2)}
.rec-dot.on{background:var(--red);animation:blink .7s ease-in-out infinite;box-shadow:0 0 12px rgba(239,68,68,.7)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.rec-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:160px;height:160px;border-radius:50%;border:3px solid;cursor:pointer;font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:.05em;transition:all .25s;-webkit-tap-highlight-color:transparent}
.rec-btn.off{border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.06);color:#ef4444}
.rec-btn.off:not(:disabled):hover{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.8);transform:scale(1.04);box-shadow:0 0 32px rgba(239,68,68,.3)}
.rec-btn.on{border-color:rgba(239,68,68,.9);background:rgba(239,68,68,.18);color:#fff;animation:pulseRing 1.4s ease-in-out infinite}
@keyframes pulseRing{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.5)}50%{box-shadow:0 0 0 14px rgba(239,68,68,0)}}
.rec-btn:disabled{opacity:.4;cursor:not-allowed;animation:none}
.rec-btn svg{flex-shrink:0}

.rec-time{display:flex;align-items:baseline;gap:9px;font-family:'JetBrains Mono',monospace;font-size:1.4rem;font-weight:700;color:#fff}
.rt-elapsed{color:var(--red)}
.rt-sep{font-size:.74rem;color:var(--mute);text-transform:uppercase}
.rt-total{color:var(--mute)}

.links-section{display:flex;flex-direction:column;gap:10px}
.link-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius:12px;color:#fff;text-decoration:none;font-size:.88rem;transition:all .15s}
.link-card:hover{border-color:rgba(0,212,255,.3);background:rgba(0,212,255,.03)}

/* ── Videos list ────────────────────────────────────── */
.videos-list{display:flex;flex-direction:column;gap:8px}
.video-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:11px}
.video-row.inactive{opacity:.4}
.vr-date{display:flex;flex-direction:column;min-width:120px}
.vr-fecha{font-size:.84rem;font-weight:600;color:#fff}
.vr-hora{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--mute)}
.vr-info{flex:1;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.vr-estado{font-size:.64rem;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:20px;letter-spacing:.06em}
.vr-est-disponible{background:rgba(52,211,153,.1);color:#34d399;border:1px solid rgba(52,211,153,.3)}
.vr-est-descargando{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.3);animation:blink 1s infinite}
.vr-est-pendiente,.vr-est-procesando{background:rgba(245,158,11,.1);color:#fbbf24;border:1px solid rgba(245,158,11,.3)}
.vr-est-error{background:rgba(239,68,68,.15);color:#f87171;border:1px solid rgba(239,68,68,.4)}
.vr-file{font-size:.8rem;opacity:.55}
.vr-deleted{font-size:.65rem;color:var(--mute);font-style:italic}
.vr-play{width:32px;height:32px;border-radius:50%;background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.3);color:var(--cyan);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .15s;flex-shrink:0}
.vr-play:hover{background:var(--cyan);color:#000;transform:scale(1.08)}
.vr-play svg{margin-left:2px}
.vr-del{width:30px;height:30px;border-radius:50%;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#f87171;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.vr-del:hover:not(:disabled){background:rgba(239,68,68,.2);border-color:rgba(239,68,68,.6)}
.vr-del:disabled{opacity:.5;cursor:wait}

@media(max-width:600px){
  .rec-btn{width:140px;height:140px;font-size:1.4rem}
  .dur-grid{grid-template-columns:repeat(3,1fr)}
  .topnav-tag{display:none}
  .vr-date{min-width:auto}
}
