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}.container{padding:20px}.header{background:linear-gradient(135deg,#667eea,#764ba2);margin-bottom:30px;padding:20px 0;text-align:center}.header h1{font-size:2.5rem;margin:0}.header p{margin:10px 0 0}.card{border-radius:8px;box-shadow:0 2px 10px #0000001a;margin-bottom:20px;padding:20px}.card h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.form-group{margin-bottom:15px}.form-group label{color:#555;font-weight:500;margin-bottom:5px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px}.btn{background:#667eea;border-radius:4px;font-size:14px;margin-bottom:10px;margin-right:10px;padding:10px 20px}.btn:hover{background:#5a6fd8}.btn-danger{background:#e74c3c}.btn-danger:hover{background:#c0392b}.btn-success{background:#27ae60}.btn-success:hover{background:#229954}.device-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.device-card{border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 5px #0000001a;padding:15px}.device-card h3{color:#333;margin-top:0}.device-info strong{color:#555}.status-active{color:#27ae60}.status-inactive{color:#e74c3c}.alert{border-radius:4px;margin-bottom:15px;padding:10px}.alert-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.loading{color:#666;padding:20px}.fabric-status{background:#e8f5e8;border:1px solid #4caf50;border-radius:4px;color:#2e7d32}.fabric-status,.mock-status{margin-bottom:20px;padding:10px;text-align:center}.mock-status{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;color:#856404}.App{background-color:#f5f5f5;min-height:100vh}.header{background:linear-gradient(135deg,#1e3a8a,#2563eb);color:#fff;padding:24px}.header h1,.header p{margin:0}.header p{margin-top:8px;opacity:.9}.admin-nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:20px}.nav-btn{background:#ffffff2e;border:none;border-radius:999px;color:#fff;cursor:pointer;padding:10px 16px}.nav-btn.active{background:#fff;color:#1e3a8a}.nav-btn.logout{background:#7f1d1de6}.container{margin:0 auto;max-width:1200px;padding:24px}.card{background:#fff;border-radius:14px;box-shadow:0 8px 24px #0f172a14;margin-bottom:24px;padding:24px}.alert,.encryption-banner,.fabric-status,.mock-status{border-radius:10px;margin-bottom:20px;padding:14px 16px}.fabric-status{background:#dcfce7;color:#166534}.mock-status{background:#fef3c7;color:#92400e}.encryption-banner{background:#dbeafe;color:#1d4ed8;display:flex;flex-direction:column;gap:6px}.alert{position:relative}.alert-success{background:#dcfce7;color:#166534}.alert-error{background:#fee2e2;color:#991b1b}.alert button{background:none;border:none;cursor:pointer;float:right;font-size:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:600;margin-bottom:8px}.form-group input,.form-group select{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;padding:12px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:10px 14px;transition:all .2s ease}.btn:hover:not(:disabled){box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-success{background:#16a34a}.btn-danger{background:#dc2626}.device-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:20px}.device-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:18px}.device-card:hover{box-shadow:0 4px 15px #00000026;transform:translateY(-2px);transition:all .3s ease}.device-info{margin-bottom:10px}.device-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.status-active{color:#16a34a;font-weight:700}.status-inactive{color:#dc2626;font-weight:700}.loading{color:#6b7280;padding:30px 0;text-align:center}.device-json{background:#f8fafc;border-radius:8px;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.4;overflow:auto;padding:15px}@media (max-width:768px){.container{padding:16px}.header{padding:20px 16px}.admin-nav{flex-direction:column}.nav-btn{width:100%}}.admin-login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.admin-login-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;width:100%}.admin-login-header{margin-bottom:24px;text-align:center}.admin-login-btn,.back-btn{border-radius:10px;cursor:pointer;margin-top:12px;padding:14px;width:100%}.admin-login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.back-btn{background:#fff;border:2px solid #667eea;color:#667eea}.admin-login-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px;padding:20px;text-align:center}.user-management{margin:0 auto;max-width:1200px;padding:20px}.user-management-header{align-items:center;border-bottom:2px solid #e1e5e9;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.user-management-header h2{margin:0}.add-user-btn,.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.add-user-btn,.cancel-btn,.delete-btn,.edit-btn,.save-btn{border:none;border-radius:8px;cursor:pointer;padding:12px 20px}.cancel-btn{background:#6c757d;color:#fff}.user-form-container{align-items:center;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.user-form-card{background:#fff;border-radius:12px;max-width:500px;padding:30px;width:90%}.user-form{display:flex;flex-direction:column;gap:16px}.form-actions,.user-actions{display:flex;gap:12px}.users-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.user-card{background:#fff;border:1px solid #e1e5e9;border-radius:12px;padding:20px}.user-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.role-badge{border-radius:999px;color:#fff;font-size:12px;padding:4px 10px;text-transform:uppercase}.role-admin{background:#dc3545}.role-user{background:#28a745}.role-operator{background:#ffc107;color:#333}.edit-btn{background:#17a2b8;color:#fff}.delete-btn{background:#dc3545;color:#fff}.error-message,.success-message{border-radius:8px;cursor:pointer;margin-bottom:20px;padding:12px 16px}.success-message{background:#d4edda;color:#155724}.user-login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.user-login-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;width:100%}.user-login-header{margin-bottom:24px;text-align:center}.back-btn,.login-btn,.switch-to-register-btn{border-radius:10px;cursor:pointer;margin-top:12px;padding:14px;width:100%}.login-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.back-btn,.switch-to-register-btn{background:#fff;border:2px solid #667eea;color:#667eea}.login-footer{padding-top:20px;text-align:center}.user-registration-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.user-registration-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:40px;width:100%}.user-registration-header{margin-bottom:24px;text-align:center}.form-row{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.back-btn,.register-btn,.switch-to-login-btn{border-radius:10px;cursor:pointer;margin-top:12px;padding:14px;width:100%}.register-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.back-btn,.switch-to-login-btn{background:#fff;border:2px solid #667eea;color:#667eea}.registration-footer{padding-top:20px;text-align:center}.error-message{background:#fee;color:#c53030;padding:12px}.landing-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.landing-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:800px;padding:40px;width:100%}.landing-header,.welcome-section{text-align:center}.landing-content{display:flex;flex-direction:column;gap:32px}.auth-options{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.auth-option{background:#f8f9fa;border:2px solid #e1e5e9;border-radius:15px;padding:24px;text-align:center}.auth-icon{font-size:28px;font-weight:700;margin-bottom:12px}.auth-btn{border:none;border-radius:10px;color:#fff;cursor:pointer;padding:12px 20px;width:100%}.user-btn{background:linear-gradient(135deg,#17a2b8,#138496)}.admin-btn{background:linear-gradient(135deg,#28a745,#20c997)}.encrypted-data-viewer{margin:0 auto;max-width:1200px;padding:20px}.viewer-header{border-bottom:2px solid #e1e5e9;margin-bottom:30px;padding-bottom:20px;text-align:center}.device-card,.encryption-key-section,.encryption-stats{background:#fff;border:1px solid #e1e5e9;border-radius:12px}.encryption-key-section,.encryption-stats{margin-bottom:24px;padding:20px}.key-input-group{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.key-input{border:2px solid #e1e5e9;border-radius:8px;flex:1 1;min-width:220px;padding:12px}.decrypt-btn,.set-key-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;padding:12px 18px}.devices-grid,.stats-grid{grid-gap:20px;display:grid;gap:20px}.devices-grid{grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.device-card{padding:20px}.device-header,.field-header{align-items:center;display:flex;justify-content:space-between}.status-badge{border-radius:999px;color:#fff;font-size:12px;padding:4px 10px;text-transform:uppercase}.status-badge.active{background:#28a745}.status-badge.inactive{background:#dc3545}.encrypted-section{background:#f8f9fa;border-radius:10px;margin-top:16px;padding:16px}.encrypted-field{margin-bottom:14px}.field-name{font-weight:600;text-transform:capitalize}.encryption-indicator{border-radius:999px;color:#fff;font-size:11px;padding:2px 8px}.encryption-indicator.encrypted{background:#dc3545}.encryption-indicator.plain{background:#28a745}.decrypted-value code,.encrypted-value code{background:#eef1f5;border-radius:6px;display:block;padding:8px 10px;word-break:break-all}.stat-item{background:#f8f9fa;border-radius:10px;padding:20px;text-align:center}.stat-number{color:#667eea;display:block;font-size:28px;font-weight:700}.error-message{background:#f8d7da;border-radius:8px;color:#721c24;margin-bottom:20px;padding:12px 16px}
/*# sourceMappingURL=main.e2b0118e.css.map*/