:root[data-theme=dark]{--bg0:#0d1117;--bg1:#161b22;--bg2:#21262d;--bg3:#30363d;--t1:#f0f6fc;--t2:#c9d1d9;--t3:#8b949e;--t4:#484f58;--accent:#2563eb;--accent2:#7c3aed;--green:#10b981;--yellow:#f59e0b;--red:#ef4444;--blue:#3b82f6;--purple:#8b5cf6;--border:#30363d;--card-bg:#161b22;--sidebar-bg:#0d1117;--input-bg:#0d1117;--hover:#1f2937;--shadow:0 4px 24px #0006}:root[data-theme=light]{--bg0:#f3f4f6;--bg1:#fff;--bg2:#f9fafb;--bg3:#e5e7eb;--t1:#111827;--t2:#374151;--t3:#6b7280;--t4:#9ca3af;--accent:#2563eb;--accent2:#7c3aed;--green:#059669;--yellow:#d97706;--red:#dc2626;--blue:#2563eb;--purple:#7c3aed;--border:#e5e7eb;--card-bg:#fff;--sidebar-bg:#1e293b;--input-bg:#f9fafb;--hover:#f3f4f6;--shadow:0 4px 24px #00000014}.mockup-page *,#sidebar *,#main *,#topbar *,#sidebar-backdrop *,*{box-sizing:border-box}html,body{background:var(--bg0);height:100%;color:var(--t2);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px}body:has(#sidebar){min-height:100vh;transition:background .2s,color .2s;display:flex}::selection{background:var(--accent);color:#fff}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--bg0)}::-webkit-scrollbar-thumb{background:var(--bg3);border-radius:3px}#sidebar{background:var(--sidebar-bg);border-right:1px solid var(--border);z-index:300;flex-direction:column;width:240px;min-height:100vh;transition:transform .25s,background .2s;display:flex;position:fixed;top:0;bottom:0;left:0}.logo-wrap{border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;gap:10px;padding:16px 14px 12px;display:flex}.logo-mark{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:flex;box-shadow:0 0 12px #2563eb4d}.logo-name{color:#f0f6fc;letter-spacing:-.3px;font-size:14px;font-weight:800}.logo-tag{color:#fff6;margin-top:1px;font-size:9px;font-weight:500}nav{flex:1;padding:8px 0;overflow-y:auto}.nav-section{color:#ffffff40;text-transform:uppercase;letter-spacing:.1em;padding:10px 14px 3px;font-size:9px;font-weight:700}.nav-item{cursor:pointer;color:#ffffff80;-webkit-user-select:none;user-select:none;border-left:2px solid #0000;border-radius:7px;align-items:center;gap:9px;margin:1px 6px;padding:8px 12px;font-size:12px;font-weight:500;transition:all .12s;display:flex}.nav-item:hover{color:#ffffffd9;background:#ffffff0f}.nav-item.active{color:#fff;border-left:2px solid var(--accent);background:linear-gradient(135deg,#2563eb40,#7c3aed26)}.nav-icon{text-align:center;flex-shrink:0;width:18px;font-size:15px}.nav-badge{background:var(--red);color:#fff;border-radius:8px;margin-left:auto;padding:1px 5px;font-size:9px;font-weight:800;line-height:15px}.sidebar-bottom{border-top:1px solid #ffffff14;flex-shrink:0;padding:12px 14px}.mk-status{color:#fff6;align-items:center;gap:6px;font-size:11px;display:flex}.mk-dot{background:var(--green);width:6px;height:6px;box-shadow:0 0 5px var(--green);border-radius:50%;animation:2s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.mk-host{color:#fff3;margin-top:2px;padding-left:12px;font-size:10px}#main{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;transition:margin .25s;display:flex}#topbar{background:var(--card-bg);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:54px;padding:0 22px;transition:background .2s,border-color .2s;display:flex;position:sticky;top:0}.sidebar-router-item{cursor:pointer;color:#ffffff8c;-webkit-user-select:none;user-select:none;border-left:2px solid #0000;border-radius:7px;align-items:center;gap:8px;margin:1px 6px;padding:7px 12px;font-size:11px;font-weight:600;transition:all .12s;display:flex}.sidebar-router-item:hover{color:#ffffffe6;background:#ffffff0f}.sidebar-router-item.active{color:#fff;border-left:2px solid var(--accent);background:linear-gradient(135deg,#2563eb40,#7c3aed26)}.sr-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;box-shadow:0 0 5px}.sr-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sr-stat{text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;font-size:8px;font-weight:800}.sr-empty{color:#ffffff4d;padding:6px 14px;font-size:10px;font-style:italic}.gauge-wrap{flex-direction:column;align-items:center;gap:6px;display:flex}.gauge-ring{background:conic-gradient(var(--g-col) calc(var(--g-pct)*1%),var(--bg2) 0);border-radius:50%;justify-content:center;align-items:center;width:90px;height:90px;display:flex;position:relative}.gauge-inner{background:var(--card-bg);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:68px;height:68px;display:flex}.gauge-val{color:var(--t1);font-size:16px;font-weight:800}.gauge-lbl{color:var(--t4);text-transform:uppercase;margin-top:2px;font-size:9px;font-weight:700}.page-title{color:var(--t1);font-size:15px;font-weight:700}.topbar-right{align-items:center;gap:8px;display:flex}.menu-btn{border:1px solid var(--border);color:var(--t1);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;display:none}#sidebar-backdrop{z-index:290;background:#00000073;display:none;position:fixed;inset:0}#sidebar-backdrop.open{display:block}.tb-btn{background:var(--bg2);border:1px solid var(--border);color:var(--t2);cursor:pointer;border-radius:8px;align-items:center;gap:5px;padding:6px 12px;font-size:12px;font-weight:600;transition:all .12s;display:inline-flex}.tb-btn:hover{background:var(--bg3);color:var(--t1)}.tb-btn.accent{background:var(--accent);border-color:var(--accent);color:#fff}.tb-btn.accent:hover{opacity:.9}.theme-btn{background:var(--bg2);border:1px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:all .12s;display:flex}.theme-btn:hover{background:var(--bg3)}.avatar{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:800;display:flex}#content{background:var(--bg0);flex:1;padding:22px;transition:background .2s}.page{display:none}.page.active{display:block}#notif-wrap{z-index:1000;pointer-events:none;flex-direction:column;gap:7px;display:flex;position:fixed;top:12px;right:12px}.notif{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);pointer-events:auto;border-radius:9px;align-items:center;gap:8px;max-width:310px;padding:10px 14px;font-size:12px;animation:.2s notifIn;display:flex}.notif.success{border-left:3px solid var(--green);color:var(--green)}.notif.error{border-left:3px solid var(--red);color:var(--red)}.notif.warning{border-left:3px solid var(--yellow);color:var(--yellow)}.notif.info{border-left:3px solid var(--blue);color:var(--blue)}.notif-msg{color:var(--t2)}@keyframes notifIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.stats-row{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;display:grid}.stat{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:16px;transition:background .2s,border-color .2s;position:relative;overflow:hidden}.stat:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat.blue:before{background:linear-gradient(90deg,#2563eb,#60a5fa)}.stat.green:before{background:linear-gradient(90deg,#059669,#34d399)}.stat.yellow:before{background:linear-gradient(90deg,#d97706,#fbbf24)}.stat.purple:before{background:linear-gradient(90deg,#7c3aed,#a78bfa)}.stat-lbl{color:var(--t4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px;font-size:9px;font-weight:700}.stat-val{color:var(--t1);font-size:24px;font-weight:800;line-height:1}.stat-sub{color:var(--t3);margin-top:4px;font-size:10px}.stat-ico{opacity:.07;color:var(--t1);font-size:26px;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.period-summary-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.period-card{background:var(--bg0);border:1px solid var(--border);border-radius:10px;padding:13px}.period-card-label{color:var(--t4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:10px;font-weight:700}.period-card-total{color:var(--t1);margin-bottom:8px;font-size:18px;font-weight:800}.period-card-split{flex-direction:column;gap:4px;margin-bottom:6px;display:flex}.period-split-row{color:var(--t3);align-items:center;gap:5px;font-size:10.5px;display:flex}.period-split-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px;display:inline-block}.period-split-val{color:var(--t2);margin-left:auto;font-weight:700}.period-card-count{color:var(--t4);border-top:1px solid var(--border);padding-top:6px;font-size:10px}.router-status-card{background:var(--bg0);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:14px}.router-status-card:last-child{margin-bottom:0}.router-status-card.offline{border-color:#ef44444d}.router-status-name{color:var(--t1);align-items:center;margin-bottom:10px;font-size:13px;font-weight:700;display:flex}.router-status-loading,.router-status-offline{color:var(--t4);font-size:11px}.router-status-offline{color:var(--red)}.router-status-metrics{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:10px;display:grid}.router-metric{align-items:center;gap:8px;display:flex}.router-metric-lbl{color:var(--t4);flex-shrink:0;width:30px;font-size:10px;font-weight:700}.router-metric .pbar{flex:1}.router-metric-val{color:var(--t2);text-align:right;flex-shrink:0;width:34px;font-size:11px;font-weight:700}.router-status-users{color:var(--t3);font-size:11px}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;margin-bottom:18px;transition:background .2s,border-color .2s}.card-hd{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:13px 18px;display:flex}.card-title{color:var(--t1);align-items:center;gap:7px;font-size:13px;font-weight:700;display:flex}.card-body{padding:18px}.tbl-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{color:var(--t4);text-transform:uppercase;letter-spacing:.08em;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg0);padding:8px 12px;font-size:9px;font-weight:700}td{color:var(--t2);border-bottom:1px solid var(--bg0);vertical-align:middle;padding:9px 12px;font-size:12px}tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--hover)}.mono{letter-spacing:.03em;font-family:Consolas,Courier New,monospace}.badge{white-space:nowrap;border-radius:10px;align-items:center;padding:2px 7px;font-size:9px;font-weight:700;line-height:16px;display:inline-flex}.bg-green{color:var(--green);background:#10b98126;border:1px solid #10b98133}.bg-red{color:var(--red);background:#ef444426;border:1px solid #ef444433}.bg-yellow{color:var(--yellow);background:#f59e0b26;border:1px solid #f59e0b33}.bg-blue{color:var(--blue);background:#3b82f626;border:1px solid #3b82f633}.bg-gray{background:var(--bg2);color:var(--t3);border:1px solid var(--border)}.bg-purple{color:var(--purple);background:#8b5cf626;border:1px solid #8b5cf633}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:5px;padding:8px 15px;font-family:inherit;font-size:12px;font-weight:600;transition:all .12s;display:inline-flex}.btn:active{transform:scale(.97)}.btn-p{background:var(--accent);color:#fff}.btn-p:hover{opacity:.88}.btn-s{background:var(--bg2);color:var(--t2);border:1px solid var(--border)}.btn-s:hover{background:var(--bg3);color:var(--t1)}.btn-g{background:var(--green);color:#fff}.btn-g:hover{opacity:.88}.btn-r{background:var(--red);color:#fff}.btn-r:hover{opacity:.88}.btn-y{background:var(--yellow);color:#fff}.btn-y:hover{opacity:.88}.btn-v{background:var(--purple);color:#fff}.btn-v:hover{opacity:.88}.btn-sm{border-radius:6px;padding:5px 10px;font-size:11px}.btn-xs{border-radius:5px;padding:3px 7px;font-size:10px}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}.fl{color:var(--t3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px;font-size:10px;font-weight:700;display:block}.fc{background:var(--input-bg);border:1px solid var(--border);width:100%;color:var(--t1);border-radius:7px;outline:none;padding:8px 10px;font-family:inherit;font-size:13px;transition:border-color .12s,background .2s}.fc:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.fc::placeholder{color:var(--t4)}.fc option{background:var(--card-bg);color:var(--t1)}textarea.fc{resize:vertical;min-height:72px}.fg{gap:12px;display:grid}.fg.c2{grid-template-columns:1fr 1fr}.fg.c3{grid-template-columns:1fr 1fr 1fr}.fhint{color:var(--t4);margin-top:4px;font-size:10px}.frq:after{content:" *";color:var(--red)}.alert{border-radius:8px;align-items:flex-start;gap:9px;margin-bottom:14px;padding:10px 14px;font-size:12px;line-height:1.6;display:flex}.ai{color:var(--blue);background:#3b82f614;border:1px solid #3b82f633}.aw{color:var(--yellow);background:#f59e0b14;border:1px solid #f59e0b33}.ag{color:var(--green);background:#10b98114;border:1px solid #10b98133}.ar{color:var(--red);background:#ef444414;border:1px solid #ef444433}.al-ico{flex-shrink:0;margin-top:1px;font-size:14px}.tab-bar{background:var(--bg0);border:1px solid var(--border);border-radius:9px;gap:2px;width:fit-content;margin-bottom:16px;padding:3px;display:flex}.tab{cursor:pointer;color:var(--t3);white-space:nowrap;background:0 0;border:none;border-radius:6px;padding:6px 13px;font-size:11px;font-weight:700;transition:all .12s}.tab:hover{color:var(--t2)}.tab.act{background:var(--card-bg);color:var(--t1);box-shadow:0 1px 3px #0003}.pbar{background:var(--bg2);border-radius:3px;height:5px;overflow:hidden}.pfill{border-radius:3px;height:100%;transition:width .4s}.modal-bg{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-bg.open{display:flex}.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;width:580px;max-width:calc(100vw - 32px);max-height:88vh;overflow-y:auto;box-shadow:0 30px 80px #00000080}.modal-hd{border-bottom:1px solid var(--border);background:var(--card-bg);z-index:1;justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:sticky;top:0}.modal-title{color:var(--t1);font-size:14px;font-weight:700}.modal-close{color:var(--t3);cursor:pointer;background:0 0;border:none;padding:2px;font-size:20px;line-height:1}.modal-close:hover{color:var(--t1)}.modal-body{padding:22px}.modal-ft{border-top:1px solid var(--border);background:var(--card-bg);justify-content:flex-end;gap:8px;padding:14px 22px;display:flex}#auth-screen{z-index:1100;background:var(--bg0);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}#auth-screen.hidden{display:none}.auth-box{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:400px;padding:32px 28px;box-shadow:0 30px 80px #00000059}.auth-logo{justify-content:center;align-items:center;gap:10px;margin-bottom:24px;display:flex}.auth-logo-name{color:var(--t1);font-size:18px;font-weight:800}.auth-tabs{background:var(--bg0);border:1px solid var(--border);border-radius:9px;gap:2px;margin-bottom:22px;padding:3px;display:flex}.auth-tab{color:var(--t3);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:9px;font-size:12px;font-weight:700;transition:all .12s}.auth-tab.act{background:var(--card-bg);color:var(--t1);box-shadow:0 1px 3px #0003}.auth-error{color:#ef4444;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;margin-bottom:14px;padding:9px 12px;font-size:12px;line-height:1.4}.auth-advanced{border-top:1px solid var(--border);margin-top:18px;padding-top:14px}.auth-advanced summary{color:var(--t4);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:600}.auth-advanced summary:hover{color:var(--t3)}.plan-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.plan-card{background:var(--bg0);border:2px solid var(--border);text-align:center;cursor:pointer;border-radius:10px;padding:14px 10px;transition:all .15s}.plan-card:hover{border-color:var(--accent);background:var(--bg2)}.plan-card.sel{border-color:var(--accent);background:#2563eb14}.plan-price{font-size:18px;font-weight:800;line-height:1.1}.plan-nm{color:var(--t3);margin-top:2px;font-size:11px}.plan-spd{color:var(--t4);margin-top:2px;font-size:9px}.voucher-ticket{background:#fff;border:2px solid #1a1a2e;border-radius:12px;padding:0;font-family:Segoe UI,sans-serif;position:relative;overflow:hidden;box-shadow:0 4px 20px #0003}.voucher-ticket.template-a .vt-head{color:#fff;text-align:center;background:linear-gradient(135deg,#1a1a2e,#16213e);padding:14px 16px}.voucher-ticket.template-b .vt-head{color:#fff;text-align:center;background:linear-gradient(135deg,#065f46,#047857);padding:14px 16px}.voucher-ticket.template-c .vt-head{color:#fff;text-align:center;background:linear-gradient(135deg,#1e3a5f,#1d4ed8);padding:14px 16px}.voucher-ticket.template-d .vt-head{color:#fff;text-align:center;background:linear-gradient(135deg,#581c87,#7c3aed);padding:14px 16px}.vt-biz{letter-spacing:.5px;font-size:14px;font-weight:800}.vt-sub{opacity:.7;margin-top:1px;font-size:9px}.vt-body{background:#fff;padding:14px 16px}.vt-code{color:#1a1a2e;letter-spacing:4px;text-align:center;background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;margin:8px 0;padding:10px;font-family:Consolas,monospace;font-size:22px;font-weight:900}.vt-plan{text-align:center;color:#666;margin:4px 0;font-size:12px}.vt-detail{color:#888;border-top:1px dashed #ddd;justify-content:space-between;margin-top:8px;padding-top:8px;font-size:10px;display:flex}.vt-footer{text-align:center;color:#999;background:#f3f4f6;border-top:1px dashed #ddd;padding:8px 16px;font-size:9px}.voucher-ticket.size-compact{width:200px}.voucher-ticket.size-compact .vt-head{padding:9px 11px}.voucher-ticket.size-compact .vt-biz{font-size:11px}.voucher-ticket.size-compact .vt-sub{font-size:8px}.voucher-ticket.size-compact .vt-body{padding:9px 11px}.voucher-ticket.size-compact .vt-code{letter-spacing:2px;padding:6px;font-size:15px}.voucher-ticket.size-compact .vt-plan{font-size:10px}.voucher-ticket.size-compact .vt-detail{font-size:8px}.voucher-ticket.size-compact .vt-footer{padding:5px 11px;font-size:7px}.voucher-ticket.size-standard{width:280px}.voucher-ticket.size-large{width:360px}.voucher-ticket.size-large .vt-head{padding:18px 20px}.voucher-ticket.size-large .vt-biz{font-size:18px}.voucher-ticket.size-large .vt-sub{font-size:11px}.voucher-ticket.size-large .vt-body{padding:18px 20px}.voucher-ticket.size-large .vt-code{letter-spacing:5px;padding:13px;font-size:28px}.voucher-ticket.size-large .vt-plan{font-size:14px}.voucher-ticket.size-large .vt-detail{font-size:11px}.voucher-ticket.size-large .vt-footer{padding:10px 20px;font-size:10px}.template-selector{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.tmpl-card{border:2px solid var(--border);cursor:pointer;border-radius:10px;transition:all .15s;overflow:hidden}.tmpl-card:hover,.tmpl-card.sel{border-color:var(--accent)}.tmpl-thumb{justify-content:center;align-items:center;height:80px;font-size:22px;display:flex}.tmpl-name{color:var(--t3);text-align:center;background:var(--bg2);padding:6px;font-size:10px;font-weight:700}.pay-opt{background:var(--bg0);border:2px solid var(--border);cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;transition:all .15s;display:flex}.pay-opt:hover,.pay-opt.sel{border-color:var(--accent);background:#2563eb0d}.pay-logo{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:11px;font-weight:800;display:flex}.mtn{color:#000;background:#fc0}.airtel{color:#fff;background:#e40000}.cash{color:#fff;background:#059669}.pay-nm{color:var(--t1);font-size:13px;font-weight:700}.pay-inf{color:var(--t3);margin-top:1px;font-size:10px}.pay-ck{color:var(--accent);opacity:0;margin-left:auto;font-size:16px;transition:opacity .12s}.pay-opt.sel .pay-ck{opacity:1}.wallet-card{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border-radius:14px;margin-bottom:18px;padding:22px;position:relative;overflow:hidden}.wallet-card:after{content:"";background:#ffffff0f;border-radius:50%;width:120px;height:120px;position:absolute;top:-20px;right:-20px}.wallet-bal{margin:6px 0;font-size:34px;font-weight:900;line-height:1}.wallet-lbl{opacity:.7;text-transform:uppercase;letter-spacing:.08em;font-size:10px}.wallet-sub{opacity:.7;margin-top:4px;font-size:12px}.credit-method{flex-wrap:wrap;gap:10px;margin-bottom:16px;display:flex}.credit-opt{background:var(--bg0);border:2px solid var(--border);text-align:center;cursor:pointer;min-width:100px;color:var(--t2);border-radius:10px;flex:1;padding:12px;font-size:11px;font-weight:700;transition:all .15s}.credit-opt:hover,.credit-opt.sel{border-color:var(--accent);color:var(--accent);background:#2563eb0d}.credit-icon{margin-bottom:5px;font-size:22px;display:block}.contact-chip{background:var(--bg2);border:1px solid var(--border);color:var(--t2);border-radius:20px;align-items:center;gap:5px;margin:2px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.contact-chip .rm{color:var(--t4);cursor:pointer;font-size:13px;line-height:1}.contact-chip .rm:hover{color:var(--red)}.template-sms{background:var(--bg0);border:1px solid var(--border);cursor:pointer;border-radius:8px;margin-bottom:8px;padding:10px;transition:all .12s}.template-sms:hover{border-color:var(--accent)}.template-sms-title{color:var(--t2);margin-bottom:3px;font-size:11px;font-weight:700}.template-sms-body{color:var(--t3);font-size:11px;line-height:1.5}.device-card{background:var(--bg0);border:1px solid var(--border);border-radius:11px;flex-wrap:wrap;align-items:center;gap:13px;margin-bottom:10px;padding:15px;transition:all .15s;display:flex}.device-card:hover{background:var(--hover)}.device-icon{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;display:flex}.device-nm{color:var(--t1);font-size:13px;font-weight:700}.device-inf{color:var(--t3);margin-top:2px;font-size:11px}.device-stats{text-align:right;margin-left:auto}.device-stat-val{color:var(--t1);font-size:13px;font-weight:700}.device-stat-lbl{color:var(--t4);text-transform:uppercase;font-size:9px}.portal-device{box-shadow:var(--shadow);background:#1a1a2e;border-radius:16px;padding:8px;display:inline-block}.portal-screen{border-radius:10px;width:280px;height:480px;position:relative;overflow:hidden}.cp-a{color:#fff;text-align:center;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:20px;display:flex}.cp-b{color:#fff;text-align:center;background:linear-gradient(160deg,#0d7377,#14a085);flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:20px;display:flex}.cp-c{color:#1a1a2e;text-align:center;background:#fff;flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:20px;display:flex}.cp-d{color:#e94560;text-align:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);flex-direction:column;justify-content:center;align-items:center;min-height:100%;padding:20px;display:flex}.cp-logo{margin-bottom:8px;font-size:32px}.cp-title{margin-bottom:4px;font-size:18px;font-weight:800}.cp-sub{opacity:.7;margin-bottom:16px;font-size:11px}.cp-card{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border-radius:12px;width:100%;padding:16px}.cp-c .cp-card{background:#f3f4f6}.cp-input{color:#fff;background:#ffffff26;border:1px solid #ffffff40;border-radius:8px;outline:none;width:100%;margin-bottom:10px;padding:9px 12px;font-family:inherit;font-size:13px}.cp-c .cp-input{color:#1a1a2e;background:#fff;border:1px solid #ddd}.cp-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;width:100%;margin-bottom:8px;padding:10px;font-size:13px;font-weight:700}.cp-plans{grid-template-columns:1fr 1fr;gap:7px;margin-top:10px;display:grid}.cp-plan{text-align:center;cursor:pointer;background:#ffffff1a;border:1px solid #ffffff26;border-radius:8px;padding:8px;font-size:11px;font-weight:700}.cp-c .cp-plan{color:#1a1a2e;background:#fff;border:1px solid #ddd}.cp-plan-price{font-size:14px;font-weight:900}@media print{#sidebar,#topbar,#notif-wrap,.no-print{display:none!important}#main{margin:0}#content{padding:0}.page{display:none!important}#print-area{display:block!important}@page{margin:10mm}}#print-area{display:none}.g2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.fee-card{background:var(--bg0);border:1px solid var(--border);border-radius:11px;padding:16px;position:relative;overflow:hidden}.fee-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.fee-lbl{color:var(--t4);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;font-size:9px;font-weight:700}.fee-val{color:var(--t1);font-size:20px;font-weight:800;line-height:1}.fee-sub{color:var(--t3);margin-top:5px;font-size:10px}.role-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:10px;align-items:center;gap:4px;padding:2px 8px;font-size:9px;font-weight:800;display:inline-flex}.role-admin{color:var(--purple);background:#8b5cf626;border:1px solid #8b5cf640}.role-staff{color:var(--blue);background:#3b82f626;border:1px solid #3b82f640}.perm-grid{grid-template-columns:1fr 1fr;gap:7px;margin-top:6px;display:grid}.perm-chip{background:var(--bg0);border:1px solid var(--border);color:var(--t2);cursor:pointer;border-radius:7px;align-items:center;gap:7px;padding:7px 9px;font-size:11px;transition:all .12s;display:flex}.perm-chip:hover{border-color:var(--accent)}.perm-chip input{accent-color:var(--accent)}.wallet-mini{background:var(--bg0);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:10px;padding:12px 14px;display:flex}.wallet-mini-lbl{color:var(--t3);font-size:11px}.wallet-mini-val{color:var(--t1);font-size:15px;font-weight:800}.platform-wallet-card{color:#fff;background:linear-gradient(135deg,#7c3aed,#2563eb);border-radius:14px;margin-bottom:18px;padding:22px;position:relative;overflow:hidden}.platform-wallet-card:after{content:"";background:#ffffff0f;border-radius:50%;width:130px;height:130px;position:absolute;top:-20px;right:-20px}.status-toggle{background:var(--bg3);cursor:pointer;border-radius:10px;flex-shrink:0;width:38px;height:20px;transition:background .15s;position:relative}.status-toggle.on{background:var(--green)}.status-toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .15s;position:absolute;top:2px;left:2px}.status-toggle.on:after{transform:translate(18px)}.empty{text-align:center;color:var(--t4);padding:40px 20px}.empty-ico{opacity:.4;margin-bottom:8px;font-size:38px;display:block}.sep{background:var(--border);height:1px;margin:16px 0}@media (width<=1180px){.g2{grid-template-columns:1fr}.fg.c3{grid-template-columns:1fr 1fr}.stats-row{grid-template-columns:repeat(2,1fr)}.template-selector{grid-template-columns:repeat(3,1fr)}[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}}@media (width<=1024px){.menu-btn{display:flex}#sidebar{transform:translate(-100%)}#sidebar.open{transform:translate(0)}#main{margin-left:0}.fg.c2,.router-status-metrics{grid-template-columns:1fr}.plan-grid{grid-template-columns:repeat(2,1fr)}.cp-plans{grid-template-columns:1fr}.tab-bar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;width:100%;overflow-x:auto}.tab-bar .tab{white-space:nowrap;flex-shrink:0}table{font-size:12px}.card-hd{flex-wrap:wrap;gap:8px}}@media (width<=640px){#topbar{padding:0 12px}#content{padding:12px!important}.stats-row{grid-template-columns:1fr 1fr;gap:8px}.stat{padding:12px}.stat-val{font-size:18px}.fg.c2,.fg.c3,.plan-grid{grid-template-columns:1fr}.template-selector{grid-template-columns:1fr 1fr}.perm-grid{grid-template-columns:1fr}.card-body{padding:12px!important}.btn-row{flex-direction:column}.btn-row .btn{width:100%}.page-title{font-size:13px}.tb-btn span,.tb-btn{padding:6px 9px;font-size:11px}.avatar{width:28px;height:28px;font-size:11px}.tbl-wrap,[class*=overflow-y-auto]{overflow-x:auto}table{min-width:520px}.credit-method{grid-template-columns:1fr!important}}
