@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.8.0 - evita titulos duplicados debajo del encabezado principal */
.xui-admin-panel #adminContent > .panel-head > h2,
.xui-admin-panel #adminContent > .panel-head.xui-section-head > div:first-child {
  display: none !important;
}
.xui-admin-panel #adminContent > .panel-head {
  justify-content: flex-end;
}
.xui-admin-panel #adminContent > .panel-head:has(> h2:only-child),
.xui-admin-panel #adminContent > .panel-head.xui-section-head:has(> div:first-child:last-child) {
  display: none !important;
}

/* v6.0.0 - reproductor cliente limpio tipo IPTV: solo cuadro + titulo, sin datos de servidor */
.compact-xui-player{
  background:rgba(5,8,16,.98)!important;
}
.xui-only-player-box{
  border-bottom:0!important;
  padding:0;
}
.compact-xui-player .smart-player{
  border-radius:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);
}
.compact-xui-player .xui-client-now.clean-player-title{
  padding:12px 14px 14px;
  border-top:1px solid rgba(255,255,255,.08);
  background:#070b14;
}
.compact-xui-player .xui-client-now.clean-player-title h2{
  font-size:16px;
  font-weight:900;
  letter-spacing:.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.compact-xui-player #playDebug.hidden{
  display:none!important;
}
.compact-xui-player #playDebug.message.err{
  margin:10px 12px 12px;
}
@media(max-width:860px){
  .compact-xui-player{
    order:-1;
  }
  .xui-player-layout{
    gap:10px;
  }
}

.verify-link-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.verify-result{margin-top:8px;padding:10px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);line-height:1.45}
.verify-result.ok{border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.08);color:#b9ffe4}
.verify-result.err{border-color:rgba(255,92,122,.35);background:rgba(255,92,122,.08);color:#ffd1da}
.status-dot{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;border:1px solid var(--line);font-size:12px;font-weight:800;white-space:nowrap}
.status-dot.online{border-color:rgba(52,211,153,.45);background:rgba(52,211,153,.11);color:#b9ffe4}
.status-dot.offline{border-color:rgba(255,92,122,.45);background:rgba(255,92,122,.1);color:#ffd1da}
.status-dot.pending{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:var(--muted)}
.err-text{color:#ffd1da!important}
@media(max-width:720px){.verify-link-row{grid-template-columns:1fr}.verify-link-row button{width:100%}}

/* Seguridad / Copias de seguridad */
.visible-card{display:block!important;}
.security-grid{align-items:stretch;margin:14px 0;}
.backup-status-card{display:grid;grid-template-columns:1fr auto;gap:10px;margin-top:12px;padding:14px;border:1px solid rgba(255,255,255,.12);border-radius:14px;background:rgba(255,255,255,.04);}
.backup-status-card span{color:var(--muted,#9aa4b2);}
.backup-status-card b{letter-spacing:.04em;}


/* Ajuste solicitado: boton de menu fijo/integrado a la izquierda, no flotante */
@media(min-width:901px){
  .xui-admin-layout.sidebar-collapsed{
    grid-template-columns:64px minmax(0,1fr)!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-admin-sidebar{
    display:none!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle{
    display:flex!important;
    position:sticky!important;
    grid-column:1!important;
    grid-row:1!important;
    top:16px!important;
    left:auto!important;
    z-index:80!important;
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    padding:0!important;
    margin:16px auto 0!important;
    align-items:center!important;
    justify-content:center!important;
    border-radius:12px!important;
    border:1px solid rgba(255,255,255,.09)!important;
    background:rgba(255,255,255,.045)!important;
    color:#dbeafe!important;
    box-shadow:none!important;
    font-size:20px!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle:hover{
    background:rgba(39,211,255,.10)!important;
    border-color:rgba(39,211,255,.28)!important;
    transform:none!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-admin-main{
    grid-column:2!important;
  }
}

@media(max-width:900px){
  .xui-sidebar-open-handle{
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    padding:0!important;
    border-radius:12px!important;
    border:1px solid rgba(255,255,255,.09)!important;
    background:rgba(255,255,255,.045)!important;
    color:#dbeafe!important;
    box-shadow:none!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:20px!important;
  }
  .xui-sidebar-open-handle:hover{
    background:rgba(39,211,255,.10)!important;
    border-color:rgba(39,211,255,.28)!important;
    transform:none!important;
  }
}

/* Mensaje de bienvenida y solicitudes de contenido */
.welcome-message-card{
  display:flex;
  align-items:center;
  gap:12px;
  border:1px solid rgba(39,211,255,.22);
  background:linear-gradient(135deg,rgba(39,211,255,.10),rgba(139,92,246,.08));
  border-radius:18px;
  padding:13px 15px;
  color:#eaf6ff;
  box-shadow:0 12px 34px rgba(0,0,0,.18);
}
.welcome-message-card .welcome-avatar{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#06111f;font-weight:950;letter-spacing:.4px;
}
.welcome-message-card span{display:block;color:#8ea0bd;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px}
.welcome-message-card strong{display:block;color:#f8fbff;font-size:16px;line-height:1.15}
.welcome-message-card small{display:block;color:#a5f3fc;font-size:12px;margin-top:4px;font-weight:800}
.client-welcome-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:12px 0 14px;flex-wrap:wrap}









@media(max-width:760px){.client-welcome-row{align-items:stretch}.client-welcome-row .primary{width:100%}}

/* Correccion solicitada: menu sin barra de subir/bajar; solo boton izquierdo con mismo diseño del boton cerrar */
.xui-admin-sidebar,
.xui-admin-sidebar *{
  scrollbar-width:none!important;
}
.xui-admin-sidebar::-webkit-scrollbar,
.xui-admin-sidebar *::-webkit-scrollbar{
  width:0!important;
  height:0!important;
  display:none!important;
}
.xui-admin-sidebar{
  overflow-y:hidden!important;
}
@media(max-width:900px){
  .xui-admin-sidebar,
  .sidebar-collapsed .xui-admin-sidebar{
    overflow-y:hidden!important;
  }
}
@media(min-width:901px){
  .xui-admin-layout.sidebar-collapsed{
    grid-template-columns:56px minmax(0,1fr)!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle{
    display:flex!important;
    position:sticky!important;
    top:16px!important;
    left:0!important;
    width:44px!important;
    height:44px!important;
    min-width:44px!important;
    padding:0!important;
    margin:16px 6px!important;
    border-radius:12px!important;
    border:1px solid rgba(255,255,255,.09)!important;
    background:rgba(255,255,255,.045)!important;
    color:#dbeafe!important;
    box-shadow:none!important;
    align-items:center!important;
    justify-content:center!important;
    font-size:20px!important;
  }
}
@media(max-width:900px){
  .xui-sidebar-open-handle{
    left:10px!important;
    top:10px!important;
    border-radius:12px!important;
    border:1px solid rgba(255,255,255,.09)!important;
    background:rgba(255,255,255,.045)!important;
    color:#dbeafe!important;
    box-shadow:none!important;
  }
}

.check-line.adult-check {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 12px;
  background: rgba(255,255,255,.04);
  cursor: pointer;
  user-select: none;
}
.check-line.adult-check input {
  width: 18px;
  height: 18px;
  accent-color: #38bdf8;
}

/* Ajuste final solicitado: menu sin control visible de subir/bajar y boton abrir centrado a la izquierda */
.xui-admin-sidebar{
  overflow-y:auto!important;
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
}
.xui-admin-sidebar::-webkit-scrollbar{
  width:0!important;
  height:0!important;
  display:none!important;
}
.xui-admin-sidebar *{
  scrollbar-width:none!important;
  -ms-overflow-style:none!important;
}
.xui-admin-sidebar *::-webkit-scrollbar{
  width:0!important;
  height:0!important;
  display:none!important;
}

.xui-admin-layout.sidebar-collapsed{
  grid-template-columns:58px minmax(0,1fr)!important;
}
.xui-admin-layout.sidebar-collapsed .xui-admin-main{
  grid-column:2!important;
}
.xui-admin-layout.sidebar-collapsed .xui-admin-sidebar{
  display:none!important;
}
.xui-sidebar-open-handle{
  display:none!important;
}
.xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle{
  display:flex!important;
  position:fixed!important;
  left:7px!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  z-index:95!important;
  width:44px!important;
  height:44px!important;
  min-width:44px!important;
  padding:0!important;
  margin:0!important;
  align-items:center!important;
  justify-content:center!important;
  gap:0!important;
  border-radius:12px!important;
  background:rgba(255,255,255,.045)!important;
  border:1px solid rgba(255,255,255,.09)!important;
  border-left:1px solid rgba(255,255,255,.09)!important;
  color:#dbeafe!important;
  box-shadow:none!important;
  font-size:20px!important;
  font-weight:900!important;
  line-height:1!important;
}
.xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle:hover{
  background:rgba(39,211,255,.10)!important;
  border-color:rgba(39,211,255,.28)!important;
  transform:translateY(-50%)!important;
}
.xui-admin-layout:not(.sidebar-collapsed) .xui-sidebar-open-handle{
  display:none!important;
}

@media(max-width:900px){
  .xui-admin-layout,
  .xui-admin-layout.sidebar-collapsed{
    display:block!important;
  }
  .xui-admin-main{
    grid-column:auto!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle{
    left:8px!important;
    top:50%!important;
    transform:translateY(-50%)!important;
  }
  .xui-admin-layout.sidebar-collapsed .xui-sidebar-open-handle:hover{
    transform:translateY(-50%)!important;
  }
  .xui-admin-sidebar,
  .sidebar-collapsed .xui-admin-sidebar{
    overflow-y:auto!important;
    scrollbar-width:none!important;
  }
}

.mass-delete-card{border-color:rgba(255,90,90,.28);background:linear-gradient(180deg,rgba(255,80,80,.055),rgba(255,255,255,.025));}
.mass-delete-options label{display:flex;align-items:flex-start;gap:9px;padding:10px;border:1px solid rgba(255,255,255,.10);border-radius:12px;background:rgba(255,255,255,.025);line-height:1.25;}
.mass-delete-options label span{display:block;margin-top:3px;width:100%;}
.mass-delete-options input[type="checkbox"]{width:auto;margin-top:2px;}
.mass-count-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:12px 0;}
.mass-count-grid span{display:block;padding:10px;border:1px solid rgba(255,255,255,.10);border-radius:12px;background:rgba(0,0,0,.14);}
.mass-count-grid b{display:block;font-size:20px;color:#fff;}
.mass-count-grid small{display:block;color:var(--muted,#9aa4b2);font-size:11px;}
@media(max-width:760px){.mass-count-grid{grid-template-columns:repeat(2,minmax(0,1fr));}.mass-delete-options{grid-template-columns:1fr;}}

/* Tema claro / oscuro persistente con boton deslizable */
.theme-toggle-btn.ghost.theme-toggle-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:0;
  min-height:42px;
  padding:5px;
  border-radius:999px;
  font-weight:950;
  white-space:nowrap;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(8,13,26,.68);
  color:var(--text);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.035),0 10px 25px rgba(0,0,0,.18);
  backdrop-filter:blur(14px);
}
.theme-toggle-btn.ghost.theme-toggle-btn:hover{
  filter:none;
  transform:translateY(-1px);
  border-color:rgba(39,211,255,.34);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.05),0 14px 32px rgba(0,0,0,.25);
}
.theme-switch-track{
  position:relative;
  width:64px;
  height:32px;
  flex:0 0 auto;
  display:block;
  border-radius:999px;
  overflow:hidden;
  background:linear-gradient(135deg,#10192d,#202d51);
  box-shadow:inset 0 2px 8px rgba(0,0,0,.42);
}
.theme-switch-track:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,#eaf6ff,#b9e8ff);
  opacity:0;
  transition:opacity .24s ease;
}
.theme-switch-symbol{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:1;
  font-size:13px;
  line-height:1;
  opacity:.86;
  pointer-events:none;
}
.theme-switch-sun{left:9px}
.theme-switch-moon{right:9px}
.theme-switch-thumb{
  position:absolute;
  z-index:2;
  top:4px;
  left:4px;
  width:24px;
  height:24px;
  border-radius:999px;
  display:grid;
  place-items:center;
  color:#06101e;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 7px 18px rgba(0,0,0,.34);
  transition:left .24s ease,background .24s ease,box-shadow .24s ease;
}
.theme-toggle-icon{font-size:13px;line-height:1}
.theme-toggle-btn.is-light .theme-switch-track:before{opacity:1}
.theme-toggle-btn.is-light .theme-switch-thumb{
  left:36px;
  background:linear-gradient(135deg,#ffffff,#ffe48a);
  box-shadow:0 7px 18px rgba(217,119,6,.20);
}
.theme-login-action{
  position:fixed;
  top:18px;
  right:18px;
  z-index:20;
}
.theme-floating-btn{box-shadow:0 14px 35px rgba(0,0,0,.25);backdrop-filter:blur(12px)}
.xui-admin-topbar-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.admin-menu-wrap{display:flex;align-items:center;gap:10px}
.client-menu-wrap{display:flex;align-items:center;gap:10px}
body[data-theme="light"] .theme-toggle-btn.ghost.theme-toggle-btn{
  background:rgba(255,255,255,.78);
  border-color:rgba(20,35,60,.15);
  color:#102033;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.55),0 12px 28px rgba(15,35,70,.12);
}
body[data-theme="light"] .theme-toggle-btn.ghost.theme-toggle-btn:hover{border-color:rgba(8,119,201,.30)}
@media(max-width:720px){
  .theme-toggle-btn.ghost.theme-toggle-btn{width:auto;min-width:auto;padding:5px}
  .theme-login-action{top:12px;right:12px}
}

body[data-theme="light"]{
  --bg:#edf3fb;
  --panel:#ffffff;
  --panel2:#e9f1fb;
  --line:rgba(20,35,60,.16);
  --text:#102033;
  --muted:#607086;
  --accent:#0877c9;
  --accent2:#6954d9;
  background:radial-gradient(circle at 0 0,rgba(8,119,201,.15),transparent 28%),radial-gradient(circle at 100% 0,rgba(105,84,217,.13),transparent 30%),var(--bg);
  color:var(--text);
}
body[data-theme="light"] button{color:var(--text);background:var(--panel2)}
body[data-theme="light"] button.primary,
body[data-theme="light"] button.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
body[data-theme="light"] button.ghost{background:rgba(255,255,255,.72);border-color:var(--line);color:#16273c}
body[data-theme="light"] button.danger{background:rgba(225,29,72,.09);border-color:rgba(225,29,72,.28);color:#9f1239}
body[data-theme="light"] button.ok{background:rgba(5,150,105,.09);border-color:rgba(5,150,105,.28);color:#065f46}
body[data-theme="light"] input,
body[data-theme="light"] select,
body[data-theme="light"] textarea{background:#ffffff;color:#102033;border-color:var(--line)}
body[data-theme="light"] input:focus,
body[data-theme="light"] select:focus,
body[data-theme="light"] textarea:focus{border-color:rgba(8,119,201,.72);box-shadow:0 0 0 3px rgba(8,119,201,.12)}
body[data-theme="light"] .login-card,
body[data-theme="light"] .topbar,
body[data-theme="light"] .side,
body[data-theme="light"] .panel,
body[data-theme="light"] .catalog,
body[data-theme="light"] .player,
body[data-theme="light"] .xui-admin-panel,
body[data-theme="light"] .xui-hero-card,
body[data-theme="light"] .xui-mini-chart-card,
body[data-theme="light"] .form-card,
body[data-theme="light"] .stat,
body[data-theme="light"] .info-card,
body[data-theme="light"] .modal-box,
body[data-theme="light"] .welcome-message-card,
body[data-theme="light"] .welcome-user-card,
body[data-theme="light"] .dashboard-welcome,
body[data-theme="light"] .backup-status-card,
body[data-theme="light"] .mass-delete-card,
body[data-theme="light"] .mass-count-card{
  background:rgba(255,255,255,.88);
  border-color:var(--line);
  color:var(--text);
  box-shadow:0 18px 55px rgba(30,54,84,.08);
}
body[data-theme="light"] .xui-admin-sidebar{
  background:linear-gradient(180deg,#ffffff,#eef5ff);
  border-right:1px solid var(--line);
  box-shadow:18px 0 55px rgba(30,54,84,.10);
}
body[data-theme="light"] .xui-sidebar-brand,
body[data-theme="light"] .xui-sidebar-footer,
body[data-theme="light"] .panel-head,
body[data-theme="light"] .filters,
body[data-theme="light"] .catalog-tabs,
body[data-theme="light"] .xui-mini-stats,
body[data-theme="light"] .xui-client-now,
body[data-theme="light"] .now{
  border-color:var(--line);
}
body[data-theme="light"] .xui-sidebar-user,
body[data-theme="light"] .xui-credit-line,
body[data-theme="light"] .xui-menu-section button,
body[data-theme="light"] .xui-module-grid button,
body[data-theme="light"] .item,
body[data-theme="light"] .category-row,
body[data-theme="light"] .xui-mini-stats div,
body[data-theme="light"] .note,
body[data-theme="light"] .message,
body[data-theme="light"] .pill{
  background:rgba(255,255,255,.70);
  border-color:var(--line);
  color:var(--muted);
}
body[data-theme="light"] .xui-menu-section button{color:#42526a}
body[data-theme="light"] .xui-menu-section button b{background:rgba(8,119,201,.10);color:#0877c9}
body[data-theme="light"] .xui-menu-section button:hover{background:rgba(8,119,201,.08);border-color:rgba(8,119,201,.22)}
body[data-theme="light"] .xui-menu-section button.active{background:linear-gradient(90deg,rgba(8,119,201,.16),rgba(105,84,217,.10));border-color:rgba(8,119,201,.32);color:#102033;box-shadow:inset 3px 0 0 var(--accent)}
body[data-theme="light"] .xui-menu-section button.active b{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff}
body[data-theme="light"] .xui-sidebar-user b,
body[data-theme="light"] .profile-summary-grid strong,
body[data-theme="light"] .xui-mini-chart-card strong,
body[data-theme="light"] .xui-hero-card h3,
body[data-theme="light"] .xui-module-grid button b,
body[data-theme="light"] .item-title,
body[data-theme="light"] .now h2,
body[data-theme="light"] .panel-head h2,
body[data-theme="light"] td,
body[data-theme="light"] .xui-diag-grid span{
  color:#102033;
}
body[data-theme="light"] .xui-sidebar-brand span,
body[data-theme="light"] .xui-sidebar-user small,
body[data-theme="light"] .xui-credit-line small,
body[data-theme="light"] .xui-menu-section span,
body[data-theme="light"] .small,
body[data-theme="light"] label,
body[data-theme="light"] .item-meta,
body[data-theme="light"] .topbar p,
body[data-theme="light"] .xui-hero-card p,
body[data-theme="light"] .xui-module-grid button span,
body[data-theme="light"] .xui-mini-chart-card p,
body[data-theme="light"] .profile-summary-grid span{
  color:#607086;
}
body[data-theme="light"] .table-wrap{background:rgba(255,255,255,.82);border-color:var(--line)}
body[data-theme="light"] th{background:#e9f1fb;color:#34445c;border-color:var(--line)}
body[data-theme="light"] td{border-color:var(--line)}
body[data-theme="light"] .client-menu-panel{
  background:rgba(255,255,255,.98);
  border-color:var(--line);
  box-shadow:0 24px 70px rgba(30,54,84,.18);
}
body[data-theme="light"] .poster-fallback,
body[data-theme="light"] .xui-video,
body[data-theme="light"] .video-box,
body[data-theme="light"] .smart-player{background:#0a0f18;color:#dce6ff}
body[data-theme="light"] .message.err{color:#9f1239;background:rgba(225,29,72,.08);border-color:rgba(225,29,72,.28)}
body[data-theme="light"] .message.ok{color:#065f46;background:rgba(5,150,105,.08);border-color:rgba(5,150,105,.28)}
body[data-theme="light"] .note.warn{border-color:rgba(217,119,6,.30);background:rgba(217,119,6,.08);color:#8a4b05}
body[data-theme="light"] .pill.ok{color:#065f46;border-color:rgba(5,150,105,.30);background:rgba(5,150,105,.08)}


/* ================================
   SISTEMA FLETES - DISEÑO TIPO IPTV
   ================================ */

#loginScreen[hidden],
#appShell[hidden] {
  display: none !important;
}

body.auth-login,
body.logged-out {
  overflow: hidden;
}

body.logged-in {
  overflow: auto;
}

.login-screen {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  min-height: 100vh;
  padding: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 10% 5%, rgba(39,211,255,.20), transparent 30%),
    radial-gradient(circle at 95% 0, rgba(139,92,246,.22), transparent 34%),
    radial-gradient(circle at 55% 95%, rgba(39,211,255,.13), transparent 30%),
    var(--bg);
  z-index: 9999;
}

.login-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(to bottom, rgba(255,255,255,.95), rgba(255,255,255,.18));
}

.login-bg-shape {
  position: absolute;
  width: 330px;
  height: 330px;
  border-radius: 999px;
  filter: blur(10px);
  opacity: .55;
  pointer-events: none;
}

.login-bg-shape-1 {
  top: 8%;
  left: 8%;
  background: radial-gradient(circle, rgba(39,211,255,.48), transparent 70%);
}

.login-bg-shape-2 {
  right: 7%;
  bottom: 7%;
  background: radial-gradient(circle, rgba(139,92,246,.44), transparent 70%);
}

.login-card.futuristic-card {
  position: relative;
  z-index: 2;
  width: min(520px, 100%);
  background: rgba(17,26,47,.88);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 28px;
  padding: 30px;
  box-shadow: 0 28px 80px rgba(0,0,0,.42);
  backdrop-filter: blur(18px);
}

.login-card.futuristic-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(39,211,255,.95), rgba(139,92,246,.7), rgba(255,255,255,.18));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

.futuristic-brand {
  display: flex;
  align-items: center;
  gap: 18px;
}

.login-logo {
  width: 76px;
  height: 76px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  font-size: 26px;
  font-weight: 950;
  box-shadow: 0 18px 45px rgba(39,211,255,.25);
  overflow: hidden;
}

.login-logo img,
.header-logo-text img,
.profile-logo-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.login-chip {
  display: inline-flex;
  border: 1px solid rgba(39,211,255,.32);
  background: rgba(39,211,255,.09);
  color: #b9f3ff;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: .14em;
  font-weight: 900;
  margin: 0 0 8px;
}

.futuristic-brand h2 {
  margin: 0;
  color: var(--text);
  font-size: 30px;
  line-height: 1.08;
}

.login-subcopy {
  margin: 8px 0 0;
  color: var(--muted);
  line-height: 1.45;
}

.futuristic-form {
  margin-top: 20px;
}

.futuristic-form label {
  color: var(--muted);
  font-weight: 800;
  font-size: 13px;
}

.futuristic-form input {
  min-height: 52px;
  background: #0d1528;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: 15px;
}

.login-error {
  color: #ffd1da;
  min-height: 20px;
  font-weight: 800;
  margin: 8px 0;
}

.futuristic-button {
  width: 100%;
  min-height: 54px;
  border-radius: 15px;
  margin-top: 8px;
  letter-spacing: .12em;
}

/* Shell */
.app-shell {
  min-height: 100vh;
}

body.logged-out .app-shell,
body.auth-login .app-shell {
  display: none !important;
}

body.logged-in #loginScreen {
  display: none !important;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  background: rgba(17,26,47,.86);
  border: 1px solid var(--line);
  border-radius: 0 0 22px 22px;
  margin: 0 18px 18px 330px;
  padding: 16px 18px;
  backdrop-filter: blur(14px);
  box-shadow: 0 16px 45px rgba(0,0,0,.18);
}

.topbar h1 {
  margin: 0;
  font-size: 24px;
}

.eyebrow {
  color: var(--accent);
  font-weight: 900;
  letter-spacing: .12em;
  font-size: 11px;
  margin: 0 0 4px;
  text-transform: uppercase;
}

.subtitle,
.hint {
  color: var(--muted);
  line-height: 1.45;
}

.subtitle {
  margin: 4px 0 0;
  font-size: 13px;
}

.brand-dynamic {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 190px;
}

.header-logo-text {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  font-weight: 950;
  overflow: hidden;
}

.header-company {
  font-weight: 900;
  color: var(--text);
}

.logout-btn,
.menu-toggle {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.04);
}

/* Menú lateral */
.sidebar-menu {
  position: fixed;
  inset: 0 auto 0 0;
  width: 310px;
  height: 100vh;
  z-index: 80;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px 14px;
  background: rgba(17,26,47,.94);
  border-right: 1px solid var(--line);
  box-shadow: 14px 0 42px rgba(0,0,0,.30);
  overflow-y: auto;
  backdrop-filter: blur(16px);
}

.sidebar-menu::before {
  content: "MENÚ PRINCIPAL";
  display: block;
  color: var(--accent);
  font-size: 12px;
  letter-spacing: .14em;
  font-weight: 950;
  padding: 8px 12px 14px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 8px;
}

.sidebar-menu .tab-btn {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  text-align: left;
  border-radius: 15px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  padding: 12px 14px;
  white-space: normal;
  line-height: 1.2;
}

.sidebar-menu .tab-btn:hover {
  background: rgba(255,255,255,.05);
  border-color: var(--line);
  color: var(--text);
}

.sidebar-menu .tab-btn.active {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  font-weight: 950;
}

body.menu-collapsed .sidebar-menu {
  width: 78px;
  padding-left: 10px;
  padding-right: 10px;
}

body.menu-collapsed .sidebar-menu::before {
  content: "MENÚ";
  writing-mode: vertical-rl;
  text-orientation: mixed;
  margin: 0 auto 12px;
  padding: 8px 0 12px;
}

body.menu-collapsed .sidebar-menu .tab-btn {
  font-size: 0;
  justify-content: center;
  min-height: 46px;
}

body.menu-collapsed .sidebar-menu .tab-btn::after {
  content: "•";
  font-size: 28px;
  line-height: 1;
}

body.menu-collapsed .topbar {
  margin-left: 98px;
}

body.menu-collapsed main,
body.menu-collapsed footer {
  margin-left: 98px;
}

body.menu-collapsed #menuToggle {
  left: 92px;
}

#menuToggle {
  position: fixed;
  left: 322px;
  top: 18px;
  z-index: 100;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  font-weight: 950;
  width: 46px;
  height: 46px;
  padding: 0;
}

/* Contenido */
main {
  width: auto;
  max-width: none;
  margin: 18px 18px 28px 330px;
}

footer {
  margin: 24px 18px 0 330px;
  color: var(--muted);
  text-align: center;
  padding: 20px;
}

.tab-panel {
  display: none;
}

.tab-panel.active {
  display: block;
}

.card,
.stat-card,
.module-toolbar,
.report-paper {
  background: rgba(17,26,47,.90);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: 0 18px 48px rgba(0,0,0,.18);
}

.card,
.report-paper {
  padding: 16px;
  margin-bottom: 16px;
}

.card h2,
.module-toolbar h2 {
  margin: 0 0 10px;
  color: var(--text);
}

.module-toolbar {
  padding: 16px;
  margin-bottom: 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
}

.module-toolbar h2 {
  margin: 0;
  font-size: 21px;
}

.grid {
  display: grid;
  gap: 12px;
}

.grid.two,
.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.two-col {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.stats {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-bottom: 16px;
}

.stat-card {
  padding: 16px;
}

.stat-card span {
  color: var(--muted);
  font-size: 12px;
}

.stat-card strong {
  display: block;
  margin-top: 6px;
  font-size: 22px;
  color: var(--text);
}

.stat-card.warning strong {
  color: var(--warn);
}

.stat-card.success strong {
  color: var(--ok);
}

.steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.steps div {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.035);
  border-radius: 16px;
  padding: 14px;
}

.steps b {
  width: 32px;
  height: 32px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  margin-bottom: 10px;
}

.form-card {
  background: rgba(255,255,255,.035);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 16px;
  margin-bottom: 16px;
}

.form-collapsed {
  display: none !important;
}

.form-card.form-open {
  display: block !important;
  border-left: 7px solid var(--accent);
}

.actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.actions.wrap {
  flex-wrap: wrap;
}

.add-btn {
  white-space: nowrap;
}

.table-wrap {
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
}

table {
  width: 100%;
  border-collapse: collapse;
  min-width: 780px;
}

th,
td {
  padding: 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  font-size: 13px;
}

th {
  color: #dce6ff;
  background: rgba(255,255,255,.05);
  font-weight: 900;
}

td {
  color: var(--text);
}

td button {
  padding: 8px 10px;
  font-size: 12px;
  margin: 2px;
}

.paper,
.mini-report,
.profile-preview,
.report-selected-note,
.total-line,
.report-controls {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  padding: 14px;
}

.mini-report,
.profile-preview {
  margin: 12px 0;
}

.profile-preview {
  display: flex;
  align-items: center;
  gap: 14px;
}

.profile-logo-preview {
  width: 74px;
  height: 74px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  overflow: hidden;
  font-weight: 950;
}

.total-line {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin: 8px 0;
}

.total-line.desc span:last-child {
  color: var(--danger);
}

.hidden-select {
  display: none !important;
}

.file-btn {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  border: 0;
  border-radius: 13px;
  padding: 11px 13px;
  background: var(--panel2);
  color: var(--text);
}

.file-btn input {
  display: none;
}

.tech-list {
  color: var(--muted);
  line-height: 1.6;
}

@media (max-width: 1000px) {
  .stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .steps {
    grid-template-columns: 1fr;
  }

  .grid.two,
  .two {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  #menuToggle {
    position: static;
  }

  .sidebar-menu {
    transform: translateX(-100%);
    transition: transform .18s ease;
  }

  body.menu-open-mobile .sidebar-menu {
    transform: translateX(0);
  }

  .topbar,
  body.menu-collapsed .topbar {
    margin-left: 14px;
    margin-right: 14px;
  }

  main,
  footer,
  body.menu-collapsed main,
  body.menu-collapsed footer {
    margin-left: 14px;
    margin-right: 14px;
  }

  .module-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .module-toolbar button {
    width: 100%;
  }
}

@media print {
  .sidebar-menu,
  .topbar,
  .module-toolbar,
  footer {
    display: none !important;
  }

  main {
    margin: 0 !important;
  }

  .tab-panel {
    display: block !important;
  }
}


/* V25: Botón Mi perfil con menú desplegable */
.profile-dropdown {
  position: relative;
  display: flex;
  align-items: center;
}

.profile-menu-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 46px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
  color: var(--text);
  border-radius: 15px;
  padding: 10px 13px;
  font-weight: 900;
}

.profile-menu-btn:hover,
.profile-menu-btn.active {
  background: linear-gradient(135deg, rgba(39,211,255,.18), rgba(139,92,246,.18));
  border-color: rgba(39,211,255,.35);
}

.profile-avatar {
  width: 30px;
  height: 30px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #06101e;
  font-size: 15px;
}

.profile-menu-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 250;
  width: 230px;
  padding: 10px;
  background: rgba(17,26,47,.98);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 22px 60px rgba(0,0,0,.42);
  backdrop-filter: blur(16px);
}

.profile-menu-panel[hidden] {
  display: none !important;
}

.profile-menu-item {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  border-radius: 13px;
  background: transparent;
  color: var(--text);
  padding: 11px 12px;
  font-weight: 850;
}

.profile-menu-item:hover {
  background: rgba(255,255,255,.06);
}

.profile-menu-item.danger {
  color: #ffd1da;
}

.profile-menu-item.danger:hover {
  background: rgba(255,92,122,.12);
}

.profile-menu-divider {
  height: 1px;
  background: var(--line);
  margin: 8px 4px;
}

@media (max-width: 720px) {
  .profile-menu-panel {
    right: auto;
    left: 0;
    width: 220px;
  }

  .profile-menu-btn span:not(.profile-avatar) {
    display: none;
  }
}


/* V31: Login limpio con logo grande y nombre debajo */
.login-brand-vertical {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 18px;
  text-align: center;
  margin-bottom: 12px;
}

.login-logo-giant {
  width: 304px;
  height: 304px;
  border-radius: 42px;
  font-size: 88px;
  font-weight: 1000;
  box-shadow: 0 28px 70px rgba(39,211,255,.30);
}

.login-logo-giant img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 18px;
}

.login-company-name {
  margin: 0;
  font-size: clamp(24px, 3vw, 34px);
  line-height: 1.15;
  font-weight: 950;
  letter-spacing: .02em;
  color: var(--text);
}

@media (max-width: 820px) {
  .login-logo-giant {
    width: 220px;
    height: 220px;
    font-size: 62px;
    border-radius: 32px;
  }

  .login-company-name {
    font-size: 24px;
  }
}

@media (max-width: 520px) {
  .login-logo-giant {
    width: 176px;
    height: 176px;
    font-size: 48px;
    border-radius: 28px;
  }
}


/* V32: Centrar completamente el login */
.login-card.futuristic-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.login-brand-vertical {
  width: 100%;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.login-company-name {
  width: 100%;
  text-align: center;
}

.login-form.futuristic-form {
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.login-form.futuristic-form label {
  width: 100%;
  text-align: center;
}

.login-form.futuristic-form input {
  text-align: center;
}

.login-form.futuristic-form .login-error {
  width: 100%;
  text-align: center;
}

.login-form.futuristic-form .login-button {
  align-self: center;
  min-width: 240px;
}

.login-card .login-error,
.login-card noscript {
  text-align: center;
  width: 100%;
}

@media (max-width: 640px) {
  .login-form.futuristic-form {
    max-width: 100%;
  }

  .login-form.futuristic-form .login-button {
    width: 100%;
    min-width: unset;
  }
}


/* V34: botón imprimir en acciones de contrato */
.row-actions button:first-child {
  border: 1px solid rgba(39,211,255,.32);
}


/* V36: logo del login un poco más pequeño */
.login-logo-giant {
  width: 250px;
  height: 250px;
  font-size: 72px;
  border-radius: 36px;
}

.login-logo-giant img {
  padding: 14px;
}

@media (max-width: 820px) {
  .login-logo-giant {
    width: 190px;
    height: 190px;
    font-size: 54px;
    border-radius: 30px;
  }
}

@media (max-width: 520px) {
  .login-logo-giant {
    width: 150px;
    height: 150px;
    font-size: 42px;
    border-radius: 24px;
  }
}


/* V37: logo del login cuadrado, esquinas redondas y sin espacio interno */
.login-logo-giant {
  width: 230px;
  height: 230px;
  aspect-ratio: 1 / 1;
  border-radius: 30px;
  overflow: hidden;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-logo-giant img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 0;
  margin: 0;
  display: block;
}

@media (max-width: 820px) {
  .login-logo-giant {
    width: 180px;
    height: 180px;
    border-radius: 24px;
  }
}

@media (max-width: 520px) {
  .login-logo-giant {
    width: 145px;
    height: 145px;
    border-radius: 20px;
  }
}


/* V38: Menú izquierdo como panel flotante/overlay */
body.logged-in .sidebar-menu {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 310px !important;
  height: 100vh !important;
  z-index: 220 !important;
  transform: translateX(-105%) !important;
  transition: transform .22s ease !important;
}

body.logged-in.menu-open .sidebar-menu {
  transform: translateX(0) !important;
}

body.logged-in .topbar,
body.logged-in main,
body.logged-in footer,
body.logged-in.menu-collapsed .topbar,
body.logged-in.menu-collapsed main,
body.logged-in.menu-collapsed footer {
  margin-left: 18px !important;
  margin-right: 18px !important;
}

body.logged-in .topbar {
  padding-left: 72px !important;
}

body.logged-in #menuToggle,
body.logged-in.menu-collapsed #menuToggle,
body.logged-in.menu-open #menuToggle {
  position: fixed !important;
  left: 18px !important;
  top: 18px !important;
  z-index: 260 !important;
}

body.logged-in.menu-open #menuToggle {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
}

body.logged-in.menu-open::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(2, 6, 23, .48);
  z-index: 210;
  pointer-events: none;
}

body.logged-in.menu-open .sidebar-menu,
body.logged-in.menu-open #menuToggle {
  pointer-events: auto;
}

body.menu-collapsed .sidebar-menu {
  width: 310px !important;
  padding: 18px 14px !important;
}

body.menu-collapsed .sidebar-menu::before {
  content: "MENÚ PRINCIPAL" !important;
  writing-mode: initial !important;
  text-orientation: initial !important;
  margin: 0 0 8px 0 !important;
  padding: 8px 12px 14px !important;
}

body.menu-collapsed .sidebar-menu .tab-btn {
  font-size: inherit !important;
  justify-content: flex-start !important;
  min-height: auto !important;
}

body.menu-collapsed .sidebar-menu .tab-btn::after {
  content: none !important;
}

@media (max-width: 900px) {
  body.logged-in .topbar,
  body.logged-in main,
  body.logged-in footer {
    margin-left: 14px !important;
    margin-right: 14px !important;
  }

  body.logged-in .topbar {
    padding-left: 68px !important;
  }

  body.logged-in #menuToggle {
    position: fixed !important;
    left: 14px !important;
    top: 14px !important;
  }
}


/* V40: Resumen tipo Excel */
.excel-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin: 12px 0;
  color: var(--muted);
  font-weight: 800;
}

.excel-wrap {
  width: 100%;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.025);
}

.excel-table {
  border-collapse: collapse;
  min-width: 760px;
  width: max-content;
}

.excel-table th,
.excel-table td {
  border: 1px solid rgba(255,255,255,.12);
  padding: 0;
  min-width: 130px;
  height: 42px;
}

.excel-table th {
  background: rgba(39,211,255,.10);
  color: var(--text);
  font-weight: 950;
  text-align: center;
  padding: 9px;
}

.excel-table .corner-cell,
.excel-table .row-number {
  min-width: 54px;
  width: 54px;
  background: rgba(139,92,246,.12);
}

.excel-cell {
  width: 100%;
  height: 42px;
  border: 0 !important;
  border-radius: 0 !important;
  background: rgba(255,255,255,.035) !important;
  color: var(--text) !important;
  padding: 8px 10px !important;
  outline: none;
}

.excel-cell:focus {
  background: rgba(39,211,255,.09) !important;
  box-shadow: inset 0 0 0 2px rgba(39,211,255,.55);
}


/* V41: Encabezados del resumen como planilla de fletes */
.excel-table th {
  background: #4a4a4a;
  color: #ffffff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .01em;
  white-space: nowrap;
  padding: 6px 8px;
}

.excel-table .corner-cell,
.excel-table .row-number {
  background: #5a5a5a;
  color: #ffffff;
  min-width: 46px;
  width: 46px;
}

.excel-table th[title] {
  max-width: 170px;
  white-space: normal;
  line-height: 1.1;
}

.excel-table th,
.excel-table td {
  min-width: 138px;
}

.excel-cell {
  font-size: 13px;
}


/* V42: edición estable de celdas del resumen */
.excel-cell {
  cursor: text;
  caret-color: var(--accent);
}

.excel-cell:focus {
  user-select: text;
}


/* V43: Resumen conectado al sistema y reportes */
.summary-import-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 10px 0 14px;
}

.summary-import-grid div {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px;
  background: rgba(39,211,255,.06);
}

@media (max-width: 760px) {
  .summary-import-grid {
    grid-template-columns: 1fr;
  }
}


/* V45: Importar / exportar Excel en Resumen */
.excel-file-btn {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}


/* V46: Resumen guardado por mes */
.month-save-label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-weight: 850;
  font-size: 13px;
}

.month-save-label input {
  min-height: 40px;
  max-width: 150px;
}

#tablaResumenMeses td,
#tablaResumenMeses th {
  white-space: nowrap;
}


/* V47: Borrado de todos los meses guardados */
#eliminarTodosResumenMeses {
  margin-top: 12px;
}


/* V49: Botones internos del reporte */
.report-mode-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 14px 0 18px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
}

.report-mode-buttons button {
  min-width: 160px;
  font-weight: 900;
}

.report-mode-buttons button.active {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(39,211,255,.20);
  border-color: rgba(39,211,255,.65);
}

.report-view-panel[hidden] {
  display: none !important;
}

.report-view-panel.active {
  display: block;
}


/* V50: principal con modelo de planilla de liquidación */
.planilla-liquidacion {
  background: #fff;
  color: #111;
  border: 1px solid #b8b8b8;
  border-radius: 6px;
  padding: 16px;
  font-family: Arial, Helvetica, sans-serif;
}

.planilla-head {
  display: grid;
  grid-template-columns: 170px 1fr 240px;
  gap: 12px;
  align-items: start;
  margin-bottom: 10px;
}

.planilla-brand {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}

.planilla-logo {
  width: 150px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: #f4f4f4;
  border-radius: 4px;
  border: 1px solid #bbb;
}

.planilla-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.planilla-logo-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: #333;
  letter-spacing: 1px;
}

.planilla-title {
  text-align: center;
}

.planilla-title h3 {
  margin: 0;
  font-size: 28px;
  font-weight: 900;
  text-decoration: underline;
  color: #000;
}

.planilla-title p {
  margin: 4px 0 0;
  font-size: 14px;
  color: #444;
}

.planilla-meta-right {
  font-size: 13px;
  line-height: 1.6;
  text-align: left;
  padding-top: 8px;
}

.planilla-subhead {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 18px;
  margin: 8px 0 12px;
  font-size: 14px;
}

.planilla-table-wrap {
  overflow-x: auto;
}

.planilla-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  color: #000;
}

.planilla-table th,
.planilla-table td {
  border: 1px solid #666;
  padding: 5px 6px;
}

.planilla-table th {
  background: #d9d9d9;
  text-align: center;
  font-weight: 900;
}

.planilla-table .num {
  text-align: right;
  white-space: nowrap;
}

.planilla-table .totals-row td {
  background: #efefef;
}

.planilla-sections {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.planilla-section {
  border: 1px solid #888;
}

.planilla-section-title {
  padding: 6px 8px;
  background: #ececec;
  font-weight: 900;
  border-bottom: 1px solid #888;
}

.planilla-section-row {
  display: grid;
  grid-template-columns: 1fr 140px;
  gap: 8px;
  padding: 6px 8px;
  font-size: 13px;
}

.planilla-section-row b {
  text-align: right;
}

.planilla-summary {
  width: min(100%, 420px);
  margin: 18px 0 0 auto;
  border: 1px solid #555;
}

.planilla-summary-row {
  display: grid;
  grid-template-columns: 1fr 120px;
  border-bottom: 1px solid #555;
  font-size: 14px;
}

.planilla-summary-row:last-child {
  border-bottom: 0;
}

.planilla-summary-row span,
.planilla-summary-row b {
  padding: 6px 8px;
}

.planilla-summary-row b {
  text-align: right;
  border-left: 1px solid #555;
}

.planilla-summary-row.highlight span,
.planilla-summary-row.highlight b {
  background: #fff36c;
  font-weight: 900;
}

.planilla-signatures {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 60px;
  text-align: center;
  font-size: 13px;
}

.planilla-signatures span {
  display: block;
  font-weight: 900;
  margin-bottom: 6px;
}

.planilla-signatures b {
  display: inline-block;
  padding-top: 6px;
  border-top: 1px solid #444;
  min-width: 240px;
}

@media (max-width: 980px) {
  .planilla-head {
    grid-template-columns: 1fr;
  }
  .planilla-brand {
    justify-content: center;
  }
  .planilla-meta-right,
  .planilla-title {
    text-align: center;
  }
  .planilla-subhead {
    grid-template-columns: 1fr;
  }
  .planilla-signatures {
    grid-template-columns: 1fr;
  }
  .planilla-signatures b {
    min-width: auto;
    width: 100%;
  }
}


/* V51: Gastos administrativos con modelo detalle de otros débitos */
.detalle-debitos {
  background: #fff;
  color: #111;
  border: 1px solid #b8b8b8;
  border-radius: 6px;
  padding: 16px;
  font-family: Arial, Helvetica, sans-serif;
}

.detalle-title {
  text-align: center;
  margin-bottom: 10px;
}

.detalle-title h3 {
  margin: 0;
  font-size: 23px;
  font-weight: 900;
  color: #000;
}

.detalle-title p {
  margin: 2px 0 0;
  color: #444;
  font-size: 14px;
}

.detalle-head-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 12px;
}

.detalle-left-info,
.detalle-right-info {
  font-size: 14px;
  line-height: 1.65;
}

.detalle-right-info {
  justify-self: end;
  min-width: 310px;
}

.detalle-body-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .95fr);
  gap: 18px;
  align-items: start;
}

.detalle-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  color: #000;
}

.detalle-table th,
.detalle-table td {
  border: 1px solid #666;
  padding: 4px 6px;
}

.detalle-table th {
  background: #d9d9d9;
  text-align: center;
  font-weight: 900;
}

.detalle-table td.num {
  text-align: right;
  white-space: nowrap;
}

.detalle-table td.center {
  text-align: center;
}

.detalle-table .subtotal-row td {
  background: #efefef;
}

.detalle-table .liquido-row td {
  background: #f4f4f4;
}

.hoja-ruta-table {
  min-width: 320px;
}

.detalle-signatures {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-top: 50px;
  text-align: center;
  font-size: 13px;
}

.detalle-signatures span {
  display: block;
  font-weight: 900;
  margin-bottom: 6px;
}

.detalle-signatures b {
  display: inline-block;
  padding-top: 6px;
  border-top: 1px solid #444;
  min-width: 240px;
}

@media (max-width: 980px) {
  .detalle-head-grid,
  .detalle-body-grid,
  .detalle-signatures {
    grid-template-columns: 1fr;
  }
  .detalle-right-info {
    justify-self: start;
    min-width: auto;
  }
  .hoja-ruta-table {
    min-width: 0;
  }
  .detalle-signatures b {
    min-width: auto;
    width: 100%;
  }
}


/* V52: Combustible con modelo detalle combustible */
.detalle-combustible {
  background: #fff;
  color: #111;
  border: 1px solid #b8b8b8;
  border-radius: 6px;
  padding: 16px;
  font-family: Arial, Helvetica, sans-serif;
}
.detalle-comb-title { text-align:center; margin-bottom: 6px; }
.detalle-comb-title h3 { margin:0; font-size:22px; font-weight:900; color:#000; }
.detalle-comb-title p { margin:2px 0 0; color:#444; font-size:14px; }
.detalle-comb-head-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:18px; margin: 8px 0 18px;
}
.detalle-comb-left-info, .detalle-comb-right-info { font-size:14px; line-height:1.65; }
.detalle-comb-right-info { justify-self:end; min-width:310px; }
.detalle-comb-table-wrap { max-width: 610px; }
.detalle-comb-table { width:100%; border-collapse:collapse; font-size:12px; color:#000; }
.detalle-comb-table th, .detalle-comb-table td { border:1px solid #666; padding:4px 6px; }
.detalle-comb-table th { background:#d9d9d9; text-align:center; font-weight:900; }
.detalle-comb-table .section-header { text-align:left; }
.detalle-comb-table td.num { text-align:right; white-space:nowrap; }
.detalle-comb-table td.center { text-align:center; }
.detalle-comb-table .subtotal-row td { background:#efefef; }
.detalle-comb-table .liquido-row td { background:#f4f4f4; }
.detalle-comb-signatures {
  display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:48px; text-align:center; font-size:13px;
}
.detalle-comb-signatures span { display:block; font-weight:900; margin-bottom:6px; }
.detalle-comb-signatures b { display:inline-block; padding-top:6px; border-top:1px solid #444; min-width:240px; }
.detalle-comb-footer-place {
  margin-top: 26px; font-weight:700; letter-spacing:.5px; font-size:13px; color:#111;
}
@media (max-width: 980px) {
  .detalle-comb-head-grid, .detalle-comb-signatures { grid-template-columns:1fr; }
  .detalle-comb-right-info { justify-self:start; min-width:auto; }
  .detalle-comb-signatures b { min-width:auto; width:100%; }
  .detalle-comb-table-wrap { max-width:100%; overflow-x:auto; }
}


/* V53: Ver reporte limpio e impresión por vista */
#reporteFlete,
#reporteFlete *,
.report-paper,
.report-paper *,
.report-sheet,
.report-sheet * {
  color: #000 !important;
}

.report-paper,
.report-sheet {
  background: #fff !important;
}

.report-mode-buttons {
  background: #f7f7f7 !important;
  border-color: #cfcfcf !important;
}

.report-mode-buttons button {
  color: #000 !important;
  background: #ffffff !important;
  border: 1px solid #777 !important;
}

.report-mode-buttons button.active,
.report-mode-buttons button.primary {
  background: #e8e8e8 !important;
  color: #000 !important;
}

.print-view-btn {
  font-weight: 900;
  border-style: dashed !important;
}

.report-paper .card,
.report-paper .report-box,
.report-paper .total-line {
  color: #000 !important;
}

@media print {
  body,
  body * {
    color: #000 !important;
  }
  .topbar,
  .sidebar-menu,
  .tabs,
  .module-toolbar,
  .report-mode-buttons,
  .report-selected-note,
  footer,
  button {
    display: none !important;
  }
  #reporteFlete,
  #reporteFlete * {
    color: #000 !important;
    background: #fff !important;
  }
}


/* V57: menú independiente, siempre clickeable */
#sideMenu,
.sidebar-menu {
  pointer-events: auto !important;
}

#sideMenu .tab-btn,
.sidebar-menu .tab-btn {
  pointer-events: auto !important;
  cursor: pointer !important;
  user-select: none;
}

body.logged-in.menu-open #sideMenu,
body.logged-in.menu-open .sidebar-menu {
  transform: translateX(0) !important;
  visibility: visible !important;
  opacity: 1 !important;
  z-index: 9999 !important;
}

body.logged-in #menuToggle {
  pointer-events: auto !important;
  z-index: 10000 !important;
}


/* V59: refuerzo final de botones y formularios */
.form-card.form-open,
form.form-open {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}

button[data-form-target],
.tab-btn,
#menuToggle {
  pointer-events: auto !important;
  cursor: pointer !important;
}

body.logged-in.menu-open #sideMenu {
  pointer-events: auto !important;
  visibility: visible !important;
  opacity: 1 !important;
  transform: translateX(0) !important;
}


/* V60: formulario con los mismos campos de la planilla importada */
.planilla-viaje-form {
  border-left: 7px solid var(--accent);
}

.planilla-viaje-form h2 {
  margin-top: 0;
}

.planilla-viaje-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(170px, 1fr));
  gap: 10px;
}

.planilla-viaje-grid label {
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
}

.planilla-viaje-grid input {
  margin-top: 5px;
}

@media (max-width: 1100px) {
  .planilla-viaje-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .planilla-viaje-grid {
    grid-template-columns: 1fr;
  }
}


/* V65: menú estable final */
#menuToggle,
#sideMenu,
#sideMenu .tab-btn,
.tab-btn[data-tab] {
  pointer-events: auto !important;
  cursor: pointer !important;
}

body.logged-in.menu-open #sideMenu,
body.logged-in.menu-open .sidebar-menu {
  transform: translateX(0) !important;
  opacity: 1 !important;
  visibility: visible !important;
  z-index: 10000 !important;
}

#appShell {
  pointer-events: auto !important;
}

.tab-panel.active {
  display: block !important;
}


/* V69: botón de perfil solo con ícono */
.profile-menu-btn.profile-icon-only {
  width: 44px;
  height: 44px;
  min-width: 44px;
  padding: 0 !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  border-radius: 999px;
}

.profile-menu-btn.profile-icon-only .profile-avatar {
  margin: 0;
  font-size: 20px;
}


/* V70: sumatoria mensual de reportes */
#tablaSumatoriaReporteMes .total-row td {
  background: rgba(39,211,255,.12) !important;
  font-weight: 900;
}


/* V71: contrato simple */
.contrato-simple-form {
  max-width: 520px;
}


/* V72: botones limpios del Resumen */
.resumen-actions-clean {
  align-items: stretch;
}

.resumen-actions-clean .resumen-excel-btn,
.resumen-actions-clean .file-btn.resumen-excel-btn {
  width: 160px;
  min-width: 160px;
  height: 42px;
  min-height: 42px;
  padding: 0 14px !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
  box-sizing: border-box;
}

.resumen-actions-clean .file-btn.resumen-excel-btn input[type="file"] {
  display: none;
}

@media (max-width: 720px) {
  .resumen-actions-clean .resumen-excel-btn,
  .resumen-actions-clean .file-btn.resumen-excel-btn {
    width: 100%;
    min-width: 100%;
  }
}


/* V73: alineación exacta de botones del Resumen */
.module-toolbar .resumen-actions-clean {
  display: flex !important;
  flex-wrap: wrap;
  align-items: center !important;
  justify-content: flex-end;
  gap: 10px;
}

.module-toolbar .resumen-actions-clean .resumen-excel-btn,
.module-toolbar .resumen-actions-clean button.resumen-excel-btn,
.module-toolbar .resumen-actions-clean label.resumen-excel-btn,
.module-toolbar .resumen-actions-clean .file-btn.resumen-excel-btn {
  width: 165px !important;
  min-width: 165px !important;
  max-width: 165px !important;
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  margin: 0 !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle !important;
  line-height: 44px !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  text-align: center !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.module-toolbar .resumen-actions-clean label.resumen-excel-btn {
  cursor: pointer;
}

.module-toolbar .resumen-actions-clean label.resumen-excel-btn input[type="file"] {
  display: none !important;
}

@media (max-width: 720px) {
  .module-toolbar .resumen-actions-clean {
    justify-content: stretch;
  }

  .module-toolbar .resumen-actions-clean .resumen-excel-btn,
  .module-toolbar .resumen-actions-clean button.resumen-excel-btn,
  .module-toolbar .resumen-actions-clean label.resumen-excel-btn,
  .module-toolbar .resumen-actions-clean .file-btn.resumen-excel-btn {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
  }
}


/* V74: formato numérico US en planilla y reportes */
.excel-cell {
  font-variant-numeric: tabular-nums;
}

.report-paper table .num,
#tablaResumenExcel input.excel-cell,
#tablaSumatoriaReporteMes td {
  font-variant-numeric: tabular-nums;
}
