@font-face{font-family:Hubot Sans;src:url(/fonts/HubotSans-Regular.woff2) format("woff2"),url(/fonts/HubotSans-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Hubot Sans;src:url(/fonts/HubotSans-Bold.woff2) format("woff2"),url(/fonts/HubotSans-Bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}:root{--bg: #444444;--bg-accent: #424242;--media-text: #dbe7ee;--topbar: #6b6b6b;--sidebar-surface: #3b3b3b;--card: #ffffff;--card-surface: #ffffff;--accent: #ff7a59;--accent-2: #6dd3b1;--muted: #9aa4b2;--text: #000000}*,*:before,*:after{box-sizing:border-box}img,svg{max-width:100%;height:auto;display:block}html,body,#root{height:100%;width:100%}body{margin:0;font-family:Hubot Sans,Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;font-weight:400;background:var(--bg);background-image:var(--bg-accent);color:var(--text)}.login-wrapper.login-background{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg);box-sizing:border-box}.login-wrapper.login-background .login-card{max-width:480px;width:min(92vw,480px);background:#fff;color:#0f172a;box-shadow:0 8px 28px #0f172a14;border-radius:12px;padding:28px 28px 22px;border:1px solid #eef2f6}.login-wrapper.login-background .brand-title{font-size:28px;color:#0f172a;letter-spacing:.6px}.login-wrapper.login-background .subtitle{color:#6b7280;text-align:center;margin-bottom:12px}.login-wrapper.login-background .input-with-icon.boxed{background:transparent;border:none;padding:0;display:flex;align-items:center;gap:12px}.login-wrapper.login-background .input-with-icon{display:flex;align-items:center;gap:12px}.login-wrapper.login-background .input-with-icon.boxed{background:#f3f4f6;border-radius:12px;padding:6px 12px}.login-wrapper.login-background .input-with-icon .icon{width:36px;height:36px;margin-right:0;opacity:1;display:inline-flex;align-items:center;justify-content:center;color:#0f172a;border-radius:8px;background:transparent}.login-wrapper.login-background .input-with-icon .icon svg{width:16px;height:16px;display:block;fill:currentColor;stroke:none}.login-wrapper.login-background .input-with-icon input{height:46px;border:none;padding:0 10px;color:#0f172a;background:transparent;outline:none;box-shadow:none;font-size:15px}.login-wrapper.login-background .input-with-icon .icon img.icon-img{width:16px;height:16px;object-fit:contain;display:block}.login-wrapper.login-background .submit{width:100%;background:#2b2b2b;color:#fff;padding:12px 14px;border-radius:999px;border:none;font-weight:800;letter-spacing:.6px}.login-wrapper.login-background .submit:hover{background:#1f1f1f}.btn-cancel{background:#ea5455;color:#fff;border:none;padding:12px 14px;border-radius:6px;font-weight:800;cursor:pointer;display:inline-block}.btn-cancel:hover{background:#d64b4b}.login-wrapper.login-background .checkbox,.login-wrapper.login-background .link{color:#475569}.login-wrapper.login-background .checkbox label{display:inline-flex;align-items:center;gap:8px;color:#475569;font-size:14px}.login-wrapper.login-background .checkbox input[type=checkbox]{width:16px;height:16px;margin:0 6px 0 0;vertical-align:middle;accent-color:#3b3b3b;border:1px solid #cbd5e1;background:#fff}.login-wrapper.login-background a.link{color:#475569!important;font-weight:600;text-decoration:none}.login-wrapper.login-background a.link:hover{text-decoration:underline}.login-wrapper.login-background .input-with-icon .icon,.login-wrapper.login-background .input-with-icon .icon svg{color:#6b7280!important;fill:#6b7280!important;stroke:none!important;filter:none!important}.login-wrapper.login-background .checkbox,.login-wrapper.login-background .link{color:#fffffff2}.login-wrapper.login-background .actions{display:block;margin-top:12px}.login-wrapper.login-background .submit{width:100%;background:var(--sidebar-surface);color:#fff;padding:12px 16px;border-radius:6px;border:none;font-weight:800;letter-spacing:1px}.login-wrapper.login-background .submit:hover{background:#313131}.login-wrapper.login-background .card-footer{color:#ffffffe6;display:flex;justify-content:space-between;margin-top:12px}h1,h2,h3,h4,h5,h6,.overview-title,.panel-title,.tile-title,.card-head,.unit-card .card-head,.modal-head,.brand-title,.dash-topbar .breadcrumbs{color:#000;font-weight:800}strong,b{font-weight:800}.app-root{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(8px,2vw,20px);overflow:hidden}.login-wrapper{width:min(92vw,480px);margin:auto;display:flex;flex-direction:column;align-items:center;gap:12px}.login-card{width:100%;max-width:480px}.forgot-wrapper{width:min(92vw,400px)}.login-card{background:#fff;color:#0f172a;box-shadow:0 8px 18px #00000052;padding:clamp(6px,1.5vw,10px);display:flex;flex-direction:column;gap:clamp(6px,1.2vw,10px);transform-origin:center;animation:fadeInUp .28s ease forwards;position:relative}.card-top{display:flex;justify-content:center;align-items:center;margin-bottom:10px}.brand-title{font-size:28px;color:#0f172a;font-weight:800;text-align:center;width:100%;letter-spacing:.6px}.forgot-title{font-weight:800;font-size:20px;letter-spacing:.2px}.center-actions{justify-content:center}.logo,.brand-logo{display:none}.actions{display:flex;justify-content:center}:root{--bp-sm: 480px;--bp-md: 900px;--bp-lg: 1200px}.dashboard-main,.main-content{padding:20px}.dashboard-sidebar{width:220px;flex:0 0 220px}.search-bar{max-width:640px;width:100%}.players-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.dash-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.dash-grid .span-3{grid-column:span 3}.dash-grid .span-2{grid-column:span 2}@media (max-width: 1200px){.dash-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 900px){.dashboard-sidebar{width:72px;flex:0 0 72px}.topbar-brand{font-size:14px}.search-bar{max-width:420px}.dash-grid{grid-template-columns:repeat(2,1fr)}.dash-grid .span-3,.dash-grid .span-2{grid-column:span 2}.overview-table,.overview-card{overflow-x:auto}}@media (max-width: 480px){.dashboard-sidebar{display:none}.dashboard-main{padding:12px}.search-bar{max-width:100%}.dash-grid{grid-template-columns:1fr}.dash-grid .span-3,.dash-grid .span-2{grid-column:auto}.breadcrumbs{font-size:13px}.tile-value{font-size:20px}.players-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.prop-table td,.prop-table th{padding:10px 12px;font-size:14px}}.unit-card,.tile,.search-result-button{touch-action:manipulation}.preloader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#9aa4b2}.spinner{width:80px;height:80px;animation:spinCurve 2s linear infinite}.spinner-path{stroke:#00bfff;stroke-width:8;fill:none;stroke-linecap:round;animation:dashCurve 2s linear infinite}.spinner-path:nth-child(2){animation:dashCurve 2s linear infinite .4s}.preloader-text{font-size:14px}.content{opacity:1;transform:none;transition:none;animation:none}.content.visible{opacity:1;transform:none}@keyframes spinCurve{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes dashCurve{0%{stroke-dasharray:0 100;opacity:1}50%{stroke-dasharray:60 40}to{stroke-dasharray:60 40;opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.subtitle{font-size:14px;color:#6b7280;text-align:left;margin-bottom:6px}.field{margin-bottom:12px}.field.stacked{display:flex;flex-direction:column;gap:10px}.small-row{margin-top:2px;margin-bottom:6px}.input-with-icon{position:relative}.input-with-icon.boxed{background:#f1f5f9;border:1px solid #e6edf6;padding:8px;display:flex;align-items:center}.input-with-icon .icon{width:32px;height:32px;margin-right:10px;opacity:1;display:inline-flex;align-items:center;justify-content:center;color:#fff!important}.input-with-icon .icon svg{width:100%;height:100%;display:block;stroke-width:2.4;fill:currentColor;stroke:#fff;paint-order:stroke;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 2px 3px rgba(0,0,0,.22))}.input-with-icon .icon i,.input-with-icon .icon .icon-font{font-size:20px;font-weight:800;color:currentColor;text-shadow:-1px -1px 0 #ffffff,1px -1px 0 #ffffff,-1px 1px 0 #ffffff,1px 1px 0 #ffffff}.input-with-icon .icon{padding:4px}.input-with-icon input{width:100%;padding:8px 10px;border:none;background:transparent;color:#0f172a;font-size:14px}.input-with-icon input:focus{box-shadow:0 6px 24px #0f172a0f;border-color:#2f6df224;outline:none}.row{display:flex;align-items:center}.row.between{justify-content:space-between}.checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}input[type=radio],input[type=checkbox]{accent-color:#3b3b3b;cursor:pointer}input[type=radio]:checked,input[type=checkbox]:checked{accent-color:#3b3b3b}.link{font-size:13px;color:var(--accent);text-decoration:none}.submit{background:var(--accent);color:#fff;padding:10px 18px;border:none;font-weight:700;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.submit:hover{transform:translateY(-2px);box-shadow:0 10px 24px #0000001f}.submit:focus{outline:3px solid rgba(11,17,27,.12)}.submit{min-width:110px}.message{padding:10px 12px;background:#fff7ed;color:#92400e;font-size:13px}.error-banner{background:#fff7ed;color:#92400e;border-left:4px solid #f97316;padding:10px 14px;margin:0 0 12px;width:100%;box-shadow:0 6px 18px #02061714}.error-banner .error-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}.error-banner .error-text{font-size:13px}.error-banner .error-close{background:transparent;border:none;font-size:16px;cursor:pointer;color:inherit}.error-banner.popup{position:absolute;left:50%;transform:translate(-50%);top:20px;max-width:min(96vw,520px);z-index:1400;margin:0;transition:opacity .18s ease,transform .18s ease;pointer-events:auto}.app-root{position:relative}.login-wrapper{margin-top:0}.login-card .card-footer{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:6px;margin-left:-4px;margin-right:-4px}.login-card .card-footer .version{font-size:12px;color:#9aa4b2}.secondary-logo{position:absolute;right:14px;bottom:8px;width:84px;opacity:.95}.login-card .card-footer .secondary-text{font-size:13px;color:#6b7280;font-weight:700}.or-row{display:flex;align-items:center;gap:8px;margin:6px 0}.or-row .line{flex:1;height:1px;background:#eef2f6}.or-row .or{font-size:12px;color:#9aa4b2}.google-btn{display:none}.warning{margin-top:12px;color:#cbd5e1;text-align:center;font-size:12px;max-width:min(92vw,400px);margin-left:auto;margin-right:auto}.warning-title{font-weight:700;margin-bottom:6px}.warning-body{max-width:640px;margin:0 auto;line-height:1.45}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.login-card{padding:12px;margin:12px}}.dashboard-root{display:flex;height:100vh;align-items:stretch;width:100vw;box-sizing:border-box;overflow:hidden}.dashboard-sidebar{flex:0 0 240px;width:240px;background:var(--sidebar-surface);color:#fff;padding:12px 16px;display:flex;flex-direction:column;justify-content:space-between;height:calc(100vh - 70px);box-sizing:border-box;transition:width .28s cubic-bezier(.2,.9,.2,1),padding .22s cubic-bezier(.2,.9,.2,1);position:fixed;top:70px;left:0;z-index:40}.dash-logo{font-weight:900;color:#fff;background:var(--sidebar-surface);padding:12px;margin-top:12px;border-radius:0;display:inline-flex;align-items:center;gap:8px;margin-bottom:18px;max-width:100%;box-sizing:border-box;position:relative;text-indent:0;font-size:15px;letter-spacing:.6px;text-transform:uppercase}.sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;position:relative;margin-bottom:12px}.dash-nav{display:flex;flex-direction:column;gap:10px;padding-top:12px}.dash-nav a{color:#fff;padding:8px 10px;text-decoration:none;display:flex;align-items:center;gap:10px;font-weight:500}.dash-nav a .icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;color:#fff}.dash-nav a .tab-text{white-space:nowrap;transition:opacity .12s ease,transform .12s ease}.dash-nav a.active{background:var(--topbar);color:#fff;border-radius:8px;padding:8px 10px;font-weight:600}.dash-nav a.active .icon,.dash-nav a.active .tab-text{color:#fff}.dash-powered{margin-top:auto;text-align:left}.dashboard-sidebar.collapsed{width:60px;padding-left:8px;padding-right:8px}.dashboard-sidebar--collapsed-removed{left:0;width:50px;height:100%;z-index:2;float:left;padding-left:8px;padding-right:8px}.dashboard-sidebar.collapsed .dash-logo{align-items:center;justify-content:center;width:40px;height:40px;padding:6px;font-size:13px}.dashboard-sidebar.collapsed .sidebar-header{align-items:center}.dashboard-sidebar .dash-nav{flex-direction:column;gap:14px}.dashboard-sidebar.collapsed .dash-nav{justify-content:center}.dashboard-sidebar.collapsed .dash-nav a{justify-content:center;padding:12px 0}.dashboard-sidebar.collapsed .tab-text{opacity:0;transform:translate(-6px);width:0;height:0;overflow:hidden;pointer-events:none}.dashboard-sidebar.collapsed .dash-nav a.active{background:#ffffff0f;width:40px;height:40px;margin:6px auto;display:flex;align-items:center;justify-content:center}.dashboard-sidebar.collapsed .dash-nav a{background:transparent}.dashboard-sidebar a .icon{background:transparent;padding:6px}.dash-nav a.active .icon{background:transparent}.dash-nav a .tab-text{transition:opacity .18s ease,transform .2s ease}.dash-nav a .icon{transition:transform .22s cubic-bezier(.2,.9,.2,1),font-size .18s ease}.dashboard-sidebar.collapsed .dash-nav a .icon{transform:translateY(-2px) scale(1.06)}.dashboard-sidebar.collapsed .profile-actions{justify-content:center}.dashboard-sidebar.collapsed .dash-powered{display:none}.dashboard-sidebar.collapsed .dash-nav a .icon{font-size:20px}.powered-by{font-size:12px;color:#fff}.adxba{font-weight:700;margin-top:6px}.version-small{font-size:12px;color:#fff}.dashboard-main{flex:1 1 auto;background:linear-gradient(#17232b 0,#17232b 70px,#f3f6f8 70px);padding:0;overflow:auto;height:100vh;display:flex;flex-direction:column;margin-left:240px;transition:margin-left .28s cubic-bezier(.2,.9,.2,1)}.dashboard-sidebar.collapsed~.dashboard-main{margin-left:60px}.main-content{padding:86px 16px 12px;flex:1 1 auto}.dash-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:10px 14px;background:#fff;box-shadow:0 8px 20px #1018280f;border:1px solid #eef2f6;height:auto}.breadcrumbs{color:#0b0b0b;font-size:14px;font-weight:700}.dash-topbar .breadcrumbs a{color:inherit;text-decoration:none}.dash-topbar .breadcrumbs a:hover{text-decoration:underline}.page-topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin:0;padding:12px 16px 12px 8px;background:var(--sidebar-surface);color:var(--media-text);height:70px;box-sizing:border-box;position:fixed;top:0;left:0;right:0;z-index:10;transition:left .18s ease}.topbar-left{display:flex;align-items:center;gap:12px;padding:0}.topbar-brand{font-weight:700;font-size:14px;letter-spacing:.6px;text-transform:uppercase;color:var(--media-text);white-space:nowrap;transition:opacity .18s ease,width .18s ease}.topbar-brand.hidden{opacity:0;width:0;overflow:hidden;pointer-events:none}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:6px;background:transparent;border:1px solid rgba(255,255,255,.08);color:inherit;cursor:pointer;border-radius:6px;flex-shrink:0}.sidebar-toggle svg{width:20px;height:20px;stroke:none}.sidebar-toggle:hover{background:#ffffff14;border-color:#ffffff1f}.sidebar-toggle:active{background:#ffffff1f}.sidebar-toggle:focus{outline:none;box-shadow:0 0 0 3px #ffffff1a}@media (max-width:900px){.page-topbar{left:0;padding:12px 16px;gap:12px}}@media (max-width:600px){.page-topbar{padding:10px 12px;gap:8px;height:60px}}.breadcrumbs{display:flex;align-items:center;gap:8px}.search-bar{flex:0 1 640px;max-width:640px;display:flex;align-items:center;height:100%;box-sizing:border-box;padding:8px 0}.search-bar input{width:100%;height:40px;padding:8px 14px;border:1px solid rgba(255,255,255,.08);background:var(--topbar);color:#fff;font-size:15px;border-radius:10px}.page-topbar{position:fixed}.page-topbar .search-bar{position:absolute;left:256px;top:50%;transform:translateY(-50%);width:min(720px,60%);max-width:800px;box-sizing:border-box}.dashboard-sidebar.collapsed~.dashboard-main .page-topbar .search-bar{left:76px}.profile-open .page-topbar .search-bar{left:16px}.search-bar input:focus{outline:none;box-shadow:0 6px 20px #0b111b14}.search-bar input::placeholder{color:#ffffffbf;opacity:1}.search-bar input:-ms-input-placeholder{color:#ffffffbf}.search-bar input::-webkit-input-placeholder{color:#ffffffbf}.search-bar input::-moz-placeholder{color:#ffffffbf;opacity:1}.search-bar input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border:none;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23fff' d='M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z'/></svg>") center/16px no-repeat transparent;cursor:pointer}.search-bar input[type=search]::-ms-clear,.search-bar input[type=search]::-ms-reveal{display:none;width:0;height:0}.search-bar input[type=search]::-moz-search-clear{display:none}@media (max-width:768px){.search-bar{max-width:none;flex:1 1 auto}.search-bar input{height:30px;font-size:13px;padding:4px 10px}}@media (max-width:480px){.search-bar{flex:1 1 100%;min-width:0}.search-bar input{height:28px;font-size:12px;padding:4px 8px}}.user-profile{display:flex;align-items:center;gap:12px;height:100%;position:relative;cursor:pointer}.user-profile .user-name{font-size:15px;color:#dbe7ee;line-height:1}.user-meta{display:flex;flex-direction:column;align-items:flex-end;text-align:right;justify-content:center}.user-role{font-size:12px;color:#dbe7eecc;margin-bottom:2px;display:none}.user-pill{display:inline-flex;align-items:center;gap:8px;background:transparent}.user-display{font-weight:800;font-size:16px;color:#dbe7ee}.user-avatar{width:44px;height:44px;background:#cfeff6;color:#0f172a;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:6px;transform:translateY(-1px);position:relative;border-radius:50%;font-size:18px}.status-dot{position:absolute;right:-2px;bottom:-2px;width:10px;height:10px;border:2px solid #fff;box-shadow:0 2px 6px #0206171f}.status-dot.green{background:#16a34a}.status-dot.warn{background:#fbbf24}.status-dot.grey{background:#9ca3af}@media (max-width:700px){.user-meta{display:none}.user-avatar{margin-left:0}}.profile-menu{position:absolute;right:0;top:100%;margin-top:10px;background:#fff;color:#0f172a;min-width:220px;box-shadow:0 8px 24px #02061747;padding:10px;z-index:1400}.profile-item{padding:6px 8px;border-bottom:1px solid #f1f5f9;font-size:13px}.profile-item:last-child{border-bottom:none}.profile-actions{padding-top:8px;display:flex;justify-content:flex-end}.profile-action{background:var(--accent);color:#fff;border:none;padding:8px 10px;cursor:pointer}.profile-action.small{padding:6px 8px;font-size:13px;min-width:90px}.profile-action.danger{background:#b20000}.profile-menu .profile-actions{display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:8px;padding-top:8px;width:100%}.profile-menu .profile-action{display:block;width:160px;height:36px;margin:0 auto;text-align:center;padding:0 12px;border-radius:6px}.profile-menu .profile-action.small{min-width:0;width:160px;padding:0 12px}.profile-menu .profile-action.danger{width:160px}.user-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0206178f;display:flex;align-items:center;justify-content:center;z-index:1200}.user-modal{background:#fff;width:min(820px,94vw);box-shadow:0 20px 60px #02061799;overflow:hidden}.user-modal .profile-card-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f7fafc;border-bottom:1px solid #f1f5f9}.user-modal .profile-body{display:flex;gap:20px;padding:18px}.user-modal .profile-main{flex:1}.user-modal .profile-name{margin:2px 0 8px;font-size:24px}.user-modal .profile-row{display:flex;align-items:center;gap:10px;color:#334155;margin-bottom:8px}.user-modal .profile-info{color:#64748b}.user-modal .profile-perms{width:320px}.back-btn{background:transparent;border:1px solid #e6edf6;padding:6px 10px;cursor:pointer}.user-profile-card{padding:12px 0}.profile-card{background:#fff;padding:0;overflow:hidden;box-shadow:0 6px 14px #0206170f;display:flex;flex-direction:column;max-width:600px;transform:none;opacity:1;transition:none}.profile-card-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;background:#f1f5f9;border-bottom:1px solid #edf2f6}.profile-title{font-weight:700}.mfa-btn{background:transparent;border:1px solid #e6edf6;padding:8px 12px;cursor:pointer}.profile-body{display:flex;gap:20px;padding:18px}.profile-main{flex:1}.profile-name{margin:2px 0 8px;font-size:24px}.profile-row{display:flex;align-items:center;gap:10px;color:#334155;margin-bottom:8px}.profile-info{color:#64748b}.profile-perms{width:280px;background:#fff}.profile-perms h3{margin-top:0}.perm-row{display:flex;justify-content:space-between;align-items:center;background:#f8fafc;padding:8px 10px;margin-bottom:8px}.perm-name{font-weight:700}.perm-tags{display:flex;gap:6px}.perm{background:#1e73b8;color:#fff;padding:4px 8px;font-size:12px}.profile-full{display:flex;align-items:flex-start;justify-content:flex-start;padding:12px 28px}.profile-full .profile-card{width:100%;max-width:600px;display:flex;flex-direction:column;margin:0}.profile-full .profile-body{flex:1;overflow:auto;padding:20px}.profile-full .profile-perms{width:280px}.profile-open .profile-card{transform:translate(0);opacity:1;box-shadow:0 18px 38px #2228311f}.profile-open .dashboard-sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1400}.profile-open .page-topbar{left:240px;z-index:1500;transition:left .22s ease,box-shadow .22s ease}.profile-open .page-main:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#080c100a;pointer-events:none;opacity:1;transition:opacity .22s ease}@media (max-width:700px){.search-bar{max-width:360px}.user-profile .user-name{display:none}}.dash-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-auto-rows:minmax(160px,auto);gap:12px;margin-bottom:16px;align-items:stretch}.tile{background:#fff;padding:18px;box-shadow:0 1px #0f172a0a;display:flex;flex-direction:column;justify-content:space-between;height:100%;min-height:0;box-sizing:border-box}.tile.span-3{grid-column:span 3}.tile.span-2{grid-column:span 2}.tile.span-5{grid-column:1 / -1}.tile-title{font-size:13px;color:#6b7280}.tile .tile-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(180deg,#fffffffa,#fffffff5);box-shadow:0 6px 18px #0206170a;color:#0f172a}.tile .tile-icon svg{width:26px;height:26px;display:block}.tile .tile-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.tile .tile-header .tile-title{flex:1}.tile-value{font-size:28px;font-weight:800;margin-top:8px}.tile-sub{font-size:12px;color:#9aa4b2;margin-top:6px}.progress{height:8px;background:#f1f5f9;margin-top:10px}.p-fill{height:100%;width:100%;background:linear-gradient(90deg,#0e7f27 var(--pct,50%),#b20000 var(--pct,50%))}.dash-overview{display:grid;grid-template-columns:2fr 1fr 1fr;gap:12px}.overview-card,.activity-card,.announcements-card{background:#fff;padding:12px;overflow:auto}.overview-title{font-weight:700;margin-bottom:8px}.overview-badge{display:inline-block;margin-left:10px;background:#fffbeb;color:#92400e;font-weight:700;font-size:12px;padding:4px 8px;border:1px solid #ffecb5;vertical-align:middle}.overview-badge:hover{box-shadow:0 6px 20px #0e1c140f}.overview-table{width:100%;border-collapse:collapse;table-layout:fixed;min-width:0}.overview-table th{font-weight:700;text-align:left;padding:8px 6px;font-size:13px;color:#6b7280}overview-table td{padding:10px 6px;border-top:1px solid #edf2f6;word-break:break-word}.activity-title{font-weight:700;margin-bottom:8px}.activity-list{list-style:none;padding:0;margin:0}.activity-list li{padding:10px 6px;border-top:1px solid #eef2f6}.activity-list .meta{float:right;color:#6b7280;font-size:12px}.activity-list .unit-item{display:flex;justify-content:space-between;align-items:center;gap:12px}.activity-list .unit-left{flex:1}.activity-list .unit-name{font-weight:700;font-size:14px;color:#1f2937;margin-bottom:4px}.activity-list .unit-location{font-size:12px;color:#9ca3af}.activity-list .unit-right{flex-shrink:0;text-align:right}.activity-list .unit-lastseen{font-size:12px;color:#6b7280}.announcements-title{font-weight:700;margin-bottom:8px}.announcements-empty{color:#9aa4b2;padding:20px}.chat-fab{position:fixed;right:22px;bottom:22px;width:52px;height:52px;background:#b20000;color:#fff;border:none;box-shadow:0 8px 24px #0000002e;font-size:20px}@media (max-width:1200px){.dashboard-sidebar{width:200px;padding:18px}.dashboard-main{padding:18px}.dash-tiles{gap:10px}.dash-overview{grid-template-columns:1.5fr 1fr .9fr}}@media (max-width:900px){.dashboard-root{flex-direction:column}.dashboard-sidebar{display:none}.dashboard-main{padding:14px}.dash-tiles{flex-direction:column}.tile{width:100%}.dash-overview{grid-template-columns:1fr;grid-auto-rows:auto}.overview-card,.activity-card,.announcements-card{width:100%}.overview-card{overflow:auto}.overview-table{display:table;width:100%;table-layout:fixed;-webkit-overflow-scrolling:touch}.dash-topbar{padding:8px 4px}}@media (max-width:600px){.dashboard-main{padding:10px}.tile{padding:12px}.tile-title{font-size:12px}.tile-value{font-size:20px}.tile-sub{font-size:11px}.overview-table th,.overview-table td{font-size:12px}.activity-list li{font-size:13px;padding:8px 4px}.dash-logo{font-size:14px}.chat-fab{right:14px;bottom:14px;width:48px;height:48px}}@media (max-width:900px){.login-wrapper{width:min(96vw,360px)}}.units-container{display:flex;gap:18px;align-items:flex-start;height:auto;overflow:visible}.units-container.compact{justify-content:center}.units-sidebar{width:320px;height:100%;display:flex;flex-direction:column}.units-select{width:100%;padding:10px;border:1px solid #e6edf6;background:#fff}.units-dropdown-toggle{width:100%;padding:10px;border:1px solid #e6edf6;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}.units-dropdown-toggle .dropdown-label{flex:1;text-align:left}.units-dropdown-toggle .dropdown-icon{flex:0 0 auto;margin-left:8px;color:#374151}.units-dropdown-menu{position:absolute;left:0;top:46px;z-index:1200;width:320px;background:#fff;border:1px solid #e6edf6;box-shadow:0 8px 24px #02061714}.units-dropdown-search{width:calc(100% - 20px);margin:8px 10px;padding:8px 10px;border:1px solid #eef2f6}.units-dropdown-list{max-height:360px;overflow:auto}.units-dropdown-item{padding:10px 12px;border-top:1px solid #f3f6f8;cursor:pointer}.units-dropdown-item:hover{background:#4242420f}.units-dropdown-item.active{background:var(--bg-accent);color:#fff}.units-panel{background:#fff;padding:12px;box-shadow:0 1px #0000000a;height:auto;overflow:visible;display:flex;flex-direction:column;margin-top:12px}.units-panel .panel-title{font-weight:700;margin-bottom:10px}.panel-disabled{opacity:.56;pointer-events:none}.units-panel{position:relative}.panel-blocker{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff9}.panel-actions{display:flex;align-items:center}.panel-action-btn{width:40px;height:40px;border:1px solid #e6edf6;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.panel-action-btn:hover{background:#f7fafc}.units-location-list{list-style:none;padding:0;margin:0}.units-location-item{display:flex;justify-content:space-between;align-items:center;padding:10px 8px;border-left:4px solid rgba(0,0,0,.06);margin-bottom:8px;cursor:pointer;gap:12px;width:100%;box-sizing:border-box;min-height:42px}.units-location-item:hover{background:#4242420a}.units-location-item.active{background:#ccc;border-left-color:#3b3b3b}.units-location-item>div:first-child{flex:1;min-width:0;word-break:break-word}.location-badge{color:#fff;padding:2px 8px;font-size:12px;white-space:nowrap;font-weight:700;flex-shrink:0}.location-badge.green{background:#0e7f27;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px #ffffff05}.location-badge.orange{background:#ff7a59;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px #ffffff05}.location-badge.yellow{background:#f59e0b;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px #ffffff05}.location-badge.red{background:#b20000;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px #ffffff05}.location-badge{border-radius:8px}.units-filter{margin-top:14px;background:#fff;padding:12px}.units-main{flex:1;height:auto;overflow:visible}.units-breadcrumbs{font-size:13px;color:#6b7280;margin-bottom:8px}.units-main-header{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:12px 16px;box-shadow:0 1px #0000000a;margin-bottom:12px}.units-main-header .header-left{display:flex;flex-direction:column}.units-main-header .header-title{font-weight:800;font-size:16px;color:#0b0b0b}.units-main-header .header-sub{color:#6b7280;font-size:13px}.units-main-header .header-actions{display:flex;gap:12px;align-items:center}.small-label{font-size:12px;color:#6b7280}.header-select{padding:6px 8px;border:1px solid #e6edf6;background:#fff}.view-toggle{display:inline-flex;gap:6px}.view-btn{padding:6px 8px;border:1px solid #e6edf6;background:#fff;cursor:pointer}.view-btn.active{background:#eef2f6}.reload-btn{background:transparent;border:1px solid #e6edf6;padding:6px 8px;cursor:pointer}.reload-btn svg{display:block}.units-overview{background:#fff;padding:12px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.units-topbar{background:#fff;padding:12px;margin-bottom:12px;display:flex;align-items:center;gap:12px}.units-topbar .breadcrumbs{font-weight:700}.units-topbar-actions{display:flex;gap:8px;align-items:center}.units-topbar{background:#fff;padding:12px;margin-bottom:12px;display:flex;align-items:center;gap:12px;box-shadow:0 1px #0000000a}.units-topbar .breadcrumbs{font-weight:700;color:#000}.units-topbar .units-subtitle{color:#6b7280;font-size:13px;margin-top:4px}.units-topbar .units-topbar-actions{display:flex;gap:8px;align-items:center}.units-progress{height:8px;background:#f1f5f9;margin-top:10px}.units-progress .fill{height:100%;width:100%;background:linear-gradient(90deg,#0e7f27 var(--pct,50%),#b20000 var(--pct,50%))}.units-topbar-stats .stats-progress{width:120px;height:8px;background:#f1f5f9;overflow:hidden}.units-topbar-stats .stats-progress-fill{height:100%;width:100%;background:linear-gradient(90deg,#4caf50 var(--pct,50%),#ef6b6b var(--pct,50%))}.units-topbar{background:#fff;padding:16px 20px;margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;border:4px solid #5b0b8a;box-shadow:0 8px 28px #5b0b8a0f;width:100%;box-sizing:border-box}.units-topbar .breadcrumbs{font-size:18px;font-weight:800;color:#0b0b0b}.units-topbar .units-subtitle{font-size:13px;color:#6b7280;margin-top:6px}.units-topbar .left-block{display:flex;flex-direction:column;gap:6px}.units-topbar-stats{display:flex;align-items:center;gap:12px;margin-left:12px}.units-topbar-stats .stats-block{display:flex;flex-direction:column;gap:6px;align-items:flex-end;min-width:120px}.units-topbar-stats .stats-count{background:#f3faf3;color:#0f5132;padding:6px 10px;font-weight:700;font-size:13px}.units-topbar-stats .stats-progress{width:160px;height:10px;background:#f1f5f9;overflow:hidden}.units-topbar-stats .stats-progress-fill{height:100%;width:100%;background:linear-gradient(90deg,#0e7f27 var(--pct,50%),#b20000 var(--pct,50%))}.units-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.units-grid.compact-grid{grid-template-columns:repeat(4,1fr)}@media (max-width:1200px){.units-grid.compact-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.units-grid.compact-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.units-grid.compact-grid{grid-template-columns:repeat(1,1fr)}}.unit-card{position:relative;background:#fff;overflow:hidden;box-shadow:0 1px #0000000a;cursor:pointer;display:flex;flex-direction:column;zoom:1!important;transform:scale(1)!important;margin-top:12px}.unit-card .card-head{background:#eef2f6;padding:8px;font-weight:700}.unit-card .card-thumb{aspect-ratio:3 / 4;width:100%;height:160px;min-height:160px;background:#111;display:flex;align-items:flex-end;justify-content:flex-start;color:#fff;padding:0;background-size:cover;background-position:center;position:relative}.unit-card .card-thumb .screenshot-badge{position:absolute;left:8px;top:8px;bottom:auto;background:#000000b3;color:#fff;padding:4px 8px;font-size:12px;opacity:.7}.unit-card .card-body{padding:10px 10px 36px;font-size:13px}.unit-meta{color:#6b7280;margin-bottom:4px;font-size:12px;line-height:1.2}.unit-status{font-weight:700}.unit-status.connected{color:#2f9a3f}.unit-status.disconnected{color:#b20000}.unit-link{color:#0f172a;text-decoration:none;cursor:pointer;font-weight:700}.unit-link:focus{outline:3px solid rgba(11,17,27,.08)}.unit-link:hover{opacity:.92}.status-bar{position:absolute;left:0;right:0;bottom:0;text-align:center;padding:6px 0;font-weight:700;color:#fff;font-size:13px}.status-bar.connected{background:#0e7f27}.status-bar.disconnected{background:#b20000}.screenshot-meta{font-size:12px;color:#475569;margin-bottom:6px}.unit-list{background:#fff;padding:8px;box-shadow:0 1px #0000000a}.unit-list-table{width:100%;border-collapse:collapse}.unit-list-table th{background:#f3f4f6;text-align:left;padding:10px;font-weight:700;color:#6b7280}.unit-list-table td{padding:10px;border-top:1px solid #eef2f6}.unit-list-table tbody tr.alt{background:#fbfcfe}.unit-list-table tbody tr{cursor:pointer}.unit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0206178f;display:flex;align-items:center;justify-content:center;z-index:1200}.unit-modal{background:#fff;width:min(720px,94vw);box-shadow:0 20px 60px #02061799;overflow:hidden}.unit-modal .modal-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f7fafc}.unit-modal .modal-body{padding:16px}.unit-modal .modal-thumb{aspect-ratio:16 / 9;width:100%;max-width:100%;background:#111;display:flex;align-items:center;justify-content:center;color:#fff;background-size:cover;background-position:center}.unit-modal .modal-close{background:transparent;border:none;font-size:20px;cursor:pointer}@media (max-width:900px){.units-container{flex-direction:column}.units-sidebar{width:100%}.units-panel{max-height:220px}}@media (max-width:600px){.unit-card .card-thumb{height:120px;min-height:120px}}.dash-nav a .icon svg{width:24px;height:24px;display:block}.dashboard-sidebar.collapsed .dash-nav a .icon svg{width:24px;height:24px}.dashboard-sidebar.collapsed .dash-nav a[data-label]{position:relative}.dashboard-sidebar.collapsed .dash-nav a[data-label]:after{content:attr(data-label);position:absolute;left:100%;top:50%;transform:translateY(-50%) translate(8px);background:#020617eb;color:#fff;padding:6px 8px;font-size:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s ease,transform .12s ease;z-index:1600}.dashboard-sidebar.collapsed .dash-nav a[data-label]:hover:after,.dashboard-sidebar.collapsed .dash-nav a[data-label]:focus:after{opacity:1;transform:translateY(-50%) translate(10px)}@keyframes badgePulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}.dashboard-sidebar.collapsed .dash-nav a.active{box-shadow:0 6px 18px #0206171f}.dashboard-sidebar.collapsed .dash-nav a.active .icon{animation:badgePulse 1.6s ease-in-out infinite}@media (max-width:480px){.dashboard-sidebar.collapsed .dash-nav a[data-label]:after{display:none}}.locations-overview{background:#f7f9fa;padding:12px}.locations-overview .overview-title{font-weight:700;margin-bottom:8px;color:#333}.locations-table{width:100%;border-collapse:collapse;background:#fff}.locations-table th{font-weight:700;text-align:left;padding:8px 6px;font-size:13px;color:#6b7280}.locations-table td{padding:10px 6px;border-top:1px solid #edf2f6;word-break:break-word}.locations-table td,.locations-table th{vertical-align:middle}.row-bar{height:8px;background:#f1f5f9;margin-top:6px;border-radius:6px;display:flex;align-items:center;overflow:hidden}.row-bar .bar-online{height:100%;transition:width .36s ease;background:#0e7f27;flex-shrink:0}.row-bar .bar-offline{height:100%;transition:width .36s ease;background:#b20000;flex-shrink:0}.progress-row{display:flex;align-items:center;gap:10px}.progress-track{flex:1;height:12px;border-radius:999px;background:linear-gradient(90deg,#b20000,#b20000);overflow:hidden;position:relative;border:1px solid rgba(178,0,0,.06);box-shadow:inset 0 1px 2px #0206170a}.progress-fill-online{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,#0e7f27,#0e7f27);border-radius:999px 0 0 999px;transition:width .36s ease;display:block;z-index:2;box-shadow:inset 0 -1px #0000000f}.progress-fill-offline{display:none!important}.progress-badge{min-width:36px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;padding:0 8px;box-shadow:0 4px 10px #0206170f}.progress-badge.green{background:#0e7f27;border:1px solid rgba(0,0,0,.06)}.progress-badge.orange{background:#ff7a59;border:1px solid rgba(0,0,0,.06)}.progress-badge.yellow{background:#f59e0b;border:1px solid rgba(0,0,0,.06)}.progress-badge.red{background:#b20000;border:1px solid rgba(0,0,0,.06)}.progress-cell{display:flex;align-items:center;gap:12px}.progress-cell .row-bar{flex:1}.bar-label{position:relative;color:#fff;font-weight:700;font-size:12px;padding:6px 10px;border-radius:6px;box-shadow:0 6px 18px #0206171f;white-space:nowrap;margin-left:6px}.bar-label.green{background:#0e7f27}.bar-label.orange{background:#ff7a59}.bar-label.yellow{background:#f59e0b}.bar-label.red{background:#b20000}.status-cell{display:flex;flex-direction:column;gap:6px}.status-top{display:flex;justify-content:space-between;align-items:center}.count-text,.percent-text{font-weight:700;font-size:13px;color:#0b0b0b;background:transparent;padding:0}.status-cell .progress-track{width:100%;height:12px}.progress-badge.green{background:#0e7f27}.progress-badge.orange{background:#ff7a59}.progress-badge.yellow{background:#f59e0b}.progress-badge.red{background:#b20000}.device-info .device-screenshot{aspect-ratio:16 / 9;width:100%;max-width:100%;overflow:hidden;position:relative;background:#111}.device-info .device-screenshot img{width:100%;height:100%;display:block;object-fit:cover;object-position:center}.device-info .device-screenshot-meta{position:static;margin:0;background:#fff;color:#073b76;padding:4px 8px;font-size:11px;display:flex;gap:8px;align-items:center;box-shadow:0 3px 8px #12263f0a;border:1px solid rgba(7,59,118,.04);width:100%;box-sizing:border-box}.device-info .device-screenshot-meta .small-label{color:#073b76;font-weight:800}.meta-action-btn{width:32px;height:32px;border:1px solid rgba(7,59,118,.06);background:#f6fbff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.device-info .device-screenshot{margin-bottom:0}.device-info .last-seen{font-size:12px;color:#6b7280;margin-top:4px;line-height:1.25}.meta-action-btn svg{color:#0b63b8}.meta-action-btn:hover{background:#eef6ff}.device-info .device-screenshot-meta{display:flex;justify-content:space-between;align-items:center;padding:8px;background:#fff}.devices-control-card{background:#fff;padding:12px;box-shadow:0 1px #0000000a;max-height:none;overflow:visible}.control-main-grid{display:grid;grid-template-columns:260px 1fr;gap:8px;align-items:start}.control-nav{background:#fff;border:1px solid #eef2f6;padding:8px}.control-nav .nav-item{display:flex;align-items:center;gap:8px;padding:6px;cursor:pointer;color:#374151}.control-nav .nav-item+.nav-item{margin-top:2px}.control-nav .nav-item .nav-icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:transparent}.control-nav .nav-item .nav-icon svg{width:18px;height:18px}.control-nav .nav-item .nav-icon{color:#1e73b8}.control-nav .nav-item.active{background:#f1f8ff;border-left:4px solid #1e73b8}.control-nav .nav-item:hover{background:#f8fbff}.small-badge{display:inline-block;background:#fef3f2;color:#ef4444;padding:2px 6px;font-size:11px;margin-left:8px}.players-grid{display:flex;gap:6px;flex-wrap:wrap}.player-tile{background:#fff;border:1px solid #eef2f6;padding:10px;display:flex;align-items:center;gap:8px;min-width:120px;cursor:pointer}.player-tile.selected{box-shadow:0 6px 18px #0e1c140f;border-color:#dbe7ee}.player-tile .status-dot{width:10px;height:10px;margin-right:6px}.player-tile .status-dot.green{background:#4ade80}.player-tile .status-dot.red{background:#ef4444}.player-card{background:#fff;border:1px solid #eef2f6;width:160px;display:flex;flex-direction:column;overflow:hidden;cursor:pointer}.player-card.selected{box-shadow:none;transform:none}.player-card-body{padding:10px 12px 8px;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center}.player-thumb-icon{width:80px;height:56px;display:flex;align-items:center;justify-content:center;color:#1e73b8;border-bottom:1px solid #f1f5f9;padding-bottom:8px}.player-indicator{display:inline-block;width:10px;height:10px;margin-right:8px;vertical-align:middle;box-shadow:0 0 0 4px #1018280a}.player-indicator.green{background:#4ade80}.player-indicator.red{background:#ef4444}.player-card-meta{padding:8px 6px;text-align:center}.player-mac{font-size:13px;font-weight:700}.player-card-footer{background:#1976d2;height:40px;display:flex;align-items:center;justify-content:center}.copy-btn{background:transparent;border:none;color:#fff;width:36px;height:28px;padding:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.copy-btn:hover{opacity:.95}.copy-btn:active{transform:none}.copy-btn[data-copied=true]{opacity:.9}.copy-label{display:inline-block;width:18px;height:18px}.image2-thumb{width:100%;max-width:min(36vw,320px);height:auto;border:1px solid #eef2f6;display:block}.players-header{display:flex;justify-content:space-between;align-items:center}.players-actions{display:flex;gap:8px;margin-top:8px}.players-thumb,.player-detail,.props-actions{margin-top:8px}.danger{background:#ef6b6b;color:#fff;border:none;padding:8px 12px;margin-right:8px}.success{background:#4ade80;color:#064e3b;border:none;padding:8px 12px}.control-nav .nav-item{-webkit-user-select:none;user-select:none}.control-nav .nav-item:focus{outline:3px solid rgba(11,17,27,.08)}.control-props .prop-table td.prop-label{width:210px;font-weight:700;color:#6b7280}.prop-table td.prop-label{width:160px;font-weight:700;color:#6b7280}.prop-table td.prop-value{color:#0f172a}.report-btn{background:#ef4444;color:#fff;border:none;padding:8px 12px}.small-icon{background:transparent;border:1px solid #e6edf6;padding:6px 8px}.units-main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.device-info .device-screenshot-meta{padding:0!important;gap:6px!important;font-size:11px!important}.device-info .device-screenshot-meta .small-label{padding:6px 8px}.device-info .device-screenshot-meta{box-shadow:0 2px 6px #12263f08!important}.meta-action-btn{width:26px!important;height:26px!important}.meta-action-btn svg{width:12px!important;height:12px!important}
