:root{
  /* P2PRO TV brand palette — púrpura profundo + cyan eléctrico + naranja vivo */
  --bg:#0e0a1f;          /* púrpura noche (del logo) */
  --bg-2:#120d28;
  --surface:#1a1338;
  --surface-2:#231a47;
  --surface-3:#2d2258;
  --line:#2a2152;
  --line-2:#3a2f6b;
  --ink:#f3f0ff;
  --ink-2:#b4abd4;
  --ink-3:#7d749e;
  --ink-4:#54496e;
  --brand:#ff7a1a;       /* naranja del logo (CTA principal) */
  --brand-2:#ff9d4d;
  --brand-soft:rgba(255,122,26,.13);
  --brand-glow:rgba(255,122,26,.45);
  --cyan:#3eb8ff;        /* cyan eléctrico del logo (live/info) */
  --cyan-2:#7dd3fc;
  --cyan-soft:rgba(62,184,255,.12);
  --cyan-glow:rgba(62,184,255,.4);
  --ok:#34d399;
  --warn:#fbbf24;
  --bad:#f87171;
  --info:#3eb8ff;
  --shadow-sm:0 1px 3px rgba(0,0,0,.4);
  --shadow-md:0 8px 24px rgba(14,10,31,.5);
  --r-sm:8px;
  --r-md:12px;
  --r-lg:16px;
  --r-xl:20px;
}

/* subtle mesh pattern (del logo) en el fondo */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.18;
  background-image:
    linear-gradient(rgba(125,211,252,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(125,211,252,.06) 1px,transparent 1px),
    radial-gradient(circle at 20% 30%,rgba(62,184,255,.12),transparent 50%),
    radial-gradient(circle at 80% 80%,rgba(255,122,26,.08),transparent 50%);
  background-size:40px 40px,40px 40px,100% 100%,100% 100%;
}
.app{position:relative;z-index:1}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:'Inter',sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;height:100%}
.num{font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
a{color:inherit;text-decoration:none}

/* ============ LAYOUT ============ */
.app{display:flex;min-height:100vh}

/* ============ DESKTOP SIDEBAR ============ */
.sidebar{
  width:240px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;z-index:20
}
.sb-brand{padding:16px 18px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.sb-logo{width:46px;height:46px;flex-shrink:0;border-radius:11px;overflow:hidden;box-shadow:0 6px 18px rgba(62,184,255,.18),0 0 0 1px rgba(255,255,255,.04)}
.sb-logo img{width:100%;height:100%;display:block;object-fit:cover}
.sb-name{font-weight:800;font-size:15px;letter-spacing:.02em;line-height:1;display:flex;align-items:baseline;gap:3px}
.sb-name .p1{color:var(--cyan-2)}
.sb-name .p2{color:var(--brand-2)}
.sb-tag{font-size:10px;color:var(--ink-3);font-weight:600;text-transform:uppercase;letter-spacing:.14em;margin-top:4px}

.sb-nav{padding:14px 12px;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.sb-section{font-size:11px;font-weight:600;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 6px}
.sb-link{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);
  font-size:14px;color:var(--ink-2);font-weight:500;transition:all .12s
}
.sb-link:hover{background:var(--surface-2);color:var(--ink)}
.sb-link.active{background:linear-gradient(90deg,var(--cyan-soft),var(--brand-soft));color:var(--cyan-2);position:relative}
.sb-link.active::before{content:'';position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,var(--cyan),var(--brand));box-shadow:0 0 8px var(--cyan-glow)}
.sb-link svg{width:18px;height:18px;flex-shrink:0;opacity:.85}
.sb-badge{
  margin-left:auto;font-size:11px;padding:2px 7px;border-radius:10px;
  background:var(--surface-3);color:var(--ink-2);font-weight:600
}
.sb-badge.live{background:rgba(52,211,153,.15);color:var(--ok)}
.sb-badge.warn{background:rgba(251,191,36,.15);color:var(--warn)}

.sb-foot{padding:14px;border-top:1px solid var(--line);display:flex;align-items:center;gap:12px}
.sb-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--cyan),var(--brand));
  display:grid;place-items:center;font-weight:800;color:#fff;font-size:14px;
  box-shadow:0 0 0 2px var(--surface),0 4px 12px rgba(62,184,255,.3)
}
.sb-user{flex:1;min-width:0}
.sb-user .name{font-size:14px;font-weight:600}
.sb-user .role{font-size:11px;color:var(--ink-3)}

/* ============ MAIN ============ */
.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* ============ TOPBAR (desktop) ============ */
.topbar{
  display:flex;align-items:center;gap:16px;padding:14px 28px;
  background:rgba(15,18,24,.85);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10;height:64px
}
.tb-mobile-btn{display:none;width:40px;height:40px;border-radius:var(--r-sm);background:var(--surface-2);align-items:center;justify-content:center;color:var(--ink)}
.tb-search{
  flex:1;max-width:420px;position:relative;display:flex;align-items:center
}
.tb-search input{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:10px;
  padding:10px 14px 10px 38px;color:var(--ink);font-size:14px
}
.tb-search input::placeholder{color:var(--ink-4)}
.tb-search input:focus{outline:none;border-color:var(--cyan);background:var(--surface-2);box-shadow:0 0 0 3px var(--cyan-soft)}
.tb-search svg{position:absolute;left:12px;width:18px;height:18px;color:var(--ink-4);pointer-events:none}
.tb-spacer{flex:1}
.tb-btn{
  width:40px;height:40px;border-radius:var(--r-sm);background:transparent;
  display:grid;place-items:center;color:var(--ink-2);position:relative;transition:all .12s
}
.tb-btn:hover{background:var(--surface-2);color:var(--ink)}
.tb-btn .pip{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--brand);border:2px solid var(--bg)}

.tb-credits{
  display:flex;align-items:center;gap:8px;padding:6px 14px;
  background:linear-gradient(90deg,var(--cyan-soft),var(--brand-soft));
  border:1px solid rgba(62,184,255,.25);border-radius:20px;
  font-size:13px;font-weight:600;color:var(--cyan-2)
}
.tb-credits .label{font-size:11px;font-weight:500;opacity:.8;color:var(--ink-2)}
.tb-credits .num{color:var(--brand-2)}

.tb-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--brand));display:grid;place-items:center;font-weight:800;color:#fff;font-size:13px;box-shadow:0 4px 12px rgba(62,184,255,.25)}

/* ============ CONTENT ============ */
.content{
  padding:28px;max-width:1500px;width:100%;
  display:flex;flex-direction:column;gap:24px;flex:1
}

/* ============ PAGE HEAD ============ */
.greet{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.greet h1{font-size:28px;font-weight:700;letter-spacing:-.025em;line-height:1.2}
.greet h1 .wave{display:inline-block;animation:wave 2.5s ease-in-out infinite}
@keyframes wave{0%,60%,100%{transform:rotate(0)}10%,30%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}}
.greet .sub{color:var(--ink-3);font-size:14px;margin-top:4px}
.greet-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;
  font-size:14px;font-weight:500;background:var(--surface);border:1px solid var(--line);
  color:var(--ink);transition:all .12s
}
.btn:hover{background:var(--surface-2);border-color:var(--line-2)}
.btn-primary{background:linear-gradient(135deg,var(--brand),#ff5e1a);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 4px 14px rgba(255,122,26,.35)}
.btn-primary:hover{background:linear-gradient(135deg,var(--brand-2),var(--brand));box-shadow:0 6px 20px rgba(255,122,26,.5)}
.btn-cyan{background:linear-gradient(135deg,var(--cyan),#0ea5e9);color:#fff;border-color:transparent;font-weight:600;box-shadow:0 4px 14px rgba(62,184,255,.3)}
.btn-cyan:hover{background:linear-gradient(135deg,var(--cyan-2),var(--cyan));box-shadow:0 6px 20px rgba(62,184,255,.45)}
.btn svg{width:16px;height:16px}

/* ============ ALERT ============ */
.alert{
  display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--r-md);
  background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.25)
}
.alert-icon{flex-shrink:0;width:38px;height:38px;border-radius:10px;background:rgba(248,113,113,.15);display:grid;place-items:center;color:var(--bad)}
.alert-text{flex:1}
.alert-text b{font-weight:600;color:var(--ink);display:block;font-size:14px}
.alert-text small{color:var(--ink-3);font-size:13px}

/* ============ KPI CARDS — friendly, big, clean ============ */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:22px 24px;display:flex;flex-direction:column;gap:14px;transition:all .15s
}
.kpi:hover{border-color:var(--line-2);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.kpi-top{display:flex;align-items:center;justify-content:space-between}
.kpi-icon{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;flex-shrink:0}
.kpi-icon.brand{background:linear-gradient(135deg,rgba(255,122,26,.18),rgba(255,122,26,.04));color:var(--brand-2);box-shadow:inset 0 0 0 1px rgba(255,122,26,.15)}
.kpi-icon.ok{background:rgba(52,211,153,.12);color:var(--ok)}
.kpi-icon.info{background:linear-gradient(135deg,rgba(62,184,255,.18),rgba(62,184,255,.04));color:var(--cyan-2);box-shadow:inset 0 0 0 1px rgba(62,184,255,.15)}
.kpi-icon.warn{background:rgba(251,191,36,.12);color:var(--warn)}
.kpi-trend{
  display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;
  padding:4px 10px;border-radius:8px
}
.trend-up{background:rgba(52,211,153,.12);color:var(--ok)}
.trend-down{background:rgba(248,113,113,.12);color:var(--bad)}
.trend-flat{background:var(--surface-3);color:var(--ink-3)}
.kpi-value{font-size:32px;font-weight:700;letter-spacing:-.025em;line-height:1}
.kpi-value small{font-size:14px;color:var(--ink-3);font-weight:500}
.kpi-label{font-size:13px;color:var(--ink-2)}

/* ============ TWO COL ============ */
.cols{display:grid;grid-template-columns:1.5fr 1fr;gap:24px}

/* ============ CARD ============ */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  display:flex;flex-direction:column;overflow:hidden
}
.card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.card-title{font-size:15px;font-weight:600;letter-spacing:-.01em}
.card-sub{font-size:13px;color:var(--ink-3);margin-top:2px}
.card-action{font-size:13px;color:var(--brand-2);font-weight:500;display:inline-flex;align-items:center;gap:4px}
.card-action:hover{color:var(--brand)}

.tab-strip{display:flex;gap:4px;background:var(--surface-2);padding:4px;border-radius:8px}
.tab{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:500;color:var(--ink-3)}
.tab.on{background:var(--surface);color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.2)}

/* ============ LIVE STREAMS LIST ============ */
.streams{display:flex;flex-direction:column}
.stream{
  display:flex;align-items:center;gap:16px;padding:18px 22px;border-bottom:1px solid var(--line);
  transition:background .12s
}
.stream:last-child{border-bottom:none}
.stream:hover{background:var(--surface-2)}
.stream-thumb{
  width:54px;height:54px;border-radius:12px;flex-shrink:0;
  background:linear-gradient(135deg,#1e293b,#0f172a);
  display:grid;place-items:center;font-weight:800;font-size:16px;position:relative
}
.stream-thumb.f1{background:linear-gradient(135deg,#7c2d12,#b91c1c);color:#fef3c7}
.stream-thumb.mp{background:linear-gradient(135deg,#1e3a8a,#1e40af);color:#fef3c7}
.stream-thumb::after{content:'';position:absolute;bottom:4px;right:4px;width:10px;height:10px;border-radius:50%;background:#ef4444;border:2px solid var(--surface);box-shadow:0 0 8px #ef4444;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.stream-info{flex:1;min-width:0}
.stream-name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.live-pill{
  display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;
  background:rgba(239,68,68,.15);color:#fca5a5;font-size:10px;font-weight:700;letter-spacing:.06em
}
.live-pill::before{content:'';width:5px;height:5px;border-radius:50%;background:#ef4444;animation:pulse 1.5s infinite}
.stream-cat{font-size:13px;color:var(--ink-3);margin-top:2px}
.stream-stats{display:flex;align-items:center;gap:24px;font-size:13px}
.stream-stat{text-align:right}
.stream-stat .v{font-weight:600;color:var(--ink);display:block}
.stream-stat .l{font-size:11px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.06em}

/* ============ QUICK ACTIONS ============ */
.actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:22px}
.action-card{
  background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-md);
  padding:16px;text-align:left;display:flex;flex-direction:column;gap:8px;transition:all .15s;cursor:pointer
}
.action-card:hover{border-color:var(--brand);background:var(--surface-3);transform:translateY(-1px)}
.action-icon{
  width:36px;height:36px;border-radius:10px;display:grid;place-items:center
}
.action-card .name{font-size:14px;font-weight:600}
.action-card .desc{font-size:12px;color:var(--ink-3)}

/* ============ ACTIVITY FEED ============ */
.feed{display:flex;flex-direction:column}
.feed-item{
  display:flex;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);align-items:center
}
.feed-item:last-child{border-bottom:none}
.feed-icon{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  display:grid;place-items:center;font-size:16px
}
.feed-icon.ok{background:rgba(52,211,153,.12);color:var(--ok)}
.feed-icon.brand{background:var(--brand-soft);color:var(--brand-2)}
.feed-icon.info{background:rgba(96,165,250,.12);color:var(--info)}
.feed-icon.bad{background:rgba(248,113,113,.12);color:var(--bad)}
.feed-icon.warn{background:rgba(251,191,36,.12);color:var(--warn)}
.feed-text{flex:1;min-width:0}
.feed-text .who{font-weight:600;color:var(--ink);font-size:14px}
.feed-text .what{font-size:13px;color:var(--ink-2);margin-top:2px}
.feed-time{font-size:12px;color:var(--ink-4);flex-shrink:0;text-align:right}
.feed-amount{font-weight:600;color:var(--ok);font-size:14px}

/* ============ MOBILE BOTTOM NAV ============ */
.mob-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:30;
  background:rgba(15,18,24,.95);backdrop-filter:blur(20px);border-top:1px solid var(--line);
  padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  grid-template-columns:repeat(5,1fr)
}
.mob-nav button{
  display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;
  font-size:10px;color:var(--ink-3);font-weight:500;border-radius:8px
}
.mob-nav button.on{color:var(--brand-2)}
.mob-nav button svg{width:22px;height:22px}
.mob-nav .fab-wrap{display:flex;justify-content:center;align-items:flex-start}
.mob-nav .fab{
  width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#ea580c);
  margin-top:-22px;display:grid;place-items:center;color:#fff;
  box-shadow:0 6px 20px rgba(251,146,60,.5)
}
.mob-nav .fab svg{width:26px;height:26px}

/* ============ MOBILE OVERLAY MENU ============ */
.mob-menu{display:none;position:fixed;inset:0;z-index:40;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.mob-menu.open{display:block}
.mob-menu-panel{position:absolute;top:0;left:0;bottom:0;width:280px;background:var(--surface);border-right:1px solid var(--line);padding:0;overflow-y:auto;animation:slidein .25s ease}
@keyframes slidein{from{transform:translateX(-100%)}to{transform:translateX(0)}}

/* ============ RESPONSIVE: TABLET ============ */
@media(max-width:1100px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .cols{grid-template-columns:1fr}
  .sidebar{width:72px}
  .sb-brand{padding:14px 0;justify-content:center}
  .sb-logo{width:40px;height:40px;border-radius:10px}
  .sb-name,.sb-tag{display:none}
  .sb-nav .sb-section{text-align:center;padding:14px 0 6px;font-size:9px}
  .sb-link{justify-content:center;padding:10px 0}
  .sb-link span:not(.sb-badge){display:none}
  .sb-link .sb-badge{position:absolute;top:6px;right:14px;font-size:9px;padding:1px 5px}
  .sb-link{position:relative}
  .sb-foot .sb-user,.sb-foot .tb-btn{display:none}
  .sb-foot{justify-content:center}
  .actions-grid{grid-template-columns:1fr 1fr 1fr}
}

/* ============ RESPONSIVE: MOBILE ============ */
@media(max-width:720px){
  .sidebar{display:none}
  .tb-mobile-btn{display:grid}
  .topbar{padding:12px 16px;height:60px;gap:10px}
  .tb-search{display:none}
  .tb-credits .label{display:none}
  .content{padding:16px;padding-bottom:100px;gap:18px}
  .greet{flex-direction:column;align-items:flex-start;gap:12px}
  .greet h1{font-size:24px}
  .greet-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .greet-actions .btn{justify-content:center;padding:12px;width:100%}
  .kpis{grid-template-columns:1fr 1fr;gap:12px}
  .kpi{padding:18px}
  .kpi-value{font-size:26px}
  .stream{padding:14px 16px;gap:12px}
  .stream-stats{display:none}
  .stream-info::after{content:'›';color:var(--ink-3);font-size:20px;margin-left:auto}
  .stream-info{display:flex;align-items:center}
  .stream-info > div{flex:1}
  .actions-grid{grid-template-columns:1fr 1fr;padding:16px}
  .feed-item{padding:12px 16px}
  .feed-amount,.feed-time{font-size:11px}
  .card-head{padding:16px}
  .mob-nav{display:grid}
}

/* ============ MINI CHART ============ */
.mini-spark{display:block;width:100%;height:36px;margin-top:8px}

/* ============ STATUS DOT ============ */
.dot{display:inline-block;width:8px;height:8px;border-radius:50%}
.dot-ok{background:var(--ok);box-shadow:0 0 6px var(--ok)}
.dot-warn{background:var(--warn)}
.dot-bad{background:var(--bad)}

/* sidebar scrollbar — invisible by default, slim on hover */
.sidebar { overflow: hidden; }
.sb-nav { overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none; }
.sb-nav::-webkit-scrollbar { width: 0; background: transparent; }
.sidebar:hover .sb-nav { scrollbar-width: thin; scrollbar-color: #2a2052 transparent; }
.sidebar:hover .sb-nav::-webkit-scrollbar { width: 4px; }
.sidebar:hover .sb-nav::-webkit-scrollbar-thumb { background: #3a2f6b; border-radius: 2px; }


/* === ROLE GATING (v12) === */
.superadmin-only { display: none !important; }
body.role-superadmin .superadmin-only { display: revert !important; }
/* For inline-flex buttons that 'revert' wouldn't restore correctly: */
body.role-superadmin button.superadmin-only { display: inline-flex !important; }
body.role-superadmin div.superadmin-only { display: block !important; }
/* readonly hint badge for normal admins */
body.role-admin .superadmin-only-replace::after {
  content: 'Solo SUPERADMIN';
  display: inline-block;
  font-size: 10px;
  color: var(--ink-4);
  margin-left: 6px;
  padding: 2px 8px;
  border-radius: 8px;
  background: var(--surface-3);
  text-transform: uppercase;
  letter-spacing: .06em;
}


/* === MOBILE: show full labels in the slide-in menu (override tablet rule) === */
@media(max-width:720px){
  .mob-menu-panel .sb-name,
  .mob-menu-panel .sb-tag { display: block !important; }
  .mob-menu-panel .sb-link { justify-content: flex-start !important; padding: 11px 18px !important; gap: 12px !important; }
  .mob-menu-panel .sb-link span:not(.sb-badge) { display: inline !important; font-size: 14px; }
  .mob-menu-panel .sb-link .sb-badge { position: static !important; font-size: 11px !important; padding: 2px 8px !important; margin-left: auto; }
  .mob-menu-panel .sb-brand { padding: 18px 18px !important; justify-content: flex-start !important; }
  .mob-menu-panel .sb-nav .sb-section { text-align: left !important; padding: 14px 18px 6px !important; font-size: 11px !important; }
  /* slightly wider drawer */
  .mob-menu-panel { width: 86vw !important; max-width: 320px; }
}


/* === MOBILE BOTTOM NAV: support <a> elements (v36) === */
.mob-nav a {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background: transparent;
  border: none;
  color: var(--ink-3);
  font-size: 10px;
  text-decoration: none;
  padding: 8px 0;
  cursor: pointer;
}
.mob-nav a.on { color: var(--brand-2); }
.mob-nav a svg { width: 22px; height: 22px; }
