:root{--bg-primary: #0F0F1A;--bg-secondary: #161625;--bg-surface: #1C1C30;--bg-surface-hover: #252538;--bg-surface-active: #2A2A42;--accent: #7C3AED;--accent-hover: #6D28D9;--accent-light: rgba(124, 58, 237, .15);--accent-glow: rgba(124, 58, 237, .3);--text-primary: #E0E0F0;--text-secondary: #C0C0DD;--text-muted: #8080A0;--text-dim: #606080;--status-success-fg: #3DBD7A;--status-success-bg: rgba(61, 189, 122, .12);--status-failed-fg: #E05252;--status-failed-bg: rgba(224, 82, 82, .12);--status-syncing-fg: #9B72E8;--status-syncing-bg: rgba(155, 114, 232, .12);--status-pending-fg: #4A90D9;--status-pending-bg: rgba(74, 144, 217, .12);--compliant-fg: #3DBD7A;--compliant-bg: rgba(61, 189, 122, .12);--noncompliant-fg: #E05252;--noncompliant-bg: rgba(224, 82, 82, .12);--border: rgba(128, 128, 180, .12);--border-strong: rgba(128, 128, 180, .2);--danger: #7F1D1D;--danger-hover: #991B1B;--danger-fg: #FCA5A5;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--transition: .15s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:14px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;max-width:1440px;width:100%;margin:0 auto;padding:0 24px 24px;min-height:0;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--bg-secondary);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.inactivity-banner{padding:10px 24px;background:#e0525226;color:var(--status-failed-fg);text-align:center;font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(224,82,82,.3);flex-shrink:0;animation:bannerPulse 2s ease-in-out infinite}@keyframes bannerPulse{0%,to{opacity:1}50%{opacity:.7}}.readonly-banner{padding:10px 24px;background:#4a90d91f;color:var(--status-pending-fg);text-align:center;font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(74,144,217,.2);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.header-dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.header-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.header-badge{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:10px}.header-right{display:flex;align-items:center;gap:12px}.header-user{display:flex;align-items:center;color:var(--text-secondary);font-size:.9rem}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 16px var(--accent-glow)}.btn-secondary{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-primary)}.btn-danger{background:var(--danger);color:var(--danger-fg)}.btn-danger:hover:not(:disabled){background:var(--danger-hover)}.platform-filter{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 0;flex-wrap:wrap;flex-shrink:0}.platform-pills{display:flex;gap:8px;flex-wrap:wrap}.platform-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;border:1px solid var(--border);background:var(--bg-surface);color:var(--text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition)}.platform-pill:hover:not(:disabled){background:var(--bg-surface-hover);color:var(--text-secondary);border-color:var(--border-strong)}.platform-pill.active{background:var(--accent-light);color:var(--accent);border-color:var(--accent);box-shadow:0 0 12px #7c3aed14}.platform-pill:disabled{opacity:.4;cursor:not-allowed}.btn-load{padding:10px 24px}.action-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;flex-wrap:wrap;flex-shrink:0}.action-bar-left{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1}.action-bar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.count-badge{font-size:.85rem;color:var(--text-muted);padding:4px 12px;background:var(--bg-surface);border-radius:16px;white-space:nowrap}.count-badge strong{color:var(--text-primary)}.count-selected strong{color:var(--accent)}.search-box{position:relative;display:flex;align-items:center;flex:1;min-width:200px;max-width:400px}.search-icon{position:absolute;left:12px;color:var(--text-dim);pointer-events:none}.search-input{width:100%;padding:8px 32px 8px 36px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;outline:none;transition:border-color var(--transition)}.search-input::placeholder{color:var(--text-dim)}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-muted);font-size:1.2rem;cursor:pointer;padding:2px 6px;border-radius:4px}.search-clear:hover{color:var(--text-primary);background:var(--bg-surface-hover)}.btn-sync{padding:8px 20px}.table-wrapper{flex:1;overflow:auto;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);min-height:0}.device-table{width:100%;border-collapse:collapse;font-size:.875rem}.device-table thead{position:sticky;top:0;z-index:10}.device-table th{padding:12px 14px;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);background:var(--bg-surface);border-bottom:1px solid var(--border-strong);white-space:nowrap}.device-table td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:middle}.device-table tbody tr{transition:background var(--transition)}.device-table tbody tr:hover{background:#7c3aed0a}.device-table tbody tr.row-selected{background:var(--accent-light)}.col-check{width:40px;text-align:center}.col-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.col-name{font-weight:500;color:var(--text-primary);min-width:160px}.col-platform{min-width:100px}.platform-tag{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:500;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.col-os{min-width:110px;color:var(--text-muted)}.col-user{min-width:180px}.col-sync{min-width:130px;color:var(--text-muted);font-variant-numeric:tabular-nums}.col-compliance{min-width:120px}.col-status{min-width:100px}.compliance-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.compliance-compliant{color:var(--compliant-fg);background:var(--compliant-bg)}.compliance-noncompliant{color:var(--noncompliant-fg);background:var(--noncompliant-bg)}.compliance-unknown{color:var(--text-muted);background:var(--bg-surface)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:12px;font-size:.8rem;font-weight:500}.status-syncing{color:var(--status-syncing-fg);background:var(--status-syncing-bg)}.status-success{color:var(--status-success-fg);background:var(--status-success-bg)}.status-failed{color:var(--status-failed-fg);background:var(--status-failed-bg)}.error-tooltip{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--status-failed-bg);color:var(--status-failed-fg);font-size:.7rem;font-weight:700;margin-left:6px;cursor:help}.table-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;color:var(--text-dim);border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);text-align:center;gap:12px}.table-empty svg{opacity:.3;margin-bottom:8px}.table-empty p{font-size:1.1rem;color:var(--text-muted);font-weight:500}.table-empty span{font-size:.9rem}.sync-progress{padding:12px 0;flex-shrink:0}.progress-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:12px}.progress-message{color:var(--text-secondary);font-size:.9rem}.progress-bar-track{position:relative;height:6px;background:var(--bg-surface);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a855f7);border-radius:3px;transition:width .3s ease}.progress-bar-label{position:absolute;right:0;top:-22px;font-size:.75rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.btn-export{padding:6px 16px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.spinner-sm{display:inline-block;width:12px;height:12px;border:2px solid rgba(155,114,232,.2);border-top-color:var(--status-syncing-fg);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-lg);padding:28px;max-width:420px;width:90%;box-shadow:0 20px 60px #0006;animation:dialogIn .2s ease}@keyframes dialogIn{0%{opacity:0;transform:scale(.95) translateY(10px)}}.dialog-title{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.dialog-message{color:var(--text-secondary);font-size:.9rem;margin-bottom:24px;line-height:1.6}.dialog-actions{display:flex;justify-content:flex-end;gap:8px}.footer{padding:12px 24px;text-align:center;font-size:.75rem;color:var(--text-dim);border-top:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.footer-sep{margin:0 8px;opacity:.3}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-surface-active);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}@media(max-width:768px){.main-content{padding:0 12px 16px}.header{padding:12px 16px}.header-title{font-size:1rem}.platform-filter{flex-direction:column;align-items:stretch}.platform-pills{justify-content:center}.btn-load{width:100%;justify-content:center}.action-bar,.action-bar-left{flex-direction:column;align-items:stretch}.action-bar-right{justify-content:center}.search-box{max-width:100%}.count-badge{text-align:center}.table-wrapper{border-radius:var(--radius-md)}.device-table{font-size:.8rem}.device-table th,.device-table td{padding:8px 10px}.col-os,.col-sync{display:none}}@media(max-width:480px){.col-compliance,.header-user{display:none}.platform-pill{padding:6px 12px;font-size:.8rem}}
