@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Roboto:wght@400;500;600;700;800&display=swap";.app{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f5f5}html,body,#root{overflow-x:hidden}*{-ms-overflow-style:none;scrollbar-width:none}*::-webkit-scrollbar{display:none}.app-header{background:#f8fafd;color:#2c3e50;padding:.5rem 1.25rem;border-bottom:1px solid rgba(16,24,32,.06);position:fixed;top:0;left:80px;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;gap:1.25rem;height:60px}.breadcrumb-bar{position:fixed;top:60px;left:80px;right:0;background:#f8fafd;border-bottom:2px solid #e5e7eb;z-index:99;width:auto;height:auto;display:flex;align-items:center;padding:0;border-radius:0;margin-top:0}.breadcrumb{padding:8px 14px;font-size:.9rem;color:#374151;font-weight:500;margin:0}.settings-card{position:absolute;top:56px;right:16px;width:320px;background:#fff;border-radius:12px;border:1px solid rgba(16,24,32,.06);box-shadow:0 10px 30px #10182014;z-index:300;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(16,24,32,.04)}.settings-close{background:transparent;border:none;cursor:pointer;font-size:1rem}.settings-body{padding:12px 14px}.settings-row{margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.settings-options{display:flex;flex-direction:column;gap:12px}.settings-options label{display:flex;gap:8px;align-items:center;cursor:pointer;padding:4px 0;font-weight:500;width:100%}.settings-options label input[type=radio]{margin:0;cursor:pointer;flex-shrink:0;width:18px;height:18px}.settings-actions{display:flex;justify-content:flex-end}.btn{padding:6px 12px;border-radius:8px;border:1px solid rgba(16,24,32,.06);background:#fff;cursor:pointer}.btn-primary{background:#0b59d6;color:#fff;border-color:transparent}.profile-card{position:absolute;top:56px;right:16px;width:360px;background:#fff;border-radius:12px;border:1px solid rgba(16,24,32,.06);box-shadow:0 10px 40px #1018201f;z-index:300;overflow:hidden;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#f6f7f9;position:relative;border-bottom:1px solid rgba(16,24,32,.06)}.profile-header-content{display:flex;align-items:center;gap:12px}.profile-name-text{font-size:1.1rem;font-weight:600;color:#0b1220}.profile-avatar-large{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.5rem;background:linear-gradient(135deg,#0b59d6,#0d66e8);border:2px solid rgba(16,24,32,.1)}.profile-close{background:transparent;border:none;cursor:pointer;font-size:1.2rem;color:#0b1220;padding:4px 8px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.profile-close:hover{transform:scale(1.2)}.profile-body{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.profile-item{display:flex;gap:12px;padding:12px;background:#f9fafb;border-radius:8px}.profile-icon{font-size:1.25rem;min-width:32px;display:flex;align-items:center;justify-content:center}.profile-info{display:flex;flex-direction:column;gap:2px;flex:1}.profile-label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.3px}.profile-value{font-size:.9rem;font-weight:500;color:#0b1220;word-break:break-word}.profile-logout-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 12px;margin-top:8px;background:linear-gradient(135deg,#ff6b6b,#ff8e72);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease}.profile-logout-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ff6b6b4d}.profile-logout-btn:active{transform:translateY(0)}.theme-dark{--bg-color: #071023;--panel-bg: #0b1220;--muted-text: rgba(255,255,255,.75);--text-color: #e6eefc;--border-color: rgba(255,255,255,.06);--accent: #0b59d6;color:#e6eefc}.theme-dark .app,.theme-dark body,.theme-dark .main-content{background-color:var(--bg-color)!important;color:#e6eefc!important}.theme-dark .app-header,.theme-dark .breadcrumb-bar,.theme-dark .sidebar,.theme-dark .sidebar-header,.theme-dark .settings-card,.theme-dark .profile-card,.theme-dark .profile-header,.theme-dark .profile-body,.theme-dark .profile-item,.theme-dark .settings-body,.theme-dark .header-time,.theme-dark .header-user,.theme-dark .nav-item,.theme-dark .nav-item.active,.theme-dark .search-input,.theme-dark .btn,.theme-dark .btn-primary{background-color:#0b1220!important;color:#e6eefc!important;border-color:#0b59d64d!important}.theme-dark .btn-primary{background-color:#0b59d6!important;border-color:#0b59d6!important}.theme-dark .app-header{background:#071023;color:#e6eefc;border-bottom-color:#ffffff0a}.theme-dark .main-content{background:var(--bg-color);color:#e6eefc}.theme-dark .search-input{background:#071023;color:#e6eefc;border-color:var(--border-color)}.theme-dark .search-input::placeholder{color:#e6eefc80}.theme-dark .nav-item:hover{background:#ffffff05}.theme-dark .nav-item.active{background:#0b59d61f;color:#cfe4ff;box-shadow:0 2px 8px #0b59d61f;border-color:#0b59d633}.theme-dark .profile-label,.theme-dark .profile-value,.theme-dark .breadcrumb,.theme-dark .user-name,.theme-dark .profile-close,.theme-dark .settings-options label{color:#e6eefc!important}.theme-dark .profile-avatar-large{border-color:#ffffff0f}.theme-dark .settings-card,.theme-dark .profile-card{box-shadow:0 10px 30px #0009}.theme-dark .sidebar{background:linear-gradient(180deg,var(--panel-bg) 0%,rgba(11,18,32,.98) 100%)!important;box-shadow:2px 0 12px #000000b3!important}.theme-dark .sidebar-header{background:var(--panel-bg)!important;border-bottom-color:#ffffff0a}.theme-dark .nav-menu{background:transparent!important}.theme-dark .nav-item{background:transparent!important;color:#dbeafe!important;border-color:#ffffff1a!important}.theme-dark .nav-item .nav-icon{color:#e6eefc!important}.theme-dark .nav-item.active{background:#0b59d633!important;color:#cfe4ff!important;box-shadow:0 2px 8px #0b59d633!important;border-color:#0b59d666!important}.theme-dark .nav-item .nav-label{color:#dbeafe!important}.theme-light{--bg-color: #f8fafd;--panel-bg: #ffffff;--muted-text: #6b7280;--text-color: #0b1220;--border-color: rgba(16,24,32,.06);--accent: #0b59d6;color:#0b1220}.theme-light .app,.theme-light .main-content,.theme-light body{background-color:var(--bg-color);color:var(--color)}.theme-light .app-header,.theme-light .breadcrumb-bar{background-color:#f8fafd;color:#0b1220;border-color:var(--border-color)}.theme-light .sidebar,.theme-light .sidebar-header{background-color:#e9eef6;color:#0b1220;border-color:var(--border-color)}.theme-light .settings-card,.theme-light .profile-card,.theme-light .search-input,.theme-light .header-user,.theme-light .header-time,.theme-light .nav-item{background-color:var(--panel-bg);color:#0b1220;border-color:var(--border-color)}.theme-light .search-input{background:#fff;color:#2c3e50}.theme-light .sidebar{background:#f0f4ff!important;box-shadow:2px 0 8px #1018200f!important}.theme-light .sidebar-header{background:#f0f4ff!important;border-bottom-color:#1018200f!important}.theme-light .nav-menu{background:transparent!important}.theme-light .nav-item{background:transparent!important;color:#1f2937!important;border:1px solid rgba(16,24,32,.04)!important;box-shadow:none!important}.theme-light .nav-item:hover{background:#0b59d60d!important}.theme-light .nav-item.active{background:#0b59d61a!important;box-shadow:none!important;border-color:#0b59d633!important}.theme-light .nav-icon,.theme-light .nav-label{color:#1f2937!important}.theme-dark [class*=card],.theme-dark [class*=panel],.theme-dark [class*=box],.theme-dark [class*=container],.theme-dark [class*=body],.theme-dark [class*=content],.theme-dark .card,.theme-dark .panel,.theme-dark .box,.theme-dark .container{background-color:var(--panel-bg)!important;color:#e6eefc!important;border-color:var(--border-color)!important}.theme-dark [class*=page],.theme-dark [class*=section],.theme-dark [class*=left],.theme-dark [class*=right],.theme-dark .login-content,.theme-dark .login-left,.theme-dark .login-right{background-color:var(--bg-color)!important;color:var(--text-color)!important}.theme-dark .priority.high,.theme-dark .log-level.error{background:#ff3c3c1f;color:#ffb3b3}.theme-dark .priority.medium,.theme-dark .log-level.warn{background:#ffb74d14;color:#ffd59e}.theme-dark .priority.low,.theme-dark .log-level.info{background:#10b9810f;color:#9be7c1}.theme-dark .units-header h2,.theme-dark .main-card h2{color:#e6eefc!important}.theme-dark .unit-card-title{background:var(--panel-bg);color:#e6eefc!important}.theme-dark .unit-card{background:var(--panel-bg);border-color:var(--border-color)}.theme-dark .status-table thead,.theme-dark .units-table thead,.theme-dark .overview-table{background:var(--panel-bg)!important}.theme-dark input[type=text],.theme-dark input[type=email],.theme-dark input[type=password],.theme-dark input[type=search],.theme-dark input[type=number],.theme-dark select,.theme-dark textarea,.theme-dark .sort-dropdown,.theme-dark .view-dropdown,.theme-dark [class*=dropdown],.theme-dark [class*=select]{background:var(--panel-bg)!important;color:#e6eefc!important;border-color:var(--border-color)!important}.theme-dark .form-label,.theme-dark label{color:#dbeafe!important}.theme-dark table,.theme-dark thead,.theme-dark tbody,.theme-dark tr,.theme-dark td,.theme-dark th,.theme-dark ul,.theme-dark li{color:#e6eefc!important}.theme-dark a{color:#8fc9ff}.theme-dark a:hover{color:#cfe4ff}.theme-dark .btn{background:#0a2338;color:#e6eefc}.theme-dark .btn-primary{background:var(--accent);color:#fff}.theme-dark h1,.theme-dark h2,.theme-dark h3,.theme-dark h4,.theme-dark h5,.theme-dark h6{color:#e6eefc!important}.theme-dark p,.theme-dark span,.theme-dark div,.theme-dark label,.theme-dark small{color:#dbeafe!important}.theme-dark input,.theme-dark select,.theme-dark textarea{color:#e6eefc!important}.theme-dark input::placeholder,.theme-dark textarea::placeholder,.theme-dark select{color:#dbeafe99!important}.theme-dark{color:#e6eefc!important}.theme-dark *{color:inherit!important}.theme-dark [style*="color: #1f2937"],.theme-dark [style*="color: #374151"],.theme-dark [style*="color: #6b7280"],.theme-dark [style*="color: #2c3e50"],.theme-dark [style*="color: #333"],.theme-dark [style*="color: #666"],.theme-dark [style*="color: #999"],.theme-dark [style*="color: #9ca3af"],.theme-dark .status-table td,.theme-dark .status-table th,.theme-dark .units-table tbody td,.theme-dark .units-table thead th,.theme-dark .overview-table td,.theme-dark .overview-table th{color:#dbeafe!important}.header-left{display:flex;align-items:center;min-width:200px}.logo{margin:0;font-size:1.45rem;font-weight:800;letter-spacing:.6px;background:linear-gradient(90deg,#2ea1ff,#0b59d6);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#0b59d6}.header-search{flex:1;max-width:400px;position:relative}.search-input{width:100%;padding:10px 16px 10px 40px;border:1px solid rgba(16,24,32,.06);border-radius:28px;background:#fff;color:#2c3e50;font-size:.95rem;transition:all .15s ease-in-out}.search-input::placeholder{color:#10182073}.search-input:focus{outline:none;background:#fff;border-color:#1018201f;box-shadow:0 6px 18px #1018200f}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);opacity:.7}.header-right{display:flex;align-items:center;gap:1.5rem;min-width:350px;justify-content:flex-end}.header-icons{display:flex;gap:.5rem}.icon-btn{background:transparent;border:none;color:#55616a;font-size:1.15rem;cursor:pointer;padding:6px 10px;border-radius:8px;transition:all .12s ease;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:#1018200a;transform:translateY(-1px)}.header-time{font-size:.85rem;color:#1f2937;font-weight:600;min-width:120px;text-align:center;background:#fff;padding:6px 12px;border-radius:20px;border:1px solid rgba(16,24,32,.06);box-shadow:0 2px 6px #1018200a;min-height:40px;display:flex;align-items:center;justify-content:center}.header-user{gap:.75rem;padding:6px 12px;background:#fff;border-radius:28px;border:1px solid rgba(16,24,32,.06);box-shadow:0 2px 6px #1018200a;min-height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.header-user:hover{background:#f9fafb;border-color:#1018201f;box-shadow:0 4px 12px #10182014}.user-name{font-size:.9rem;font-weight:600;color:#0b1220}.user-avatar{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.8rem;background:linear-gradient(135deg,#ff6b6b,#ff8e72);box-shadow:0 4px 10px #ff6b6b29;border:2px solid rgba(255,255,255,.12)}.app-body{flex:1;gap:0;padding:0;margin-left:80px;margin-top:105px;width:calc(100% - 80px);min-height:calc(100vh - 115px)}.main-content{background-color:#f8fafd}.sidebar{width:80px;background:#e9eef6;border-radius:0;padding:0;box-shadow:2px 0 8px #00000014;height:100vh;display:flex;flex-direction:column;align-items:center;position:fixed;left:0;top:0;z-index:101;overflow:hidden}.sidebar-header{width:100%;display:flex;justify-content:center;align-items:center;padding:0;border-bottom:1px solid rgba(16,24,32,.06);height:60px;background:#e9eef6;flex-shrink:0;position:relative;top:0;left:0}.hamburger-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#2c3e50;padding:0;transition:transform .2s;height:48px;width:48px;display:flex;align-items:center;justify-content:center}.hamburger-btn:hover{transform:scale(1.1)}.nav-menu{display:flex;flex-direction:column;gap:.5rem;width:100%;padding:.5rem .3rem;align-items:center}.nav-item{background:none;border:none;padding:0;text-align:center;border-radius:8px;cursor:pointer;color:#2c3e50;font-size:.65rem;font-weight:500;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;width:60px;height:60px;text-decoration:none;border:1px solid transparent}.nav-icon{font-size:1.5rem;transition:transform .2s;display:flex;align-items:center;justify-content:center;min-height:32px}.nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60px;font-size:.6rem}.nav-item:hover{background-color:#0066cc14;border-color:#06c3}.nav-item:hover .nav-icon{transform:scale(1.15)}.nav-item.active{background:linear-gradient(135deg,#0066cc26,#0066cc14);color:#06c;border-color:#06c;font-weight:600;box-shadow:0 2px 8px #0066cc26}@media (max-width: 1024px){.app-body{gap:.75rem;padding:.75rem;margin-left:80px}.sidebar{width:80px}.nav-item{padding:10px 6px}.nav-icon{font-size:1.5rem}.nav-label{font-size:.6rem}}@media (max-width: 768px){.app-body{flex-direction:column;margin-left:0;margin-top:120px}.sidebar{width:100%;height:auto;position:static;flex-direction:row;gap:.5rem;padding:1rem;overflow-x:auto;border-radius:10px;margin-top:1rem}.sidebar-header{border:none;order:-1}.nav-menu{flex-direction:row;gap:.5rem;flex-wrap:wrap}.nav-item{min-width:100px}.header-content{flex-direction:column;gap:.5rem;align-items:flex-start}.logo{font-size:1.25rem}}@media (max-width: 480px){.app-header{padding:.75rem 1rem;flex-direction:column;gap:.75rem}.header-left{min-width:auto}.header-search{max-width:100%}.header-right{min-width:auto;gap:.75rem;flex-wrap:wrap;justify-content:space-between;width:100%}.header-time{min-width:auto;font-size:.75rem}.logo{font-size:1rem}.sidebar{padding:.75rem}.nav-item{padding:8px 10px;font-size:.7rem;min-width:80px}.nav-icon{font-size:1.25rem}.main-content{min-height:auto}}html,body,#root{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,SF Pro Text,SF Pro Display,Helvetica Neue,Arial,sans-serif}.app{--sidebar-width: 220px;--sidebar-collapsed-width: 78px;--right-rail-width: 0px;--right-panel-width: 0px;--brand-blue: #0b5ed7;--brand-blue-light: rgba(11, 94, 215, .12);--brand-blue-border: rgba(11, 94, 215, .35);background:linear-gradient(180deg,#f6f8fb,#eef2f7)}.app.sidebar-collapsed{--sidebar-width: var(--sidebar-collapsed-width)}.app-header{left:0;right:0;height:72px;background:#f5f6f8;border-bottom:1px solid rgba(15,23,42,.08);gap:1rem}.breadcrumb-bar{left:var(--sidebar-width);right:0;top:72px;height:36px;background:#f5f6f8;border-bottom:1px solid rgba(15,23,42,.08)}.breadcrumb{padding:8px 18px;font-size:.85rem;letter-spacing:.02em;text-transform:none}.app-body{display:block;margin-left:0;margin-top:108px;width:100%;min-height:calc(100vh - 108px);background:transparent}.header-left{gap:.75rem;min-width:240px}.header-menu-btn{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:12px;padding:6px;color:var(--brand-blue);display:grid;place-items:center;width:36px;height:36px}.brand-mark{width:36px;height:36px;border-radius:12px;background:#fff;border:1px solid rgba(15,23,42,.08);display:grid;place-items:center}.brand-logo-img{width:24px;height:24px;object-fit:contain;display:block}.brand-icon-img{width:20px;height:20px;object-fit:contain;display:block}.brand-text{display:flex;flex-direction:column;line-height:1.1}.brand-subtitle{font-size:.7rem;font-weight:600;color:#64748b;letter-spacing:.05em;text-transform:uppercase}.logo{font-size:1.2rem;letter-spacing:.12em;font-weight:800;color:var(--brand-blue)}.header-search{max-width:none;flex:1 1 auto;width:100%;margin:0 1rem}.search-input{border-radius:14px;padding:10px 60px 10px 52px;background:#f3f4f6;border:1px solid #d7dbe2;box-shadow:inset 0 1px #ffffffe6;height:42px;font-size:.95rem;transition:all .15s ease}.search-input:focus{outline:none;background:#fff;border-color:#0b5ed766;box-shadow:0 6px 16px #0b5ed726}.search-icon{font-weight:700;font-size:.75rem;background:#fff;color:#94a3b8;border-radius:10px;padding:6px;display:grid;place-items:center;border:1px solid #e5e7eb;left:16px}.search-hint{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.7rem;color:#6b7280;background:#f8fafc;padding:4px 10px;border-radius:999px;border:1px solid #d7dbe2}.header-right{min-width:360px;gap:1rem;flex-wrap:nowrap}.icon-btn{width:36px;height:36px;border-radius:12px;border:1px solid rgba(15,23,42,.08);background:#fff;font-size:.75rem;font-weight:700;color:var(--brand-blue);display:grid;place-items:center}.icon-btn.active{background:var(--brand-blue);color:#fff;border-color:transparent}.header-badge{height:36px;padding:0 14px;border-radius:12px;border:1px solid rgba(15,23,42,.08);background:#fff;color:var(--brand-blue);font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:.08em}.header-time{min-height:36px;font-size:.75rem;background:#fff}.header-user{min-height:36px;background:#fff;border-radius:999px}.app-body .main-content{background:transparent;padding:1.75rem 2rem 2rem;min-width:0;margin-left:var(--sidebar-width);margin-right:0}.sidebar{width:var(--sidebar-width);align-items:stretch;padding:0;background:#f7f7f8;border-right:1px solid rgba(15,23,42,.08);box-shadow:none;position:fixed;top:72px;left:0;height:calc(100vh - 72px);overflow-y:auto;z-index:90}.sidebar-header{display:none}.sidebar-brand{display:flex;align-items:center;gap:.6rem}.sidebar-brand-text{font-weight:700;letter-spacing:.08em;font-size:.8rem;color:var(--brand-blue)}.hamburger-btn{border:1px solid rgba(15,23,42,.1);border-radius:10px;padding:6px;color:var(--brand-blue);display:grid;place-items:center}.sidebar-search{padding:0 1.25rem .75rem}.sidebar-search input{width:100%;border-radius:12px;border:1px solid rgba(15,23,42,.08);padding:10px 12px;background:#fff}.nav-menu{align-items:stretch;padding:0 1.25rem;gap:.5rem}.nav-section{display:flex;flex-direction:column;gap:.35rem}.nav-section-title{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#64748b;margin:.25rem 0 .15rem;font-weight:700}.nav-section-items{display:flex;flex-direction:column;gap:.5rem}.nav-item{height:38px;flex-direction:row;justify-content:flex-start;gap:.75rem;width:100%;padding:6px 12px;border-radius:12px;text-align:left;border:1px solid transparent}.nav-icon{min-height:auto;width:20px;height:20px;border-radius:0;background:transparent;color:var(--brand-blue);display:block;padding:0}.nav-label{font-size:.85rem;max-width:none}.nav-chevron{margin-left:auto;font-size:.75rem;color:#94a3b8}.nav-item.active{background:var(--brand-blue-light);border-color:var(--brand-blue-border);color:#0f172a;box-shadow:none}.sidebar-footer{margin-top:auto;padding:1rem 1.25rem 1.5rem;font-size:.7rem;color:#94a3b8}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-collapsed .sidebar-search,.sidebar-collapsed .sidebar-brand-text,.sidebar-collapsed .nav-label,.sidebar-collapsed .nav-chevron,.sidebar-collapsed .sidebar-footer{display:none}.sidebar-collapsed .nav-menu{padding:.75rem .5rem;gap:.4rem}.sidebar-collapsed .nav-item{justify-content:center;padding:0;width:52px;height:52px;margin:0 auto}.sidebar-collapsed .nav-section-title{display:none}.sidebar-collapsed .nav-section{padding:.45rem 0;border-bottom:1px solid rgba(15,23,42,.08)}.sidebar-collapsed .nav-section:last-child{border-bottom:none}.sidebar-collapsed .nav-section-items{gap:.55rem}.sidebar-collapsed .nav-item{background:#eef3ff;border:1px solid rgba(15,23,42,.08);border-radius:16px;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.sidebar-collapsed .nav-item.active{background:#dbe8ff;border-color:#0b5ed773;box-shadow:0 6px 14px #0b5ed726}.sidebar-collapsed .nav-item:hover{background:#e4ecff;border-color:#0b5ed733}.sidebar-collapsed .nav-icon{width:22px;height:22px;border-radius:0;background:transparent;border:none;padding:0;margin:0 auto;transition:color .15s ease}.sidebar-collapsed .nav-item.active .nav-icon{background:transparent;color:#0b5ed7}.sidebar-collapsed .nav-item:hover .nav-icon{background:transparent}.theme-dark .sidebar-collapsed .nav-item{background:#1c1f24;border-color:#ffffff14}.theme-dark .sidebar-collapsed .nav-item.active{background:#10b98138;border-color:#10b98173;box-shadow:0 6px 14px #10b9812e}.theme-dark .sidebar-collapsed .nav-item:hover{background:#ffffff0f;border-color:#ffffff1f}.theme-dark .sidebar-collapsed .nav-icon{background:transparent;color:#cbd5e1}.theme-dark .sidebar-collapsed .nav-item.active .nav-icon{background:transparent;color:#8ff5e3}.theme-dark .sidebar-collapsed .nav-item:hover .nav-icon{background:transparent}.icon-sm{width:18px;height:18px;color:currentColor}.brand-icon{width:20px;height:20px;color:var(--brand-blue)}.theme-dark .app{background:#0b1120}.theme-dark .app-header,.theme-dark .breadcrumb-bar,.theme-dark .sidebar{background:#141618!important;border-color:#ffffff0f!important}.theme-dark .search-input,.theme-dark .sidebar-search input,.theme-dark .nav-icon,.theme-dark .icon-btn{background:#22252b!important;color:#e5e7eb!important;border-color:#ffffff1f!important}.theme-dark .nav-icon,.theme-dark .icon-btn{color:#6ed6c9!important}.theme-dark .app{background:#0e0f11!important}.theme-dark .breadcrumb{color:#cbd5e1!important}.theme-dark .header-time,.theme-dark .header-user,.theme-dark .header-badge{background:#2a2b2f!important;color:#e5e7eb!important;border-color:#ffffff1f!important}.theme-dark .logo{color:#86f3e7!important}.theme-dark .search-icon,.theme-dark .search-hint{background:#1b1e24!important;color:#a7b0bd!important;border-color:#ffffff1f!important}.theme-dark .search-input:focus{background:#2b2f36!important;border-color:#6ed6c980!important;box-shadow:0 6px 16px #6ed6c926!important}.theme-dark .nav-item{background:#121316!important;border-color:#ffffff0f!important;color:#d1d5db!important}.theme-dark .nav-item.active{background:#10b9812e!important;border-color:#10b98166!important;color:#e6fffa!important}.theme-dark .nav-section-title{color:#94a3b8!important}.theme-dark .main-content{background:#0e0f11!important}.theme-dark .panel,.theme-dark .card,.theme-dark .data-card,.theme-dark .overview-section,.theme-dark .info-card{background:#1e1f23!important;border-color:#ffffff0f!important;box-shadow:none!important}:root{--ui-surface: #ffffff;--ui-muted: #f3f4f6;--ui-border: #e5e7eb;--ui-text: #0f172a;--ui-subtext: #64748b;--ui-radius: 14px}.main-content{color:var(--ui-text)}.card,.panel,[class*=card],[class*=panel],[class*=box],[class*=section]{border-radius:var(--ui-radius);border:1px solid var(--ui-border)}table{border-collapse:collapse}thead th{font-weight:600;color:var(--ui-subtext)}tbody td{color:var(--ui-text)}input[type=text],input[type=search],input[type=email],input[type=password],select,textarea{border-radius:12px;border:1px solid var(--ui-border);background:#f8fafc;color:var(--ui-text)}input:focus,select:focus,textarea:focus{outline:none;border-color:#0b5ed766;box-shadow:0 0 0 3px #0b5ed726}button,.btn{border-radius:12px;border:1px solid var(--ui-border)}.badge,.pill,[class*=badge],[class*=pill]{border-radius:999px}.theme-dark{--ui-surface: #1e1f23;--ui-muted: #141618;--ui-border: rgba(255,255,255,.08);--ui-text: #e5e7eb;--ui-subtext: #9ca3af}.theme-dark .main-content{color:var(--ui-text)}.theme-dark .card,.theme-dark .panel,.theme-dark [class*=card],.theme-dark [class*=panel],.theme-dark [class*=box],.theme-dark [class*=section]{background:var(--ui-surface)!important;border-color:var(--ui-border)!important;color:var(--ui-text)!important;box-shadow:none!important}.theme-dark thead th{color:var(--ui-subtext)!important}.theme-dark tbody td{color:var(--ui-text)!important}.theme-dark input[type=text],.theme-dark input[type=search],.theme-dark input[type=email],.theme-dark input[type=password],.theme-dark select,.theme-dark textarea{background:#1b1e24!important;border-color:#ffffff1f!important;color:#e5e7eb!important}.theme-dark input:focus,.theme-dark select:focus,.theme-dark textarea:focus{border-color:#6ed6c980!important;box-shadow:0 0 0 3px #6ed6c92e!important}.theme-dark .header-user,.theme-dark .header-time,.theme-dark .pill-btn{background:#111827!important;border-color:#ffffff14!important;color:#e2e8f0!important}.theme-dark .nav-item.active{background:#0b5ed733!important;border-color:#0b5ed766!important}.theme-dark .drawer-title,.theme-dark .section-title,.theme-dark .product-title{color:#e2e8f0!important}@media (max-width: 1200px){.app-header,.breadcrumb-bar{right:0}.app-body{grid-template-columns:var(--sidebar-width) 1fr}.right-panel{display:none}}@media (max-width: 900px){.app-header{flex-wrap:wrap;height:auto;padding:.75rem 1rem}.header-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.header-search{order:3;width:100%;max-width:none}}.theme-dark .brand-mark,.theme-dark .header-menu-btn{background:#1f2126!important;border-color:#ffffff14!important}.sidebar,.breadcrumb-bar,.app-header,.sidebar-search input,.nav-item,.nav-section,.sidebar-collapsed .nav-item,.sidebar-collapsed .nav-section{border:none!important;box-shadow:none!important}.nav-section{border-bottom:none!important}.sidebar-collapsed .nav-item,.sidebar-collapsed .nav-item.active,.sidebar-collapsed .nav-item:hover{border:none!important;box-shadow:none!important}.nav-item.active{border:none!important}.nav-item{border:none!important;box-shadow:none!important;background:#eef2f7}.nav-item:hover{background:#e6edf6}.nav-item.active{background:#dbeafe;color:#0f172a}.nav-section-title{background:transparent}.nav-section-items{background:transparent!important}.nav-item{background:transparent!important;border:none!important;box-shadow:none!important}.nav-item:hover{background:#0b5ed70d!important}.nav-item.active{background:#0b5ed71f!important}.nav-section-title{padding:0!important;background:transparent!important;border:none!important}.nav-item{background:transparent!important;border:none!important;border-radius:8px!important;box-shadow:none!important}.nav-item:hover{background:#0b5ed70f!important}.nav-item.active{background:#0b5ed71f!important;box-shadow:inset 3px 0 #0f766e!important}.theme-light .nav-item,.theme-light .nav-section-items,.theme-light .nav-section-title{border:none!important;background:transparent!important;box-shadow:none!important}.dashboard-page{margin:0;padding:0 0 2rem;width:100%;background:transparent}.dashboard-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.dashboard-head h2{margin:0;font-size:1.3rem;font-weight:700;color:#0f172a}.dashboard-tabs{display:flex;gap:.5rem}.tab-btn{border:1px solid rgba(15,23,42,.08);background:#fff;border-radius:999px;padding:6px 14px;font-size:.8rem;font-weight:600;color:#64748b}.tab-btn.active{background:#e6f6f8;color:#0f172a;border-color:#14b8a6}.data-cards-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1.75rem}.data-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:1.25rem;box-shadow:0 14px 30px #0f172a0f}.main-card{grid-column:span 2}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.card-header h3{margin:0;font-size:.95rem;font-weight:700;color:#0f172a}.pill{background:#fef3c7;color:#92400e;border-radius:999px;padding:4px 10px;font-size:.7rem;font-weight:700}.percentage-display{font-size:3rem;font-weight:800;color:#0f172a;margin-bottom:.25rem}.units-info-text{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ef4444;margin-bottom:1rem}.progress-bar{display:flex;height:8px;border-radius:999px;overflow:hidden;background:#e2e8f0}.secondary-card{display:flex;flex-direction:column;gap:.5rem}.card-icon{width:36px;height:36px;border-radius:12px;background:#e2e8f0;display:grid;place-items:center;font-size:.7rem;font-weight:700;color:#0f172a}.stat-number{font-size:2rem;font-weight:800;color:#0f172a}.stat-label{font-size:.85rem;font-weight:600;color:#475569}.stat-sublabel{font-size:.75rem;color:#94a3b8}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.overview-section,.info-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:16px;padding:1.25rem;box-shadow:0 14px 30px #0f172a0a}.overview-header,.info-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.overview-header h3,.info-card h4{margin:0;font-size:.95rem;font-weight:700;color:#0f172a}.subtext{display:block;font-size:.75rem;color:#94a3b8;margin-top:4px}.collapse-btn{border:1px solid rgba(15,23,42,.08);background:#f8fafc;border-radius:999px;padding:6px 12px;font-size:.7rem;font-weight:700;color:#0f172a}.overview-table{width:100%;border-collapse:collapse;font-size:.85rem}.overview-table th{text-align:left;padding:.75rem 0;font-weight:600;color:#64748b;border-bottom:1px solid #e2e8f0}.overview-table td{padding:.75rem 0;border-bottom:1px solid #e2e8f0;color:#0f172a}.link{color:#0ea5e9;text-decoration:none;font-weight:600}.card-empty{padding:1.5rem 0;text-align:center;color:#94a3b8;font-size:.9rem}.theme-dark .dashboard-head h2,.theme-dark .card-header h3,.theme-dark .overview-header h3,.theme-dark .info-card h4{color:#e2e8f0!important}.theme-dark .data-card,.theme-dark .overview-section,.theme-dark .info-card{background:#111827!important;border-color:#ffffff14!important;box-shadow:none}.theme-dark .overview-table th,.theme-dark .overview-table td,.theme-dark .stat-number,.theme-dark .stat-label,.theme-dark .stat-sublabel,.theme-dark .subtext,.theme-dark .card-empty{color:#cbd5f5!important}@media (max-width: 1100px){.data-cards-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.main-card{grid-column:span 2}.dashboard-content{grid-template-columns:1fr}}@media (max-width: 720px){.data-cards-grid{grid-template-columns:1fr}.main-card{grid-column:span 1}}.units-page{padding:0;background:var(--bg-color, #f5f5f5);position:relative;display:flex;flex-direction:column;flex:1;width:100%}.units-container{display:flex;gap:.5rem;padding:.75rem;margin-left:0;margin-right:0;flex:1;width:100%}.units-sidebar{width:240px;background:transparent;border-radius:6px;padding:0;flex-shrink:0;display:flex;flex-direction:column;gap:.5rem;max-height:calc(100vh - 200px);overflow-y:auto}.sidebar-section{display:flex;flex-direction:column;gap:10px;background:var(--panel-bg, #ffffff);border-radius:8px;padding:16px;box-shadow:0 2px 6px #10182814;flex-shrink:0;border:1px solid var(--border-color, #f0f0f0)}.sidebar-section h3{font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.6px;margin:0}.group-select{width:100%;padding:8px 36px 8px 12px;border:1.5px solid #e5e7eb;border-radius:6px;background:var(--panel-bg, #ffffff);font-size:.8rem;font-weight:500;color:#1f2937;cursor:pointer;transition:all .25s ease;max-height:200px;overflow-y:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:16px}.group-select:hover{border-color:#0b59d6;background-color:#0b59d608;box-shadow:0 2px 8px #0b59d61a}.group-select:focus{outline:none;border-color:#0b59d6;box-shadow:0 0 0 3px #0b59d626;background-color:var(--panel-bg, #ffffff)}.group-select::-webkit-scrollbar{width:6px}.group-select::-webkit-scrollbar-track{background:#f3f4f6}.group-select::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.group-select::-webkit-scrollbar-thumb:hover{background:#94a3b8}.selected-group-tag{display:none}.locations-list{display:flex;flex-direction:column;gap:.4rem;max-height:220px;overflow-y:auto;padding-right:4px}.locations-list::-webkit-scrollbar{width:6px}.locations-list::-webkit-scrollbar-track{background:transparent}.locations-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.locations-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.location-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem .5rem;background:transparent;border-radius:6px;cursor:pointer;transition:all .12s ease;border-left:6px solid transparent;color:#374151;font-size:.85rem}.location-item:hover{background:#0f172a05}.location-item.active{background:#0b59d60f;border-left-color:#0b59d6;color:#0b59d6;font-weight:700}.location-name{font-size:.85rem;font-weight:500}.location-count{font-size:.7rem;background:#fee2e2;color:#991b1b;padding:2px 6px;border-radius:10px;font-weight:700}.location-item.active .location-count{background:#bfdbfe;color:#0c4a6e}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-label{font-size:.7rem;font-weight:800;color:#374151;text-transform:uppercase;letter-spacing:.5px}.radio-options{display:flex;flex-direction:column;gap:.5rem}.radio-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.85rem;color:#374151}.radio-item input[type=radio]{cursor:pointer;width:16px;height:16px;accent-color:#0b59d6}.main-card{background:var(--panel-bg, #ffffff);border-radius:8px;padding:.75rem;margin-right:0;margin-left:0;box-shadow:0 1px 3px #1018280f;flex:1;display:flex;flex-direction:column;width:100%;overflow:hidden}.main-card h2{font-size:1.5rem;color:#374151;font-weight:700;margin:0 0 .5rem}.main-card>p:first-of-type{text-align:left;color:#6b7280;padding:0;margin:0;font-size:.9rem}.location-count-text{font-size:.9rem;color:#6b7280;margin:0}.status-table-wrapper{overflow-x:auto}.status-table{width:100%;border-collapse:collapse}.status-table thead{background:transparent;border-bottom:1px solid var(--border-color, #e5e7eb);display:flex}.status-table thead tr{width:100%;display:flex;gap:16px;align-items:center}.status-table th{padding:12px 0;text-align:left;font-size:.75rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.status-table th:nth-child(1){width:120px;flex-shrink:0}.status-table th:nth-child(2){width:180px;flex-shrink:0}.status-table th:nth-child(3){flex:1;min-width:300px}.status-table tbody{display:block}.status-table tbody tr{border-bottom:1px solid var(--border-color, #e5e7eb);transition:all .2s ease;display:flex;gap:16px;align-items:center;padding:16px 0;width:100%}.status-table tbody tr:hover{background:#ffffff05}.status-table td{padding:0;font-size:.9rem;color:#1f2937;display:flex;align-items:center}.status-table td.location-col{width:120px;flex-shrink:0;font-weight:600;white-space:nowrap}.status-table td.units-col{width:180px;flex-shrink:0;font-weight:600;font-size:1rem;color:#1f2937}.status-table td.progress-col{flex:1;min-width:140px;display:flex;align-items:center;gap:12px}.location-col{font-weight:600}.units-col{color:#1f2937;display:flex;align-items:center;justify-content:flex-start;gap:.3rem;width:auto;white-space:nowrap;flex-shrink:0;font-size:.95rem;font-weight:600}.connected-count{color:#6b7280;font-weight:500}.units-separator{color:#6b7280}.total-count{color:#6b7280;font-weight:500}.units-percentage{color:#6b7280}.progress-col{width:220px;padding:0;display:flex;align-items:center;gap:12px;flex:1}.progress-bar{flex:1;height:8px;background:transparent;border-radius:4px;overflow:hidden;display:flex;gap:0;min-width:100px}.progress-fill{height:100%;transition:width .3s ease}.progress-fill.connected{background:#10b981}.progress-fill.disconnected{background:#ef4444}.unit-status-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:20px;margin-top:20px}.unit-status-card{background:var(--panel-bg, #ffffff);border-radius:12px;padding:20px;box-shadow:0 2px 8px #10182814;border:1px solid var(--border-color, #f0f0f0);transition:all .2s ease}.unit-status-card:hover{box-shadow:0 4px 16px #1018281f;transform:translateY(-2px)}.unit-status-card .card-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #f3f4f6}.unit-status-card .location-name{font-size:1.1rem;font-weight:700;color:#1f2937;margin:0}.unit-status-card .card-content{display:flex;flex-direction:column;gap:16px}.unit-status-card .status-info{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.unit-status-card .status-label{font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.unit-status-card .status-value{display:flex;align-items:center;gap:4px;font-size:.95rem;color:#1f2937;font-weight:500}.unit-status-card .connected-count{color:#10b981;font-weight:700}.unit-status-card .total-count{color:#6b7280}.unit-status-card .separator{color:#d1d5db}.unit-status-card .percentage{color:#6b7280;font-size:.85rem}.unit-status-card .progress-section{display:flex;flex-direction:column;gap:8px}.unit-status-card .progress-bar-container{width:100%;height:12px;background:#e5e7eb;border-radius:8px;overflow:hidden;display:flex;gap:0}.unit-status-card .progress-bar-fill{height:100%;transition:width .3s ease}.unit-status-card .progress-bar-fill.connected{background:#10b981}.unit-status-card .progress-bar-fill.disconnected{background:#ef4444}.units-header{display:flex;justify-content:space-between;align-items:center;margin:0 0 .5rem;padding:.25rem 0 .5rem;background:transparent;border-bottom:1px solid #eef2f6;gap:1rem}.units-header h2{font-size:1.4rem;color:#1f2937;font-weight:700;margin:0;min-width:max-content}.overview-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;background:#e3f2fd;border:1px solid #0b59d6;border-radius:6px;cursor:pointer;transition:all .12s ease;color:#0b59d6;font-weight:600;font-size:.85rem;width:100%;margin-bottom:.5rem}.overview-item:hover{background:#bbdefb;border-color:#0947aa;color:#0947aa}.locations-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.theme-dark .units-page,.theme-dark .units-container,.theme-dark .units-sidebar,.theme-dark .sidebar-section,.theme-dark .group-select,.theme-dark .main-card,.theme-dark .status-table thead,.theme-dark .status-table tbody tr,.theme-dark .status-table td,.theme-dark .status-table th,.theme-dark .overview-item,.theme-dark .locations-list,.theme-dark .location-item,.theme-dark .units-header{background-color:var(--panel-bg)!important;color:var(--text-color)!important;border-color:var(--border-color)!important;box-shadow:none!important}.theme-dark .sidebar-section{box-shadow:0 8px 30px #0000008c}.theme-dark .group-select{background:var(--panel-bg)!important;color:var(--text-color)!important;border-color:var(--border-color)}.theme-dark .main-card{background:var(--panel-bg)!important;color:var(--text-color)!important;box-shadow:0 10px 30px #0009}.theme-dark .status-table thead{background:transparent;border-bottom-color:#ffffff0a}.theme-dark .status-table tbody tr:hover{background:#ffffff05}.theme-dark .status-table td,.theme-dark .status-table th{color:var(--muted-text)!important;border-color:#ffffff08}.theme-dark .overview-item{background:#ffffff05;border-color:#ffffff08;color:var(--muted-text)}.theme-dark .location-count{background:#ffffff0a;color:var(--text-color)}.theme-dark .location-count,.theme-dark .location-item .badge,.theme-dark .progress-fill.connected,.theme-dark .progress-fill.disconnected{opacity:.95}.theme-dark .units-header h2{color:#e6eefc!important}.theme-dark .sidebar-section h3,.theme-dark .filter-label,.theme-dark .unit-card-title,.theme-dark .location-name,.theme-dark .location-item{color:#dbeafe!important}.theme-dark .location-item.active{color:#cfe4ff}.theme-dark .status-table th,.theme-dark .status-table td,.theme-dark .units-table th,.theme-dark .units-table td{color:#dbeafe!important}.theme-dark .unit-link{color:#8fc9ff}.theme-dark .unit-link:hover{color:#cfe4ff}.theme-dark .no-units{color:#9ca3af}.locations-header h3{font-size:.7rem;font-weight:800;color:#374151;text-transform:uppercase;letter-spacing:.5px;margin:0}.overview-btn{padding:.3rem .6rem;font-size:.75rem;font-weight:600;background:#e3f2fd;border:1px solid #0b59d6;border-radius:4px;color:#0b59d6;cursor:pointer;transition:all .12s ease}.overview-btn:hover:not(:disabled){background:#bbdefb;border-color:#0947aa;color:#0947aa}.overview-btn:disabled{background:#e5e7eb;border-color:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.units-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;margin-left:auto}.control-group{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.control-group label{color:#6b7280;font-weight:500;white-space:nowrap}.sort-dropdown,.view-dropdown{padding:6px 10px;border:1px solid #d1d5db;background:var(--panel-bg, #ffffff);border-radius:4px;font-size:.85rem;color:#374151;cursor:pointer;transition:all .2s ease}.sort-dropdown:hover,.view-dropdown:hover{border-color:#9ca3af}.sort-dropdown:focus,.view-dropdown:focus{outline:none;border-color:#0b59d6;box-shadow:0 0 0 2px #0b59d61a}.control-btn{padding:6px 12px;border:1px solid #d1d5db;background:var(--panel-bg, #ffffff);border-radius:4px;font-size:.85rem;color:#374151;cursor:pointer;transition:all .2s ease;font-weight:500;white-space:nowrap;height:32px;display:flex;align-items:center;justify-content:center}.control-btn:hover{background:#ffffff08;border-color:#9ca3af}.control-btn.sort-btn{background:#0b59d6;color:#fff;border-color:#0b59d6;font-weight:600}.control-btn.sort-btn:hover{background:#0947aa;border-color:#0947aa}.control-btn.sort-btn:not(.active){background:var(--panel-bg, #ffffff);color:#374151;border-color:#d1d5db}.control-btn.sort-btn:not(.active):hover{background:#ffffff08;border-color:#9ca3af}.control-btn.sort-btn.active{background:#0b59d6;color:#fff;border-color:#0b59d6}.control-btn.status-btn{background:var(--panel-bg, #ffffff);color:#0b59d6;border-color:#d1d5db;font-weight:600}.control-btn.icon-btn{padding:6px 8px;min-width:auto;width:32px}.control-btn.icon-btn.active{background:#0b59d6;color:#fff;border-color:#0b59d6}.control-btn.grid-btn,.control-btn.list-btn{padding:6px 8px;min-width:auto;width:32px;background:var(--panel-bg, #ffffff);color:#374151;border-color:#d1d5db}.control-btn.grid-btn:hover,.control-btn.list-btn:hover{background:#ffffff08;border-color:#9ca3af}.control-btn.grid-btn.active,.control-btn.list-btn.active{background:#0b59d6;color:#fff;border-color:#0b59d6}.control-btn.menu-btn{padding:6px 8px;min-width:auto;width:32px}.units-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;flex:1;overflow-y:auto;overflow-x:hidden;padding-right:1rem;padding-bottom:1rem;margin-top:0;width:100%}.unit-card{position:relative;display:flex;flex-direction:column;border:1px solid #d1d5db;background:var(--panel-bg, #ffffff);box-shadow:0 1px 2px #0000000d;border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.unit-card:hover{box-shadow:0 4px 12px #0000001a}.unit-card-title{padding:.75rem;font-size:.9rem;font-weight:700;color:#374151;background:var(--panel-bg, #f9fafb);border-bottom:1px solid var(--border-color, #e5e7eb);text-decoration:none;cursor:pointer;transition:color .2s ease;display:flex;align-items:center;gap:.6rem}.unit-card-title a{color:inherit;text-decoration:none}.unit-card-title:hover a{color:#0b59d6}.status-dot{width:12px;height:12px;border-radius:50%;flex:0 0 12px;box-shadow:0 0 0 4px #10b98114}.status-dot.connected{background:#10b981;box-shadow:0 0 0 4px #10b9811f}.status-dot.disconnected{background:#ef4444;box-shadow:0 0 0 4px #ef44441f}.unit-image-wrapper{position:relative;width:100%;height:200px;overflow:hidden}.unit-image{width:100%;height:100%;background:transparent;display:block;position:relative}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af;background:#f7f7f7;border:1px solid #eef2f6;font-weight:700;font-size:.95rem}.unit-timestamp{position:absolute;top:8px;left:8px;background:#6b7280;color:#fff;padding:4px 8px;font-size:.7rem;border-radius:12px;font-weight:700;box-shadow:0 2px 6px #10182814;opacity:.7}.unit-last-seen{padding:.5rem .75rem;font-size:.85rem;color:#0b59d6;background:var(--panel-bg, #ffffff);border-bottom:1px solid var(--border-color, #e5e7eb)}.unit-status{padding:.4rem .75rem;font-size:.75rem;font-weight:900;text-align:center;letter-spacing:.8px;color:#fff;text-transform:uppercase}.unit-status.connected{background:#10b981}.unit-status.disconnected{background:#ef4444}.no-units{grid-column:1 / -1;text-align:center;padding:2rem;color:#9ca3af;font-size:.95rem}.units-list-view{background:var(--panel-bg, #ffffff);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #1018280f}.units-table{width:100%;border-collapse:collapse;font-size:.85rem}.units-table thead{background:var(--panel-bg, #f3f4f6);border-bottom:1px solid var(--border-color, #e5e7eb)}.units-table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#374151;text-transform:none;letter-spacing:normal}.units-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .12s ease}.units-table tbody tr:hover{background:#ffffff05}.units-table tbody td{padding:.4rem 1rem;color:#374151;vertical-align:middle}.unit-link{color:#0b59d6;text-decoration:none;font-weight:500;cursor:pointer;transition:color .12s ease}.unit-link:hover{color:#0947aa}.status-badge{display:inline-block;padding:.4rem .75rem;font-size:.7rem;font-weight:700;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.status-badge.connected{background:#d1fae5;color:#065f46}.status-badge.disconnected{background:#fee2e2;color:#7f1d1d}.units-sidebar::-webkit-scrollbar,.units-grid::-webkit-scrollbar{width:6px}.units-sidebar::-webkit-scrollbar-track,.units-grid::-webkit-scrollbar-track{background:transparent}.units-sidebar::-webkit-scrollbar-thumb,.units-grid::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.units-sidebar::-webkit-scrollbar-thumb:hover,.units-grid::-webkit-scrollbar-thumb:hover{background:#9ca3af}@media (max-width: 1400px){.units-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.units-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.units-container{flex-direction:column;gap:1rem}.units-sidebar{width:100%}.units-grid{grid-template-columns:repeat(2,1fr)}.units-header{flex-direction:column;align-items:flex-start;gap:1rem}}.devices-container{width:100%;height:100%;background-color:#f5f5f5;padding:8px;display:flex;flex-direction:column}.devices-layout{display:grid;grid-template-columns:420px 280px 1fr;gap:12px;margin-bottom:30px;height:auto;width:100%;align-items:stretch}.devices-layout>*{min-height:0}.devices-panel-header,.control-header,.control-section-header,.control-header-card,.device-section-header,.system-info-header{padding:0 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:space-between;min-height:56px;border-radius:12px 12px 0 0}.device-section-header,.control-section-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#1f2937}.theme-dark .device-section-header,.theme-dark .control-section-header{background:#0f1720!important;border-color:#ffffff0a!important;color:#cbd5e1!important}.panel-outline,.device-section,.devices-center-panel,.control-panel,.control-section,.control-header-card,.system-info-card,.system-players-content,.device-info-card{border:1px solid #e5e7eb;background:#fff;border-radius:12px}.devices-left-panel,.devices-center-panel,.control-panel,.devices-right-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #00000014!important}.devices-left-panel{display:flex;flex-direction:column;gap:10px;padding-right:0;border-radius:12px;overflow:hidden}.devices-left-panel .device-section,.devices-left-panel .device-info-card,.devices-left-panel .device-section-header{border-radius:0}.devices-left-panel .device-info-card,.devices-left-panel .device-section{border:none}.devices-left-panel .device-section,.devices-left-panel .device-info-card,.devices-left-panel .device-section-header{box-shadow:none;background:#fff}.devices-left-panel,.devices-center-panel,.devices-right-panel{display:flex;flex-direction:column;gap:8px}.device-info-card,.control-panel,.system-info-card{padding:16px;box-sizing:border-box}.devices-left-panel .device-section{padding:0}.devices-left-panel{max-width:420px}.devices-left-panel .device-section,.devices-left-panel .device-info-card{position:static;align-self:stretch;width:100%;height:auto;max-height:none;overflow:visible;box-sizing:border-box}.devices-left-panel .device-info-card{padding:12px}.devices-left-panel .device-section-header{padding:0 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:space-between;min-height:56px;border-radius:12px 12px 0 0}.devices-left-panel .device-section-header h3{margin:0;font-size:16px;font-weight:700;color:#1f2937}.devices-left-panel .device-section-header .refresh-btn{width:44px;height:44px;padding:0;border-radius:8px;background:#fff;border:1px solid #dbeafe;color:#0b59d6;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0206170a}.devices-left-panel .device-section-header .refresh-btn .refresh-icon{width:20px;height:20px}.theme-dark .devices-left-panel .device-section-header .refresh-btn{background:#ffffff08!important;border-color:#ffffff0a!important;box-shadow:none!important}.theme-dark .devices-left-panel .device-section-header .refresh-btn img.refresh-icon{filter:brightness(0) invert(1)!important}.devices-container .devices-center-panel{position:sticky;top:100px;height:auto;max-height:none;overflow:visible;align-self:flex-start;box-sizing:border-box}.devices-center-panel,.devices-right-panel{position:sticky;top:100px;align-self:flex-start;height:auto;max-height:none;overflow:visible;box-sizing:border-box}.control-panel,.devices-right-panel .system-info-content{padding:12px;border-radius:0}.devices-center-panel{background:#fff;border-radius:12px;box-shadow:0 2px 6px #0000000f;display:flex;flex-direction:column;height:auto;max-height:none;overflow-y:visible;width:280px;min-width:280px;max-width:280px;flex:0 0 280px;-webkit-text-size-adjust:100%;text-size-adjust:100%;min-height:0;box-sizing:border-box;z-index:1}.control-header{padding:0 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;min-height:56px;border-top-left-radius:12px}.control-header h2{margin:0;font-size:18px;font-weight:700;color:#1f2937}.device-name-small{display:block;font-size:12px;color:#6b7280;margin-top:4px;font-weight:500}.control-menu{display:flex;flex-direction:column;padding:8px 0}.control-menu-item{display:flex;align-items:center;gap:12px;padding:px 16px;background:transparent;border:none;cursor:pointer;transition:all .2s ease;color:#6b7280;font-size:13px;font-weight:500;text-align:left;border-left:3px solid transparent}.control-menu-item:hover{background:#f3f4f6;color:#374151}.control-menu-item:focus{outline:none;box-shadow:none}.control-menu-item:focus-visible{outline:2px solid rgba(11,89,214,.18);outline-offset:2px}.control-menu-item.active{background:#eff6ff;color:#0b59d6;border-left-color:#0b59d6;font-weight:600}.menu-icon{font-size:16px;min-width:16px}.menu-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.control-panel{background:#fff;box-shadow:0 2px 6px #0000000f;border-radius:12px;padding:24px;display:flex;flex-direction:column;flex:1 1 auto;overflow:hidden}.control-panel-content h3{margin:0 0 16px;font-size:20px;font-weight:700;color:#1f2937}.no-panel-selected{display:flex;align-items:center;justify-content:center;height:300px;color:#9ca3af;font-size:16px}.panel-info{color:#6b7280;font-size:14px;margin:16px 0}.player-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.player-card{width:100px;background:#fff;border-radius:14px;padding:12px 12px 10px 20px;box-shadow:0 2px 6px #1018280a;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;cursor:pointer;border:none;position:relative;overflow:visible;height:auto}.player-card.selected{box-shadow:0 6px 20px #10b98114;border-color:#10b9812e}.player-card-icon{font-size:28px;margin-bottom:10px;color:#111827}.player-card-id{font-size:18px;font-weight:800;color:#0f172a;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;padding:6px 0 0}.player-card-status{width:14px;height:14px;border-radius:50%;margin-top:10px;position:relative;z-index:2}.player-card-status:before{content:"";position:absolute;left:-8px;top:-8px;width:34px;height:34px;border-radius:50%;background:#10b98114;z-index:1}.player-card-status.online{background:#10b981}.player-card-status.offline{background:#ef4444}.player-card-status.offline:before{background:#ef44440f}.player-card-status.online:before{background:#10b98114}.player-system-info{margin-top:12px;border-top:1px solid #e5e7eb;padding-top:12px}.player-card:before,.player-card:after{content:none;display:none}.player-card.online:after{background:transparent}.player-card.offline:after{background:transparent}.player-card-body{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.player-card-footer{position:static;width:calc(100% - 24px);height:56px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;border-bottom-left-radius:12px;border-bottom-right-radius:12px;margin-top:12px;margin-bottom:0}.player-copy-btn{width:40px;height:40px;border-radius:8px;background:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #0206170f;font-size:16px;cursor:pointer}.player-copy-btn.online{background:#10b981;color:#fff}.player-copy-btn.offline{background:#ef4444;color:#fff}.player-copy-btn:active{transform:translateY(1px)}.player-system-info{margin-top:12px;border-top:1px solid #e5e7eb;padding-top:12px;padding-bottom:0}.player-system-info h4{margin:0 0 12px;font-size:13px;color:#374151;letter-spacing:.02em}.player-mac-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;padding:12px;margin-bottom:16px;box-shadow:0 4px 12px #667eea26}.mac-card-header{font-size:12px;font-weight:600;color:#fffc;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;text-align:center}.mac-card-content{display:flex;align-items:center;gap:8px}.mac-code{flex:1;background:#fffffff2;color:#1f2937;padding:8px 12px;border-radius:6px;font-family:Courier New,monospace;font-size:12px;font-weight:600;text-align:center;border:1px solid rgba(255,255,255,.3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mac-copy-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;padding:6px 10px;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.mac-copy-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.mac-copy-button:active{transform:translateY(0)}.info-grid{display:flex;flex-direction:column;gap:4px}.info-grid .row{display:grid;grid-template-columns:150px 1fr;align-items:center;padding:12px 0;border-bottom:1px solid #f3f4f6}.info-grid .label{color:#6b7280;font-size:13px;font-weight:700}.info-grid .value{color:#111827;font-size:13px;text-align:right}.player-actions{width:100%;display:flex;justify-content:center;gap:12px;padding:16px 0 0;border-top:1px solid #eaeaea;margin-top:16px;box-sizing:border-box}.player-actions button{padding:10px 16px;border-radius:8px;border:none;cursor:pointer;font-weight:700;font-size:13px}.player-actions .add-player{background:var(--accent);color:var(--accent-contrast)}.player-actions .add-player:hover{background:var(--accent-light)}.player-actions .retire-player{background:var(--danger);color:var(--accent-contrast)}.player-actions .retire-player:hover{background:var(--danger-light)}.player-actions .move-player{background:var(--success);color:var(--accent-contrast)}.player-actions .move-player:hover{background:var(--success-light)}.player-actions .report-fault-inline{background:var(--danger);color:var(--accent-contrast)}.player-actions{margin-top:14px;display:flex;gap:12px}.player-actions button{padding:8px 12px;border-radius:6px;border:none;cursor:pointer;font-weight:600}.report-fault-top{background:var(--danger);color:var(--accent-contrast);border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:600}.report-fault-top:hover{background:var(--danger-light)}.open-archive-top{background:#fff;color:#0b59d6;border:1px solid #dbeafe;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:700}.open-archive-top:hover{background:#eff6ff}.modal-content.camshots-modal{max-width:1720px!important;width:98%!important;padding:8px 12px 12px;position:relative}.modal-content.camshots-modal .modal-title{padding:14px 48px 14px 18px}.modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:6px;border:none;background:#0000000f;color:#111827;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#0000001f}.camshot-archive-wrap{display:flex;gap:12px;align-items:flex-start}.camshot-dates{width:92px;display:flex;flex-direction:column;gap:10px;padding-left:2px;padding-right:6px;max-height:none;height:auto;overflow:visible;flex:0 0 auto}.camshot-thumbs{flex:1;padding-left:8px;max-height:calc(80vh - 140px);overflow:auto}.thumb-item{display:flex;flex-direction:column;width:220px}.thumb-img-wrapper{width:100%;height:123.75px;overflow:hidden;border-radius:8px;background:#000}.thumb-caption{padding:8px 6px;font-size:13px;color:#6b7280;background:#fff;border-radius:0 0 6px 6px;margin-top:8px;text-align:left}.camshot-archive-wrap .thumbs-grid,.camshots-archive .thumbs-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;align-items:start;justify-content:start}.modal-content.camshots-modal .thumbs-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:18px;align-items:start;justify-content:start}.camshot-archive-wrap .thumb-item,.modal-content.camshots-modal .thumb-item,.camshots-archive .thumb-item{display:flex;flex-direction:column;width:auto;border-radius:0;overflow:visible}.camshot-archive-wrap .thumb-img-wrapper,.modal-content.camshots-modal .thumb-img-wrapper,.camshots-archive .thumb-img-wrapper{width:100%;aspect-ratio:16 / 9;overflow:hidden;border-radius:0;background:#000}.camshot-archive-wrap .thumb-img,.modal-content.camshots-modal .thumb-img,.camshots-archive .thumb-img{width:100%;height:100%;object-fit:cover;display:block}.thumb-caption{padding:6px 8px;font-size:12px;color:#6b7280;background:#fff;border-radius:0;margin-top:6px;text-align:left;line-height:1.1}.modal-content.camshots-modal{max-height:92vh!important;overflow:auto}.modal-content.camshots-modal .camshot-thumbs,.modal-content.camshots-modal .camshot-dates{max-height:calc(88vh - 160px);overflow-y:auto;overflow-x:hidden}.devices-right-panel .system-info-content{max-height:calc(100vh - 120px);overflow:visible}.devices-right-panel .system-info-content .camshot-archive-wrap{align-items:flex-start}.camshot-thumbs{max-height:calc(100vh - 220px);overflow:auto}.theme-dark .camshot-dates .date-btn{background:transparent;border-color:#ffffff0f;color:#cbd5e1}.theme-dark .camshot-dates .date-btn.active{background:#3b82f61f;border-color:#3b82f640;color:#c7e0ff}.theme-dark .camshot-archive-wrap .thumb-item,.theme-dark .camshots-archive .thumb-item,.theme-dark .modal-content.camshots-modal .thumb-item{background:transparent;border-color:#ffffff0a}.theme-dark .devices-panel-header,.theme-dark .control-header,.theme-dark .control-section-header,.theme-dark .control-header-card,.theme-dark .device-section-header,.theme-dark .system-info-header{background:#0f1720!important;border-color:#ffffff0a!important;color:#cbd5e1}.theme-dark .panel-outline,.theme-dark .device-section,.theme-dark .devices-center-panel,.theme-dark .control-panel,.theme-dark .control-section,.theme-dark .control-header-card,.theme-dark .system-info-card,.theme-dark .system-players-content,.theme-dark .device-info-card{background:#0b1116!important;border-color:#ffffff0a!important;color:#cbd5e1}.devices-left-panel,.devices-center-panel,.devices-right-panel,.theme-dark .devices-left-panel,.theme-dark .devices-center-panel,.theme-dark .devices-right-panel{border:none!important}.theme-dark .control-panel-content .btn,.theme-dark .control-panel-content .btn.btn-start,.theme-dark .control-panel-content .btn.btn-disable{background:#ffffff08!important;border:1px solid rgba(255,255,255,.04)!important;color:#cbd5e1!important;box-shadow:none!important}.theme-dark .control-panel-content .btn:hover{background:#ffffff0d!important}.theme-dark .devices-left-panel .device-section-header .refresh-btn{background:#ffffff08!important;border-color:#ffffff0a!important;box-shadow:none!important;color:#e6eef7!important}.theme-dark .modal-close,.theme-dark .report-fault-top,.theme-dark .open-archive-top{background:#ffffff08!important;color:#e6eef7!important}.theme-dark .thumb-caption,.theme-dark .camshot-archive-wrap .thumb-caption,.theme-dark .modal-content.camshots-modal .thumb-caption{background:transparent;color:#cbd5e1}.player-item{padding:10px 12px;background:#f3f4f6;border-radius:6px;font-size:13px;color:#374151}.activity-log{display:flex;flex-direction:column;gap:12px;margin-top:12px}.activity-item{padding:12px;background:#f9fafb;border-left:3px solid #0b59d6;border-radius:4px;font-size:13px;color:#374151;line-height:1.5}.activity-panel .activity-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.activity-entry{display:flex;gap:12px;padding:12px 8px;border-bottom:1px solid #eef2f6;align-items:flex-start;position:relative}.activity-avatar{width:48px;height:48px;border-radius:50%;background:#e6e9ee;flex:0 0 48px}.activity-content{flex:1;padding-right:120px}.activity-row{display:flex;gap:12px;align-items:center}.activity-tag{background:#10b981;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:700}.activity-title{font-weight:600;color:#1f2937}.activity-meta{color:#6b7280;font-size:13px;margin-top:6px}.activity-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px;margin:0;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.scope-select{width:92px;height:28px;padding:4px 8px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;font-size:13px}.delete-activity{width:92px;height:28px;background:#f3f4f6;border:1px solid #e5e7eb;color:#374151;padding:4px 8px;border-radius:6px;cursor:pointer;font-size:13px}.delete-activity:hover{background:#ef4444;color:#fff;border-color:transparent}.empty-activity{color:#9ca3af;padding:12px}.activity-meta .meta-date{margin-left:12px;color:#9ca3af;font-weight:500}.activity-comment{margin-top:14px}.activity-textarea{width:100%;min-height:100px;border:1px solid #e5e7eb;border-radius:4px;padding:12px;resize:vertical}.activity-controls{display:flex;align-items:center;gap:12px;margin-top:8px}.activity-checkbox{color:#374151;font-weight:600;display:flex;align-items:center;gap:8px}.btn-post{background:#2b9cf0;color:#fff;border:none;padding:8px 14px;border-radius:6px;cursor:pointer}.livecam-placeholder,.liveview-placeholder{width:100%;aspect-ratio:16 / 9;background:#f5f7fa;border:2px dashed #e8eef3;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;color:#9ca3af;margin:12px 0}.livecam-icon,.liveview-icon{font-size:36px}.livecam-text,.liveview-text{font-size:14px;font-weight:700;color:#374151}.livecam-controls,.liveview-controls{display:flex;gap:8px;margin-top:8px}.control-panel-content .btn{padding:8px 12px;border-radius:6px;border:1px solid #e5e7eb;background:#fff;cursor:pointer}.control-panel-content .btn:hover{background:#f3f4f6}.control-panel-content .btn.btn-start{background:var(--success);color:var(--accent-contrast);border:1px solid rgba(16,185,129,.12);padding:10px 16px;border-radius:8px;font-weight:700;box-shadow:none}.control-panel-content .btn.btn-start:hover{background:var(--success-light)}.control-panel-content .btn.btn-start:focus{outline:none;box-shadow:none}.control-panel-content .btn.btn-disable{background:var(--danger);color:var(--accent-contrast);border:1px solid rgba(239,68,68,.12);padding:10px 16px;border-radius:8px;font-weight:700;box-shadow:none}.control-panel-content .btn.btn-disable:hover{background:var(--danger-light)}.control-panel-content .btn.btn-disable:focus{outline:none;box-shadow:none}.info-alert{background:#fff7e6;border:1px solid #f0e6c8;color:#6b4f1a;padding:12px;border-radius:6px}.btn-start{background:var(--success);color:var(--accent-contrast);border:1px solid rgba(16,185,129,.12);padding:10px 16px;border-radius:8px;font-weight:700;transition:transform .12s ease,filter .12s ease}.btn-start:hover{background:var(--success-light);transform:translateY(-1px)}.btn-start:focus{outline:none;box-shadow:none}.btn-disable{background:var(--danger);color:var(--accent-contrast);border:1px solid rgba(239,68,68,.12);padding:10px 16px;border-radius:8px;font-weight:700;transition:transform .12s ease,filter .12s ease}.btn-disable:hover{background:var(--danger-light);transform:translateY(-1px)}.btn-disable:focus{outline:none;box-shadow:none}.live-feed-container{width:100%;display:block;position:relative;overflow:hidden}.live-feed-container.landscape{aspect-ratio:16 / 9}.live-feed-container.portrait{aspect-ratio:9 / 16}.live-feed-container{border-radius:6px;overflow:hidden}.live-feed-img{width:100%;height:100%;display:block;background:#000;object-fit:cover}.live-feed-img img{width:100%;height:100%;object-fit:cover;display:block}.fullscreen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:9999;display:flex;align-items:center;justify-content:center}.fullscreen-media{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.fullscreen-media img{width:100%;height:100%;object-fit:contain}.fullscreen-close{position:fixed;top:18px;right:18px;background:#ffffffe6;color:#111827;border:none;padding:8px 12px;border-radius:6px;font-weight:700;z-index:10000;cursor:pointer}.live-feed-meta{font-size:12px;color:#9ca3af;padding:8px 12px;background:#fff}.theme-dark .livecam-placeholder,.theme-dark .liveview-placeholder{background:#071023!important;border-color:#ffffff0a!important;color:#cbd5e1!important}.theme-dark .livecam-text,.theme-dark .liveview-text{color:#cbd5e1!important}.theme-dark .live-feed-container{background:#071023!important;border:1px solid rgba(255,255,255,.03)!important}.theme-dark .live-feed-container .live-feed-img{background:#000!important}.theme-dark .info-alert{background:#ffffff05!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important}.theme-dark .live-feed-meta{background:#ffffff05!important;color:#cbd5e1!important}.theme-dark .fullscreen-close{background:#ffffff0f!important;color:#dbeafe!important;border:none!important}.theme-dark .report-fault-top,.theme-dark .player-actions .report-fault-inline,.theme-dark .report-fault-inline{background:var(--danger)!important;color:var(--accent-contrast)!important;border:none!important;box-shadow:none!important}.theme-dark .report-fault-top:hover,.theme-dark .player-actions .report-fault-inline:hover,.theme-dark .report-fault-inline:hover{background:var(--danger-light)!important}.theme-dark .uptime-chart,.theme-dark .uptime-panel,.theme-dark .uptime-panel .card{background:#ffffff05!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important}.theme-dark .uptime-chart svg,.theme-dark .uptime-chart svg text,.theme-dark .uptime-chart .apexcharts-text,.theme-dark .uptime-chart .apexcharts-xaxis-label,.theme-dark .uptime-chart .apexcharts-yaxis-label,.theme-dark .uptime-chart .apexcharts-legend-text,.theme-dark .uptime-chart .apexcharts-tooltip,.theme-dark .uptime-chart .apexcharts-tooltip *{fill:#94a3b8!important;color:#94a3b8!important}.theme-dark .uptime-chart .apexcharts-gridline,.theme-dark .uptime-chart .apexcharts-yaxis-tick,.theme-dark .uptime-chart .apexcharts-xaxis-tick{stroke:#ffffff08!important}.theme-dark .uptime-chart .apexcharts-tooltip{background:#ffffff0a!important;color:#e6eefc!important;border:1px solid rgba(255,255,255,.06)!important}.theme-dark .uptime-chart svg text{fill:#94a3b8!important}.theme-dark .tickets-panel,.theme-dark .tickets-panel .ticket-row{background:#ffffff05!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important;box-shadow:none!important}.theme-dark .tickets-panel .ticket-row .btn{background:#ffffff08!important;border:1px solid rgba(255,255,255,.04)!important;color:#cbd5e1!important}.theme-dark .pc-logs,.theme-dark .pc-selected-box,.theme-dark .pc-logs-list{background:#071023!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important}.theme-dark .control-panel-content [style*="#fff8d6"],.theme-dark [style*="#fff8d6"],.theme-dark [style*="#fff7e6"]{background:#ffffff05!important;color:#cbd5e1!important;border-color:#ffffff08!important}.inline-info{margin-top:12px;padding:12px;border-radius:4px;background:#fff8d6;color:#6b4b00}.inline-wrap{background:#f8fafc;color:#0f172a;padding:12px;border-radius:6px;box-shadow:0 4px 12px #0000000d}.empty-history{text-align:center;color:#6b7280}.theme-dark .inline-info{background:#ffffff05!important;color:#cbd5e1!important;border:1px solid rgba(255,255,255,.03)!important}.theme-dark .inline-wrap{background:#ffffff05!important;color:#cbd5e1!important;box-shadow:none!important;border:1px solid rgba(255,255,255,.03)!important}.theme-dark .empty-history{color:#94a3b8!important}.live-feed-container:fullscreen,.live-feed-container:-webkit-full-screen,.live-feed-container:-ms-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:99999;border-radius:0;display:flex;align-items:center;justify-content:center;background:#000}.live-feed-container:fullscreen .live-feed-img,.live-feed-container:-webkit-full-screen .live-feed-img,.live-feed-container:-ms-fullscreen .live-feed-img{width:100%;height:100%;object-fit:contain}.uptime-chart{background:#fff;border:1px solid #eef2ff;border-radius:8px;padding:8px}.uptime-panel h4{margin:0 0 8px}.tickets-panel .ticket-row{box-shadow:0 6px 18px #02061705}.tickets-panel .ticket-row .btn{padding:8px 10px;border-radius:6px;border:none;cursor:pointer;font-weight:700}.tickets-panel .ticket-row .btn.btn-start{background:var(--success);color:#fff}.tickets-panel .ticket-row .btn.btn-disable{background:var(--danger);color:#fff}.commands-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:12px 0}.command-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:106px;padding:14px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:600;color:#374151;text-align:center}.command-btn:hover{background:#f8fbff;border-color:#93c5fd;color:#0b59d6;transform:translateY(-1px);box-shadow:0 8px 18px #0206170f}.command-btn:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.pc-commands-panel .pc-commands-grid-wrapper{display:grid;grid-template-columns:1fr 360px;gap:18px;align-items:start}.pc-commands-side{display:flex;flex-direction:column;gap:12px}.pc-selected-header{background:#dff3ff;border:1px solid #cfeefc;padding:12px;border-radius:6px;color:#0b4f73;font-weight:700;font-size:15px}.pc-selected-box{background:#fff;border:1px solid #eef7fb;padding:10px;border-radius:6px;color:#0b4f73;font-weight:600}.pc-selected-summary{background:#f8fbff;border:1px solid #e6f0ff;border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px}.pc-selected-meta{font-size:12px;color:#4b5563}.pc-selected-hint{font-size:12px;color:#64748b}.pc-pending-pill{width:fit-content;background:#f59e0b;color:#111827;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700}.pc-logs{background:#fff;border:1px solid #eef2f6;padding:8px;border-radius:6px}.pc-logs-header{font-size:13px;color:#6b7280;margin-bottom:8px}.pc-logs-list{max-height:200px;overflow-y:auto;border-top:1px solid #f3f4f6;padding-top:8px}.pc-log-entry{padding:6px 8px;font-size:13px;border-bottom:1px solid #f3f4f6;color:#374151}.pc-log-empty{color:#9ca3af;padding:10px}.link-btn{background:none;border:none;color:#0b59d6;cursor:pointer;padding:0;font-size:13px}.pc-send-btn{width:100%;margin-top:12px;padding:12px 16px;border:none;border-radius:8px;font-weight:700}.pc-send-btn:disabled{background:#cbd5e1!important;color:#475569!important;cursor:not-allowed}.pc-pending-wrap{margin-top:12px}.pc-pending-header{display:flex;justify-content:space-between;align-items:center}.pc-pending-title{font-weight:700}.pc-pending-list{margin-top:8px;max-height:220px;overflow:auto;border:1px solid #e6e6e6;padding:8px;border-radius:6px}.pc-pending-empty{color:#666}.pc-pending-item{display:flex;justify-content:space-between;gap:8px;padding:6px 4px;border-bottom:1px solid #f2f2f2}.pc-pending-item-main{flex:1}.pc-pending-item-title{font-size:13px;font-weight:700}.pc-pending-item-time{font-size:12px;color:#666}.pc-pending-item-actions{display:flex;gap:8px;align-items:center}.command-btn.selected{background:#eff6ff;color:#0b59d6;border-color:#60a5fa;box-shadow:inset 0 0 0 1px #93c5fd;font-weight:700}.cmd-svg{width:36px;height:36px;display:block;margin:8px auto 6px;filter:none}.command-btn img.cmd-svg{width:36px;height:36px;object-fit:contain}.command-btn .cmd-label{font-size:13px;color:#374151}.cmd-icon{font-size:24px}.command-section{display:flex;gap:12px;margin-top:20px;align-items:flex-end}.command-section label{font-size:13px;font-weight:600;color:#374151;margin-bottom:4px;display:block}.command-select{padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px;color:#374151;background:#fff;cursor:pointer;transition:all .2s ease}.command-select:hover{border-color:#0b59d6}.command-select:focus{outline:none;border-color:#0b59d6;box-shadow:0 0 0 3px #0b59d61a}.send-btn{padding:8px 24px;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:13px}.send-btn:hover{background:#059669}.theme-dark .pc-commands-panel .command-btn{background:#ffffff05!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important}.theme-dark .pc-commands-panel .command-btn:hover{background:#ffffff0a!important;color:#e6eefc!important}.theme-dark .pc-commands-panel .command-btn.selected{background:#0b59d61f!important;color:#dbeafe!important;border:1px solid rgba(96,165,250,.55)!important;box-shadow:inset 0 0 0 1px #60a5fa59!important}.theme-dark .pc-commands-panel .command-btn .cmd-label{color:#cbd5e1!important}.theme-dark .pc-commands-panel img.cmd-svg{filter:brightness(0) invert(1)!important}.theme-dark .pc-commands-panel .pc-selected-summary,.theme-dark .pc-commands-panel .pc-selected-box,.theme-dark .pc-commands-panel .pc-logs,.theme-dark .pc-commands-panel .pc-logs-list{background:#071023!important;border:1px solid rgba(255,255,255,.03)!important;color:#cbd5e1!important}.theme-dark .pc-commands-panel .pc-selected-meta,.theme-dark .pc-commands-panel .pc-selected-hint,.theme-dark .pc-commands-panel .pc-pending-item-time{color:#94a3b8!important}@media (max-width: 1200px){.pc-commands-panel .pc-commands-grid-wrapper{grid-template-columns:1fr}}@media (max-width: 860px){.commands-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.commands-grid{grid-template-columns:1fr}}.terminal-window{background:#1e1e1e;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;margin:16px 0;font-family:Courier New,monospace}.terminal-header{background:#dc2626;color:#fff;padding:8px 12px;font-size:12px;font-weight:600}.terminal-body{padding:16px;color:#a3a3a3;font-size:12px;line-height:1.6;max-height:200px;overflow-y:auto}.terminal-btn{padding:8px 16px;background:#0b59d6;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:13px;margin-top:12px}.terminal-btn:hover{background:#0947aa}.chart-placeholder,.gallery-placeholder{height:200px;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:14px;margin-top:16px}.devices-right-panel{display:flex;flex-direction:column;gap:10px;width:100%;max-width:none;flex:0 0 auto;height:auto;min-width:0;align-items:stretch}.device-section{background:#fff;border-radius:12px;box-shadow:0 2px 6px #0000000f;overflow:hidden}.device-section-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb;min-height:56px}.device-section-header h3{margin:0;font-size:16px;font-weight:700;color:#222;letter-spacing:-.3px}.device-info-card{background:transparent;border-radius:0;padding:12px;box-shadow:none}.device-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:12px;padding-bottom:0;border-bottom:none}.device-status{display:flex;align-items:flex-start;gap:12px}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:3px}.status-indicator.online{background-color:#4caf50;box-shadow:0 0 8px #4caf5099}.status-indicator.offline{background-color:#f44336;box-shadow:0 0 8px #f4433699}.status-indicator.no-active{background-color:#9ca3af;box-shadow:none}.device-title{flex:1}.device-name{margin:0;font-size:14px;font-weight:700;color:#222;line-height:1.3}.device-subtitle{margin:3px 0 0;font-size:11px;color:#888;line-height:1.4}.device-screenshot{margin-bottom:12px}.screenshot-placeholder{width:100%;aspect-ratio:16 / 9;background:#f5f5f5;border-radius:4px;overflow:hidden;margin-bottom:8px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#ccc;position:relative}.screenshot-placeholder img{width:100%;height:100%;object-fit:cover}.screenshot-controls{display:none}.device-stats{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.stat-item{display:flex;flex-direction:column;gap:6px;width:100%}.stat-item label{font-size:12px;font-weight:700;color:#222}.stat-value{margin:0 0 2px;font-size:11px;color:#777;font-weight:500}.device-stats .progress-bar{margin-top:0!important}.progress-bar{width:100%;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden;display:block;min-height:12px}.progress-fill{height:100%;background:#2563eb;transition:width .3s ease;border-radius:6px;display:block;min-height:12px}.device-stats .progress-bar{height:12px!important;min-height:12px!important;border-radius:6px!important;overflow:hidden!important;background:#e5e7eb!important;display:block!important;margin-top:8px!important;width:100%!important}.device-stats .progress-fill{height:12px!important;min-height:12px!important;border-radius:6px!important;background:#2563eb!important;display:block!important}.camshots-archive .camshot-archive-wrap{display:flex;gap:8px;padding-left:2px;align-items:stretch}.camshot-dates{width:100px;display:flex;flex-direction:column;gap:8px;padding-left:2px;padding-right:6px;border-right:1px solid #eef2f6;max-height:none;height:auto;overflow:visible;flex:0 0 auto}.camshot-dates .date-btn{background:#fff;border:1px solid #e5e7eb;padding:6px 8px;border-radius:6px;text-align:center;font-size:12px;color:#374151;cursor:pointer;width:100%;box-sizing:border-box}.camshot-dates .date-btn.active{background:#eff6ff;border-color:#0b59d6;color:#0b59d6;font-weight:700}.camshot-thumbs{flex:1;padding-left:12px;overflow:auto;max-height:520px}.thumbs-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:18px;align-items:start;justify-content:start}.thumb-item{background:#fff;border:1px solid #eef2f6;border-radius:0;overflow:hidden;display:flex;flex-direction:column;width:auto}.thumb-img-wrapper{width:100%;aspect-ratio:16 / 9;overflow:hidden;background:#000;border-radius:0}.thumb-img{width:100%;height:100%;object-fit:cover;display:block}.thumb-caption{padding:4px 8px;font-size:11px;font-weight:700;color:#1f2937;background:#fff;line-height:1}.empty-choose{color:#9ca3af;padding:18px}.device-details{background:transparent;padding:0;border-radius:0;margin-bottom:0}.device-details h4{margin:0 0 8px;font-size:13px;font-weight:700;color:#222}.device-details h4+p,.detail-text{margin:0 0 6px;font-size:13px;font-weight:400;color:#222;line-height:1.5}.detail-text strong{font-weight:700}.detail-link{margin:0 0 6px;font-size:13px;font-weight:700;color:#222;text-decoration:none;cursor:pointer;word-break:break-word}.edit-device-btn{width:100%;padding:10px 12px;background:var(--accent);color:var(--accent-contrast);border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s,box-shadow .15s;margin-top:8px}.edit-device-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 12px #155fa81f}.devices-right-panel{display:flex;flex-direction:column;gap:15px;width:100%;max-width:none;flex:0 0 auto;height:auto;min-width:0;align-items:stretch;border-radius:12px;overflow:hidden}.control-system-wrapper{display:flex;flex-direction:row;gap:15px;width:100%;flex:1;align-items:stretch;height:100%;min-height:0}.control-header-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;width:100%}.control-header-card h3{margin:0;font-size:16px;font-weight:700;color:#222;letter-spacing:-.3px}.control-section-header{display:flex;justify-content:space-between;align-items:center;padding:0 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb;min-height:56px}.control-section-header h3{margin:0;font-size:16px;font-weight:700;color:#222;letter-spacing:-.3px}.control-left-section{display:flex;flex-direction:column;gap:12px;flex-shrink:0;width:280px;box-sizing:border-box;overflow-y:auto}.control-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001f;overflow:hidden}.control-menu-card{background:#fff;border-radius:0;box-shadow:none;display:flex;flex-direction:column;padding:8px}.system-info-card{flex:0 0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001f;display:flex;flex-direction:column;overflow:visible;width:100%;min-width:0;height:auto}.system-info-header{padding:0 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;display:flex;align-items:center;justify-content:space-between;min-height:56px;border-radius:12px 12px 0 0}.system-info-header h3{margin:0;font-size:16px;font-weight:700;color:#1f2937}.system-info-subheader{font-size:12px;color:#374151;background:#10b9810f;padding:6px 10px;border-radius:8px;display:inline-block}.system-info-content{display:flex;flex-direction:column;gap:16px;flex:0 0 auto;padding:16px;overflow:visible;width:100%;height:auto}.device-section-header,.devices-left-panel .device-section-header,.control-section-header{padding:0 16px!important;border-bottom:1px solid #e5e7eb!important;background:#f9fafb!important;display:flex!important;align-items:center!important;justify-content:space-between!important;min-height:56px!important;border-radius:12px 12px 0 0!important;color:#1f2937!important}.device-section-header h3,.devices-left-panel .device-section-header h3,.control-section-header h3{margin:0!important;font-size:16px!important;font-weight:700!important;color:#1f2937!important}.theme-dark .device-section-header,.theme-dark .devices-left-panel .device-section-header,.theme-dark .control-section-header{background:#0f1720!important;border-bottom-color:#ffffff0a!important;color:#cbd5e1!important;box-shadow:none!important}.theme-dark .device-section-header h3,.theme-dark .devices-left-panel .device-section-header h3,.theme-dark .control-section-header h3{color:#cbd5e1!important}.device-section-header,.devices-left-panel .device-section-header,.control-section-header,.system-info-header,.devices-panel-header,.control-header{border-bottom:1px solid #e5e7eb!important;box-shadow:none!important;border-radius:12px 12px 0 0!important}.theme-dark .device-section-header,.theme-dark .devices-left-panel .device-section-header,.theme-dark .control-section-header,.theme-dark .system-info-header,.theme-dark .devices-panel-header,.theme-dark .control-header{border-bottom:1px solid rgba(255,255,255,.04)!important;box-shadow:none!important;border-radius:12px 12px 0 0!important}.control-panel,.control-panel-content,.system-info-content,.device-info-card,.system-players-content{padding:16px;background:transparent;box-sizing:border-box}.control-panel-content{display:flex;flex-direction:column;gap:16px;flex:1 1 auto;overflow:auto}.control-panel-content h3{margin:0;font-size:18px;font-weight:700;color:#1f2937}.panel-info{color:#6b7280;font-size:14px;line-height:1.5}.activity-log{display:flex;flex-direction:column;gap:12px}.activity-item{padding:12px;background:#f9fafb;border-left:3px solid #0b59d6;color:#374151;font-size:13px;border-radius:4px}.player-list{display:flex;flex-direction:column;gap:10px}.player-item{padding:10px 12px;background:#f3f4f6;border-radius:6px;font-size:14px;color:#374151}.terminal-window{background:#1f2937;color:#0f0;padding:12px;border-radius:6px;font-family:Courier New,monospace;font-size:12px;height:200px;overflow-y:auto;margin-bottom:12px}.terminal-header{color:#ef4444;margin-bottom:8px;font-weight:600}.terminal-body{display:flex;flex-direction:column;gap:4px}.terminal-btn{padding:8px 12px;background:#0b59d6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:background .2s}.terminal-btn:hover{background:#0a4cb0}.chart-placeholder,.gallery-placeholder{padding:40px 20px;text-align:center;background:#f9fafb;border-radius:6px;color:#6b7280;font-size:14px;min-height:200px;display:flex;align-items:center;justify-content:center}.history-table-wrapper{overflow-x:auto}.history-table{width:100%;border-collapse:collapse;font-size:13px}.history-table thead{background:#f3f4f6;border-bottom:1px solid #e5e7eb}.history-table th{padding:10px 12px;text-align:left;font-weight:600;color:#374151}.history-table td{padding:10px 12px;border-bottom:1px solid #e5e7eb;color:#374151}.history-table tbody tr:hover{background:#f9fafb}.plus-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#e3f2fd;color:#1976d2;border-radius:4px;cursor:pointer;font-weight:600}.system-players-content{display:flex;flex-direction:column;padding:16px;background:transparent;flex:1 1 auto;overflow:auto}.players-grid-inline{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:16px;width:100%;max-width:100%;justify-content:start}.system-divider{height:1px;background:#e5e7eb;margin:0 -16px}.system-specs-content{padding:16px 0;background:transparent}.system-specs-content h4{margin:0 0 8px;font-size:13px;font-weight:700;color:#222;text-transform:uppercase;letter-spacing:.5px}.refresh-btn{background:transparent;border:1px solid #d1d5db;font-size:12px;cursor:pointer;padding:4px 6px;transition:all .2s ease;color:#6b7280;border-radius:4px;display:flex;align-items:center;justify-content:center}.refresh-btn:hover{background:#f3f4f6;color:#1f2937;border-color:#9ca3af}.refresh-icon{display:inline-block;width:18px;height:18px;object-fit:contain;transition:transform .3s ease}.refresh-btn:hover .refresh-icon{transform:rotate(180deg)}.menu-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:none;border-left:4px solid transparent;text-align:left;cursor:pointer;font-size:13px;color:#666;font-weight:400;transition:all .2s;position:relative;border-radius:4px}.menu-item:hover{background:#f5f5f5;color:#222}.menu-item.active{background:#e3f2fd;color:#1976d2;font-weight:500;border-left-color:#1976d2}.menu-item span{font-size:16px}.warning-badge{margin-left:auto;font-size:12px;font-weight:600;background:#ffebee;color:#c62828;padding:2px 6px;border-radius:3px}.menu-item.sub-menu{padding-left:12px;font-size:13px;color:#666;background:transparent}.menu-item.sub-menu:hover{color:#222;background:#f5f5f5}.menu-item.sub-menu.active{color:#1976d2;background:#e3f2fd;border-left-color:#1976d2;font-weight:500}.players-section{background:#fff;border-radius:12px;padding:0;box-shadow:0 4px 12px #0000001f;overflow:hidden}.players-section h3{margin:0;font-size:16px;font-weight:700;color:#222;background:linear-gradient(135deg,#f5f7fa,#f9fafb);padding:14px 16px;border-bottom:1px solid #e5e7eb;letter-spacing:-.3px}.system-info-content .player-card.large{position:relative;width:100%;max-width:340px;margin:0 12px 0 0;background:#fff;border-radius:24px;padding:0;box-shadow:0 2px 8px #0206170d;border:1px solid #e8ecf1;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden}.system-info-content .player-card.large:before{content:none;display:none}.system-info-content .player-card.large.online:before{background:transparent}.system-info-content .player-card.large.offline:before{background:transparent}.system-info-content .player-card.large .player-avatar{width:44px;height:44px;margin:20px 0 16px 60px;background-size:contain}.system-info-content .player-card.large .player-id{font-size:18px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-left:60px}.system-info-content .player-card.large .status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.system-info-content .player-card.large.online .status-dot{background:#10b981}.system-info-content .player-card.large.offline .status-dot{background:#ef4444}.system-info-content .player-card.large .player-card-footer{position:relative;width:100%;height:64px;background:#f0f4f8;border-bottom-left-radius:24px;border-bottom-right-radius:24px;display:flex;align-items:center;justify-content:center;margin-top:auto}.system-info-content .player-card.large .player-copy-btn{width:100%;height:100%;border-radius:0;background:transparent;border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.system-info-content .player-card.large .player-copy-btn:hover{background:#0000000d}.players-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px}.system-players-content .player-card,.players-grid .player-card{max-width:140px;min-height:100px;padding:10px 10px 6px 22px;border-radius:12px;border-left-width:6px;border-left-style:solid;border-left-color:transparent;box-shadow:none}.system-players-content .player-card .player-avatar,.players-grid .player-card .player-avatar{width:28px;height:28px;margin:4px 0 8px}.system-players-content .player-card .player-id,.players-grid .player-card .player-id{font-size:14px;font-weight:800}.system-players-content .player-card .player-card-footer,.players-grid .player-card .player-card-footer{height:40px;background:#1673c8;border-radius:8px;margin-top:8px}.players-grid .player-card.online{border-left-color:#10b981}.players-grid .player-card.offline{border-left-color:#ef4444}.player-card{background:#fff;border:1px solid #e6eaed;border-left:6px solid transparent;border-radius:14px;text-align:center;transition:all .15s ease;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:110px;position:relative;overflow:hidden}.player-card:hover{border-color:#d1e7ff;box-shadow:0 6px 18px #1053cc0f}.player-card.online:hover,.player-card.selected.online{border-color:#10b98138;box-shadow:0 6px 18px #10b9810f}.player-card.online{border-left-color:#10b981}.player-card.offline{border-left-color:#ef4444;opacity:.98}.player-avatar{width:40px;height:40px;background:transparent;border-radius:0;margin:4px auto 0;display:flex;align-items:center;justify-content:center;font-size:14px;position:relative}.player-avatar:before{content:"";display:block;width:36px;height:36px;background-image:url(/assets/player-icon-D6TF-ULs.svg);background-repeat:no-repeat;background-position:center;background-size:contain;color:#333}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:0;vertical-align:middle;border:2px solid #ffffff}.status-dot.online{background:#10b981}.status-dot.offline{background:#ef4444}.player-card .status-dot{box-shadow:none!important}.player-id{margin:8px 0 6px;padding:0 12px;font-size:18px;font-weight:800;display:flex;align-items:center;gap:8px;justify-content:center}.player-id-dot{width:12px;height:12px;display:inline-block;border-radius:2px;margin-right:6px;vertical-align:middle;box-shadow:none}.player-id-dot.online{background:#10b981}.player-id-dot.offline{background:#ef4444}.player-avatar:after{content:"";display:block;width:56%;height:1px;background:#e6eef6;position:absolute;left:50%;transform:translate(-50%);top:44px}.player-card-footer{display:flex;align-items:center;justify-content:center}.player-lock{background:transparent;border:none;color:#fff;font-size:18px;cursor:pointer}.player-mac{font-size:12px;color:#6b7280;margin-top:6px;text-transform:uppercase}.players-selected-row{display:flex;gap:12px;padding:8px 0 6px;align-items:flex-start}.player-card.mini,.system-players-content .player-card.mini{width:128px;max-width:128px;min-height:96px;padding:0;border-radius:10px;background:#fff;text-align:center;position:relative}.player-card.mini .player-avatar{width:28px;height:28px;margin-top:4px}.player-card.mini .player-id{font-size:13px;margin:6px 0;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-card.mini .player-id strong{font-size:13px;font-weight:700;letter-spacing:.6px}.player-card.mini .player-card-footer{height:28px;position:absolute;left:0;right:0;bottom:0;width:auto;box-sizing:border-box;padding:0;margin:0;display:flex;justify-content:center;align-items:center}.player-card.mini .player-mac{font-size:11px;color:#6b7280;margin-top:4px}.player-card.mini .player-lock{font-size:14px}.player-card.mini .player-lock{width:100%;height:28px;display:flex;align-items:center;justify-content:center;border-radius:0 0 8px 8px;background:#fff;box-shadow:0 4px 12px #0206170d;border:none}.player-card.mini:before{left:8px;top:8px;bottom:8px;width:6px;border-radius:6px}.player-card.mini .player-avatar:before,.player-card.mini .player-avatar:after{display:none!important}.player-card.mini .player-id-dot{display:none!important}.player-card.mini:after{display:none!important}.player-card.mini:before{left:12px!important;top:10px!important;bottom:18px!important;width:8px!important}.copy-btn{background:#e9eef6;border:none;cursor:pointer;font-size:12px;padding:6px;height:26px;display:block;width:calc(100% + 16px);margin:auto -8px 0;border-radius:0 0 6px 6px;transition:opacity .2s,background .2s;opacity:.95;font-weight:600;text-align:center}.copy-btn:hover{opacity:1;background:#dce5f0}.player-card:before{content:none;display:none}.player-card.online:before{background:transparent}.player-card.offline:before{background:transparent}.player-card-footer{width:100%;height:44px;background:#f1f5f9;display:flex;align-items:center;justify-content:center;position:absolute;bottom:0;left:0}.player-card .player-avatar{margin-top:18px}.player-card .player-id{margin-bottom:36px}.player-status{margin:0;font-size:11px;font-weight:600;color:#6b7280;letter-spacing:0}.player-actions{display:flex;gap:10px;padding:12px;background:transparent;border-top:none;justify-content:flex-start}.player-actions-inline{display:flex;gap:10px;padding:12px 16px;justify-content:flex-start}.action-btn{flex:1;max-width:140px;padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;text-transform:capitalize;letter-spacing:.3px}.system-info-header .action-btn.fault{flex:none;max-width:none;padding:6px 12px;font-size:12px}.player-actions .action-btn,.player-actions-inline .action-btn{flex:none!important;width:auto!important;max-width:120px!important;padding:6px 10px!important}.action-btn.retire{background:#ef4444;color:#fff;box-shadow:0 2px 4px #ef444433}.action-btn.retire:hover{background:#dc2626;box-shadow:0 4px 8px #dc26264d}.action-btn.add{background:#3b82f6;color:#fff;box-shadow:0 2px 4px #3b82f633}.action-btn.add:hover{background:#2563eb;box-shadow:0 4px 8px #2563eb4d}.action-btn.move{background:#10b981;color:#fff;box-shadow:0 2px 4px #10b98133}.action-btn.move:hover{background:#059669;box-shadow:0 4px 8px #0596694d}.action-btn.fault{background:#ef4444;color:#fff;box-shadow:0 2px 4px #ef444433}.action-btn.fault:hover{background:#dc2626;box-shadow:0 4px 8px #dc26264d}.specs-table{width:100%;border-collapse:collapse;background:transparent;font-size:13px;padding:16px 0}.specs-table tbody tr{border-bottom:1px solid #e5e7eb}.specs-table tbody tr:last-child{border-bottom:none}.specs-table td{padding:10px 0;font-size:13px}.specs-table td:first-child{color:#6b7280;font-weight:700;width:40%;letter-spacing:-.2px}.specs-table td:last-child{color:#1f2937;text-align:left;font-weight:500;padding-left:12px}.theme-dark .devices-container{background-color:var(--bg-color)!important}.theme-dark .device-section{background:var(--panel-bg)!important;box-shadow:0 4px 12px #0000004d!important}.theme-dark .device-section-header{background:#1e293b!important;border-bottom-color:#334155!important}.theme-dark .device-section-header h3{color:#e6eefc!important}.theme-dark .device-info-card{background:transparent!important;color:#dbeafe!important}.theme-dark .device-name{color:#e6eefc!important}.theme-dark .device-subtitle{color:#94b9d8!important}.theme-dark .screenshot-placeholder{background:#1e293b!important;color:#64748b!important}.theme-dark .stat-item label{color:#e6eefc!important}.theme-dark .stat-value{color:#94b9d8!important}.theme-dark .progress-bar{background:#1e293b!important}.theme-dark .device-details h4{color:#e6eefc!important}.theme-dark .detail-text{color:#94b9d8!important}.theme-dark .detail-link{color:#60a5fa!important}.theme-dark .edit-device-btn{background:var(--accent);color:var(--accent-contrast)}.theme-dark .edit-device-btn:hover{background:var(--accent-hover)}.theme-dark .control-header-card{background:var(--panel-bg)!important;color:#e6eefc!important;box-shadow:0 2px 8px #0000004d!important}.theme-dark .control-header-card h3{color:#e6eefc!important}.theme-dark .control-section-header{background:#0f1720!important;border-bottom-color:#ffffff0a!important;color:#cbd5e1!important}.theme-dark .control-section-header h3{color:#e6eefc!important}.theme-dark .control-section{background:var(--panel-bg)!important;box-shadow:0 4px 12px #0000004d!important}.theme-dark .control-menu-card{background:var(--panel-bg)!important;box-shadow:0 2px 8px #0000004d!important}.theme-dark .plus-btn{background:#60a5fa1a!important;color:#60a5fa!important}.theme-dark .system-divider{background:#334155!important}.theme-dark .system-specs-content h4{color:#e6eefc!important}.theme-dark .menu-item{color:#cbd5e1!important}.theme-dark .menu-item:hover{background:#1e293b!important;color:#e6eefc!important}.theme-dark .menu-item.active{background:#60a5fa1a!important;color:#60a5fa!important;border-left-color:#60a5fa!important}.theme-dark .warning-badge{background:#ef44441a!important;color:#fca5a5!important}.theme-dark .view-history-btn{background:#3b82f6}.theme-dark .view-history-btn:hover{background:#2563eb}.theme-dark .players-section{background:var(--panel-bg)!important;box-shadow:0 4px 12px #0000004d!important}.theme-dark .players-section h3{color:#e6eefc!important;background:#1e293b!important;border-bottom-color:#334155!important}.theme-dark .player-card{background:#1e293b!important;border-color:#334155!important;color:#dbeafe!important}.theme-dark .player-card:hover{border-color:#60a5fa!important;box-shadow:0 6px 18px #60a5fa1a!important}.theme-dark .player-id{color:#cbd5e1!important}.theme-dark .copy-btn{background:#60a5fa1a!important;color:#60a5fa!important;border:none}.theme-dark .copy-btn:hover{background:#60a5fa26!important}.theme-dark .player-status{color:#94b9d8!important}.theme-dark .player-actions{background:#1e293b!important;border-top-color:#334155!important}.theme-dark .specs-table{background:transparent!important;color:#dbeafe!important}.theme-dark .specs-table tbody tr{border-bottom-color:#334155!important}.theme-dark .specs-table td{color:#dbeafe!important;padding:10px 0!important}.theme-dark .specs-table td:first-child{color:#cbd5e1!important;font-weight:700!important}.theme-dark .specs-table td:last-child{color:#dbeafe!important;padding-left:12px!important}.theme-dark .system-players-content{background:transparent!important;padding:16px!important}.theme-dark .system-specs-content{background:transparent!important;padding:8px 0 0!important}@media (max-width: 900px){.devices-layout{grid-template-columns:1fr}.devices-right-panel{order:-1}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;padding:0;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-title{margin:0;padding:20px;font-size:20px;font-weight:700;color:#1f2937;border-bottom:1px solid #e5e7eb}.modal-body{padding:20px;display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#374151}.fault-select{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background-color:#fff;color:#1f2937;cursor:pointer;transition:border-color .2s,box-shadow .2s}.fault-select:hover{border-color:#9ca3af}.fault-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.fault-textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;color:#1f2937;transition:border-color .2s,box-shadow .2s}.fault-textarea::placeholder{color:#9ca3af}.fault-textarea:hover{border-color:#9ca3af}.fault-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-footer{padding:20px;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background-color:#f3f4f6;color:#374151}.btn-cancel:hover{background-color:#e5e7eb}.btn-report{background-color:#ef4444;color:#fff}.edit-select{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background-color:#fff;color:#1f2937;cursor:pointer;transition:border-color .2s,box-shadow .2s}.edit-select:hover{border-color:#9ca3af}.edit-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.edit-textarea{padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;color:#1f2937;transition:border-color .2s,box-shadow .2s}.edit-textarea::placeholder{color:#9ca3af}.edit-textarea:hover{border-color:#9ca3af}.edit-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-update{background-color:#0b59d6;color:#fff}.btn-update:hover{background-color:#0a4cb0}.btn-close{background-color:#f3f4f6;color:#374151}.btn-close:hover{background-color:#e5e7eb}.btn-report:hover{background-color:#dc2626}.btn-report:active{transform:scale(.98)}@media (max-width: 768px){.devices-container{padding:10px}.modal-content{width:90vw}.player-actions{flex-direction:column}.specs-table td:last-child{text-align:left}}.theme-dark .panel-outline,.theme-dark .panel,.theme-dark .card,.theme-dark .control-panel-content,.theme-dark .control-panel,.theme-dark .devices-right-panel .system-info-content,.theme-dark .devices-left-panel,.theme-dark .archived-camshots,.theme-dark .camshots-archive-header{background:#071023;border-color:#ffffff08;color:#dbeafe}.theme-dark .panel h3,.theme-dark .panel .panel-title,.theme-dark .devices-section-title{color:#dbeafe}.theme-dark .control-panel-content .btn:not(.btn-danger):not(.danger):not(.report-fault):not(.profile-logout-btn){background:#ffffff05;border:1px solid rgba(255,255,255,.03);color:#cbd5e1}.theme-dark .icon-btn{background:#ffffff05;border:1px solid rgba(255,255,255,.03);color:#cbd5e1}.theme-dark .report-fault,.theme-dark .btn-danger,.theme-dark .danger,.theme-dark .report-fault-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e72)!important;color:#fff!important;border:none!important;box-shadow:none!important}.theme-dark .breadcrumb-bar,.theme-dark .app-header{background:#071023;color:#dbeafe;border-bottom-color:#ffffff08}.players-grid .player-card{width:100%;max-width:220px;min-height:200px;border-radius:14px;padding:16px 16px 0 48px;display:block;text-align:center;box-shadow:0 6px 14px #0206170a;border:1px solid rgba(15,23,42,.04);background:#fff;cursor:pointer;transition:box-shadow .18s ease,transform .12s ease}.players-grid .player-card:before,.players-grid .player-card:after{content:none;display:none}.players-grid .player-card .player-avatar{margin-top:4px}.players-grid .player-card .player-id{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;font-size:24px;font-weight:700;margin:10px 0 6px;color:#24323a;letter-spacing:.6px}.players-grid .player-card .player-mac,.players-grid .player-card .player-id-dot{display:none}.players-grid .player-card .player-card-footer{position:absolute;left:12px;right:12px;bottom:12px;height:56px;display:block;padding:0}.players-grid .player-card .player-copy-btn{width:100%;height:100%;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 18px #0206170f;border:none;font-size:16px}.players-grid .player-card.online:after{background:#10b981}.players-grid .player-card.offline:after{background:#ef4444}.players-grid .player-card:hover{box-shadow:0 14px 30px #02061714;transform:translateY(-3px)}.players-grid .player-card.online:hover{box-shadow:0 14px 30px #10b98114;transform:translateY(-3px)}@media (max-width: 560px){.players-grid{grid-template-columns:1fr}.players-grid .player-card{max-width:100%;padding-left:40px}}.players-grid .player-card{position:relative;padding-bottom:80px}.players-grid .player-card .player-mac{display:none!important}.players-grid .player-card .player-card-footer{position:absolute!important;left:12px!important;right:12px!important;bottom:12px!important;height:56px!important;padding:0!important;display:block!important}.players-grid .player-card .player-copy-btn{width:100%!important;height:100%!important;border-radius:8px!important;display:flex!important;align-items:center!important;justify-content:center!important}.theme-dark .player-card-status.online{background:#10b981!important}.theme-dark .player-card-status.offline{background:#ef4444!important}.theme-dark .player-id-dot.online{background:#10b981!important}.theme-dark .player-id-dot.offline{background:#ef4444!important}.theme-dark .player-card.mini:before{background:#10b981!important}.theme-dark .player-card.mini.offline:before{background:#ef4444!important}.theme-dark .players-grid .player-card.online:after{background:#10b981!important}.theme-dark .players-grid .player-card.offline:after{background:#ef4444!important}.theme-dark .player-card-status.online:before{background:#10b98138!important;box-shadow:0 0 8px #10b9812e!important}.theme-dark .player-card-status.offline:before{background:#ef444424!important;box-shadow:0 0 8px #ef44441f!important}.theme-dark .players-grid .player-card.online:after{box-shadow:0 0 12px #10b9812e!important}.theme-dark .players-grid .player-card.offline:after{box-shadow:0 0 12px #ef444424!important}.theme-dark .player-card.mini:before{box-shadow:0 0 10px #10b9811f!important}.players-panel .players-empty-state{border:1px dashed #d1d5db;border-radius:10px;padding:14px;color:#6b7280;font-size:14px;background:#f8fafc}.players-panel>h4{margin:0 0 10px}.players-panel .players-grid{grid-template-columns:repeat(auto-fill,minmax(180px,180px));justify-content:flex-start;gap:12px;padding:8px 0}.players-panel .players-grid .player-card{width:180px;max-width:180px;min-height:176px;padding:10px;border-left-width:4px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;overflow:hidden}.players-panel .players-grid .player-card .player-avatar{width:100%;margin-top:0;display:flex;align-items:center;justify-content:center}.players-panel .players-grid .player-card .player-avatar:before{display:none!important}.players-panel .players-grid .player-card .player-avatar:after{display:none!important;content:none!important}.players-panel .players-grid .player-card .player-avatar-svg{width:30px;height:22px;object-fit:contain;display:block}.players-panel .players-grid .player-card .player-id{font-size:12px;margin:10px 0 8px;padding:0;line-height:1.2;display:flex;align-items:center;justify-content:center;gap:8px;width:100%;text-align:center}.players-panel .players-grid .player-card .player-id strong{display:block;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.players-panel .players-grid .player-card .player-id-dot{display:inline-block!important}.players-panel .players-grid .player-card .player-mac{display:block!important;font-size:11px;color:#64748b;margin:0}.players-panel .players-grid .player-card .player-card-footer{position:static!important;left:auto!important;right:auto!important;bottom:auto!important;width:100%!important;height:40px!important;margin-top:auto!important;border-radius:8px!important;background:transparent!important;padding:0!important}.players-panel .players-grid .player-card .player-copy-btn{font-size:12px;font-weight:700;width:100%;height:100%;border:1px solid #dbeafe;background:#eff6ff;color:#1d4ed8;box-shadow:none;border-radius:8px}.players-panel .players-grid .player-card.selected{border-color:#60a5fa;box-shadow:0 10px 22px #3b82f61f}.players-panel .player-card-status-chip-wrap{width:100%;display:flex;justify-content:flex-end;margin-bottom:4px}.players-panel .player-card-status-chip{font-size:8px;font-weight:700;padding:2px 6px;border-radius:999px}.players-panel .player-card-status-chip.online{background:#dcfce7;color:#166534}.players-panel .player-card-status-chip.offline{background:#fee2e2;color:#991b1b}.players-panel .players-selected-row{padding:4px 0 2px}.players-panel .player-selected-summary{width:100%;max-width:180px;min-height:176px;border:1px solid #dbeafe;border-radius:10px;padding:12px 10px 42px;display:flex;flex-direction:column;align-items:center;justify-content:center}.players-panel .player-selected-summary-icon{display:flex;justify-content:center;align-items:center;margin:2px 0 6px}.players-panel .player-selected-summary-icon svg{display:block}.players-panel .player-selected-summary .player-card-footer{left:8px;right:8px;bottom:8px;height:30px}.players-panel .player-selected-summary .player-lock{height:100%;border-radius:8px;font-size:12px;font-weight:700;background:#eff6ff;color:#1d4ed8}.players-panel .player-selected-summary-head{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;width:100%;text-align:center}.players-panel .player-selected-summary-sub{margin-top:6px;color:#475569;font-size:12px;font-family:Courier New,monospace}.players-panel .player-mac-card{background:#f8fbff;border:1px solid #dbeafe;box-shadow:none}.players-panel .mac-card-header{display:flex;align-items:center;justify-content:space-between;color:#0f172a;text-transform:none;font-size:13px;margin-bottom:10px}.players-panel .mac-card-status{font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px}.players-panel .mac-card-status.online{background:#dcfce7;color:#166534}.players-panel .mac-card-status.offline{background:#fee2e2;color:#991b1b}.players-panel .mac-card-hint{margin-top:8px;font-size:12px;color:#64748b}.players-panel .player-actions button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 980px){.players-panel .players-grid{grid-template-columns:repeat(auto-fill,minmax(180px,180px))}}@media (max-width: 640px){.players-panel .players-grid{grid-template-columns:1fr}.players-panel .players-grid .player-card{width:100%;max-width:100%}}.theme-dark .players-panel .players-empty-state,.theme-dark .players-panel .player-mac-card,.theme-dark .players-panel .player-selected-summary{background:#071023;border-color:#ffffff14;color:#cbd5e1}.theme-dark .players-panel .players-grid .player-card{background:#1e2d46;border-color:#60a5fa47}.theme-dark .players-panel .players-grid .player-card .player-id{color:#f1f5f9}.theme-dark .players-panel .mac-card-header,.theme-dark .players-panel .player-selected-summary-sub,.theme-dark .players-panel .player-mac,.theme-dark .players-panel .mac-card-hint{color:#94a3b8}.theme-dark .players-panel .players-grid .player-card .player-copy-btn,.theme-dark .players-panel .player-selected-summary .player-lock{background:#2563eb38;border-color:#60a5fa59;color:#dbeafe}.unit-details-layout{display:flex;flex-direction:column;gap:16px}.unit-details-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;border:1px solid #e5e7eb;border-radius:12px;background:#f8fafc}.unit-action-group{display:flex;align-items:center;gap:8px}.unit-action-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#1f2937;font-size:13px;font-weight:600}.unit-action-btn:hover{background:#f3f4f6}.unit-toolbar-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.unit-select{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff}.unit-select select{border:none;outline:none;background:transparent;font-size:13px;color:#1f2937}.unit-select-icon{color:#6b7280}.unit-primary-tabs{display:inline-flex;align-items:center;gap:6px;padding:4px;background:#eef2f7;border-radius:10px}.unit-primary-tabs button{border:none;background:transparent;padding:8px 12px;border-radius:8px;font-size:13px;color:#6b7280;font-weight:600}.unit-primary-tabs button.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0000000f}.unit-details-body{display:grid;grid-template-columns:320px 1fr;gap:16px;width:100%}.unit-details-left,.unit-details-right{display:flex;flex-direction:column;gap:16px}.unit-panel{border:1px solid #e5e7eb;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 6px 14px #0f172a0f}.unit-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #eef2f7;background:#f9fafb}.unit-panel-title{font-weight:700;font-size:13px;color:#1f2937;text-transform:uppercase;letter-spacing:.04em}.unit-panel-actions{display:flex;align-items:center;gap:8px}.pill-btn{border:1px solid #e5e7eb;background:#fff;color:#1f2937;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600}.unit-panel-body{padding:14px 16px}.unit-media-card{width:100%;border-radius:12px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.unit-media-card img{width:100%;height:auto;display:block}.unit-media-card.empty{min-height:180px;flex-direction:column;gap:8px;color:#94a3b8;font-weight:600}.unit-media-meta{margin-top:10px;font-size:12px;color:#94a3b8;text-align:center}.unit-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 16px}.unit-detail-label{font-size:11px;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;margin-bottom:6px}.unit-detail-value{font-size:13px;color:#1f2937;font-weight:600}.unit-panel-title-row{display:flex;align-items:center;gap:12px}.unit-icon-chip{width:36px;height:36px;border-radius:12px;background:#e6f6f1;color:#0f766e;display:inline-flex;align-items:center;justify-content:center}.unit-panel-heading{font-size:16px;font-weight:700;color:#1f2937}.unit-panel-subtitle{font-size:12px;color:#94a3b8;margin-top:2px}.unit-subtabs{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:10px 16px;border-bottom:1px solid #eef2f7;background:#fff}.unit-subtabs button{border:1px solid #e5e7eb;background:#f8fafc;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600;color:#64748b}.unit-subtabs button.active{background:#e6f6f1;border-color:#99f6e4;color:#0f766e}.unit-process-card{border:1px solid #eef2f7;border-radius:12px;overflow:hidden;background:#fff}.unit-process-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eef2f7}.unit-status-pill{padding:4px 10px;border-radius:999px;background:#f1f5f9;color:#64748b;font-size:12px;font-weight:600}.unit-process-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #eef2f7}.primary-btn{background:#0f766e;color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:12px;font-weight:700}.unit-process-tools{display:flex;align-items:center;gap:10px;font-size:12px;color:#94a3b8}.icon-btn{width:32px;height:32px;border-radius:8px;border:1px solid #e5e7eb;background:#fff;display:inline-flex;align-items:center;justify-content:center;color:#64748b}.unit-process-body{padding:24px 16px 30px}.unit-empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;color:#94a3b8;font-weight:600;text-align:center}.unit-empty-subtext{font-size:12px;color:#cbd5e1;font-weight:500}.switch{position:relative;display:inline-block;width:34px;height:18px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#e2e8f0;transition:.2s;border-radius:999px}.switch .slider:before{position:absolute;content:"";height:14px;width:14px;left:2px;top:2px;background-color:#fff;transition:.2s;border-radius:50%}.switch input:checked+.slider{background-color:#0f766e}.switch input:checked+.slider:before{transform:translate(16px)}@media (max-width: 1200px){.unit-details-body{grid-template-columns:1fr}}.theme-dark .unit-details-topbar{background:#0f1720;border-color:#ffffff0f}.theme-dark .unit-panel{background:#0b1220;border-color:#ffffff14;box-shadow:none}.theme-dark .unit-panel-header{background:#0f1720;border-color:#ffffff0f}.theme-dark .unit-panel-title,.theme-dark .unit-panel-heading{color:#e2e8f0}.theme-dark .unit-panel-subtitle,.theme-dark .unit-detail-label,.theme-dark .unit-media-meta,.theme-dark .unit-empty-state{color:#94a3b8}.theme-dark .unit-detail-value{color:#e2e8f0}.theme-dark .unit-subtabs{background:#0b1220;border-color:#ffffff0f}.theme-dark .unit-subtabs button{background:#0f1720;border-color:#ffffff14;color:#94a3b8}.theme-dark .unit-subtabs button.active{background:#0e749033;border-color:#0e749059;color:#e2e8f0}.jobs-page{margin-left:0;margin-right:0;padding:2rem;width:100%}.jobs-page h1{color:#2c3e50;margin-bottom:1.5rem}.jobs-page .btn{margin-bottom:1.5rem}.jobs-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.job-card{background:var(--panel-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.job-card h3{margin-top:0;color:#2c3e50}.job-card .status{font-weight:600;margin:.5rem 0}.status.pending{color:#ff9800}.status.running{color:#4caf50}.jobs-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:1rem}.jobs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.jobs-column{background:transparent}.job-card{background:var(--panel-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:.75rem 1rem;box-shadow:0 4px 12px #0000000f;margin-bottom:.75rem}.job-card-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.job-card h4,.job-card-header h4{margin:0;font-size:1rem}.job-card .meta{font-size:.85rem;color:#6b7280;margin-top:6px}.job-card .notes{margin-top:8px;font-size:.9rem;color:#374151}.status{font-weight:700;padding:4px 8px;border-radius:6px;font-size:.75rem}.status.running{background:#48bb781f;color:#2e7d32}.status.done{background:#10b9810f;color:#0b8450}.status.pending{background:#ff980014;color:#a04a00}.status.upcoming{background:#0b59d60f;color:#0b59d6}.empty{color:#9aa3b2;padding:.5rem 0}.jobs-history{margin-top:1.25rem}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{padding:10px;background:var(--panel-bg, #ffffff);border-radius:6px;border:1px solid var(--border-color, #e0e0e0)}.history-title{font-weight:600}.history-notes{margin-top:6px;color:#6b7280}@media (max-width: 1000px){.jobs-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.jobs-grid{grid-template-columns:1fr}}.theme-dark .jobs-page{background:var(--bg-color)!important}.theme-dark .jobs-page h1{color:#e6eefc!important}.theme-dark .job-card{background:var(--panel-bg)!important;color:#dbeafe!important}.theme-dark .job-card h3{color:#e6eefc!important}.theme-dark .job-card .status{color:#dbeafe!important}.theme-dark .status.pending{color:#ffd59e!important}.theme-dark .status.running{color:#9be7c1!important}.tickets-page{margin-left:0;margin-right:0;padding:2rem;width:100%}.tickets-page h1{color:#2c3e50;margin-bottom:1.5rem}.tickets-page .btn{margin-bottom:1.5rem}.priority{font-weight:600;padding:4px 8px;border-radius:4px}.priority.high{background:#ffebee;color:#c62828}.priority.medium{background:#fff3e0;color:#e65100}.priority.low{background:#e8f5e9;color:#2e7d32}.badge{font-weight:600;padding:4px 8px;border-radius:4px;display:inline-block}.badge.open{background:#e3f2fd;color:#1565c0}.badge.closed{background:#f3e5f5;color:#6a1b9a}.badge.in-progress{background:#fff3e0;color:#e65100}.no-tickets-message{padding:40px 20px;text-align:center;background-color:#f5f5f5;border-radius:8px;color:#666;font-size:16px}.admin-page{margin-left:0;margin-right:0;padding:2rem;width:100%}.admin-page h1{color:#2c3e50;margin-bottom:2rem}.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.admin-section{background:var(--panel-bg, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.admin-section h3{margin-top:0;color:#2c3e50}.admin-section .btn{margin-top:1rem}.theme-dark .admin-page{background:var(--bg-color)!important}.theme-dark .admin-page h1{color:#e6eefc!important}.theme-dark .admin-section{background:var(--panel-bg)!important;color:#dbeafe!important}.theme-dark .admin-section h3{color:#e6eefc!important}.inventory-page{margin-left:0;margin-right:0;padding:2rem;width:100%}.inventory-page h1{color:#2c3e50;margin-bottom:1.5rem}.theme-dark .inventory-page{background:var(--bg-color)!important}.theme-dark .inventory-page h1{color:#e6eefc!important}.theme-dark [class*=inventory]{color:#dbeafe!important}.theme-dark .inventory-page table{background:var(--panel-bg)!important}.theme-dark .inventory-page tbody tr{background:var(--panel-bg)!important;color:#dbeafe!important}.theme-dark .inventory-page thead{background:var(--panel-bg)!important}.theme-dark .inventory-page th,.theme-dark .inventory-page td{color:#dbeafe!important}.inventory-page .btn{margin-bottom:1.5rem}.logs-page{margin-left:0;margin-right:0;padding:2rem;width:100%}.logs-page h1{color:#2c3e50;margin-bottom:1.5rem}.filters{margin-bottom:1.5rem;display:flex;gap:1rem}.select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.log-level{font-weight:600;padding:4px 8px;border-radius:4px;font-size:.85rem}.log-level.info{background:#e3f2fd;color:#1976d2}.log-level.warn{background:#fff3e0;color:#f57c00}.log-level.error{background:#ffebee;color:#c62828}.theme-dark .logs-page{background:var(--bg-color)!important}.theme-dark .logs-page h1{color:#e6eefc!important}.theme-dark .logs-page table,.theme-dark .logs-page .table{background:#060a12e6!important;box-shadow:0 6px 24px #0009!important;border-radius:10px;overflow:hidden}.theme-dark .logs-page thead{background:#0b1220f2!important;border-bottom:1px solid rgba(255,255,255,.04)!important}.theme-dark .logs-page th{color:#dbeafe!important}.theme-dark .logs-page tbody tr{background:transparent!important;color:#dbeafe!important}.theme-dark .logs-page tbody tr:hover{background:#ffffff05!important}.theme-dark .logs-page td{color:#dbeafe!important}.theme-dark .select{background:#0b1220e6!important;color:#dbeafe!important;border-color:var(--border-color)!important}.admin-page{display:flex;flex-direction:column;gap:1.25rem}.admin-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.admin-header h2{margin:0 0 .25rem;font-size:1.5rem;font-weight:700}.admin-header p{margin:0;color:#64748b}.admin-card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:1rem 1.25rem}.admin-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.admin-card-header h3{margin:0;font-size:1rem;font-weight:700}.admin-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.admin-actions input,.admin-actions select{height:36px}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.6rem;padding-top:.5rem}.permission-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid #e5e7eb;border-radius:10px;background:#f8fafc}.theme-dark .permission-item{background:#1b1e24!important;border-color:#ffffff14!important}.matrix-wrap{overflow-x:auto}.matrix-table th,.matrix-table td{text-align:center}.matrix-table th:first-child,.matrix-table td:first-child{text-align:left;min-width:220px}.admin-empty{padding:1rem 0;color:#6b7280}.admin-error{padding:1rem 0;color:#ef4444;font-weight:600}.admin-table{width:100%}.admin-table th,.admin-table td{padding:.75rem .4rem;border-bottom:1px solid #e5e7eb}.link-btn{background:transparent;border:none;color:#0b5ed7;cursor:pointer;font-weight:600}.row-actions{display:inline-flex;gap:.5rem}.link-btn.danger{color:#ef4444}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;justify-content:flex-end;z-index:200}.drawer{width:420px;height:100%;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column}.drawer-header{padding:1rem 1.25rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.drawer-header h3{margin:0 0 .25rem}.drawer-header p{margin:0;color:#64748b}.role-usage-badges{display:inline-flex;gap:.5rem;margin-top:.5rem}.drawer-close{border:1px solid #e5e7eb;border-radius:8px;background:#f8fafc;padding:4px 8px}.drawer-body{padding:1rem 1.25rem;overflow:auto;display:flex;flex-direction:column;gap:1rem}.drawer-form{display:grid;gap:.5rem}.drawer-footer{padding:1rem 1.25rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.5rem}.theme-dark .drawer{background:#1e1f23!important;border-color:#ffffff14!important}.theme-dark .drawer-header,.theme-dark .drawer-footer{border-color:#ffffff14!important}.status-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;background:#e8f1ff;color:#0b5ed7}.status-chip.active{background:#e6f6f8;color:#0f766e}.status-chip.disabled{background:#f3f4f6;color:#6b7280}.admin-pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;color:#64748b}.admin-pagination-actions{display:inline-flex;gap:.5rem}.audit-details{display:flex;align-items:center;gap:.5rem}.audit-details code{display:inline-block;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.diff-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:220}.diff-modal{width:min(900px,90vw);background:#fff;border-radius:12px;border:1px solid #e5e7eb;box-shadow:0 20px 50px #0003}.diff-modal-header{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.diff-modal-body{padding:1rem;display:grid;grid-template-columns:1fr 1fr;gap:1rem}.diff-modal-body pre{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem;max-height:360px;overflow:auto}.diff-title{font-weight:700;margin-bottom:.5rem}.theme-dark .diff-modal{background:#1e1f23!important;border-color:#ffffff14!important}.theme-dark .diff-modal-header{border-color:#ffffff14!important}.theme-dark .diff-modal-body pre{background:#ffffff0a!important;border-color:#ffffff14!important}.theme-dark .status-chip.disabled{background:#94a3b833!important;color:#cbd5f5!important}.theme-dark .admin-card{background:#1e1f23!important;border-color:#ffffff14!important}.theme-dark .admin-header p{color:#94a3b8!important}.theme-dark .admin-table th,.theme-dark .admin-table td{border-color:#ffffff14!important}.theme-dark .link-btn{color:#7ab6ff!important}.theme-dark .status-chip{background:#0b5ed733!important;color:#cfe2ff!important}.admin-hero{display:flex;align-items:stretch;justify-content:space-between;gap:1rem;flex-wrap:wrap}.hero-card{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1px solid #e5e7eb;border-radius:16px;flex:1 1 420px}.hero-card h2{margin:0 0 .25rem;font-size:1.4rem}.hero-card p{margin:0;color:#64748b}.hero-icon{width:52px;height:52px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;color:#0f172a;background:#e0f2fe}.hero-icon.blue{background:#dbeafe;color:#1d4ed8}.hero-icon.orange{background:#ffedd5;color:#c2410c}.hero-icon.purple{background:#ede9fe;color:#6d28d9}.hero-icon.red{background:#fee2e2;color:#b91c1c}.hero-icon.indigo{background:#e0e7ff;color:#3730a3}.hero-icon.yellow{background:#fef9c3;color:#a16207}.hero-stats{display:grid;grid-auto-flow:column;gap:.75rem;align-items:stretch}.hero-stats .stat{min-width:120px;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:.75rem 1rem;text-align:right}.hero-stats .stat strong{display:block;font-size:1.1rem}.hero-stats .stat span{color:#64748b;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.filter-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.filter-tabs{display:inline-flex;gap:6px;background:#f3f4f6;padding:4px;border-radius:999px}.filter-tabs .tab{border:none;background:transparent;padding:6px 12px;border-radius:999px;font-weight:600;color:#64748b;cursor:pointer;display:inline-flex;align-items:center;gap:6px}.filter-tabs .tab span{background:#e2e8f0;border-radius:999px;padding:2px 6px;font-size:11px;color:#475569}.filter-tabs .tab.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a14}.filter-actions{display:inline-flex;align-items:center;gap:.5rem;flex-wrap:wrap}.filter-actions input,.filter-actions select{height:36px;padding:0 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff}.card-list{display:flex;flex-direction:column;gap:.75rem}.list-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:1rem}.list-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.list-title{display:flex;align-items:center;gap:.75rem}.avatar{width:40px;height:40px;border-radius:12px;background:#f1f5f9;color:#0f172a;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.list-card-body{margin-top:.75rem;border-top:1px solid #f1f5f9;padding-top:.75rem}.meta-row{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;color:#475569;font-size:.85rem}.list-actions{display:inline-flex;align-items:center;gap:.5rem;position:relative}.status-pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.72rem;font-weight:700;background:#e2e8f0;color:#475569}.status-pill.success{background:#dcfce7;color:#166534}.status-pill.danger{background:#fee2e2;color:#b91c1c}.status-pill.warning{background:#fef3c7;color:#92400e}.pill{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:.7rem;font-weight:700}.icon-btn{width:32px;height:32px;border-radius:10px;border:1px solid #e5e7eb;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 12px 28px #0f172a1f;min-width:160px;z-index:10;overflow:hidden}.menu button{width:100%;text-align:left;background:transparent;border:none;padding:10px 12px;font-weight:600;color:#334155;cursor:pointer}.menu button:hover{background:#f8fafc}.menu button.danger{color:#b91c1c}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:flex;align-items:center;justify-content:center;z-index:200}.modal{width:min(560px,92vw);background:#fff;border-radius:16px;box-shadow:0 24px 60px #0f172a33;border:1px solid #e5e7eb}.modal-header,.modal-footer{padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5e7eb}.modal-footer{border-top:1px solid #e5e7eb;border-bottom:none}.modal-body{padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.modal-tabs{display:inline-flex;gap:.5rem;background:#f3f4f6;border-radius:12px;padding:4px}.modal-tabs .tab{padding:6px 12px;border-radius:10px;background:transparent;border:none;font-weight:600;color:#64748b}.modal-tabs .tab.active{background:#fff;color:#0f172a}.toggle-row{display:flex;align-items:center;justify-content:space-between;background:#f8fafc;border-radius:12px;padding:.75rem 1rem;border:1px solid #e5e7eb}.info-callout{background:#e0f2fe;color:#0f172a;padding:.75rem 1rem;border-radius:12px;font-weight:600}.field-label{font-size:.85rem;color:#475569;font-weight:600}.event-cell{display:flex;align-items:center;gap:.75rem}.event-dot{width:12px;height:12px;border-radius:999px;background:#e2e8f0}.event-dot.success{background:#22c55e}.event-dot.danger{background:#ef4444}.event-dot.warning{background:#f59e0b}.event-title{font-weight:700}.theme-dark .hero-card,.theme-dark .hero-stats .stat,.theme-dark .list-card,.theme-dark .admin-card,.theme-dark .modal{background:#0f172a!important;border-color:#94a3b833!important;color:#e2e8f0!important}.theme-dark .hero-card p,.theme-dark .muted,.theme-dark .meta-row{color:#94a3b8!important}.theme-dark .filter-tabs{background:#94a3b81a!important}.theme-dark .filter-tabs .tab.active{background:#0f172ab3!important;color:#e2e8f0!important}.theme-dark .filter-actions input,.theme-dark .filter-actions select{background:#0b1220!important;border-color:#94a3b833!important;color:#e2e8f0!important}.theme-dark .menu{background:#0b1220!important;border-color:#94a3b833!important}.theme-dark .menu button{color:#e2e8f0!important}.theme-dark .toggle-row{background:#94a3b814!important}.theme-dark .info-callout{background:#3b82f62e!important;color:#e2e8f0!important}@media (max-width: 960px){.hero-stats{grid-auto-flow:row}.filter-actions{width:100%}}.muted{color:#64748b;font-size:.85rem}.tab-icon{width:22px;height:22px;border-radius:8px;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;font-size:12px}.count-badge{background:#e2e8f0;color:#475569;border-radius:999px;padding:2px 6px;font-size:11px}.input-icon{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:0 10px;height:36px}.input-icon .icon{font-size:12px;color:#64748b}.input-icon input{border:none;outline:none;height:32px}.meta-item{display:inline-flex;align-items:center;gap:6px}.hero-icon svg{width:26px;height:26px}.modal .field-label{margin-bottom:6px;display:block}.theme-dark .input-icon{background:#0b1220!important;border-color:#94a3b833!important}.theme-dark .count-badge{background:#94a3b833!important;color:#cbd5e1!important}.btn{height:36px;padding:0 12px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;color:#334155;font-weight:600;display:inline-flex;align-items:center;gap:8px;cursor:pointer}.btn svg{width:14px;height:14px}.btn-primary{background:#0f766e;border-color:#0f766e;color:#fff}.btn-primary:hover{background:#0b5f58}.btn-outline{background:#e6f6f1;border-color:#b6e4d7;color:#0f766e}.btn-plus{font-weight:900;margin-right:4px}.page-menu{position:relative}.tab-icon{width:22px;height:22px;border-radius:8px;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center}.tab-icon svg{width:14px;height:14px;fill:currentColor;stroke:currentColor}.tab.active .tab-icon{background:#dbeafe;color:#1d4ed8}.count-badge{background:#e2e8f0;color:#475569;border-radius:999px;padding:1px 6px;font-size:11px}.input-icon{gap:8px;padding:0 12px}.input-icon .icon svg{width:14px;height:14px;stroke:currentColor;fill:none}.list-card{border-radius:14px;box-shadow:0 6px 14px #0f172a0a}.list-card-body{background:#f8fafc}.status-pill{letter-spacing:.05em;font-size:.68rem}.sso-label{font-size:.7rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.08em}.meta-item svg{width:14px;height:14px;stroke:currentColor;fill:none}.meta-item svg path,.meta-item svg rect,.meta-item svg circle,.meta-item svg ellipse{stroke:currentColor}.bulk-select{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:#475569}.hero-stats .stat{min-width:110px}.avatar.icon-blue{background:#dbeafe;color:#1d4ed8}.avatar.icon-orange{background:#ffedd5;color:#c2410c}.avatar.icon-purple{background:#ede9fe;color:#6d28d9}.avatar.icon-yellow{background:#fef9c3;color:#a16207}.avatar.icon-indigo{background:#e0e7ff;color:#3730a3}.theme-dark .btn{background:#0b1220!important;border-color:#94a3b833!important;color:#e2e8f0!important}.theme-dark .btn-primary{background:#0f766e!important;border-color:#0f766e!important}.theme-dark .btn-outline{background:#0e749033!important;border-color:#0e749059!important;color:#e2e8f0!important}.theme-dark .list-card-body{background:#ffffff0a!important}.icon-btn svg{width:14px;height:14px;fill:currentColor;stroke:currentColor}.filter-tabs .tab span{background:none;padding:0}.filter-tabs .tab .count-badge{background:#e2e8f0;padding:1px 6px}.filter-tabs .tab .tab-icon{background:#e2e8f0}.section-header{display:flex;align-items:center;gap:12px;margin-top:8px;color:#334155}.section-icon{width:34px;height:34px;border-radius:10px;background:#e2e8f0;display:inline-flex;align-items:center;justify-content:center;color:#64748b}.section-icon svg{width:16px;height:16px;stroke:currentColor;fill:none}.section-title{font-weight:700}.section-subtitle{font-size:12px;color:#94a3b8}.theme-dark .section-icon{background:#94a3b833;color:#cbd5e1}.modal input,.modal select{height:38px;border:1px solid #e5e7eb;border-radius:10px;padding:0 12px;background:#fff}.admin-table thead th{color:#64748b;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em}.admin-table tbody tr:hover{background:#f8fafc}.theme-dark .modal input,.theme-dark .modal select{background:#0b1220!important;border-color:#94a3b833!important;color:#e2e8f0!important}.admin-page{gap:16px}.admin-hero{gap:14px}.hero-card{padding:14px 16px;border-radius:14px;border-color:#e6e8ef;background:#fff}.hero-card h2{font-size:20px;line-height:24px;letter-spacing:-.01em}.hero-card p{font-size:13px;color:#6b7280}.hero-icon{width:48px;height:48px;border-radius:12px}.hero-stats .stat{min-width:96px;padding:10px 12px;border-radius:12px;border-color:#e6e8ef}.hero-stats .stat strong{font-size:16px}.hero-stats .stat span{font-size:10px;letter-spacing:.08em}.filter-row{gap:12px}.filter-tabs{background:#eef0f4;padding:4px;border-radius:999px;gap:4px}.filter-tabs .tab{padding:6px 10px;font-size:12.5px;color:#6b7280}.filter-tabs .tab.active{background:#fff;color:#111827}.filter-tabs .tab .tab-icon{width:20px;height:20px;border-radius:7px;background:#e8ecf3}.filter-actions input,.filter-actions select,.input-icon{height:34px;border-radius:9px;border-color:#e6e8ef}.btn{height:34px;padding:0 10px;border-radius:9px;font-size:12.5px}.btn-primary{background:#0f9b7a;border-color:#0f9b7a}.btn-primary:hover{background:#0b8367}.btn-outline{background:#e6f6f1;border-color:#bfe8da;color:#0f766e}.card-list{gap:12px}.list-card{border-radius:14px;border-color:#e6e8ef;padding:14px 16px}.list-card-body{padding-top:10px;margin-top:10px;background:#f7f8fb}.list-title strong{font-size:14px}.muted{color:#7b8794;font-size:12.5px}.meta-row{font-size:12.5px;color:#5f6b7a;gap:12px}.status-pill{font-size:10.5px;padding:4px 8px}.admin-table th{font-size:10px;color:#8a94a6}.admin-table td{font-size:12.5px;color:#1f2937}.modal{border-radius:14px}.modal-header h3{font-size:16px}.modal-body{gap:10px}.modal input,.modal select{height:36px;border-radius:9px}.info-callout{font-size:12.5px}.theme-dark .hero-card,.theme-dark .hero-stats .stat,.theme-dark .list-card,.theme-dark .admin-card,.theme-dark .modal{border-color:#ffffff14!important}.theme-dark .list-card-body{background:#ffffff08!important}.theme-dark .filter-tabs{background:#ffffff0f!important}.filter-actions select{min-width:140px}.filter-actions .input-icon{min-width:200px}.filter-actions .btn-primary{padding:0 14px}.admin-hero{align-items:center}.hero-card{min-height:72px}.list-card-header{padding-bottom:2px}.list-card-body{border-top-color:#edf0f5}.status-pill.success{background:#dcfce7;color:#16a34a}.status-pill.danger{background:#fee2e2;color:#dc2626}.status-pill.warning{background:#fef3c7;color:#d97706}.page-menu .menu{min-width:180px}.modal{max-width:600px}.admin-table th{padding-top:10px;padding-bottom:10px}.admin-table td{padding-top:12px;padding-bottom:12px}.hero-card,.hero-stats .stat,.list-card,.admin-card{border-radius:12px}.hero-card{padding:12px 14px}.hero-icon{width:44px;height:44px;border-radius:12px}.list-card{padding:12px 14px}.list-card-body{margin-top:8px;padding-top:8px}.avatar{width:36px;height:36px;border-radius:10px;font-size:12px}.filter-tabs{padding:3px}.filter-tabs .tab{padding:5px 10px;font-size:12px}.filter-actions input,.filter-actions select,.input-icon,.btn{height:32px}.btn{font-size:12px}.modal{border-radius:12px}.modal-header,.modal-footer,.modal-body{padding:12px 14px}.hero-card,.hero-stats .stat,.list-card,.admin-card,.modal,.filter-tabs,.input-icon,.btn,.status-pill,.pill,.admin-table th,.admin-table td{border:none!important}.list-card-body{border-top:none!important}.filter-actions input,.filter-actions select,.modal input,.modal select{border:none!important}.admin-table tbody tr{border-bottom:1px solid #eef1f5}.login-container{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.login-content{display:flex;background:var(--panel-bg, white);border-radius:16px;box-shadow:0 20px 60px #0000001f;max-width:900px;width:100%;overflow:hidden}.login-left{flex:1;background:linear-gradient(135deg,#f5f7fa,#e9ecef);display:flex;align-items:center;justify-content:center;padding:60px 40px;min-height:500px}.login-illustration{position:relative;width:100%;height:100%;max-width:300px;max-height:300px}.circle-bg{width:260px;height:260px;background:var(--panel-bg, #f0f3f7);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;margin:0 auto}.laptop-icon{width:120px;height:100px;background:#36475c;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:60px;color:#fff;box-shadow:0 4px 16px #00000026}.decorative-shape{position:absolute;opacity:.6}.shape-1{width:12px;height:12px;background:#87ceeb;border-radius:50%;top:20px;left:-10px}.shape-2{width:10px;height:10px;background:#90ee90;clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);bottom:40px;left:10px}.shape-3{width:12px;height:12px;background:#87ceeb;border-radius:2px;top:50%;right:-15px;transform:rotate(45deg)}.login-right{flex:1;padding:80px 60px;display:flex;align-items:center;justify-content:center;min-height:500px}.login-form-wrapper{width:100%;max-width:320px}.login-title{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 40px;text-align:left}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{position:relative}.form-input{width:100%;padding:12px 16px 12px 42px;border:none;border-radius:28px;background:var(--panel-bg, #f0f2f5);font-size:14px;font-family:inherit;transition:all .3s ease;color:#333}.form-input::placeholder{color:#999}.form-input:focus{outline:none;background:#e8eaed;box-shadow:0 4px 12px #00000014}.form-input:disabled{opacity:.6;cursor:not-allowed}.input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none}.error-message{background:var(--panel-bg, #fff3cd);border:1px solid var(--border-color, #ffc107);color:var(--text-color, #856404);padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.error-message:before{content:"⚠️";font-size:16px}.login-button{width:100%;padding:14px 20px;background:#4caf50;color:#fff;border:none;border-radius:28px;font-size:14px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .3s ease;margin-top:10px}.login-button:hover:not(:disabled){background:#45a049;box-shadow:0 6px 20px #4caf504d;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-button.secondary{background:#0b5ed7;margin-top:12px}.login-button.secondary:hover:not(:disabled){background:#0a53c1;box-shadow:0 6px 20px #0b5ed74d}.login-footer{text-align:center;margin-top:24px}.forgot-link{color:#666;text-decoration:none;font-size:13px;transition:color .3s ease}.forgot-link:hover{color:#4caf50}.theme-dark .login-container{background:var(--bg-color)!important}.theme-dark .login-content,.theme-dark .login-right{background:var(--panel-bg)!important}.theme-dark .login-title{color:#e6eefc!important}.theme-dark .login-form label{color:#dbeafe!important}.theme-dark .form-input{background:var(--panel-bg)!important;color:#e6eefc!important}.theme-dark .form-input:focus{background:#ffffff0d!important}.theme-dark .error-message{background:var(--panel-bg)!important;color:#ffb3b3!important}@media (max-width: 768px){.login-content{flex-direction:column}.login-left{min-height:300px;padding:40px 20px}.login-right{min-height:auto;padding:40px 20px}.login-title{font-size:24px;margin-bottom:30px}.login-form-wrapper{max-width:100%}}.forgot-password-container{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:20px}.forgot-password-content{display:flex;background:var(--panel-bg, white);border-radius:16px;box-shadow:0 20px 60px #0000001f;max-width:900px;width:100%;overflow:hidden}.forgot-left{flex:1;background:linear-gradient(135deg,#f5f7fa,#e9ecef);display:flex;align-items:center;justify-content:center;padding:60px 40px;min-height:500px}.forgot-illustration{position:relative;width:100%;height:100%;max-width:300px;max-height:300px}.circle-bg-forgot{width:260px;height:260px;background:var(--panel-bg, #f0f3f7);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;margin:0 auto}.key-icon{width:120px;height:100px;background:#ff9800;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:60px;color:#fff;box-shadow:0 4px 16px #ff98004d}.decorative-shape-forgot{position:absolute;opacity:.6}.shape-1-forgot{width:12px;height:12px;background:#ffb74d;border-radius:50%;top:20px;left:-10px}.shape-2-forgot{width:10px;height:10px;background:#ffe082;clip-path:polygon(50% 0%,100% 38%,82% 100%,18% 100%,0% 38%);bottom:40px;left:10px}.shape-3-forgot{width:12px;height:12px;background:#ffb74d;border-radius:2px;top:50%;right:-15px;transform:rotate(45deg)}.forgot-right{flex:1;padding:80px 60px;display:flex;align-items:center;justify-content:center;min-height:500px}.forgot-form-wrapper{width:100%;max-width:320px}.forgot-title{font-size:28px;font-weight:700;color:#1a1a1a;margin:0 0 12px;text-align:left}.forgot-subtitle{font-size:14px;color:#666;margin:0 0 30px;line-height:1.5}.forgot-form{display:flex;flex-direction:column;gap:20px}.form-group-forgot{position:relative}.form-input-forgot{width:100%;padding:12px 16px 12px 42px;border:none;border-radius:28px;background:var(--panel-bg, #f0f2f5);font-size:14px;font-family:inherit;transition:all .3s ease;color:#333}.form-input-forgot::placeholder{color:#999}.form-input-forgot:focus{outline:none;background:#e8eaed;box-shadow:0 4px 12px #00000014}.form-input-forgot:disabled{opacity:.6;cursor:not-allowed}.input-icon-forgot{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:16px;pointer-events:none}.error-message-forgot{background:var(--panel-bg, #fff3cd);border:1px solid var(--border-color, #ffc107);color:var(--text-color, #856404);padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.error-message-forgot:before{content:"⚠️";font-size:16px}.reset-button{width:100%;padding:14px 20px;background:#ff9800;color:#fff;border:none;border-radius:28px;font-size:14px;font-weight:700;letter-spacing:1px;cursor:pointer;transition:all .3s ease;margin-top:10px}.reset-button:hover:not(:disabled){background:#f57c00;box-shadow:0 6px 20px #ff98004d;transform:translateY(-2px)}.reset-button:active:not(:disabled){transform:translateY(0)}.reset-button:disabled{opacity:.7;cursor:not-allowed}.success-message-forgot{background:var(--panel-bg, #d4edda);border:1px solid var(--border-color, #28a745);color:var(--text-color, #155724);padding:30px 20px;border-radius:12px;text-align:center;font-size:14px}.success-icon{font-size:48px;display:block;margin-bottom:16px}.success-message-forgot p{margin:8px 0;line-height:1.5}.success-redirect{font-size:12px;color:#5a7c6e;margin-top:12px;font-style:italic}.forgot-footer{text-align:center;margin-top:24px}.back-to-login{color:#666;text-decoration:none;font-size:13px;transition:color .3s ease;display:inline-flex;align-items:center;gap:4px}.back-to-login:hover{color:#ff9800}.theme-dark .forgot-password-container{background:var(--bg-color)!important}.theme-dark .forgot-password-content,.theme-dark .forgot-right{background:var(--panel-bg)!important}.theme-dark .forgot-title{color:#e6eefc!important}.theme-dark .forgot-subtitle,.theme-dark .forgot-form label{color:#dbeafe!important}.theme-dark .form-input-forgot{background:var(--panel-bg)!important;color:#e6eefc!important}.theme-dark .form-input-forgot:focus{background:#ffffff0d!important}.theme-dark .error-message-forgot{background:var(--panel-bg)!important;color:#ffb3b3!important}} @media (max-width: 768px){.forgot-password-content{flex-direction:column}.forgot-left{min-height:300px;padding:40px 20px}.forgot-right{min-height:auto;padding:40px 20px}.forgot-title{font-size:24px;margin-bottom:16px}.forgot-form-wrapper{max-width:100%}.forgot-subtitle{font-size:13px}}.player-container{padding:24px;max-width:1400px;margin:0 auto}.player-header{margin-bottom:32px;text-align:center}.player-header h1{font-size:2.5rem;margin:0 0 8px;color:#1f2937}.player-header .subtitle{color:#6b7280;font-size:1rem;margin:0}.player-controls{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}@media (min-width: 768px){.player-controls{flex-direction:row;justify-content:space-between;align-items:center}}.search-box{flex:1;min-width:250px}.search-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.control-buttons{display:flex;gap:12px;flex-wrap:wrap}.refresh-button{padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:background .2s}.refresh-button:hover{background:#2563eb}.view-mode-toggle{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:6px}.toggle-btn{padding:8px 14px;background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s;color:#6b7280}.toggle-btn.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.player-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;text-align:center;box-shadow:0 1px 3px #0000000d}.stat-label{display:block;font-size:.9rem;color:#6b7280;margin-bottom:8px}.stat-value{display:block;font-size:2rem;font-weight:700;color:#1f2937}.stat-value.online{color:#22c55e}.stat-value.offline{color:#ef4444}.loading,.empty-state{text-align:center;padding:60px 20px;color:#6b7280;font-size:1.1rem}.empty-subtext{margin-top:8px;font-size:.95rem;color:#9ca3af}.players-container{display:grid;gap:20px}.players-container.grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.player-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d;transition:all .2s}.player-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;display:flex;justify-content:space-between;align-items:center}.card-header h3{margin:0;font-size:1.1rem}.status-badge{font-size:1.5rem;opacity:.9}.card-content{padding:16px}.info-group{margin-bottom:16px}.info-group:last-child{margin-bottom:0}.info-group label{display:block;font-size:.8rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.mac-display{display:flex;align-items:center;gap:8px}.mac-value{flex:1;background:#f9fafb;padding:8px 12px;border-radius:6px;font-family:Courier New,monospace;font-size:.9rem;color:#1f2937;border:1px solid #e5e7eb;overflow-x:auto}.info-value{font-size:.95rem;color:#374151;padding:6px 0}.copy-btn{padding:6px 10px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.copy-btn:hover{background:#e5e7eb;border-color:#9ca3af}.copy-btn-sm{padding:4px 8px;background:transparent;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;font-size:.8rem;transition:all .2s}.copy-btn-sm:hover{background:#f3f4f6;border-color:#9ca3af}.players-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000d}.players-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.players-table th{padding:12px 16px;text-align:left;font-weight:600;color:#374151;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.players-table td{padding:12px 16px;border-bottom:1px solid #f3f4f6;font-size:.95rem;color:#374151}.players-table tbody tr:last-child td{border-bottom:none}.players-table tbody tr:hover{background:#f9fafb}.status-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.mac-code{background:#f9fafb;padding:4px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem;border:1px solid #e5e7eb}.status-online{color:#22c55e}.status-offline{color:#ef4444}@media (max-width: 768px){.player-container{padding:16px}.player-header h1{font-size:2rem}.players-container.grid{grid-template-columns:1fr}.players-table{font-size:.85rem}.players-table th,.players-table td{padding:10px 12px}}.page-wrap{padding:16px 20px 24px}.page-header{display:flex;align-items:center;gap:14px;background:#f6f7f9;border-radius:14px;padding:16px 18px;margin-bottom:14px}.header-icon{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-weight:700;color:#fff}.bg-teal{background:#0ea5a4}.header-text h2{margin:0;font-size:20px}.header-text p{margin:4px 0 0;color:#6b7280;font-size:13px}.card{background:#fff;border-radius:14px;padding:18px;box-shadow:0 1px #10182808}.empty-state{padding:24px;text-align:center;color:#6b7280}.empty-title{font-size:15px;font-weight:600;color:#111827}.empty-subtitle{font-size:13px;margin-top:6px}*{margin:0;padding:0;box-sizing:border-box}:root{--accent: #1976d2;--accent-hover: #155fa8;--accent-contrast: #ffffff}:root{--accent-light: #60a5fa;--accent-light-hover: #3b82f6;--success: #10b981;--success-light: #6ee7b7;--success-hover: #059669;--danger: #ef4444;--danger-light: #f87171;--danger-hover: #dc2626}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:1000;padding:12px}.modal-content{background:#fff;border-radius:10px;width:100%;max-width:520px;box-shadow:0 10px 30px #0000001f;overflow:hidden;padding:12px;box-sizing:border-box;max-height:calc(100vh - 48px);overflow-y:auto}.modal-title{margin:0 0 8px;font-size:1rem;font-weight:700}.modal-body .form-group{margin-bottom:8px}input,textarea,select,.edit-select,.text-input,.edit-textarea{padding:8px 10px;font-size:.95rem}.edit-textarea{min-height:72px;max-height:220px}.modal-footer{display:flex;gap:8px;justify-content:flex-end;padding-top:8px;padding-bottom:6px}.btn,.btn-close,.btn-update,.btn-cancel,.btn-create,.btn-report,.btn-confirm{padding:8px 12px;font-size:.95rem;border-radius:6px}.player-card{min-height:90px}.player-card-footer{height:40px}.players-grid .player-card .player-card-footer,.system-players-content .player-card .player-card-footer{height:36px}.player-card .player-id{margin-bottom:28px}.aspect-16-9{width:100%;aspect-ratio:16 / 9;overflow:hidden;display:block}.aspect-9-16{width:100%;aspect-ratio:9 / 16;overflow:hidden;display:block}.aspect-16-9>img,.aspect-16-9>video,.aspect-9-16>img,.aspect-9-16>video{width:100%;height:100%;object-fit:cover;display:block}.system-info-content .player-card.large .player-avatar{margin:12px 0 10px 56px;width:40px;height:40px}.system-info-content .player-card.large .player-id{margin-bottom:12px;padding-left:56px}.system-info-content .player-card.large .player-card-footer{height:52px}html{font-size:16px}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,SF Pro Text,SF Pro Display,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{color:#2c3e50;margin:1rem 0 .5rem}h1{font-size:2.5rem;font-weight:700}h2{font-size:2rem;font-weight:600}h3{font-size:1.5rem;font-weight:600}h4{font-size:1.25rem;font-weight:500}h5{font-size:1rem;font-weight:500}h6{font-size:.95rem;font-weight:500}p{margin:.5rem 0}a{color:#06c;text-decoration:none;transition:color .2s}a:hover{color:#0052a3}button,.btn{display:inline-block;padding:10px 16px;font-size:.95rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .2s;text-decoration:none;text-align:center}.btn-primary{background-color:var(--accent);color:var(--accent-contrast)}.btn-primary:hover{background-color:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 8px #155fa838}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#5a6268}.btn-sm{padding:6px 12px;font-size:.85rem}.btn:disabled{opacity:.6;cursor:not-allowed}input,textarea,select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #1976d214}label{display:block;margin-bottom:.5rem;font-weight:500}.form-group{margin-bottom:1.5rem}.table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 8px #0000001a;border-radius:8px;overflow:hidden}.table thead{background-color:#f8f9fa;border-bottom:2px solid #ddd}.table th{padding:12px 16px;text-align:left;font-weight:600;color:#2c3e50}.table td{padding:12px 16px;border-bottom:1px solid #eee}.table tbody tr:hover{background-color:#f8f9fa}.table tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:.85rem;font-weight:600}.badge.active{background-color:#d4edda;color:#155724}.badge.open{background-color:#d1ecf1;color:#0c5460}.badge.closed{background-color:#f8d7da;color:#721c24}.card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.card-header{padding:1rem;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.card-body{padding:1.5rem}.card-footer{padding:1rem;background:#f8f9fa;border-top:1px solid #e0e0e0}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.text-center{text-align:center}.text-right{text-align:right}.text-left{text-align:left}.text-muted{color:#6c757d}.text-success{color:#28a745}.text-danger{color:#dc3545}.text-warning{color:#ffc107}.text-info{color:#17a2b8}.d-flex{display:flex}.justify-content-between{justify-content:space-between}.align-items-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}@media (max-width: 768px){h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.table{font-size:.9rem}.table th,.table td{padding:8px 12px}}@media (max-width: 480px){h1{font-size:1.5rem}h2{font-size:1.25rem}button,.btn{width:100%}}
