body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:2rem 3rem;width:100%}.login-card h2{color:#333;margin:0 0 1.5rem;text-align:center}.auth-method-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.auth-method-tabs button{background:#fff;border:2px solid #e0e0e0;border-radius:5px;cursor:pointer;flex:1 1;font-weight:500;padding:.75rem;transition:all .3s}.auth-method-tabs button.active{background:#667eea;border-color:#667eea;color:#fff}.form-group{margin-bottom:1.25rem}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.form-group input{border:2px solid #e0e0e0;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.error-message{background:#fdf2f2;color:#e74c3c;text-align:center}.submit-btn{border:none;border-radius:5px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:transform .2s;width:100%}.submit-btn:hover:not(:disabled){transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.register-link{color:#666;margin-top:1.5rem;text-align:center}.register-link a{color:#667eea;font-weight:500;text-decoration:none}.register-link a:hover{text-decoration:underline}.dashboard-container{background:#f5f5f5;min-height:100vh}.dashboard-nav{align-items:center;background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:1rem 2rem}.dashboard-nav h1{color:#333;margin:0}.nav-left{gap:1rem}.nav-actions,.nav-left{align-items:center;display:flex}.nav-actions{gap:1.5rem}.dashboard-content{margin:2rem auto;max-width:1200px;padding:0 2rem}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.dashboard-header h2{color:#333;margin:0}.add-device-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:transform .2s}.add-device-btn:hover{transform:translateY(-2px)}.loading,.no-devices{color:#666;padding:3rem;text-align:center}.devices-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.device-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;color:inherit;cursor:pointer;padding:1.5rem;text-decoration:none;transition:transform .2s,box-shadow .2s}.device-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-5px)}.device-card h3{color:#333;margin:0 0 .5rem}.device-id,.device-type{color:#666;font-size:.9rem;margin:.25rem 0}.device-status{font-weight:600;margin:.5rem 0}.device-status.online{color:#27ae60}.device-status.offline{color:#e74c3c}.device-status.unknown{color:#95a5a6}.control-btn{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;margin-top:1rem;padding:.75rem;transition:background .3s;width:100%}.control-btn:hover{background:#5568d3}.device-list-container{background:#f5f5f5;min-height:100vh}.device-list-container .dashboard-nav{margin-bottom:0}.device-list-container .devices-grid{margin:2rem auto;max-width:1200px;padding:0 2rem}.device-list-container h1{color:#333;margin-bottom:2rem}.modal-content{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:500px;overflow-y:auto;padding:0;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1.5rem}.modal-header h3{color:#333;margin:0}.close-btn{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;line-height:1;padding:0;transition:color .3s;width:30px}.close-btn:hover{color:#333}.device-form{padding:1.5rem}.device-form .form-group{margin-bottom:1.5rem}.device-form label{color:#333;display:block;font-weight:500;margin-bottom:.5rem}.device-form input,.device-form select{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s;width:100%}.device-form input:focus,.device-form select:focus{border-color:#667eea;outline:none}.device-form select{background:#fff;cursor:pointer}.error-message{background:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:1rem;padding:.75rem}.modal-actions{justify-content:flex-end;margin-top:2rem}.cancel-btn,.submit-btn{border:none;border-radius:5px;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .3s}.cancel-btn{background:#e0e0e0;color:#333}.cancel-btn:hover{background:#d0d0d0}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.device-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.device-card-header h3{flex:1 1;margin:0}.device-actions{display:flex;gap:.5rem}.delete-btn-small,.edit-btn{background:none;border:none;border-radius:5px;cursor:pointer;font-size:1.2rem;opacity:.7;padding:.25rem .5rem;transition:all .3s}.edit-btn:hover{background:#e3f2fd;opacity:1;transform:scale(1.1)}.delete-btn-small:hover{background:#ffebee;opacity:1;transform:scale(1.1)}.delete-modal{max-width:400px}.delete-content{padding:1.5rem}.delete-content p{color:#333;margin:0 0 1rem}.device-info-box{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;line-height:1.8;margin:1rem 0;padding:1rem}.device-info-box strong{color:#667eea}.delete-btn{background:#e74c3c;color:#fff}.delete-btn:hover{background:#c0392b;box-shadow:0 4px 12px #e74c3c66;transform:translateY(-2px)}.device-control-container{margin:0 auto;max-width:1200px;padding:2rem}.control-header{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.header-actions{align-items:center;display:flex;gap:1.5rem}.user-name{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;color:#333;font-size:.95rem;font-weight:600;padding:.25rem .75rem}.back-btn{background:#95a5a6;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:background .3s}.back-btn:hover{background:#7f8c8d}.control-header h1{color:#333;margin:0}.device-info{grid-gap:1rem;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem;padding:1.5rem}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item label{color:#666;font-size:.9rem;font-weight:600}.info-item span{color:#333;font-size:1rem}.status.online{color:#27ae60}.status.offline{color:#e74c3c}.status.unknown{color:#95a5a6}.command-section,.messages-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.command-section h2,.messages-section h2{color:#333;margin:0 0 1rem}.command-form{gap:1rem}.command-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#333;font-size:.95rem;font-weight:600}.form-group input,.form-group select{border:2px solid #e0e0e0;border-radius:5px;font-family:inherit;font-size:1rem;padding:.75rem}.form-group input:focus,.form-group select:focus{border-color:#667eea;outline:none}.form-group small{color:#666;font-size:.85rem;margin-top:.25rem}.command-preview{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;margin:1rem 0;padding:1rem}.command-preview strong{color:#333;display:block;margin-bottom:.5rem}.command-preview pre{color:#667eea;font-size:.9rem;margin:0;overflow-x:auto}.send-btn{background:#667eea;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:background .3s}.send-btn:hover{background:#5568d3}.command-examples{border-top:2px solid #e0e0e0;margin-top:2rem;padding-top:2rem}.command-examples h3{color:#333;font-size:1.1rem;margin:0 0 1rem}.example-buttons{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.example-btn{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:5px;color:#333;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1rem;transition:all .3s}.example-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.messages-list{border:1px solid #e0e0e0;border-radius:5px;max-height:400px;overflow-y:auto;padding:.5rem}.no-messages{color:#666;padding:2rem;text-align:center}.message-item{grid-gap:1rem;border-bottom:1px solid #f0f0f0;display:grid;font-size:.9rem;gap:1rem;grid-template-columns:100px 200px 1fr;padding:.75rem}.message-item:last-child{border-bottom:none}.message-time{color:#666}.message-topic{color:#667eea;font-weight:500}.message-content{color:#333}.admin-dashboard{background:#f5f5f5;min-height:100vh}.admin-nav{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem}.admin-nav h1{font-size:1.8rem;margin:0}.admin-tabs{background:#fff;box-shadow:0 2px 4px #0000001a;display:flex;gap:.5rem;padding:1rem 2rem}.admin-tabs button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .3s}.admin-tabs button:hover{background:#f0f0f0;color:#667eea}.admin-tabs button.active{border-bottom-color:#667eea;color:#667eea}.admin-content{margin:2rem auto;max-width:1400px;padding:0 2rem}.admin-content h2{color:#333;margin-bottom:1.5rem}.admin-table{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%}.admin-table th{background:#667eea;color:#fff;font-weight:600;padding:1rem;text-align:left}.admin-table td{border-bottom:1px solid #f0f0f0;padding:.75rem 1rem}.admin-table tr:hover{background:#f9f9f9}.btn-delete,.btn-edit,.btn-password{border:none;border-radius:5px;cursor:pointer;font-size:.9rem;margin-right:.5rem;padding:.5rem 1rem;transition:all .3s}.btn-edit{background:#4caf50;color:#fff}.btn-password{background:#ff9800;color:#fff}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover,.btn-edit:hover,.btn-password:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.status.online{color:#4caf50;font-weight:600}.status.offline{color:#f44336;font-weight:600}.status.unknown{color:#999;font-weight:600}.mqtt-topic{color:#666;font-family:monospace;font-size:.85rem}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0000004d;min-width:400px;padding:2rem}.modal h3{color:#333;margin-top:0}.modal label{color:#666;display:block;font-weight:500;margin:1rem 0 .5rem}.modal input{border:2px solid #e0e0e0;border-radius:5px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.modal input:focus{border-color:#667eea;outline:none}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-save{background:#4caf50}.btn-cancel,.btn-save{border:none;border-radius:5px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:.75rem}.btn-cancel{background:#999}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;text-align:center}.stat-card h3{color:#666;font-size:.9rem;margin:0 0 1rem}.stat-value{color:#667eea;font-size:2.5rem;font-weight:700;margin:0}.devices-by-type,.recent-users{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.devices-by-type h3,.recent-users h3{color:#333;margin-top:0}.loading{color:#666;padding:3rem;text-align:center}.logout-btn{background:#e74c3c!important;border:2px solid #c0392b!important;border-radius:6px!important;box-shadow:0 2px 4px #e74c3c4d!important;color:#fff!important;cursor:pointer!important;font-size:.95rem!important;font-weight:600!important;letter-spacing:.5px!important;opacity:1!important;padding:.5rem 1.25rem!important;text-transform:uppercase!important;transition:all .3s!important;visibility:visible!important}.logout-btn:hover{background:#c0392b!important;border-color:#a93226!important;box-shadow:0 4px 8px #e74c3c66!important;transform:translateY(-1px)!important}.logout-btn:active{box-shadow:0 1px 2px #e74c3c4d!important;transform:translateY(0)!important}.logout-btn:focus{outline:2px solid #e74c3c!important;outline-offset:2px!important}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.df1f6e74.css.map*/