*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh}#root{min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:48px;width:100%;max-width:440px;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:#667eea;font-size:32px;font-weight:700;margin:0 0 8px}.login-header h2{color:#4a5568;font-size:20px;font-weight:500;margin:0 0 12px}.environment-badge{display:inline-block;background:#edf2f7;color:#4a5568;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;margin-top:8px}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#2d3748;font-size:14px;font-weight:600}.form-group input{padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:16px;transition:all .2s;outline:none}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#f56565}.form-group input:disabled{background-color:#f7fafc;cursor:not-allowed}.error-message{color:#f56565;font-size:13px;font-weight:500;margin-top:-4px}.login-error{background-color:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 20px #667eea4d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:24px;text-align:center}.forgot-password{color:#667eea;background:none;border:none;padding:0;font-size:14px;font-weight:500;cursor:pointer;transition:color .2s}.forgot-password:hover{color:#764ba2;text-decoration:underline}@media(max-width:480px){.login-card{padding:32px 24px}.login-header h1{font-size:28px}.login-header h2{font-size:18px}}.dashboard-layout{display:flex;min-height:100vh;background:#f7fafc}.sidebar{background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;transition:width .3s ease;display:flex;flex-direction:column;position:fixed;left:0;top:0;height:100vh;z-index:100;box-shadow:2px 0 10px #0000001a}.sidebar.open{width:260px}.sidebar.closed{width:80px}.sidebar-header{padding:24px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.sidebar-title{font-size:24px;font-weight:700;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.closed .sidebar-title{display:none}.sidebar-toggle{background:#ffffff1a;border:none;color:#fff;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1;padding:20px 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:14px 20px;margin:4px 12px;background:transparent;border:none;color:#fffc;cursor:pointer;border-radius:8px;transition:all .2s;font-size:15px;font-weight:500;width:calc(100% - 24px);text-align:left}.sidebar.closed .nav-item{justify-content:center;padding:14px 10px}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#fff3;color:#fff;font-weight:600}.nav-icon{font-size:20px;min-width:24px;display:flex;align-items:center;justify-content:center}.sidebar.closed .nav-text{display:none}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.user-info-sidebar{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding:12px;background:#ffffff1a;border-radius:8px}.sidebar.closed .user-info-sidebar{justify-content:center;padding:12px 0}.user-avatar{width:40px;height:40px;border-radius:50%;background:#ffffff4d;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;min-width:40px}.user-details{flex:1;overflow:hidden}.sidebar.closed .user-details{display:none}.user-name{font-size:14px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;margin:2px 0 0;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-button-sidebar{width:100%;padding:12px;background:#f5656533;border:1px solid rgba(245,101,101,.3);color:#fff;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:500;transition:all .2s}.sidebar.closed .logout-button-sidebar{padding:12px 0}.logout-button-sidebar:hover{background:#f565654d}.logout-icon{font-size:18px}.sidebar.closed .logout-button-sidebar span:not(.logout-icon){display:none}.main-content{flex:1;transition:margin-left .3s ease}.sidebar.open~.main-content,.dashboard-layout:has(.sidebar.open) .main-content{margin-left:260px}.sidebar.closed~.main-content,.dashboard-layout:has(.sidebar.closed) .main-content{margin-left:80px}.content-header{background:#fff;padding:24px 40px;box-shadow:0 2px 8px #0000000d;display:flex;justify-content:space-between;align-items:center}.content-title{font-size:28px;font-weight:700;color:#2d3748;margin:0}.user-badge{display:flex;gap:12px;align-items:center}.environment-badge{background:#edf2f7;color:#4a5568;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600}.content-body{padding:40px}.tab-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.content-card{background:#fff;border-radius:12px;padding:32px;box-shadow:0 2px 12px #00000014}.content-card h2{color:#2d3748;font-size:24px;font-weight:600;margin:0 0 8px}.content-description{color:#718096;font-size:15px;margin:0 0 32px}.placeholder-content{text-align:center;padding:60px 20px;background:#f7fafc;border-radius:8px;border:2px dashed #e2e8f0}.placeholder-icon{font-size:64px;margin-bottom:16px}.placeholder-content p{color:#718096;font-size:16px;margin:0}.error-message{background:#fff5f5;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.loading-state{text-align:center;padding:60px 20px}.loading-spinner{width:48px;height:48px;margin:0 auto 16px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-state p{color:#718096;font-size:16px;margin:0}.data-table{margin-top:24px;overflow-x:auto}.data-table table{width:100%;border-collapse:collapse;background:#fff}.data-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.data-table th{padding:12px 16px;text-align:left;font-weight:600;color:#2d3748;font-size:14px;text-transform:uppercase;letter-spacing:.05em}.data-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s}.data-table tbody tr:hover{background-color:#f7fafc}.data-table td{padding:16px;color:#4a5568;font-size:14px}.uuid-cell{font-family:Courier New,monospace;font-size:12px;color:#718096;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.sidebar{position:fixed;z-index:1000}.sidebar.closed{transform:translate(-100%)}.main-content{margin-left:0!important}.content-header{padding:20px;flex-direction:column;gap:16px;align-items:flex-start}.content-title{font-size:22px}.content-body{padding:20px}.content-card{padding:24px}}.action-button{padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.view-button{background:#667eea;color:#fff}.view-button:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.unassign-button{background:#f56565;color:#fff}.unassign-button:hover:not(:disabled){background:#e53e3e;transform:translateY(-1px);box-shadow:0 2px 8px #f565654d}.unassign-button:disabled{background:#fc8181;cursor:not-allowed;opacity:.7}.assign-button{background:#48bb78;color:#fff}.assign-button:hover:not(:disabled){background:#38a169;transform:translateY(-1px);box-shadow:0 2px 8px #48bb784d}.assign-button:disabled{background:#68d391;cursor:not-allowed;opacity:.7}.no-action-text{color:#a0aec0;font-size:13px;font-style:italic}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease}.modal-content{background:#fff;border-radius:12px;max-width:700px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e2e8f0}.modal-header h2{color:#2d3748;font-size:22px;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:24px;color:#718096;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:#edf2f7;color:#2d3748}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:12px}.button-secondary{padding:10px 20px;background:#e2e8f0;color:#4a5568;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.button-secondary:hover{background:#cbd5e0}.user-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:12px;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:15px;color:#2d3748;font-weight:500}.uuid-value{font-family:Courier New,monospace;font-size:13px;color:#667eea;word-break:break-all}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600}.status-yes,.status-active,.status-verified,.status-unlocked{background:#c6f6d5;color:#22543d}.status-no,.status-inactive,.status-unverified,.status-locked{background:#fed7d7;color:#742a2a}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;background:#e6fffa;color:#234e52;margin-right:4px;margin-bottom:4px}.error-text{color:#e53e3e;text-align:center;padding:20px;margin:0}.card-header-with-action{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:20px}.card-header-with-action>div{flex:1}.add-device-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border-radius:8px;font-weight:600;font-size:14px;white-space:nowrap;box-shadow:0 2px 8px #667eea4d;transition:all .2s}.add-device-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.add-device-button:active{transform:translateY(0)}.form-content{padding:10px 0}.form-description{color:#718096;margin-bottom:24px;font-size:14px;line-height:1.6}.form-group{margin-bottom:20px}.form-label{display:block;font-weight:600;color:#2d3748;margin-bottom:8px;font-size:14px}.form-select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:15px;color:#2d3748;background-color:#fff;transition:all .2s;cursor:pointer}.form-select:hover{border-color:#cbd5e0}.form-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-select:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.success-message{background-color:#c6f6d5;border:1px solid #9ae6b4;color:#22543d;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;display:flex;align-items:center;gap:8px}.success-message:before{content:"✓";font-weight:700;font-size:18px}.button-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 24px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #667eea4d}.button-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.button-primary:active:not(:disabled){transform:translateY(0)}.button-primary:disabled{opacity:.6;cursor:not-allowed}.button-secondary{background:#fff;color:#4a5568;padding:12px 24px;border:2px solid #e2e8f0;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.button-secondary:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0}.button-secondary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.modal-content{width:95%;max-height:90vh}.user-detail-grid{grid-template-columns:1fr}.modal-header,.modal-body{padding:16px}.card-header-with-action{flex-direction:column;align-items:stretch}.add-device-button{width:100%}.search-filter-container{flex-direction:column}.search-input{width:100%}.clear-search-button{position:absolute;right:12px;top:50%;transform:translateY(-50%)}}.search-filter-container{display:flex;align-items:center;gap:12px;margin-bottom:20px;position:relative}.search-input{flex:1;padding:12px 40px 12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:all .2s;background-color:#fff}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.search-input::placeholder{color:#a0aec0}.clear-search-button{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:#e2e8f0;color:#4a5568;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:12px}.clear-search-button:hover{background:#cbd5e0;transform:translateY(-50%) scale(1.1)}.clear-search-button:active{transform:translateY(-50%) scale(.95)}.battery-percentage{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600}.battery-good{background-color:#c6f6d5;color:#22543d}.battery-medium{background-color:#fefcbf;color:#744210}.battery-low{background-color:#fed7d7;color:#742a2a}.battery-unknown{color:#a0aec0;font-size:13px;font-style:italic}.status-pending{background-color:#fef5e7;color:#856404}.status-processed{background-color:#d4edda;color:#155724}.status-cancelled{background-color:#f8d7da;color:#721c24}.status-unknown{background-color:#e2e8f0;color:#4a5568}.process-button{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:8px 16px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 2px 6px #48bb784d}.process-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 10px #48bb7866}.process-button:active:not(:disabled){transform:translateY(0)}.process-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.timestamp-old{animation:blink 1.5s ease-in-out infinite}@keyframes blink{0%,to{opacity:9;color:red}50%{opacity:.1}}.activate-button{background:#48bb78;color:#fff}.activate-button:hover:not(:disabled){background:#38a169;transform:translateY(-1px);box-shadow:0 2px 8px #48bb784d}.activate-button:disabled{background:#68d391;cursor:not-allowed;opacity:.7}.deactivate-button{background:#f56565;color:#fff}.deactivate-button:hover:not(:disabled){background:#e53e3e;transform:translateY(-1px);box-shadow:0 2px 8px #f565654d}.deactivate-button:disabled{background:#fc8181;cursor:not-allowed;opacity:.7}.action-buttons-container{display:flex;gap:8px;flex-wrap:wrap}
