.device-card{background:#2a2a2a;border:1px solid #444;border-radius:8px;padding:1rem;transition:all .3s;display:flex;flex-direction:column;gap:1rem}.device-card:hover{border-color:#666;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.device-card.disconnected{opacity:.6}.device-card-header{display:flex;justify-content:space-between;align-items:center}.device-status{display:flex;align-items:center;gap:.5rem}.status-indicator{width:10px;height:10px;border-radius:50%;background:#4caf50;animation:pulse 2s infinite}.status-indicator.offline{background:#f44336;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{color:#ccc;font-size:.9rem;font-weight:500}.country-flag{font-size:1.5rem}.device-card-body{flex:1}.device-info{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid #333}.info-row:last-child{border-bottom:none}.info-label{color:#999;font-size:.9rem}.info-value{color:#fff;font-size:.9rem;font-weight:500}.device-card-footer{display:flex;gap:.5rem}.btn-open,.btn-delete{flex:1;padding:.6rem;border:none;border-radius:4px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s}.btn-open{background:#2196f3;color:#fff}.btn-open:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.btn-open:disabled{opacity:.5;cursor:not-allowed}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{background:#d32f2f;transform:translateY(-1px)}.log-panel{background:#1a1a1a;border:1px solid #333;border-radius:8px;display:flex;flex-direction:column;height:calc(100vh - 120px);max-height:800px}.log-panel-header{padding:1rem;border-bottom:1px solid #333;display:flex;justify-content:space-between;align-items:center;background:#2a2a2a;border-radius:8px 8px 0 0}.log-panel-header h3{color:#fff;font-size:1.1rem;font-weight:600}.log-count{background:#444;color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.8rem}.log-panel-body{flex:1;overflow-y:auto;padding:1rem;font-family:Courier New,monospace;font-size:.85rem}.empty-logs{color:#666;text-align:center;padding:2rem}.log-entry{display:flex;gap:1rem;padding:.3rem 0;border-bottom:1px solid #2a2a2a}.log-entry:last-child{border-bottom:none}.log-timestamp{color:#888;min-width:150px;font-size:.8rem}.log-message{flex:1;word-break:break-word}.dashboard{min-height:100vh;display:flex;flex-direction:column}.dashboard-header{background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);border-bottom:2px solid #333;padding:1.5rem 2rem;box-shadow:0 2px 10px #0000004d}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.header-content h1{font-size:1.8rem;color:#fff;display:flex;align-items:center;gap:.5rem}.header-content .icon{font-size:2rem}.header-controls{display:flex;align-items:center;gap:1rem}.port-input{display:flex;align-items:center;gap:.5rem}.port-input label{color:#ccc;font-weight:500}.port-input input{width:100px;padding:.5rem;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#fff;font-size:1rem}.port-input input:disabled{opacity:.5;cursor:not-allowed}.listen-btn{padding:.6rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.listen-btn:hover:not(:disabled){background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #4caf504d}.listen-btn:disabled{opacity:.7;cursor:not-allowed}.listen-btn.listening{background:#2196f3}.dashboard-content{flex:1;display:grid;grid-template-columns:1fr 350px;gap:1rem;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.devices-section{display:flex;flex-direction:column;gap:1.5rem}.section-header{padding:.5rem 0;border-bottom:1px solid #333}.section-header h2{color:#fff;font-size:1.3rem;font-weight:600}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.empty-state{grid-column:1 / -1;text-align:center;padding:3rem;color:#888;background:#2a2a2a;border-radius:8px;border:2px dashed #444}@media (max-width: 1024px){.dashboard-content{grid-template-columns:1fr}}.camera-view{display:flex;flex-direction:column;gap:1.5rem;height:100%}.camera-controls{display:flex;gap:1rem;align-items:center}.camera-select{flex:1;padding:.7rem;background:#1a1a1a;border:1px solid #444;border-radius:4px;color:#fff;font-size:1rem}.camera-select:disabled{opacity:.5;cursor:not-allowed}.snap-btn{padding:.7rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.snap-btn:hover:not(:disabled){background:#1976d2;transform:translateY(-1px)}.snap-btn:disabled{opacity:.5;cursor:not-allowed}.camera-preview{flex:1;background:#1a1a1a;border:1px solid #444;border-radius:8px;position:relative;min-height:400px;display:flex;align-items:center;justify-content:center}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:rgba(0,0,0,.7);color:#fff}.image-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-container img{max-width:100%;max-height:100%;object-fit:contain}.save-btn{position:absolute;top:1rem;right:1rem;padding:.6rem 1.2rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;z-index:10;transition:all .3s}.save-btn:hover{background:#45a049;transform:translateY(-1px)}.placeholder{color:#666;text-align:center;padding:3rem}.file-manager-view{display:flex;flex-direction:column;gap:1rem;height:100%}.file-manager-header{display:flex;align-items:center;gap:1rem;padding:1rem;background:#1a1a1a;border-radius:6px;border:1px solid #444}.back-btn{padding:.5rem 1rem;background:#444;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .3s}.back-btn:hover:not(:disabled){background:#555}.back-btn:disabled{opacity:.5;cursor:not-allowed}.current-path{color:#ccc;font-family:monospace;font-size:.9rem;flex:1}.files-list{flex:1;overflow-y:auto;background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1rem}.file-item{display:flex;align-items:center;justify-content:space-between;padding:.8rem;margin-bottom:.5rem;background:#2a2a2a;border:1px solid #333;border-radius:4px;transition:all .3s}.file-item:hover{background:#333;border-color:#555}.file-info{display:flex;align-items:center;gap:1rem;flex:1;cursor:pointer}.file-icon{font-size:1.5rem}.file-name{color:#fff;flex:1}.file-size{color:#999;font-size:.85rem}.download-btn{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .3s}.download-btn:hover{background:#45a049}.sms-manager-view{display:flex;flex-direction:column;gap:1.5rem;height:100%}.sms-controls{display:flex;gap:1rem}.get-sms-btn,.save-sms-btn{padding:.7rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.get-sms-btn:hover:not(:disabled){background:#1976d2}.get-sms-btn:disabled{opacity:.5;cursor:not-allowed}.save-sms-btn{background:#4caf50}.save-sms-btn:hover{background:#45a049}.send-sms-section{background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1.5rem}.send-sms-section h3{color:#fff;margin-bottom:1rem}.send-sms-form{display:flex;flex-direction:column;gap:1rem}.phone-input,.message-input{padding:.7rem;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#fff;font-size:1rem;font-family:inherit}.phone-input:focus,.message-input:focus{outline:none;border-color:#2196f3}.send-btn{padding:.7rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.send-btn:hover{background:#45a049}.sms-list{flex:1;overflow-y:auto;background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1rem}.sms-item{background:#2a2a2a;border:1px solid #333;border-radius:4px;padding:1rem;margin-bottom:.5rem}.sms-header{display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #333}.sms-phone{color:#2196f3;font-weight:600}.sms-body{color:#ccc;line-height:1.5}.contacts-view{display:flex;flex-direction:column;gap:1.5rem;height:100%}.contacts-controls{display:flex;justify-content:space-between;align-items:center}.contacts-controls h3{color:#fff;font-size:1.3rem}.contacts-list{flex:1;overflow-y:auto;background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1rem}.contact-item{background:#2a2a2a;border:1px solid #333;border-radius:4px;padding:1rem;margin-bottom:.5rem;display:flex;justify-content:space-between;align-items:center}.contact-name{color:#fff;font-weight:600;font-size:1.1rem}.contact-phone{color:#999;font-family:monospace}.call-logs-view{display:flex;flex-direction:column;gap:1.5rem;height:100%}.call-logs-controls{display:flex;justify-content:space-between;align-items:center}.call-logs-controls h3{color:#fff;font-size:1.3rem}.save-btn{padding:.7rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.save-btn:hover{background:#45a049}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.empty-state{text-align:center;padding:3rem;color:#666}.calls-list{flex:1;overflow-y:auto;background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1rem}.call-item{background:#2a2a2a;border:1px solid #333;border-radius:4px;padding:1rem;margin-bottom:.5rem}.call-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.call-name{color:#fff;font-weight:600;font-size:1.1rem}.call-type{font-size:.9rem;font-weight:600;padding:.3rem .8rem;border-radius:12px}.call-type.incoming{background:#4caf50;color:#fff}.call-type.outgoing{background:#2196f3;color:#fff}.call-details{display:flex;justify-content:space-between;color:#999;font-size:.9rem}.call-phone{font-family:monospace}.call-duration{font-weight:500}.load-more-btn{width:100%;padding:1rem;background:#444;color:#fff;border:none;border-radius:4px;cursor:pointer;margin-top:1rem;transition:all .3s}.load-more-btn:hover{background:#555}.location-view{display:flex;flex-direction:column;gap:1.5rem;height:100%}.location-controls{display:flex;justify-content:space-between;align-items:center}.location-controls h3{color:#fff;font-size:1.3rem}.refresh-btn{padding:.7rem 1.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.refresh-btn:hover:not(:disabled){background:#1976d2}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.location-info{background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1rem}.location-coords{display:flex;gap:2rem;color:#ccc}.location-coords strong{color:#fff;font-family:monospace}.map-container{flex:1;min-height:500px;background:#1a1a1a;border:1px solid #444;border-radius:6px;position:relative;overflow:hidden}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:rgba(0,0,0,.8);color:#fff;z-index:10}.spinner{width:40px;height:40px;border:4px solid #333;border-top-color:#2196f3;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-map{display:flex;align-items:center;justify-content:center;height:100%;color:#666;text-align:center;padding:3rem}.microphone-view{display:flex;flex-direction:column;gap:2rem;height:100%}.mic-controls{background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1.5rem}.record-section h3{color:#fff;margin-bottom:1rem}.record-form{display:flex;flex-direction:column;gap:1rem}.record-form label{color:#ccc;display:flex;flex-direction:column;gap:.5rem}.seconds-input{padding:.7rem;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#fff;font-size:1rem;max-width:200px}.seconds-input:disabled{opacity:.5;cursor:not-allowed}.record-btn{padding:.7rem 1.5rem;background:#f44336;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;max-width:200px}.record-btn:hover:not(:disabled){background:#d32f2f}.record-btn:disabled{opacity:.5;cursor:not-allowed}.audio-player-section{background:#1a1a1a;border:1px solid #444;border-radius:6px;padding:1.5rem}.audio-player-section h3{color:#fff;margin-bottom:1rem}.audio-container{display:flex;flex-direction:column;gap:1rem}.audio-container audio{width:100%}.save-audio-btn{padding:.7rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;max-width:200px}.save-audio-btn:hover{background:#45a049}.empty-state{text-align:center;padding:3rem;color:#666;background:#1a1a1a;border:1px solid #444;border-radius:6px}.recording-indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;background:#1a1a1a;border:1px solid #444;border-radius:6px;color:#fff}.recording-dot{width:20px;height:20px;background:#f44336;border-radius:50%;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.device-detail{min-height:100vh;display:flex;flex-direction:column}.device-detail-header{background:linear-gradient(135deg,#2a2a2a 0%,#1a1a1a 100%);border-bottom:2px solid #333;padding:1.5rem 2rem;display:flex;align-items:center;gap:2rem;box-shadow:0 2px 10px #0000004d}.back-btn{padding:.6rem 1.2rem;background:#444;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .3s}.back-btn:hover{background:#555;transform:translateY(-1px)}.device-info-header{flex:1}.device-info-header h2{color:#fff;font-size:1.5rem;margin-bottom:.3rem}.device-id{color:#999;font-size:.9rem;font-family:monospace}.status-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem}.status-badge.online{background:#4caf50;color:#fff}.status-badge.offline{background:#f44336;color:#fff}.device-detail-content{flex:1;display:grid;grid-template-columns:1fr 350px;gap:1rem;padding:1.5rem;max-width:1400px;margin:0 auto;width:100%}.device-detail-main{display:flex;flex-direction:column;gap:1rem}.tabs{display:flex;gap:.5rem;flex-wrap:wrap;border-bottom:2px solid #333;padding-bottom:.5rem}.tab{display:flex;align-items:center;gap:.5rem;padding:.7rem 1.2rem;background:#2a2a2a;border:1px solid #444;border-radius:6px 6px 0 0;color:#ccc;cursor:pointer;transition:all .3s;font-size:.9rem}.tab:hover:not(:disabled){background:#333;border-color:#666}.tab.active{background:#1a1a1a;border-color:#2196f3;border-bottom-color:#1a1a1a;color:#fff;position:relative;bottom:-2px}.tab:disabled{opacity:.5;cursor:not-allowed}.tab-icon{font-size:1.2rem}.tab-content{background:#2a2a2a;border:1px solid #444;border-radius:8px;padding:2rem;min-height:500px}.main-view h3{color:#fff;margin-bottom:1.5rem;font-size:1.3rem}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-item{display:flex;flex-direction:column;gap:.3rem;padding:1rem;background:#1a1a1a;border-radius:6px;border:1px solid #333}.info-item label{color:#999;font-size:.85rem;font-weight:500}.info-item span{color:#fff;font-size:1rem}.status-online{color:#4caf50!important;font-weight:600}.status-offline{color:#f44336!important;font-weight:600}.device-detail-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;color:#fff;font-size:1.2rem}@media (max-width: 1024px){.device-detail-content{grid-template-columns:1fr}}.App{min-height:100vh;background-color:#1a1a1a}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#2a2a2a}::-webkit-scrollbar-thumb{background:#555;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#666}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1a1a1a;color:#e0e0e0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
