/* ===== body global (páginas normales como lineup) ===== */
body{
  margin:0;
  background: var(--bg, #0f1115);
  color: var(--text, #e6eaf2);
  font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto;
  position: relative;           /* sin flex aquí */
}

/* ===== SOLO login ===== */
.login-page{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  --bg-url: none;
}

/* Fondo con imagen — SOLO login */
.login-page::before{
  content:"";
  position:fixed; inset:0;
  background-image: var(--bg-url);
  background-size: cover;
  background-position: center;
  z-index:-2;
}

/* Oscurecido — SOLO login */
.login-page::after{
  content:"";
  position:fixed; inset:0;
  background: rgba(0,0,0,.55);
  z-index:-1;
}

/* Card estilo glass — SOLO login */
.login-page .card{
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.15);
  color:#fff;
  box-shadow:0 4px 30px rgba(0,0,0,.4);
}
.login-page .card h1,
.login-page .card p,
.login-page .card label { color:#fff; }


:root{--bg:#0f1115;--card:#171a21;--text:#e6eaf2;--muted:#98a2b3;--accent:#4f46e5;--accent-2:#7c3aed;--line:#222733}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font:16px/1.5 system-ui,-apple-system,Segoe UI,Roboto}
.container{max-width:1100px;margin:40px auto;padding:0 16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px}
.topbar{position:sticky;top:0;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);background:linear-gradient(0deg,rgba(15,17,21,.7),rgba(15,17,21,.9));backdrop-filter:blur(6px)}
.brand{font-weight:700}
.form{display:grid;gap:12px;margin-top:10px}
input,select,button{padding:10px 12px;border-radius:10px;border:1px solid var(--line);background:#0c0f14;color:var(--text)}
button{cursor:pointer;background:var(--accent);border-color:transparent}
button:hover{filter:brightness(1.1)}
button.ghost{background:transparent;border:1px solid var(--line)}
.alert{background:#2a1224;border:1px solid #80355d;color:#ffd6e7;border-radius:10px;padding:10px;margin:10px 0}
.muted{color:var(--muted)}
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.tile{position:relative;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:8px;overflow:hidden}
/* Marca de agua con el logo del canal */
.tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--bg-logo);
  background-repeat: no-repeat;
  background-position: center;      /* lo centramos */
  background-size: 160px auto;      /* más pequeño */
  opacity: 0.10;                     /* más tenue */
  pointer-events: none;
  filter: saturate(1.2) contrast(1.15);
}
.tile-header{position:relative;z-index:1;display:flex;align-items:center;gap:8px}
.badge{background:var(--accent-2);padding:4px 8px;border-radius:999px;font-size:12px}
.pill{display:inline-block;border:1px solid var(--line);border-radius:999px;padding:2px 8px;margin-right:6px;font-size:12px;color:var(--muted)}
.logo{width:28px;height:28px;object-fit:contain;border-radius:6px;background:#0c0f14;border:1px solid var(--line);padding:2px}


/* Estados por sucursal: mantenimiento / falla */
.is-maint { border-color: #eab308 !important; box-shadow: 0 0 0 1px rgba(234,179,8,.35) inset; }
.is-down  { border-color: #ef4444 !important; box-shadow: 0 0 0 1px rgba(239,68,68,.35) inset; }

/* Píldoras de estado en el header */
.st{
  margin-left: 8px;
  font-size: 12px;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.25);
}
.st-maint{ border-color:#eab308; color:#eab308; }
.st-down { border-color:#ef4444; color:#ef4444; }

/* Parpadeo */
@keyframes blink {
  0%, 100% { opacity: .35; }
  50%      { opacity: 1; }
}
.blink { animation: blink 1.1s infinite; }

.card h1 {
    text-align: center;
}

/* Botón Ver */
.mini.watch-btn{
  margin-left:auto; background:#4f46e5; color:#fff; border:none;
  border-radius:999px; padding:6px 10px; font-size:12px; cursor:pointer;
}
.mini.watch-btn:hover{ opacity:.9 }

/* ===== Modal Player pequeño y centrado ===== */
.modal[hidden]{ display:none !important }
.modal{
  position:fixed; inset:0; z-index:1000;
  display:grid; place-items:center;
}
.modal-backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(2px);
}
.player-box{
  position:relative; z-index:1;
  width:min(620px, 92vw);               /* tamaño del cuadro */
  background:#0f131a; border:1px solid #1e2633;
  border-radius:14px; padding:12px;
  box-shadow:0 10px 40px rgba(0,0,0,.55);
}
.player-top{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-bottom:8px }
.player-top #playerTitle{ color:#e8eef9; font-weight:700 }
.player-media{ width:100%; aspect-ratio:16/9; background:#000; border-radius:10px; overflow:hidden }
.player-media video{ width:100%; height:100%; display:block }
.player-tip{ margin-top:8px; font-size:12px }

/* Bloquear scroll del fondo cuando el modal está abierto */
body.modal-open{ overflow:hidden }