@property --p{
  syntax:'<number>';
  inherits:true;
  initial-value:0;
}
:root{
  --bg:#080d1a;--panel:#111a2f;--panel2:#172340;--line:rgba(255,255,255,.12);
  --text:#eef3ff;--muted:#9eabc9;--accent:#27d3ff;--accent2:#8b5cf6;--ok:#34d399;--danger:#ff5c7a;--warn:#fbbf24;
  --radius:18px;
}
*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 0 0,rgba(39,211,255,.18),transparent 28%),radial-gradient(circle at 100% 0,rgba(139,92,246,.18),transparent 30%),var(--bg);font-family:Arial,Helvetica,sans-serif;color:var(--text)}
button,input,select,textarea{font:inherit}button{cursor:pointer;border:0;border-radius:13px;padding:11px 13px;background:var(--panel2);color:var(--text);transition:.16s ease}button:hover{filter:brightness(1.08);transform:translateY(-1px)}button.primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06101e;font-weight:800}button.danger{background:rgba(255,92,122,.16);border:1px solid rgba(255,92,122,.32);color:#ffd1da}button.ok{background:rgba(52,211,153,.14);border:1px solid rgba(52,211,153,.32);color:#b9ffe4}button.ghost{background:transparent;border:1px solid var(--line)}button.active{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#06101e;font-weight:800}
input,select,textarea{width:100%;background:#0d1528;color:var(--text);border:1px solid var(--line);border-radius:13px;padding:11px 12px;outline:0}textarea{min-height:130px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:rgba(39,211,255,.75);box-shadow:0 0 0 3px rgba(39,211,255,.12)}label{display:block;margin:10px 0 6px;color:var(--muted);font-size:13px}.hidden{display:none!important}.small{font-size:12px;color:var(--muted)}
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(440px,100%);background:rgba(17,26,47,.92);border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:0 24px 70px rgba(0,0,0,.35);backdrop-filter:blur(14px)}.logo{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:grid;place-items:center;color:#06101e;font-weight:900;font-size:25px;margin-bottom:16px}.login-card h1{margin:0;font-size:28px}.login-card p{margin:8px 0 18px;color:var(--muted);line-height:1.45}.login-actions{display:grid;gap:10px;margin-top:14px}.message{margin-top:12px;padding:12px;border-radius:13px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--muted)}.message.err{color:#ffd1da;background:rgba(255,92,122,.09);border-color:rgba(255,92,122,.28)}.message.ok{color:#b9ffe4;background:rgba(52,211,153,.08);border-color:rgba(52,211,153,.28)}
.shell{width:min(1480px,100%);margin:auto;padding:16px;display:grid;gap:16px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:14px;background:rgba(17,26,47,.9);border:1px solid var(--line);border-radius:var(--radius);padding:16px}.topbar h1{margin:0;font-size:24px}.topbar p{margin:4px 0 0;color:var(--muted);font-size:13px}.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.pill{padding:9px 11px;border-radius:999px;border:1px solid var(--line);color:var(--muted);background:rgba(255,255,255,.035);font-size:13px}.pill.ok{color:#b9ffe4;border-color:rgba(52,211,153,.32);background:rgba(52,211,153,.07)}
.admin-layout{display:grid;grid-template-columns:280px 1fr;gap:16px}.side{background:rgba(17,26,47,.9);border:1px solid var(--line);border-radius:var(--radius);padding:12px;height:max-content}.side button{width:100%;text-align:left;margin-bottom:8px}.panel{background:rgba(17,26,47,.9);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.panel-head{padding:16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:12px;align-items:center}.panel-head h2{margin:0;font-size:20px}.panel-body{padding:16px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.form-card{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:14px}.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}.stat{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:16px;padding:14px}.stat strong{display:block;font-size:24px;margin-bottom:4px}.stat span{color:var(--muted);font-size:12px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:12px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}th{color:#dce6ff;background:rgba(255,255,255,.045);font-weight:800}td{color:#edf3ff}tr:last-child td{border-bottom:0}.status-active{color:#b9ffe4}.status-block{color:#ffd1da}.td-actions{display:flex;gap:8px;flex-wrap:wrap}.td-actions button{padding:8px 10px;font-size:12px}.note{padding:13px;border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:14px;color:var(--muted);line-height:1.45;font-size:13px}.note.warn{border-color:rgba(251,191,36,.35);background:rgba(251,191,36,.08);color:#ffe8a8}
.player-layout{display:grid;grid-template-columns:380px 1fr;gap:16px}.catalog{background:rgba(17,26,47,.9);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.catalog-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px;border-bottom:1px solid var(--line)}.filters{padding:12px;display:grid;gap:10px;border-bottom:1px solid var(--line)}.list{height:560px;overflow:auto;padding:10px}.item{display:grid;grid-template-columns:54px 1fr;gap:10px;align-items:center;padding:10px;margin-bottom:8px;border:1px solid transparent;background:rgba(255,255,255,.035);border-radius:14px}.item:hover{border-color:rgba(39,211,255,.34);background:rgba(39,211,255,.07)}.poster,.poster-fallback{width:54px;height:54px;border-radius:12px;object-fit:cover;background:#0b1020;display:grid;place-items:center;font-weight:900;color:var(--muted);font-size:12px}.item-title{font-weight:800;line-height:1.25}.item-meta{font-size:12px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player{background:rgba(17,26,47,.9);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.video-box{background:#000}.video-box video{display:block;width:100%;aspect-ratio:16/9;background:#000}.now{padding:15px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}.now h2{margin:0;font-size:21px}.now p{margin:6px 0 0;color:var(--muted);font-size:13px}.player-info{padding:15px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.info-card{border:1px solid var(--line);border-radius:15px;background:rgba(255,255,255,.035);padding:13px}.info-card strong{display:block;font-size:22px}.info-card span{color:var(--muted);font-size:12px}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.72);display:none;align-items:center;justify-content:center;padding:20px;z-index:10}.modal.show{display:flex}.modal-box{width:min(760px,100%);max-height:84vh;overflow:auto;border-radius:20px;background:var(--panel);border:1px solid var(--line);padding:16px}.modal-head{display:flex;justify-content:space-between;gap:12px;align-items:center;border-bottom:1px solid var(--line);padding-bottom:12px;margin-bottom:12px}.modal-head h2{margin:0}.close{background:transparent;border:1px solid var(--line)}
@media(max-width:980px){.admin-layout,.player-layout{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}.grid,.grid-3,.grid-4{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.list{height:420px}}@media(max-width:520px){.stats,.player-info,.catalog-tabs{grid-template-columns:1fr}.td-actions{flex-direction:column}.td-actions button{width:100%}}

/* Marca Digital Plus Tv con efecto RGB */
.rgb-title{
  display:inline-block;
  font-weight:900;
  letter-spacing:-.6px;
  background:linear-gradient(90deg,#ff004c,#ffb700,#00ff85,#00d9ff,#7a5cff,#ff00ea,#ff004c);
  background-size:400% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation:rgbMove 5s linear infinite;
  text-shadow:0 0 22px rgba(39,211,255,.18);
}
.top-title{font-size:28px!important;}
.rgb-logo{
  background:linear-gradient(135deg,#ff004c,#ffb700,#00ff85,#00d9ff,#7a5cff,#ff00ea)!important;
  background-size:300% 300%!important;
  animation:rgbGlow 4s ease infinite;
  color:#050912!important;
  box-shadow:0 0 24px rgba(39,211,255,.28),0 0 42px rgba(255,0,234,.12);
}
.login-card{position:relative;overflow:hidden;}
.login-card:before{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:linear-gradient(120deg,rgba(255,0,76,.16),rgba(0,217,255,.16),rgba(122,92,255,.16),rgba(255,183,0,.14));
  opacity:.55;
  filter:blur(28px);
}
.login-card>*{position:relative;z-index:1;}
@keyframes rgbMove{0%{background-position:0% 50%}100%{background-position:400% 50%}}
@keyframes rgbGlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Tabla de listas / accesos */
.wide-table{min-width:1080px}
.mono-cell{font-family:Consolas,"Courier New",monospace;font-size:12px;word-break:break-all;color:#dbe7ff}

/* Categorias / carpetas */
.category-columns{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:start}
.category-card{margin-bottom:0}
.category-title{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:12px}
.category-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.03);margin-bottom:8px}
.category-row:last-child{margin-bottom:0}
.compact-actions{margin-top:0}
@media(max-width:1100px){.category-columns{grid-template-columns:1fr}}
.copy-box{display:block;margin-top:6px;padding:10px;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.18)}


/* Servidores instalados */
.status-active{font-weight:700}.status-block{font-weight:700}.wide-table td .ghost{margin-top:6px;padding:7px 9px;font-size:12px}

/* Monitoreo de servidores: CPU, RAM, trafico y velocidad */
.server-monitor{min-width:270px;display:grid;gap:10px}.server-status{font-size:12px;line-height:1.35}.metric-gauges{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.gauge-wrap{display:grid;place-items:center;gap:4px;min-width:68px}.gauge-wrap small{font-size:10px;color:var(--muted);font-weight:800;letter-spacing:.5px}.gauge{--p:0;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--accent) calc(var(--p)*1%),rgba(255,255,255,.12) 0);position:relative;box-shadow:inset 0 0 12px rgba(0,0,0,.18)}.gauge:before{content:"";position:absolute;inset:7px;border-radius:50%;background:#0d1528;border:1px solid rgba(255,255,255,.08)}.gauge span{position:relative;z-index:1;font-size:12px;font-weight:900}.traffic-grid{display:grid;grid-template-columns:repeat(2,minmax(110px,1fr));gap:8px;min-width:260px}.traffic-grid div{border:1px solid var(--line);background:rgba(255,255,255,.035);border-radius:12px;padding:9px}.traffic-grid strong{display:block;font-size:13px}.traffic-grid span{display:block;font-size:10px;color:var(--muted);margin-top:3px}.no-metrics .gauge{background:conic-gradient(rgba(255,255,255,.18) 0%,rgba(255,255,255,.12) 0)}
.server-state-line{margin-top:7px;margin-bottom:4px}.server-state-badge{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--line);border-radius:999px;padding:5px 8px;font-size:10px;font-weight:900;letter-spacing:.5px;background:rgba(255,255,255,.06)}.server-state-badge.status-active{border-color:rgba(52,211,153,.55);background:rgba(52,211,153,.14);color:#b7ffe2}.server-state-badge.status-block{border-color:rgba(255,92,122,.55);background:rgba(255,92,122,.14);color:#ffd1da}


.primary-server-row{outline:1px solid rgba(39,211,255,.22);background:rgba(39,211,255,.035)}
.pill-mini{display:inline-flex;align-items:center;margin-left:6px;padding:3px 7px;border-radius:999px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#06101e;font-size:9px;font-weight:900;letter-spacing:.5px;vertical-align:middle}

.realtime-box{margin:0 0 14px 0;font-size:13px}
.server-monitor,.traffic-grid,.gauge span,.server-status,.server-state-badge{transition:all .35s ease}
.gauge{transition:--p var(--smooth,.65s) cubic-bezier(.22,.61,.36,1),filter .25s ease,box-shadow .25s ease}
.gauge span{transition:transform .35s ease,opacity .35s ease}
.gauge.smooth-gauge{will-change:background}


.connection-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.connection-cell span{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:999px;padding:5px 8px;background:rgba(255,255,255,.035);font-size:12px}.connection-cell .online-count{border-color:rgba(39,211,255,.35);background:rgba(39,211,255,.08);color:#c8f6ff}.connection-cell .online-count.status-active{border-color:rgba(52,211,153,.5);background:rgba(52,211,153,.12);color:#b7ffe2}
.connection-cell .offline-count{border-color:rgba(255,92,122,.42);background:rgba(255,92,122,.08);color:#ffd1da}
.connection-cell .geo-count{border-color:rgba(139,92,246,.38);background:rgba(139,92,246,.08);color:#e5ddff;max-width:100%;white-space:normal;line-height:1.25}

/* Reproductor estilo IPTV profesional inspirado en flujo XUI, sin copiar marca/interfaz propietaria */
.xui-player-shell{max-width:1680px}.xui-status-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);font-size:13px;color:var(--muted)}.xui-status-strip strong{color:#eaf2ff}.xui-player-layout{display:grid;grid-template-columns:290px 390px 1fr;gap:14px;align-items:start}.xui-panel-title{padding:12px 14px;border-bottom:1px solid var(--line);font-size:12px;font-weight:900;letter-spacing:1px;color:#dce6ff;background:linear-gradient(90deg,rgba(39,211,255,.12),rgba(139,92,246,.08))}.xui-bouquets,.xui-stream-table,.xui-screen-panel{border-radius:16px;border:1px solid var(--line);background:rgba(10,15,28,.92);overflow:hidden;box-shadow:0 18px 50px rgba(0,0,0,.20)}.xui-type-tabs{grid-template-columns:1fr;gap:7px}.xui-type-tabs button{text-align:left;border-radius:10px}.xui-mini-stats{display:grid;grid-template-columns:1fr;gap:8px;padding:12px;border-top:1px solid var(--line)}.xui-mini-stats div{display:flex;justify-content:space-between;align-items:center;border:1px solid var(--line);border-radius:12px;padding:10px;background:rgba(255,255,255,.035)}.xui-mini-stats b{font-size:20px}.xui-mini-stats span{font-size:12px;color:var(--muted)}.xui-list{height:690px;padding:10px}.xui-stream-row{grid-template-columns:48px 1fr;border-radius:11px;background:rgba(255,255,255,.025);margin-bottom:7px}.xui-stream-row:hover{background:rgba(39,211,255,.10);border-color:rgba(39,211,255,.45)}.xui-stream-meta{font-size:11px;color:#7f8cad;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.xui-video{border-bottom:1px solid var(--line);background:radial-gradient(circle at center,rgba(39,211,255,.06),#000 54%)}.xui-video video{min-height:420px}.xui-now{background:rgba(255,255,255,.025)}.xui-player-actions{display:flex;gap:8px;flex-wrap:wrap;padding:12px;border-bottom:1px solid var(--line)}.xui-player-actions button{padding:9px 11px;font-size:12px}.xui-debug{margin:12px}.xui-diag-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.xui-diag-grid div{border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.035);padding:10px}.xui-diag-grid b{display:block;font-size:11px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.xui-diag-grid span{display:block;font-size:13px;color:#edf3ff;word-break:break-word}@media(max-width:1320px){.xui-player-layout{grid-template-columns:280px 1fr}.xui-screen-panel{grid-column:1/-1}.xui-video video{min-height:auto}.xui-list{height:520px}}@media(max-width:860px){.xui-player-layout,.xui-status-strip{grid-template-columns:1fr}.xui-list{height:420px}.xui-diag-grid{grid-template-columns:1fr}}

/* Panel administrador estilo IPTV profesional inspirado en XUI, sin copiar marca propietaria */
.xui-admin-shell{width:min(1760px,100%);padding:0;background:#070b14;min-height:100vh}
.xui-admin-layout{display:grid;grid-template-columns:292px 1fr;min-height:100vh;background:linear-gradient(180deg,#07101f,#070b14 48%,#050812)}
.xui-admin-sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:14px;padding:16px 12px;background:linear-gradient(180deg,#0d172c,#0a1121);border-right:1px solid rgba(255,255,255,.09);box-shadow:24px 0 80px rgba(0,0,0,.25);overflow:auto}
.xui-sidebar-brand{display:grid;grid-template-columns:52px 1fr;gap:11px;align-items:center;padding:10px 9px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.xui-sidebar-logo{width:52px;height:52px;border-radius:16px;display:grid;place-items:center;font-weight:950;color:#07101f;font-size:19px}
.xui-sidebar-brand strong{display:block;font-size:18px;line-height:1.1}.xui-sidebar-brand span{display:block;margin-top:4px;color:#73829e;font-size:10px;font-weight:900;letter-spacing:1.5px}
.xui-sidebar-user{display:flex;justify-content:space-between;align-items:center;gap:9px;padding:12px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(255,255,255,.035)}
.xui-sidebar-user small,.xui-credit-line small{display:block;color:#7f8ba6;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.8px}.xui-sidebar-user b{display:block;margin-top:3px;color:#edf5ff;max-width:136px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.xui-role-badge{font-size:10px;font-weight:900;padding:7px 9px;border-radius:999px;background:rgba(39,211,255,.12);border:1px solid rgba(39,211,255,.35);color:#bcefff;white-space:nowrap}
.xui-menu-section{display:grid;gap:7px}.xui-menu-section span{padding:6px 11px 2px;color:#65728c;font-size:10px;font-weight:950;text-transform:uppercase;letter-spacing:1.3px}.xui-menu-section button{display:flex;align-items:center;gap:10px;width:100%;margin:0;text-align:left;border-radius:11px;background:transparent;border:1px solid transparent;color:#b8c3db;padding:10px 11px;font-size:13px;font-weight:800}.xui-menu-section button b{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.055);color:#83ddff;font-size:12px}.xui-menu-section button:hover{background:rgba(39,211,255,.08);border-color:rgba(39,211,255,.18);transform:none}.xui-menu-section button.active{background:linear-gradient(90deg,rgba(39,211,255,.22),rgba(139,92,246,.12));border-color:rgba(39,211,255,.35);color:#ffffff;box-shadow:inset 3px 0 0 var(--accent)}.xui-menu-section button.active b{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#05101f}
.xui-sidebar-footer{margin-top:auto;display:grid;gap:10px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.xui-credit-line{display:flex;justify-content:space-between;align-items:end;gap:10px;padding:10px 11px;border-radius:14px;background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.08)}.xui-credit-line strong{color:#caffec}.xui-logout-btn{width:100%;border-radius:12px}
.xui-admin-main{min-width:0;padding:18px;display:grid;grid-template-rows:auto 1fr;gap:16px}.xui-admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 18px;border:1px solid rgba(255,255,255,.10);border-radius:18px;background:linear-gradient(90deg,rgba(17,26,47,.95),rgba(12,20,38,.92));box-shadow:0 18px 60px rgba(0,0,0,.22)}.xui-admin-topbar h1{margin:0;font-size:24px;letter-spacing:-.5px}.xui-admin-topbar p{margin:5px 0 0;color:#8f9bb7;font-size:13px}.xui-top-pills{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end}.xui-admin-panel{border-radius:18px;background:rgba(13,21,40,.94);box-shadow:0 22px 70px rgba(0,0,0,.28);min-height:calc(100vh - 126px)}
.xui-section-head{background:linear-gradient(90deg,rgba(39,211,255,.08),rgba(139,92,246,.06));align-items:center}.xui-kicker{display:block;color:#7fdfff;font-size:10px;font-weight:950;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:4px}.xui-head-actions{display:flex;gap:9px;flex-wrap:wrap}.xui-dashboard-body{display:grid;gap:14px}.xui-hero-grid{display:grid;grid-template-columns:minmax(0,1.8fr) minmax(280px,.8fr);gap:14px}.xui-hero-card,.xui-mini-chart-card{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:18px;background:radial-gradient(circle at top right,rgba(39,211,255,.16),transparent 34%),rgba(255,255,255,.035)}.xui-hero-card:after{content:"";position:absolute;right:-70px;top:-70px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.26),transparent 60%)}.xui-hero-card h3{margin:0;font-size:30px;letter-spacing:-.8px}.xui-hero-card p{max-width:720px;color:#9aa8c5;line-height:1.45;margin:9px 0 18px}.xui-status-row{display:flex;gap:10px;flex-wrap:wrap;color:#9aa8c5;font-size:13px}.xui-mini-chart-card strong{display:block;font-size:42px;line-height:1;margin:8px 0;color:#eaf6ff}.xui-mini-chart-card p{margin:9px 0 0;color:#8e9bb5;font-size:12px}.xui-meter{height:9px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden}.xui-meter i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .45s ease}.xui-stats-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin-bottom:0}.xui-stat{position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));min-height:102px}.xui-stat em{position:absolute;right:13px;top:12px;font-style:normal;font-size:11px;font-weight:950;color:rgba(39,211,255,.62);letter-spacing:1px}.xui-stat strong{font-size:30px;margin-top:12px}.xui-module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.xui-module-grid button{text-align:left;border-radius:16px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.035);padding:15px}.xui-module-grid button b{display:block;margin-bottom:6px;color:#eaf6ff}.xui-module-grid button span{display:block;color:#8996b0;font-size:12px;line-height:1.35}.xui-module-grid button:hover{background:rgba(39,211,255,.08);border-color:rgba(39,211,255,.28);transform:translateY(-1px)}.xui-note{margin-top:0}.xui-admin-panel .table-wrap{background:rgba(7,12,24,.35)}.xui-admin-panel th{background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.04));font-size:12px;text-transform:uppercase;letter-spacing:.55px;color:#aebde0}.xui-admin-panel td{font-size:13px}.xui-admin-panel .panel-head h2{letter-spacing:-.35px}.xui-admin-panel .form-card{background:rgba(255,255,255,.03);box-shadow:inset 0 0 0 1px rgba(255,255,255,.025)}
@media(max-width:1180px){.xui-admin-layout{grid-template-columns:1fr}.xui-admin-sidebar{position:relative;height:auto}.xui-admin-main{padding:12px}.xui-stats-grid,.xui-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.xui-hero-grid{grid-template-columns:1fr}}
@media(max-width:720px){.xui-admin-topbar{flex-direction:column;align-items:flex-start}.xui-stats-grid,.xui-module-grid{grid-template-columns:1fr}.xui-sidebar-brand{grid-template-columns:44px 1fr}.xui-sidebar-logo{width:44px;height:44px}.xui-menu-section button{font-size:12px}.xui-admin-main{padding:10px}.xui-admin-panel{min-height:auto}}

/* Perfil y panel lateral plegable */
.xui-compact-topbar{justify-content:flex-start;gap:12px}.sidebar-toggle-btn{width:44px;height:44px;display:grid;place-items:center;font-size:20px;padding:0;flex:0 0 auto}.xui-menu-section button em{font-style:normal;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.xui-admin-layout.sidebar-collapsed{grid-template-columns:78px 1fr}.sidebar-collapsed .xui-admin-sidebar{padding:14px 8px;align-items:center}.sidebar-collapsed .xui-sidebar-brand{display:flex;justify-content:center;padding:8px 0 12px;width:100%}.sidebar-collapsed .xui-sidebar-logo{width:48px;height:48px}.sidebar-collapsed .xui-sidebar-brand-text,.sidebar-collapsed .xui-sidebar-user-text,.sidebar-collapsed .xui-role-badge,.sidebar-collapsed .xui-menu-section span,.sidebar-collapsed .xui-menu-section button em,.sidebar-collapsed .xui-credit-line,.sidebar-collapsed .xui-logout-btn{display:none}.sidebar-collapsed .xui-sidebar-user{justify-content:center;width:100%;padding:8px;background:transparent;border-color:transparent}.sidebar-collapsed .xui-menu-section{width:100%}.sidebar-collapsed .xui-menu-section button{justify-content:center;padding:10px 6px}.sidebar-collapsed .xui-menu-section button b{margin:0}.sidebar-collapsed .xui-sidebar-footer{border-top:0;width:100%;padding-top:0}.profile-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:12px 0}.profile-summary-grid div{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035);padding:12px}.profile-summary-grid span{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;font-weight:900;letter-spacing:.6px;margin-bottom:5px}.profile-summary-grid strong{display:block;color:#eef5ff;font-size:14px;word-break:break-word}@media(max-width:1180px){.xui-admin-layout.sidebar-collapsed{grid-template-columns:1fr}.sidebar-collapsed .xui-admin-sidebar{display:none}}@media(max-width:760px){.profile-summary-grid{grid-template-columns:1fr}.xui-compact-topbar{align-items:flex-start}}

/* Enlace de perfil dentro del bloque Usuario activo */
.xui-profile-inline-link{
  margin-top:6px;
  padding:0;
  border:0;
  background:transparent;
  color:var(--accent);
  font-size:12px;
  font-weight:800;
  text-align:left;
  cursor:pointer;
  width:auto;
  display:inline-flex;
  align-items:center;
  gap:4px;
}
.xui-profile-inline-link:hover{
  color:#fff;
  text-decoration:underline;
  transform:none;
  filter:none;
}
.sidebar-collapsed .xui-profile-inline-link{display:none}


/* Marca editable desde Mi Perfil */
.brand-logo-box{background:rgba(255,255,255,.06)!important;border:1px solid rgba(255,255,255,.12);overflow:hidden;padding:5px}
.brand-logo-box img{width:100%;height:100%;object-fit:contain;display:block;border-radius:inherit}
.logo.brand-logo-box{display:grid;place-items:center}
.xui-sidebar-logo.brand-logo-box{display:grid;place-items:center;background:rgba(255,255,255,.06)!important;color:inherit}
.profile-system-card{margin-top:12px}
.profile-logo-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:10px}
.profile-logo-preview{width:86px;height:86px;border-radius:18px;border:1px solid var(--line);background:rgba(255,255,255,.04);display:grid;place-items:center;color:var(--muted);font-size:12px;text-align:center;padding:8px;overflow:hidden}
.profile-logo-preview img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.inline-check{display:flex!important;align-items:center;gap:8px;margin:0;color:var(--muted);font-size:13px}
.inline-check input{width:auto!important}

/* Vista cliente limpia: menu superior y datos debajo del reproductor reducidos */
.client-player-topbar{position:relative;align-items:center;background:rgba(10,15,28,.94)}
.client-player-brand{display:flex;align-items:center;gap:12px;min-width:0}
.client-player-brand h1{margin:0;line-height:1.05}
.client-player-brand p{margin:3px 0 0;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.8px;font-weight:800}
.client-player-logo{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-weight:900;flex:0 0 auto}
.client-menu-wrap{position:relative;margin-left:auto;z-index:30}
.client-menu-button{min-width:48px;width:48px;height:48px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(39,211,255,.95),rgba(139,92,246,.95));color:#06101e;font-weight:900;border:0;box-shadow:0 12px 32px rgba(39,211,255,.14);padding:0}
.client-menu-button svg{width:24px;height:24px;fill:currentColor;display:block}
.client-menu-button.icon-only{border-radius:999px}
.client-menu-panel{position:absolute;right:0;top:calc(100% + 10px);width:180px;border:1px solid var(--line);border-radius:16px;background:rgba(11,17,32,.98);box-shadow:0 24px 70px rgba(0,0,0,.42);padding:10px;animation:clientMenuDrop .16s ease-out;z-index:50}
.client-menu-panel button{width:100%;display:flex;justify-content:center;margin-top:8px;background:rgba(255,255,255,.055);border:1px solid var(--line);font-weight:800}
.client-menu-panel button:hover{background:rgba(39,211,255,.11);border-color:rgba(39,211,255,.35)}
.client-menu-close{background:rgba(255,92,122,.10)!important;border-color:rgba(255,92,122,.28)!important;color:#ffd1da!important}
.client-menu-user{padding:9px 10px;border:1px solid rgba(255,255,255,.10);border-radius:13px;background:rgba(255,255,255,.035);margin-bottom:4px}
.client-menu-user small{display:block;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.6px;font-weight:900;margin-bottom:3px}
.client-menu-user strong{display:block;color:#f3f7ff;word-break:break-word}
.xui-client-now{display:block;text-align:center;padding:16px 14px;border-top:1px solid var(--line);background:rgba(255,255,255,.025)}
.xui-client-now h2{margin:0;font-size:20px;line-height:1.25;color:#f3f7ff}
.xui-screen-panel .xui-client-now + .hidden{display:none!important}
@keyframes clientMenuDrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:720px){.client-player-topbar{flex-direction:row;align-items:center}.client-player-brand h1{font-size:20px}.client-menu-button{min-width:44px;width:44px;height:44px;padding:0}.client-menu-panel{right:0;width:180px}.client-player-logo{width:42px;height:42px}}

/* Menu de cuenta superior para administrador/revendedor */
.xui-compact-topbar{
  justify-content:space-between;
  gap:12px;
}
.xui-topbar-left{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.xui-topbar-left > div{min-width:0}
.admin-menu-wrap{
  position:relative;
  margin-left:auto;
  z-index:40;
  flex:0 0 auto;
}
.admin-menu-button svg{
  width:24px;
  height:24px;
  fill:currentColor;
  display:block;
}
.admin-menu-panel{
  right:0;
  top:calc(100% + 10px);
}
.xui-sidebar-footer{
  padding-top:8px;
}
@media(max-width:720px){
  .xui-admin-topbar.xui-compact-topbar{
    flex-direction:row;
    align-items:center;
  }
  .xui-topbar-left h1{font-size:20px}
  .xui-topbar-left p{font-size:12px}
  .admin-menu-panel{right:0;width:180px}
}

/* Botón de abrir/cerrar panel dentro del menú lateral */
.xui-sidebar-toggle-zone{
  display:flex;
  justify-content:flex-start;
  padding:0 9px 2px;
}
.sidebar-toggle-inside{
  width:100%;
  height:40px;
  border-radius:12px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.09);
}
.sidebar-toggle-inside:hover{
  background:rgba(39,211,255,.10);
  border-color:rgba(39,211,255,.28);
  transform:none;
}
.sidebar-collapsed .xui-sidebar-toggle-zone{
  width:100%;
  justify-content:center;
  padding:0 0 2px;
}
.sidebar-collapsed .sidebar-toggle-inside{
  width:48px;
  height:42px;
  padding:0;
}
@media(max-width:1180px){
  .xui-sidebar-toggle-zone{padding:0 9px 4px}
}

/* Bienvenida de usuario y limpieza del bloque lateral */
.welcome-user-card{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(39,211,255,.22);
  background:linear-gradient(135deg,rgba(39,211,255,.10),rgba(139,92,246,.09));
  border-radius:999px;
  padding:9px 12px;
  color:#dbeafe;
  box-shadow:0 10px 30px rgba(0,0,0,.12);
}
.welcome-user-card span{
  color:#8ea0bd;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.7px;
}
.welcome-user-card strong{
  color:#f8fbff;
  font-size:14px;
  max-width:180px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.welcome-user-card small{
  color:#a5f3fc;
  font-size:11px;
  font-weight:900;
  padding:5px 8px;
  border-radius:999px;
  background:rgba(39,211,255,.12);
  border:1px solid rgba(39,211,255,.20);
}
.admin-welcome-inline{margin-left:auto;margin-right:8px}
.dashboard-welcome{
  width:100%;
  justify-content:flex-start;
  border-radius:18px;
  padding:13px 15px;
  margin-bottom:14px;
}
.client-player-brand p{font-weight:800;color:#a5f3fc}
.sidebar-collapsed .welcome-user-card{display:none}
@media(max-width:760px){
  .admin-welcome-inline{margin:8px 0 0;width:100%;justify-content:center}
  .welcome-user-card{border-radius:16px;flex-wrap:wrap}
}

/* Login centrado */
.login-card .logo{
  margin-left:auto;
  margin-right:auto;
  margin-bottom:16px;
}
.login-card h1,
.login-card > p{
  text-align:center;
}

/* Corrección responsive PC / celular y bienvenida sin duplicar */
.xui-dashboard-body .dashboard-welcome{
  display:inline-flex!important;
}
.xui-topbar-left{
  flex-wrap:wrap;
}
.xui-topbar-left .admin-welcome-inline{
  flex:0 0 auto;
}
.xui-admin-main,
.panel,
.xui-admin-panel,
.form-card,
.table-wrap,
.video-box,
.xui-screen-panel{
  min-width:0;
}
.table-wrap{
  -webkit-overflow-scrolling:touch;
}
img,video{
  max-width:100%;
}
input,select,textarea,button{
  max-width:100%;
}

@media(max-width:1180px){
  .xui-admin-layout,
  .xui-admin-layout.sidebar-collapsed{
    grid-template-columns:1fr!important;
  }
  .xui-admin-sidebar,
  .sidebar-collapsed .xui-admin-sidebar{
    position:relative!important;
    top:auto!important;
    height:auto!important;
    min-height:0!important;
    display:flex!important;
  }
  .sidebar-collapsed .xui-menu-section,
  .sidebar-collapsed .xui-sidebar-footer{
    display:none!important;
  }
  .sidebar-collapsed .xui-sidebar-brand{
    border-bottom:0;
    padding-bottom:6px;
  }
  .xui-admin-main{
    padding:12px!important;
  }
}

@media(max-width:900px){
  body{
    overflow-x:hidden;
  }
  .app{
    padding:10px;
  }
  .xui-admin-layout{
    min-height:100dvh;
  }
  .xui-admin-sidebar{
    border-right:0;
    border-bottom:1px solid rgba(255,255,255,.09);
    border-radius:0 0 20px 20px;
    gap:10px;
    padding:12px 10px;
  }
  .xui-sidebar-brand{
    grid-template-columns:44px minmax(0,1fr);
    padding:8px 8px 10px;
  }
  .xui-sidebar-brand-text strong{
    font-size:16px;
  }
  .xui-sidebar-brand-text span{
    font-size:10px;
  }
  .xui-menu-section{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:7px;
  }
  .xui-menu-section span{
    grid-column:1/-1;
  }
  .xui-menu-section button{
    margin:0;
    padding:10px 9px;
    min-height:42px;
  }
  .xui-admin-topbar.xui-compact-topbar{
    align-items:flex-start!important;
    gap:10px;
    padding:12px;
  }
  .xui-topbar-left{
    width:calc(100% - 58px);
    gap:8px;
  }
  .xui-topbar-left h1{
    font-size:20px;
    line-height:1.1;
  }
  .xui-topbar-left p{
    font-size:12px;
    line-height:1.25;
  }
  .admin-welcome-inline{
    margin:6px 0 0!important;
    width:100%;
    justify-content:flex-start!important;
  }
  .welcome-user-card{
    max-width:100%;
    border-radius:14px;
    padding:8px 10px;
  }
  .welcome-user-card strong{
    max-width:140px;
  }
  .admin-menu-wrap{
    position:absolute;
    right:12px;
    top:12px;
  }
  .client-menu-panel,
  .admin-menu-panel{
    position:absolute;
    right:0;
    width:min(210px,calc(100vw - 24px));
  }
  .panel-head,
  .modal-head{
    flex-direction:column;
    align-items:flex-start;
  }
  .panel-body{
    padding:12px;
  }
  .grid,
  .grid-3,
  .grid-4,
  .stats,
  .xui-stats-grid,
  .xui-module-grid,
  .xui-hero-grid,
  .category-columns,
  .profile-summary-grid{
    grid-template-columns:1fr!important;
  }
  .actions,
  .td-actions,
  .xui-head-actions{
    width:100%;
  }
  .actions button,
  .td-actions button,
  .xui-head-actions button{
    flex:1 1 160px;
  }
  table{
    min-width:720px;
  }
  th,td{
    padding:10px;
    font-size:12px;
  }
  .xui-player-layout,
  .player-layout,
  .xui-status-strip{
    grid-template-columns:1fr!important;
  }
  .xui-list,
  .list{
    height:360px!important;
  }
  .xui-video video,
  .video-box video{
    min-height:0!important;
    aspect-ratio:16/9;
  }
  .client-player-topbar{
    padding:10px 12px;
  }
  .client-player-brand{
    max-width:calc(100% - 58px);
  }
  .client-player-brand h1{
    font-size:18px;
  }
  .client-player-brand p{
    font-size:11px;
  }
}

@media(max-width:560px){
  .login-card{
    width:100%;
    margin:0;
    border-radius:20px;
    padding:18px;
  }
  .xui-menu-section{
    grid-template-columns:1fr;
  }
  .xui-sidebar-toggle-zone{
    padding-left:8px;
    padding-right:8px;
  }
  .sidebar-toggle-inside{
    height:38px;
  }
  .xui-admin-main{
    padding:8px!important;
    gap:10px;
  }
  .xui-admin-panel,
  .panel,
  .catalog,
  .player,
  .xui-bouquets,
  .xui-stream-table,
  .xui-screen-panel{
    border-radius:14px;
  }
  .xui-hero-card h3{
    font-size:24px;
  }
  .xui-mini-chart-card strong,
  .stat strong,
  .xui-stat strong{
    font-size:28px;
  }
  .client-player-logo{
    width:38px;
    height:38px;
  }
  .client-menu-button{
    width:42px;
    height:42px;
    min-width:42px;
  }
  .modal{
    padding:10px;
  }
  .modal-box{
    border-radius:16px;
    padding:12px;
    max-height:90dvh;
  }
}


/* Login limpio: logo grande centrado y nombre del sistema al medio */
.login-card{
  text-align:center;
}
.login-card .logo{
  width:174px!important;
  height:174px!important;
  border-radius:34px!important;
  font-size:58px!important;
  margin:0 auto 18px auto!important;
}
.login-card .brand-logo-box{
  padding:10px!important;
}
.login-card .brand-logo-box img{
  object-fit:contain!important;
}
.login-card .login-system-name{
  display:block;
  text-align:center;
  font-size:34px!important;
  margin:0 0 22px!important;
  width:100%;
}
.login-card > p{
  display:none!important;
}
@media(max-width:520px){
  .login-card .logo{
    width:142px!important;
    height:142px!important;
    border-radius:30px!important;
    font-size:48px!important;
  }
  .login-card .login-system-name{
    font-size:29px!important;
  }
}

/* v5.5 - Menú lateral deslizable: PC a la izquierda, contenido a la derecha; móvil como drawer */
.xui-admin-layout{
  position:relative;
  grid-template-columns:292px minmax(0,1fr)!important;
  align-items:stretch;
  overflow:hidden;
}
.xui-admin-sidebar{
  width:292px;
  max-width:292px;
  transform:translateX(0);
  transition:transform .28s ease, opacity .22s ease, box-shadow .28s ease;
  z-index:60;
}
.xui-admin-main{
  min-width:0;
  overflow:hidden;
}
.xui-admin-layout.sidebar-collapsed{
  grid-template-columns:0 minmax(0,1fr)!important;
}
.xui-admin-layout.sidebar-collapsed .xui-admin-sidebar{
  transform:translateX(-112%);
  opacity:0;
  pointer-events:none;
}
.xui-sidebar-open-handle{
  display:none;
  position:fixed;
  left:10px;
  top:12px;
  z-index:95;
  align-items:center;
  gap:7px;
  height:42px;
  padding:0 13px;
  border-radius:0 14px 14px 0;
  border:1px solid rgba(39,211,255,.25);
  border-left:0;
  background:linear-gradient(135deg,rgba(39,211,255,.96),rgba(139,92,246,.96));
  color:#06101e;
  font-weight:950;
  box-shadow:0 12px 35px rgba(0,0,0,.32);
}
.xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle{
  display:flex;
}
.xui-sidebar-backdrop{
  display:none;
}
.sidebar-collapsed .xui-sidebar-brand-text,
.sidebar-collapsed .xui-menu-section span,
.sidebar-collapsed .xui-menu-section button em,
.sidebar-collapsed .xui-credit-line{
  display:block;
}
.sidebar-collapsed .xui-admin-sidebar{
  align-items:stretch;
}
.sidebar-collapsed .xui-menu-section button{
  justify-content:flex-start;
}
.sidebar-collapsed .xui-menu-section button b{
  margin:0;
}

/* El formulario/contenido nunca baja debajo del menú en PC */
@media(min-width:901px){
  .xui-admin-layout{
    min-height:100vh;
  }
  .xui-admin-sidebar{
    position:sticky!important;
    top:0!important;
    height:100vh!important;
    border-radius:0!important;
    border-bottom:0!important;
  }
  .xui-admin-main{
    padding:18px!important;
  }
}

/* Móvil: el menú se desliza desde la izquierda y no empuja el contenido hacia abajo */
@media(max-width:900px){
  .xui-admin-layout,
  .xui-admin-layout.sidebar-collapsed{
    display:block!important;
    min-height:100dvh;
    overflow-x:hidden;
  }
  .xui-admin-sidebar,
  .sidebar-collapsed .xui-admin-sidebar{
    position:fixed!important;
    top:0!important;
    left:0!important;
    bottom:0!important;
    width:min(292px,86vw)!important;
    max-width:min(292px,86vw)!important;
    height:100dvh!important;
    min-height:100dvh!important;
    display:flex!important;
    border-radius:0 20px 20px 0!important;
    border-right:1px solid rgba(255,255,255,.12)!important;
    border-bottom:0!important;
    box-shadow:24px 0 80px rgba(0,0,0,.42)!important;
    overflow-y:auto!important;
  }
  .xui-admin-layout:not(.sidebar-collapsed) .xui-sidebar-backdrop{
    display:block;
    position:fixed;
    inset:0;
    z-index:55;
    background:rgba(0,0,0,.56);
    backdrop-filter:blur(2px);
  }
  .xui-admin-layout.sidebar-collapsed .xui-admin-sidebar{
    transform:translateX(-112%)!important;
    opacity:0!important;
    pointer-events:none!important;
  }
  .xui-admin-layout:not(.sidebar-collapsed) .xui-admin-sidebar{
    transform:translateX(0)!important;
    opacity:1!important;
    pointer-events:auto!important;
  }
  .xui-admin-main{
    width:100%!important;
    padding:12px!important;
    margin:0!important;
  }
  .xui-admin-topbar.xui-compact-topbar{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
    justify-content:space-between!important;
    gap:10px!important;
    padding-left:58px!important;
  }
  .xui-topbar-left{
    width:auto!important;
    flex:1 1 auto!important;
  }
  .admin-menu-wrap{
    position:relative!important;
    right:auto!important;
    top:auto!important;
  }
  .xui-sidebar-toggle-zone{
    display:flex!important;
  }
  .xui-menu-section{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .xui-menu-section button{
    width:100%!important;
  }
  .xui-sidebar-footer{
    display:grid!important;
  }
  .xui-sidebar-open-handle{
    display:flex;
  }
  .xui-admin-layout:not(.sidebar-collapsed) .xui-sidebar-open-handle{
    display:none;
  }
}

@media(max-width:520px){
  .xui-admin-topbar.xui-compact-topbar{
    padding:10px 10px 10px 54px!important;
  }
  .xui-topbar-left h1{
    font-size:18px!important;
  }
  .xui-topbar-left p{
    display:none;
  }
  .xui-sidebar-open-handle{
    height:38px;
    padding:0 10px;
  }
  .xui-sidebar-open-handle span{
    display:none;
  }
}

/* Reproductor rapido y ligero con controles propios */
.fast-player-panel{
  background:rgba(8,12,22,.96)!important;
}
.fast-video-box{
  position:relative;
  background:#000!important;
  overflow:hidden;
}
.smart-player{
  position:relative;
  width:100%;
  aspect-ratio:16/9;
  min-height:360px;
  background:#000;
  overflow:hidden;
  user-select:none;
  touch-action:manipulation;
}
.smart-player video{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  background:#000;
  min-height:0!important;
  aspect-ratio:auto!important;
}
.player-title-float{
  position:absolute;
  left:14px;
  top:14px;
  right:72px;
  z-index:4;
  color:#fff;
  font-weight:900;
  font-size:14px;
  line-height:1.25;
  text-shadow:0 2px 12px rgba(0,0,0,.85);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  opacity:.98;
  pointer-events:none;
}
.center-play-btn{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:74px;
  height:74px;
  border-radius:999px;
  display:grid;
  place-items:center;
  z-index:6;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(10,15,28,.72);
  color:#fff;
  font-size:30px;
  line-height:1;
  box-shadow:0 18px 50px rgba(0,0,0,.45);
  backdrop-filter:blur(8px);
  opacity:.92;
}
.smart-player:not(.controls-visible) .center-play-btn{
  opacity:0;
  pointer-events:none;
}
.smart-player video:paused + .player-loader + .center-play-btn,
.smart-player.controls-visible .center-play-btn{
  opacity:.92;
  pointer-events:auto;
}
.player-loader{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  align-content:center;
  gap:10px;
  z-index:7;
  background:radial-gradient(circle at center,rgba(39,211,255,.08),rgba(0,0,0,.18) 44%,rgba(0,0,0,.52));
  color:#fff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.7px;
  text-transform:uppercase;
}
.player-loader span{
  width:42px;
  height:42px;
  border-radius:999px;
  border:4px solid rgba(255,255,255,.16);
  border-top-color:#27d3ff;
  animation:spinPlayer .8s linear infinite;
}
@keyframes spinPlayer{to{transform:rotate(360deg)}}
.smart-controls{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  z-index:8;
  padding:38px 14px 12px;
  background:linear-gradient(to top,rgba(0,0,0,.86),rgba(0,0,0,.48),rgba(0,0,0,0));
  opacity:0;
  transform:translateY(16px);
  transition:opacity .16s ease,transform .16s ease;
  pointer-events:none;
}
.smart-player.controls-visible .smart-controls,
.smart-player:hover .smart-controls{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.smart-progress{
  position:relative;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.20);
  overflow:hidden;
  cursor:pointer;
  margin-bottom:10px;
  box-shadow:0 0 0 1px rgba(255,255,255,.08) inset;
}
.smart-progress:hover{height:10px}
.smart-buffer,
.smart-progress-bar{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:0%;
  border-radius:inherit;
  transition:width .18s linear;
}
.smart-buffer{background:rgba(255,255,255,.34)}
.smart-progress-bar{background:linear-gradient(90deg,#27d3ff,#8b5cf6);box-shadow:0 0 18px rgba(39,211,255,.34)}
.smart-control-row{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:0;
}
.ctrl-btn,
.quality-select{
  height:38px;
  border-radius:11px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.10);
  color:#fff;
  font-weight:900;
  padding:0 11px;
  backdrop-filter:blur(8px);
  box-shadow:none;
}
.ctrl-btn:hover,
.quality-select:hover{
  background:rgba(39,211,255,.18);
  border-color:rgba(39,211,255,.38);
  transform:none;
}
.main-play{
  width:44px;
  min-width:44px;
  font-size:18px;
  background:linear-gradient(135deg,rgba(39,211,255,.94),rgba(139,92,246,.94));
  color:#06101e;
}
.icon-mini{width:42px;min-width:42px;padding:0}
.smart-time{
  color:#eaf2ff;
  font-size:12px;
  font-weight:900;
  min-width:98px;
  text-align:center;
  text-shadow:0 1px 8px rgba(0,0,0,.8);
}
.volume-box{
  display:flex;
  align-items:center;
  gap:6px;
  min-width:132px;
}
.volume-box input[type=range]{
  width:86px;
  height:4px;
  accent-color:#27d3ff;
  padding:0;
}
.quality-select{
  min-width:132px;
  max-width:190px;
  background:rgba(10,15,28,.84);
}
.quality-select:disabled{opacity:.72}
.smart-player:fullscreen{
  width:100vw;
  height:100vh;
  aspect-ratio:auto;
}
.smart-player:fullscreen video{
  width:100vw;
  height:100vh;
}
.smart-player:fullscreen .smart-controls{padding-bottom:18px}

@media(max-width:1100px){
  .smart-player{min-height:300px}
  .smart-control-row{flex-wrap:wrap}
  .quality-select{margin-left:auto}
}
@media(max-width:720px){
  .smart-player{min-height:220px;aspect-ratio:16/9}
  .player-title-float{font-size:12px;left:10px;top:10px;right:54px}
  .center-play-btn{width:58px;height:58px;font-size:24px}
  .smart-controls{padding:34px 9px 9px}
  .smart-control-row{gap:6px}
  .ctrl-btn,.quality-select{height:34px;border-radius:10px;font-size:12px;padding:0 8px}
  .main-play{width:38px;min-width:38px}
  .icon-mini{width:36px;min-width:36px}
  .smart-time{order:10;width:100%;text-align:left;min-width:0;font-size:11px}
  .volume-box{min-width:104px;flex:1 1 104px}
  .volume-box input[type=range]{width:64px}
  .quality-select{flex:1 1 118px;min-width:118px;max-width:none;margin-left:0}
}

/* v5.7.1 - Barra de progreso para importacion de contenido */
.import-progress-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px;
  background:rgba(3,7,18,.62);
  backdrop-filter:blur(8px);
}
.import-progress-card{
  width:min(520px,100%);
  border:1px solid rgba(39,211,255,.24);
  border-radius:22px;
  padding:22px;
  background:linear-gradient(180deg,rgba(13,21,40,.98),rgba(8,13,25,.98));
  box-shadow:0 24px 70px rgba(0,0,0,.42),0 0 34px rgba(39,211,255,.10);
}
.import-progress-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}
.import-progress-head strong{
  color:#f2f7ff;
  font-size:18px;
  letter-spacing:.2px;
}
.import-progress-head span{
  min-width:58px;
  text-align:right;
  color:#27d3ff;
  font-weight:900;
  font-size:16px;
}
.import-progress-track{
  width:100%;
  height:15px;
  overflow:hidden;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.08);
}
.import-progress-bar{
  height:100%;
  width:0%;
  border-radius:999px;
  background:linear-gradient(90deg,#27d3ff,#7a5cff,#00ff85);
  box-shadow:0 0 20px rgba(39,211,255,.36);
  transition:width .26s ease;
}
.import-progress-text{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}
.import-progress-overlay.done .import-progress-card{border-color:rgba(0,255,133,.30)}
.import-progress-overlay.done .import-progress-head span{color:#00ff85}
.import-progress-overlay.error .import-progress-card{border-color:rgba(255,92,122,.40)}
.import-progress-overlay.error .import-progress-head span{color:#ff5c7a}
.import-progress-overlay.error .import-progress-bar{background:linear-gradient(90deg,#ff5c7a,#ffb86b)}
.import-inline-progress{
  margin-top:12px;
  padding:12px;
  border:1px dashed rgba(39,211,255,.24);
  border-radius:14px;
  background:rgba(39,211,255,.05);
}
.import-inline-track{
  height:8px;
  border-radius:999px;
  overflow:hidden;
  background:rgba(255,255,255,.08);
  margin-bottom:8px;
}
.import-inline-track span{
  display:block;
  width:38%;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,#27d3ff,#7a5cff);
}
.import-inline-progress small{color:var(--muted)}
@media(max-width:720px){
  .import-progress-card{padding:18px;border-radius:18px}
  .import-progress-head strong{font-size:16px}
}
