@import"https://fonts.googleapis.com/css2?family=Oxanium:wght@200..800&display=swap";:root{font-family:Oxanium,monospace,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #ff8113;--primary-hover: #eaf253;--success-color: #ecc781;--error-color: #f44336;--warning-color: #ff9800;--background-dark: #1a1a1a;--surface-color: #2d2d2d;--border-color: #404040}button{font-family:Oxanium,monospace,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;background-color:var(--background-dark)}#app{min-height:100vh;display:flex;flex-direction:column}.header{background-color:var(--surface-color);border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header h1{margin:0;font-size:1.5rem;color:#fff}.connection-status{display:flex;align-items:center;gap:1rem}.status-disconnected{color:var(--error-color);font-weight:500}.status-connected{color:var(--success-color);font-weight:500}.status-connecting{color:var(--warning-color);font-weight:500}.logout-btn{background-color:transparent;border:1px solid var(--border-color);color:#fffc;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.logout-btn:hover{background-color:var(--error-color);border-color:var(--error-color);color:#fff}.app-container{display:flex;flex:1;min-height:0}.sidebar{width:250px;background-color:var(--surface-color);border-right:1px solid var(--border-color);display:flex;flex-direction:column}.sidebar-nav{display:flex;flex-direction:column;padding:1rem 0}.nav-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:#ffffffb3;text-decoration:none;transition:all .2s ease;border-left:3px solid transparent}.nav-link:hover{background-color:#646cff1a;color:#fff}.nav-link.active{background-color:var(--border-color);color:#fff;border-left-color:var(--primary-color)}.nav-icon{font-size:1.5rem}.nav-text{font-weight:500;font-size:1rem}.main-content{flex:1;display:flex;flex-direction:column;padding:2rem;overflow-y:auto;background-color:var(--background-dark)}.page-header{margin-bottom:2rem}.page-header h2{margin:0 0 .5rem;color:#fff;font-size:1.8rem}.subtitle{color:#fff9;font-size:.95rem;margin:0}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.9rem}.breadcrumb-link{color:var(--primary-color);text-decoration:none;transition:color .2s ease}.breadcrumb-link:hover{color:var(--primary-hover);text-decoration:underline}.breadcrumb-separator{color:#fff6}.breadcrumb-current{color:#fffc}.table-container{background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table thead{background-color:#0000004d}.data-table th{text-align:left;padding:1rem 1.5rem;color:#ffffffe6;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.data-table tbody tr{border-top:1px solid var(--border-color);transition:background-color .2s ease;cursor:pointer}.data-table tbody tr:hover{background-color:#646cff1a}.data-table td{padding:1rem 1.5rem;color:#fffc}.city-name,.location-name,.box-name{font-weight:500;font-size:1rem;color:#fff}.action-btn{background-color:var(--primary-color);border:none;color:#fff;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background-color .2s ease}.action-btn:hover{background-color:var(--primary-hover)}.phone-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.phone-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .2s ease}.phone-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 12px #646cff33}.phone-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.phone-status{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.phone-status.status-online{background-color:#4caf5033;color:var(--success-color)}.phone-status.status-offline{background-color:#f4433633;color:var(--error-color)}.phone-status.status-unknown{background-color:#ff980033;color:var(--warning-color)}.phone-slot{font-size:.8rem;color:#fff9}.phone-card-body{display:flex;flex-direction:column;gap:.5rem}.phone-name{margin:0;color:#fff;font-size:1.1rem;font-weight:600}.phone-model{margin:0;color:#ffffffb3;font-size:.9rem}.phone-specs,.phone-version{margin:0;color:#ffffff80;font-size:.85rem}.loading{text-align:center;color:#fff9;padding:4rem 2rem;font-size:1.1rem}.empty-state{text-align:center;padding:4rem 2rem}.empty-state h2{color:#fff;margin:0 0 1rem}.empty-state p{color:#fff9;margin:0 0 2rem}.error-message{text-align:center;padding:4rem 2rem}.error-message h2{color:var(--error-color);margin:0 0 1rem}.error-message p{color:#ffffffb3;margin:0 0 2rem}.uncategorized-section{margin-top:3rem;padding-top:2rem;border-top:2px solid var(--border-color)}.section-title{color:var(--warning-color);font-size:1.3rem;margin:0 0 .5rem}.section-subtitle{color:#fff9;font-size:.9rem;margin:0 0 1.5rem}.uncategorized-device{background-color:#ff98000d}.uncategorized-device:hover{background-color:#ff98001a}.device-id{font-family:monospace;font-size:.9rem;color:#ffffffb3}.edit-device-btn{background-color:var(--warning-color)}.edit-device-btn:hover{background-color:#f57c00}.profile-content{max-width:800px}.profile-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:2rem}.profile-card h3{margin:0 0 1rem;color:#fff}.modal{display:none;position:fixed;inset:0;background-color:#000c;z-index:1000;align-items:center;justify-content:center;padding:1.5rem}.modal-content{background-color:var(--surface-color);border-radius:8px;border:1px solid var(--border-color);width:100%;max-width:1200px;height:95vh;display:flex;flex-direction:column;position:relative;overflow:hidden;resize:both;min-width:600px;min-height:400px}.modal-close{position:absolute;top:1rem;right:1rem;background-color:#ffffff1a;border:none;color:#fff;font-size:2rem;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background-color .2s ease;line-height:1}.modal-close:hover{background-color:#fff3}.device-info{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background-color:#0003}.device-info-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:.5rem;gap:10px}.device-info h3{margin:0;color:#fff;font-size:1.1rem}.edit-btn{background-color:var(--primary-color);border:none;color:#fff;padding:5px 10px;border-radius:4px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background-color .2s ease}.edit-btn:hover{background-color:var(--primary-hover)}.device-info-form{display:none;margin-top:1rem}.device-info-form.editing{display:block}.form-row{display:flex;gap:1rem;margin-bottom:.75rem}.form-group{flex:1;display:flex;flex-direction:column}.form-group label{font-size:.8rem;color:#ffffffb3;margin-bottom:.25rem;font-weight:500}.form-group input{background-color:var(--background-dark);border:1px solid var(--border-color);border-radius:4px;padding:.5rem;color:#fff;font-size:.9rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input::placeholder{color:#ffffff4d}.form-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.save-btn{background-color:var(--success-color);border:none;color:#fff;padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:500;font-size:.9rem;transition:background-color .2s ease}.save-btn:hover{background-color:#45a049}.cancel-btn{background-color:var(--border-color);border:none;color:#fff;padding:.5rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:500;font-size:.9rem;transition:background-color .2s ease}.cancel-btn:hover{background-color:#505050}.device-details{display:flex;gap:1rem;font-size:.9rem;color:#ffffffb3}.device-stats{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.latency-info{display:flex;gap:1rem;padding:.5rem .75rem;background-color:#0003;border-radius:4px;font-size:.75rem}.latency-item{display:flex;align-items:baseline;gap:.4rem}.latency-label{color:#ffffff80;font-size:.7rem;white-space:nowrap}.latency-value{font-size:.85rem;font-weight:600;color:#ffffffe6;font-family:Courier New,monospace;min-width:3rem;text-align:right}.latency-value.latency-good{color:#4caf50}.latency-value.latency-ok{color:#ff9800}.latency-value.latency-bad{color:#f44336}.screen-container{flex:1;display:flex;justify-content:center;align-items:center;background-color:#000;position:relative;min-height:400px}.device-screen{max-width:100%;max-height:100%;border-radius:4px;cursor:pointer;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.screen-overlay{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;background-color:#000c;color:#fff;font-size:1.1rem}.screen-overlay.hidden{display:none}.loading-screen{display:flex;align-items:center;gap:.5rem}.loading-screen:after{content:"";width:20px;height:20px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.controls{padding:1rem 1.5rem;display:flex;gap:.5rem;border-top:1px solid var(--border-color);background-color:#0003}.control-btn{background-color:var(--primary-color);border:none;color:#fff;padding:.6rem 1.2rem;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s ease}.control-btn:hover{background-color:var(--primary-hover)}.control-btn:disabled{background-color:var(--border-color);cursor:not-allowed}#disconnect-btn{background-color:var(--error-color);margin-right:auto}#disconnect-btn:hover{background-color:#d32f2f}@media (max-width: 1024px){.phone-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width: 768px){.app-container{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color)}.sidebar-nav{flex-direction:row;overflow-x:auto}.nav-link{border-left:none;border-bottom:3px solid transparent;flex-shrink:0}.nav-link.active{border-left-color:transparent;border-bottom-color:var(--primary-color)}.main-content,.header{padding:1rem}.header h1{font-size:1.2rem}.controls{flex-wrap:wrap}.control-btn{flex:1;min-width:0}.phone-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.modal{padding:.5rem}.modal-content{max-width:100%;min-width:100%;height:98vh;resize:none}}@media (max-width: 480px){.device-details{flex-direction:column;gap:.25rem}.screen-container{min-height:300px}.phone-grid{grid-template-columns:1fr}.data-table th,.data-table td{padding:.75rem 1rem;font-size:.85rem}.breadcrumb{flex-wrap:wrap}}#login-app{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--background-dark);padding:2rem}.login-container{width:100%;max-width:420px}.login-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;padding:3rem 2.5rem;box-shadow:0 4px 20px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{margin:0 0 .5rem;font-size:2.5rem;color:#fff;font-weight:700}.login-subtitle{margin:0;color:#fff9;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-form label{font-size:.9rem;color:#fffc;font-weight:500}.login-form input{background-color:var(--background-dark);border:1px solid var(--border-color);border-radius:6px;padding:.85rem 1rem;color:#fff;font-size:1rem;transition:border-color .2s ease;font-family:Oxanium,monospace,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.login-form input:focus{outline:none;border-color:var(--primary-color)}.login-form input::placeholder{color:#ffffff4d}.login-error{background-color:#f443361a;border:1px solid var(--error-color);border-radius:6px;padding:.85rem 1rem;color:var(--error-color);font-size:.9rem;margin:-.5rem 0 0}.login-btn{background-color:var(--primary-color);border:none;color:#fff;padding:.95rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:1rem;transition:background-color .2s ease;margin-top:.5rem;font-family:Oxanium,monospace,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.login-btn:hover{background-color:var(--primary-hover)}.login-btn:disabled{background-color:var(--border-color);cursor:not-allowed;opacity:.6}.login-btn.loading:after{content:"";width:16px;height:16px;margin-left:10px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;display:inline-block;animation:spin 1s linear infinite;vertical-align:middle}.login-footer{text-align:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.login-footer p{margin:0;color:#ffffff80;font-size:.85rem}@media (max-width: 480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:2rem}}
