/* VenMedia Panel — StrPanel dark UI, compatible con app/index actuales */
:root{
  --bg:#020817;--bg-2:#060B1A;--panel:#0a1428;--panel-2:#0f1d38;
  --line:#172445;--line-2:#243661;--text:#e6f1ff;--text-dim:#7a8aa8;--muted:#5e6c87;
  --accent:#e5a00d;--accent-2:#c4880a;--ok:#22c55e;--warn:#f59e0b;--bad:#ef4444;
  --blue:#3b82f6;--purple:#8b5cf6;--cyan:#06b6d4;--shadow:0 18px 55px rgba(0,0,0,.42)
}
*{box-sizing:border-box}html,body{height:100%;margin:0;overflow:hidden;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;font-size:14px;line-height:1.45}body{background:radial-gradient(circle at 18% 0%,rgba(229,160,13,.08),transparent 32%),var(--bg)}[hidden]{display:none!important}button,input,select,textarea{font:inherit}button{cursor:pointer}a{color:var(--accent)}
label{display:block;margin:0 0 12px;color:var(--text-dim);font-size:12px;font-weight:700}input,select,textarea{width:100%;margin-top:6px;padding:10px 11px;border-radius:7px;border:1px solid var(--line);background:var(--bg-2);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(229,160,13,.22)}input::placeholder,textarea::placeholder{color:var(--muted)}textarea{resize:vertical;min-height:80px}small{font-size:11px;font-weight:500}
/* shell */
#view-app{height:100vh;display:grid!important;grid-template-columns:244px minmax(0,1fr);overflow:hidden;background:var(--bg)}.sidebar{min-height:0;padding:14px 12px;background:linear-gradient(180deg,#030917,#050b17);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:10px}.brand{display:flex;align-items:center;gap:10px;margin:0 0 8px}.brand.small{padding:2px 4px 10px;border-bottom:1px solid rgba(255,255,255,.05)}.brand-logo{width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,#00d4ff,#0ea5e9);color:#001018;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px rgba(14,165,233,.25)}.brand h1{margin:0;font-size:15px;line-height:1.08;font-weight:850}.brand-sub{font-size:11px;color:var(--text-dim);margin-top:2px}
#sidebar-nav{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:4px;padding-right:2px}.nav-btn{width:100%;border:0;border-radius:8px;background:transparent;color:var(--text-dim);display:flex;align-items:center;gap:9px;text-align:left;padding:9px 10px;font-size:13px;font-weight:700;transition:background .15s,color .15s,box-shadow .15s}.nav-btn span{width:18px;text-align:center}.nav-btn:hover{background:rgba(255,255,255,.05);color:var(--text)}.nav-btn.active{background:linear-gradient(90deg,rgba(229,160,13,.18),rgba(229,160,13,.05));color:var(--accent);box-shadow:inset 3px 0 0 var(--accent)}.sidebar-foot{border-top:1px solid var(--line);padding-top:10px;display:flex;flex-direction:column;gap:8px}.sync-status{display:flex;align-items:center;gap:8px;color:var(--text-dim);font-size:12px;padding:2px 4px}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--muted)}.dot.ok{background:var(--ok);box-shadow:0 0 10px rgba(34,197,94,.6)}.dot.bad{background:var(--bad);box-shadow:0 0 10px rgba(239,68,68,.6)}
.topbar{height:58px;background:rgba(5,11,23,.88);border-bottom:1px solid var(--line);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 20px;min-width:0}.topbar-metrics{display:flex;align-items:center;gap:8px;min-width:0;overflow:auto}.metric-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;background:var(--panel);white-space:nowrap}.chip-label{font-size:10px;color:var(--muted);font-weight:850;text-transform:uppercase;letter-spacing:.05em}.chip-val{font-size:13px;font-weight:900}.metric-chip.orange .chip-val,.metric-chip.amber .chip-val{color:var(--accent)}.metric-chip.blue .chip-val{color:#60a5fa}.metric-chip.green .chip-val{color:var(--ok)}.metric-chip.purple .chip-val{color:#a78bfa}.metric-chip.red .chip-val{color:var(--bad)}.main{height:calc(100vh - 58px);overflow:auto;padding:22px 24px 36px;background:radial-gradient(circle at 90% 0%,rgba(59,130,246,.06),transparent 30%),var(--bg);min-width:0}
#sidebar-nav::-webkit-scrollbar,.main::-webkit-scrollbar,.table-wrap::-webkit-scrollbar{width:8px;height:8px}#sidebar-nav::-webkit-scrollbar-thumb,.main::-webkit-scrollbar-thumb,.table-wrap::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px}
/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 14px;border:1px solid var(--line-2);border-radius:8px;background:var(--panel-2);color:var(--text);font-size:13px;font-weight:800;text-decoration:none;transition:background .15s,border-color .15s,opacity .15s,transform .08s}.btn:hover{background:#15284c;border-color:#34507f}.btn:active{transform:translateY(1px)}.btn.primary{background:linear-gradient(180deg,var(--accent),var(--accent-2));border-color:var(--accent);color:#141006;box-shadow:0 6px 20px rgba(229,160,13,.22)}.btn.ghost{background:transparent;color:var(--text-dim)}.btn.small{padding:6px 10px;font-size:12px;border-radius:7px}.btn.danger,.btn.small.danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.38);color:#fecaca}.btn:disabled,.action-btn:disabled{opacity:.45;cursor:not-allowed}.icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--panel-2);color:var(--text-dim)}.icon-btn:hover{color:var(--text);border-color:var(--line-2)}.copy-btn{padding:4px 8px;border:1px solid var(--line);border-radius:6px;background:var(--panel-2);color:var(--text-dim);font-size:11px}
/* login */
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:auto;padding:20px 0;background:radial-gradient(circle at 50% 0%,rgba(229,160,13,.14),transparent 35%),var(--bg)}.login-bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(6,11,26,.9),rgba(2,8,23,.98))}.login-card{position:relative;z-index:1;width:380px;max-width:calc(100vw - 32px);padding:28px;border:1px solid var(--line-2);border-radius:16px;background:rgba(10,20,40,.92);box-shadow:var(--shadow)}.login-card .brand{margin-bottom:22px}.login-card .btn{width:100%;margin-top:8px}.pw-field{display:flex;gap:6px;align-items:center}.pw-field input{flex:1}.pw-actions button{margin-top:6px;padding:9px 10px;border:1px solid var(--line);border-radius:6px;background:var(--panel-2);color:var(--text-dim)}
/* headers */
.tab-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}.tab-title h2{margin:0 0 3px;font-size:22px;font-weight:900;letter-spacing:-.02em}.tab-title p{margin:0;color:var(--text-dim)}.tab-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.inner-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}.inner-tab{padding:8px 13px;border:1px solid var(--line);border-radius:8px;background:var(--panel);color:var(--text-dim);font-weight:800;font-size:13px}.inner-tab:hover{border-color:var(--accent);color:var(--text)}.inner-tab.active{background:rgba(229,160,13,.14);border-color:var(--accent);color:var(--accent)}
/* cards */
.stats-grid,.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px}.stat-card,.dash-card,.srv-card,.package-card,.demo-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;box-shadow:0 10px 30px rgba(0,0,0,.18)}.stat{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}.stat-label{display:block;color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.stat-value{display:block;margin-top:4px;font-size:24px;font-weight:900}.stat-value.ok{color:var(--ok)}.stat-value.warn{color:var(--warn)}.stat-value.bad{color:var(--bad)}.srv-grid,.packages-grid,.demos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.srv-card-head,.package-head,.demo-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}.srv-name{font-weight:900;display:flex;align-items:center;gap:8px}.srv-type-badge,.method-badge{font-size:10px;border:1px solid rgba(229,160,13,.4);color:var(--accent);border-radius:999px;padding:2px 7px}.method-badge.green{color:var(--ok);border-color:rgba(34,197,94,.4)}.method-badge.orange{color:var(--accent)}.srv-status{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:800}.srv-status.online{color:var(--ok)}.srv-status.offline{color:var(--bad)}.srv-meta,.srv-url{display:flex;gap:10px;align-items:center;color:var(--text-dim);font-size:12px;margin-top:8px}.srv-actions{display:flex;gap:7px;flex-wrap:wrap;margin-top:14px}.stream-av,.user-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1d4ed8,#06b6d4);font-weight:900;color:#fff}
.method-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.method-card{border:1px solid var(--line);border-radius:13px;background:var(--panel);padding:16px;display:flex;gap:14px;cursor:pointer;transition:border-color .15s,transform .12s,background .15s}.method-card:hover{border-color:var(--accent);background:var(--panel-2);transform:translateY(-1px)}.method-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(229,160,13,.14);font-size:22px}.method-icon.manual{background:rgba(99,102,241,.14)}.method-content{flex:1}.method-title{font-weight:900;margin-bottom:5px}.method-desc{color:var(--text-dim);font-size:12px;margin:0 0 10px}.method-feature,.method-warning{font-size:12px;color:var(--text-dim);margin-top:4px}.method-btn{margin-top:12px;border:1px solid var(--line-2);border-radius:8px;background:var(--panel-2);color:var(--text);padding:8px 12px;font-weight:800}.method-btn.oauth{background:rgba(229,160,13,.14);color:var(--accent);border-color:rgba(229,160,13,.4)}
/* tables */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:auto;box-shadow:0 10px 30px rgba(0,0,0,.18)}.data-table{width:100%;border-collapse:collapse;min-width:760px}.data-table th{padding:11px 12px;border-bottom:1px solid var(--line);background:var(--bg-2);color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.07em;text-align:left;white-space:nowrap}.data-table td{padding:11px 12px;border-bottom:1px solid rgba(23,36,69,.65);font-size:13px;vertical-align:middle}.data-table tr:hover td{background:rgba(255,255,255,.025)}.data-table tr:last-child td{border-bottom:0}.table-empty{text-align:center;color:var(--text-dim);padding:40px!important}.user-actions{display:flex;align-items:center;gap:5px;flex-wrap:wrap}.action-btn{border:0;border-radius:6px;padding:5px 9px;font-size:11px;font-weight:900}.action-btn.edit{background:rgba(99,102,241,.16);color:#a5b4fc}.action-btn.suspend{background:rgba(245,158,11,.14);color:#fbbf24}.action-btn.reactivate{background:rgba(34,197,94,.14);color:#4ade80}.action-btn.renew{background:rgba(59,130,246,.14);color:#93c5fd}.action-btn.view{background:rgba(6,182,212,.14);color:#67e8f9}.action-btn.whatsapp{background:rgba(34,197,94,.14);color:#86efac}.action-btn.telegram{background:rgba(59,130,246,.14);color:#93c5fd}.action-btn.danger{background:rgba(239,68,68,.14);color:#fca5a5}
/* badges/stats */
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:900;white-space:nowrap}.badge.activo,.badge.active{background:rgba(34,197,94,.14);color:#4ade80}.badge.por-vencer{background:rgba(245,158,11,.15);color:#fbbf24}.badge.suspendido,.badge.suspended{background:rgba(148,163,184,.14);color:#cbd5e1}.badge.vencido{background:rgba(239,68,68,.14);color:#fca5a5}.badge.admin{background:rgba(99,102,241,.16);color:#c4b5fd}.badge.demo{background:rgba(6,182,212,.14);color:#67e8f9}.crm-stats-bar{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:12px;margin:0 0 16px}.crm-stat{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:13px 16px}.crm-stat-label{font-size:10px;color:var(--muted);font-weight:900;letter-spacing:.07em;text-transform:uppercase}.crm-stat-val{font-size:24px;font-weight:900;margin-top:4px}.crm-stat.ok .crm-stat-val{color:var(--ok)}.crm-stat.warn .crm-stat-val{color:var(--warn)}.crm-stat.amber .crm-stat-val{color:var(--accent)}.crm-stat.bad .crm-stat-val{color:var(--bad)}
/* alerts/empty/loading */
.alert{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin:0 0 12px;background:var(--panel);color:var(--text-dim)}.alert.info{border-color:rgba(59,130,246,.35);background:rgba(59,130,246,.08);color:#bfdbfe}.alert.ok{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.08);color:#bbf7d0}.alert.error{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.08);color:#fecaca}.alert.warn{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.08);color:#fde68a}.empty-state{text-align:center;padding:50px 20px;background:var(--panel);border:1px solid var(--line);border-radius:12px;color:var(--text-dim)}.empty-icon{font-size:34px;display:block;margin-bottom:8px}.empty-state h3{color:var(--text);margin:0 0 5px}.loading-wrap{display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-dim);padding:60px}.spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.08);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
/* modal */
#modal-container:not(:empty){position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.62);display:flex;align-items:center;justify-content:center;padding:20px}.modal{width:520px;max-width:calc(100vw - 32px);max-height:90vh;background:var(--panel);border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}.modal.wide{width:760px}.modal.xl{width:940px}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);background:var(--bg-2)}.modal-head h2{font-size:18px;margin:0}.modal-head p{margin:4px 0 0;color:var(--text-dim);font-size:12px}.modal-body{padding:18px;overflow:auto}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--line);background:var(--bg-2)}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.form-sep{font-size:12px;font-weight:900;color:var(--text-dim);border-top:1px solid var(--line);padding-top:12px;margin:8px 0 6px}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.detail-item{background:var(--bg-2);border:1px solid var(--line);border-radius:8px;padding:10px}.detail-label{display:block;color:var(--muted);font-size:10px;font-weight:900;text-transform:uppercase}.detail-value{display:block;margin-top:3px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.user-detail-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}.user-detail-info{flex:1}.user-detail-name{font-weight:900}.user-detail-email{font-size:12px;color:var(--text-dim)}
.toast{background:var(--panel);border:1px solid var(--line-2);box-shadow:var(--shadow);color:var(--text);border-radius:10px;padding:12px 14px;font-size:13px}.toast.ok{border-color:rgba(34,197,94,.5)}.toast.err{border-color:rgba(239,68,68,.5)}
@media(max-width:980px){#view-app{grid-template-columns:76px minmax(0,1fr)}.sidebar{padding:10px 8px}.brand.small h1,.brand.small .brand-sub,.nav-btn{font-size:0}.nav-btn{justify-content:center;padding:10px}.nav-btn span{font-size:16px}.sidebar nav div{display:none}.topbar-metrics{max-width:60vw}.crm-stats-bar{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){html,body{overflow:auto}#view-app{display:block!important;height:auto;min-height:100vh}.sidebar{position:relative;width:100%;display:block}.topbar{height:auto;min-height:54px;align-items:flex-start;padding:10px;flex-wrap:wrap}.main{height:auto;padding:16px}.tab-head{flex-direction:column}.tab-actions{justify-content:flex-start}.form-row,.detail-grid,.method-cards{grid-template-columns:1fr}.crm-stats-bar{grid-template-columns:1fr}.modal{max-height:calc(100vh - 20px)}}


/* Dashboard minimalista estilo StreamPanel */
.sp-dash{max-width:1550px;margin:0 auto;color:var(--text)}
.sp-dash-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin:2px 0 18px}
.sp-dash-head h2{margin:0;font-size:21px;font-weight:900;letter-spacing:-.02em}
.sp-dash-head p{margin:3px 0 0;color:var(--text-dim);font-size:12px}
.sp-live-wrap{display:flex;align-items:center;gap:12px;font-size:11px;color:var(--muted)}
.sp-muted{color:var(--muted)}
.sp-live{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(34,197,94,.28);background:rgba(34,197,94,.10);color:#5df59a;border-radius:999px;padding:5px 10px;font-size:10px;font-weight:900;letter-spacing:.05em}
.sp-live span{width:6px;height:6px;border-radius:50%;background:#00e676;box-shadow:0 0 10px rgba(0,230,118,.8)}
.sp-metrics{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;margin-bottom:14px}
.sp-metric{background:rgba(15,29,56,.72);border:1px solid rgba(55,76,118,.65);border-radius:8px;padding:13px 14px;min-height:74px;text-align:center;box-shadow:0 8px 18px rgba(0,0,0,.13)}
.sp-metric-value{font-size:19px;line-height:1;font-weight:950;margin-bottom:6px;color:var(--text)}
.sp-metric.orange .sp-metric-value{color:#f5a623}.sp-metric.red .sp-metric-value{color:#ff6b6b}.sp-metric.blue .sp-metric-value{color:#7db3ff}.sp-metric.cyan .sp-metric-value{color:#16e0c1}
.sp-metric-label{font-size:10px;color:var(--text-dim);font-weight:800}
.sp-metric-sub{font-size:9px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sp-section{background:rgba(15,29,56,.72);border:1px solid rgba(55,76,118,.65);border-radius:8px;margin-bottom:14px;overflow:hidden}
.sp-section-title{height:38px;display:flex;align-items:center;gap:8px;padding:0 12px;border-bottom:1px solid rgba(55,76,118,.55);font-size:12px;font-weight:900;color:var(--text)}
.sp-section-title.small{border-bottom:0;height:auto;padding:0;margin-bottom:14px}
.sp-section-title button{margin-left:auto;background:transparent;border:0;color:#6ea8ff;font-size:10px;font-weight:800}
.sp-security-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;padding:10px 12px}
.sp-security-box{background:rgba(2,8,23,.35);border:1px solid rgba(55,76,118,.45);border-radius:6px;padding:9px 12px}
.sp-security-box div{font-size:9px;color:var(--muted);font-weight:900;letter-spacing:.05em}
.sp-security-box b{display:block;margin-top:3px;font-size:16px;color:var(--text)}
.sp-security-box b.ok{color:#00e676}
.sp-security-ok{display:flex;align-items:center;gap:8px;border-top:1px solid rgba(55,76,118,.45);padding:10px 12px;color:var(--text-dim);font-size:11px}
.sp-security-ok span{width:8px;height:8px;border-radius:50%;background:#00e676;box-shadow:0 0 9px rgba(0,230,118,.75)}
.sp-empty-line{padding:14px 12px;color:var(--text-dim);font-size:12px}
.sp-layout{display:grid;grid-template-columns:minmax(0,1fr) 310px;gap:18px;align-items:start}
.sp-left,.sp-right{min-width:0}.sp-right{display:flex;flex-direction:column;gap:14px;margin-top:148px}
.sp-block-title{font-size:10px;color:var(--text-dim);font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin:0 0 8px}
.sp-block-title.with-gap{margin-top:14px;color:var(--text)}
.sp-server-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;margin-bottom:12px}
.sp-server-mini{background:rgba(15,29,56,.86);border:1px solid rgba(55,76,118,.65);border-radius:7px;padding:10px;min-height:78px}
.sp-server-top{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px}.sp-server-top b{font-size:12px}.sp-server-top span{font-size:9px;font-weight:900}.sp-server-top span.ok{color:#00e676}.sp-server-top span.bad{color:#ff6b6b}
.sp-plex{display:inline-block;margin-top:3px;padding:1px 5px;border-radius:4px;background:rgba(229,160,13,.18);color:#f5a623;font-size:8px;font-weight:900}
.sp-server-stats{display:flex;gap:26px;margin-top:7px;color:var(--muted);font-size:8px}.sp-server-stats b{font-size:11px;color:var(--text)}
.sp-conn{display:flex;align-items:center;gap:5px;margin-top:7px;font-size:9px;font-weight:800}.sp-conn span{width:5px;height:5px;border-radius:50%}.sp-conn.ok{color:#00e676}.sp-conn.ok span{background:#00e676}.sp-conn.bad{color:#ff6b6b}.sp-conn.bad span{background:#ff6b6b}
.sp-streams-card,.sp-side-card{background:rgba(15,29,56,.78);border:1px solid rgba(55,76,118,.65);border-radius:8px;padding:10px}
.sp-filter-row{display:flex;align-items:center;gap:8px;border-bottom:1px solid rgba(55,76,118,.55);padding-bottom:8px;margin-bottom:8px;color:var(--text-dim);font-size:10px;flex-wrap:wrap}
.sp-filter-row button,.sp-filter-row select{width:auto;margin:0;background:rgba(2,8,23,.45);border-color:rgba(55,76,118,.65);color:var(--text);font-size:10px;padding:6px 9px;border-radius:6px}
.sp-filter-row label{display:flex;align-items:center;gap:5px;margin:0;font-size:10px;color:var(--text-dim)}.sp-filter-row input{width:auto;margin:0}.sp-filter-row span{margin-left:auto;font-size:9px;color:var(--muted)}
.sp-stream-row{display:flex;align-items:center;gap:10px;border:1px solid rgba(55,76,118,.45);border-radius:7px;background:rgba(2,8,23,.28);padding:10px;margin-top:8px}
.sp-stream-icon{width:28px;height:28px;border-radius:8px;background:rgba(34,197,94,.13);color:#4ade80;display:flex;align-items:center;justify-content:center;font-size:11px}.sp-stream-row b{font-size:12px}.sp-stream-row p{margin:1px 0 0;color:var(--muted);font-size:10px}.sp-stream-row span{margin-left:auto;color:var(--muted);font-size:10px}
.sp-top-user{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid rgba(55,76,118,.35)}.sp-top-user:last-child{border-bottom:0}.sp-user-dot{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#0ea5e9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:900}.sp-top-user b{font-size:12px}.sp-top-user p{margin:1px 0 0;color:var(--muted);font-size:10px}.sp-top-user span{margin-left:auto;color:#d1d5db;font-size:11px;font-weight:800}
@media(max-width:1100px){.sp-layout{grid-template-columns:1fr}.sp-right{margin-top:0}.sp-metrics{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.sp-metrics,.sp-security-grid{grid-template-columns:1fr}.sp-dash-head{flex-direction:column}.sp-layout{gap:12px}}

.sp-stream-rich{display:flex;gap:12px;border:1px solid rgba(55,76,118,.55);border-radius:10px;background:rgba(2,8,23,.30);padding:12px;margin-top:9px;border-left:3px solid #10b981}
.sp-stream-poster{width:54px;height:74px;border-radius:7px;background:rgba(34,197,94,.13);color:#4ade80;display:flex;align-items:center;justify-content:center;font-size:16px;flex:0 0 auto;overflow:hidden}.sp-stream-poster img{width:100%;height:100%;object-fit:cover}
.sp-stream-main{min-width:0;flex:1}.sp-stream-head{display:flex;justify-content:space-between;gap:10px}.sp-stream-head b{font-size:13px}.sp-stream-head p{margin:3px 0 0;color:var(--muted);font-size:10px}.sp-stream-badges{display:flex;gap:5px;flex-wrap:wrap;justify-content:flex-end}.sp-stream-badges span{height:19px;border-radius:999px;padding:3px 7px;font-size:9px;font-weight:900}.sp-stream-badges .playing{background:rgba(34,197,94,.15);color:#86efac}.sp-stream-badges .direct{background:rgba(59,130,246,.15);color:#93c5fd}.sp-stream-badges .transcode{background:rgba(245,158,11,.16);color:#fbbf24}.sp-stream-tags{display:flex;gap:5px;flex-wrap:wrap;margin-top:10px}.sp-stream-tags span{background:rgba(55,76,118,.55);color:#dbeafe;border-radius:999px;padding:3px 7px;font-size:9px;font-weight:800}.sp-progress{height:6px;background:#263653;border-radius:999px;margin-top:11px;overflow:hidden}.sp-progress i{display:block;height:100%;background:#10b981;border-radius:999px}

/* Streams vivos completos estilo StrPanel */
.sp-stream-rich.strpanel{display:block;padding:12px 14px;border-left:3px solid #10b981;background:rgba(15,29,56,.82);border-color:rgba(55,76,118,.72)}
.sp-stream-user{display:flex;align-items:center;gap:10px;margin-bottom:10px}.sp-stream-user b{font-size:12px}.sp-stream-user p{margin:2px 0 0;color:var(--muted);font-size:10px}.sp-user-dot.orange{background:linear-gradient(135deg,#f97316,#ef4444)}
.sp-stream-content{display:flex;gap:12px;align-items:flex-start}.sp-stream-poster.big{width:72px;height:102px;border-radius:8px;background:rgba(55,76,118,.45);font-size:20px}.sp-stream-poster.big img{width:100%;height:100%;object-fit:cover}
.sp-stream-rich.strpanel .sp-stream-head b{font-size:13px;color:#fff}.sp-stream-rich.strpanel .sp-stream-head p{font-size:10px;color:var(--text-dim)}.sp-stream-rich.strpanel .sp-stream-badges .mbps{background:rgba(55,76,118,.65);color:#dbeafe}
.sp-progress-text{display:flex;justify-content:space-between;color:var(--muted);font-size:9px;margin-top:5px}.sp-stream-rich.strpanel .sp-progress{height:7px;margin-top:13px}.sp-stream-rich.strpanel .sp-progress i{background:#10b981}
@media(max-width:720px){.sp-stream-content{flex-direction:column}.sp-stream-poster.big{width:86px;height:122px}.sp-stream-head{flex-direction:column}.sp-stream-badges{justify-content:flex-start}}

.export-card{display:flex;justify-content:space-between;align-items:center;gap:14px;background:linear-gradient(135deg,rgba(229,160,13,.11),rgba(15,29,56,.86));border:1px solid rgba(229,160,13,.28);border-radius:12px;padding:14px 16px;margin:0 0 16px;box-shadow:0 10px 28px rgba(0,0,0,.18)}
.export-title{font-weight:900;color:var(--text);font-size:14px}.export-sub{color:var(--text-dim);font-size:12px;margin-top:3px;max-width:720px}.export-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
@media(max-width:760px){.export-card{flex-direction:column;align-items:flex-start}.export-actions{justify-content:flex-start}}

.sp-resources{margin-top:14px}.sp-resource-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.sp-resource-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;background:rgba(10,20,40,.9);border:1px solid var(--line);border-radius:13px;padding:14px;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.sp-resource-card > div:last-child{display:flex;flex-direction:column;align-items:center}.sp-resource-card:hover{transform:translateY(-2px);border-color:rgba(229,160,13,.4);box-shadow:0 4px 15px rgba(229,160,13,.08)}.sp-resource-card b{font-size:13px}.sp-resource-card p{margin:4px 0 0;color:var(--muted);font-size:11px}.sp-ring{--p:0;--ring:#22c55e;width:76px;height:76px;flex:0 0 76px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--ring) calc(var(--p)*1%),rgba(255,255,255,.08) 0);position:relative}.sp-ring:after{content:'';position:absolute;inset:7px;background:var(--panel);border-radius:50%}.sp-ring span{position:relative;z-index:1;font-size:18px;font-weight:900;color:var(--text)}@media(max-width:900px){.sp-resource-grid{grid-template-columns:1fr}}

.sys-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px}.sys-info-item{background:rgba(15,29,56,.72);border:1px solid var(--line);border-radius:10px;padding:10px 12px}.sys-info-item span{display:block;color:var(--muted);font-size:10px;text-transform:uppercase;font-weight:900;letter-spacing:.06em}.sys-info-item b{display:block;margin-top:4px;color:var(--text);font-size:12px;line-height:1.25}.sp-resource-grid.webmin-like{grid-template-columns:repeat(4,minmax(0,1fr))}@media(max-width:1100px){.sp-resource-grid.webmin-like,.sys-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:700px){.sp-resource-grid.webmin-like,.sys-info-grid{grid-template-columns:1fr}}

/* Paginacion usuarios */
.pag-bar { display:flex; align-items:center; justify-content:space-between; padding:12px 0; flex-wrap:wrap; gap:8px; }
.pag-info { color:var(--text-dim); font-size:13px; }
.pag-btns { display:flex; gap:4px; flex-wrap:wrap; }
.pag-btns .btn.small { min-width:32px; padding:4px 8px; font-size:12px; }
.pag-btns .btn.small.active { background:var(--accent); color:#000; font-weight:700; }
.pag-btns .btn.small:disabled { opacity:.35; cursor:default; }

/* Multi-server health */
.sp-health-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(460px,1fr)); gap:16px; }
.sp-health-row .sp-section { margin:0; }
.sp-health-error { padding:12px; color:var(--bad); font-size:13px; }
.webmin-link { font-size:11px; color:var(--accent); margin-left:8px; text-decoration:none; }
.webmin-link:hover { text-decoration:underline; }

/* QR and Pairing Code visual blocks */
.qr {
  background: #fff;
  color: #000;
  padding: 14px;
  border-radius: 8px;
  font-family: monospace;
  font-size: 8px;
  line-height: 8px;
  white-space: pre;
  overflow: auto;
  max-height: 380px;
  margin: 10px 0;
}
.qr.small {
  font-size: 10px;
  line-height: 12px;
}

input[type="checkbox"] {
  width: 16px !important;
  height: 16px !important;
  margin-top: 0 !important;
  padding: 0 !important;
  cursor: pointer;
  accent-color: var(--accent);
}

/* Recordatorios automatizados */
.rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 16px;
  margin-top: 14px;
}
.rule-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px;
  position: relative;
  transition: opacity 0.2s;
}
.rule-card.disabled {
  opacity: 0.45;
}
.rule-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}
.rule-key {
  font-weight: 800;
  color: var(--accent);
  font-size: 16px;
}
.switch {
  position: relative;
  width: 38px;
  height: 22px;
  background: var(--line);
  border-radius: 99px;
  cursor: pointer;
  transition: background .2s;
  flex-shrink: 0;
}
.switch::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 18px;
  height: 18px;
  background: #fff;
  border-radius: 50%;
  transition: transform .2s;
}
.switch.on {
  background: var(--accent);
}
.switch.on::after {
  transform: translateX(16px);
}
.channels-pick {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 6px;
  margin-bottom: 10px;
}
.chip {
  padding: 5px 12px;
  border-radius: 99px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  user-select: none;
  transition: all 0.2s;
}
.chip.on {
  background: rgba(0, 212, 255, 0.1);
  border-color: var(--accent);
  color: var(--accent);
}


