:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:250px;background-color:#1e293b;color:#fff;display:flex;flex-direction:column;transition:width .3s}.sidebar-header{padding:20px;font-size:1.2rem;font-weight:700;border-bottom:1px solid #334155}.sidebar-menu{flex:1;padding:10px 0}.menu-item{padding:15px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background-color .2s;color:#cbd5e1;text-decoration:none}.menu-item:hover{background-color:#334155}.menu-item.active{background-color:#3b82f6;color:#fff}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.header{height:60px;background-color:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between;padding:0 20px;box-shadow:0 1px 3px #0000001a}.header-title{font-size:1.5rem;font-weight:600;color:#1e293b}.header-actions{display:flex;align-items:center;gap:15px}.icon-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.icon-button:hover{background-color:#f1f5f9}.content{flex:1;overflow-y:auto;background-color:#f8fafc;padding:20px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-card h1{text-align:center;margin-bottom:30px;color:#1e293b}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#475569;font-weight:500}.form-group input{width:100%;padding:12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#3b82f6}.btn-primary{width:100%;padding:12px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:6px;margin-bottom:20px;text-align:center}.customers-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.customers-header{padding:20px;border-bottom:1px solid #e2e8f0}.customers-header h2{color:#1e293b;font-size:1.5rem}.customers-list{padding:20px}.customer-item{padding:15px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.customer-item:last-child{border-bottom:none}.customer-info h3{color:#1e293b;font-size:1.1rem;margin-bottom:5px}.customer-info p{color:#64748b;font-size:.9rem}.loading{text-align:center;padding:40px;color:#64748b}.no-data{text-align:center;padding:40px;color:#64748b;font-size:1.1rem}.customer-item.clickable{cursor:pointer;transition:background-color .2s}.customer-item.clickable:hover{background-color:#f8fafc}.tabs{display:flex;border-bottom:2px solid #e2e8f0;padding:0 20px;background:#fff}.tab{padding:15px 20px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;color:#64748b;transition:all .2s;display:flex;align-items:center;gap:8px;margin-bottom:-2px}.tab:hover{color:#3b82f6}.tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.tab-content{padding:20px;background:#fff}.settings-content{padding:10px}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.info-item{display:flex;flex-direction:column;gap:8px}.info-item label{font-weight:600;color:#475569;font-size:.9rem}.info-item span{color:#1e293b;font-size:1rem}.attributes-content{display:flex;flex-direction:column;gap:30px}.attribute-section h3{color:#1e293b;font-size:1.2rem;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e2e8f0}.attribute-list{display:flex;flex-direction:column;gap:10px}.attribute-item{display:grid;grid-template-columns:200px 1fr auto;gap:15px;padding:12px;background:#f8fafc;border-radius:6px;align-items:center}.attribute-key{font-weight:600;color:#475569;word-break:break-word}.attribute-value{color:#1e293b;word-break:break-all}.attribute-timestamp{color:#94a3b8;font-size:.85rem;white-space:nowrap}.timeseries-content h3{color:#1e293b;font-size:1.2rem;margin-bottom:20px}.search-box{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;width:300px;transition:border-color .2s}.search-box:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-box input{flex:1;border:none;outline:none;font-size:14px;background:transparent}.search-results-count{font-size:.85rem;color:#64748b;white-space:nowrap}.timeseries-keys{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px}.timeseries-key-item{display:flex;align-items:center;gap:10px;padding:15px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0;color:#1e293b;font-weight:500}.timeseries-key-item.clickable{cursor:pointer;transition:all .2s}.timeseries-key-item.clickable:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 6px #3b82f633}.timeseries-controls{background:#fff;padding:20px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:20px;flex-wrap:wrap}.time-window-selector{display:flex;align-items:center;gap:10px}.time-window-select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.time-window-select:focus{outline:none;border-color:#3b82f6}.custom-date-range{display:flex;gap:15px;align-items:center}.date-input-group{display:flex;align-items:center;gap:8px}.date-input-group label{font-weight:500;color:#475569}.date-input-group input{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:14px}.date-input-group input:focus{outline:none;border-color:#3b82f6}.refresh-button{padding:8px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s;margin-left:auto}.refresh-button:hover:not(:disabled){background:#2563eb}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.timeseries-details{background:#fff;padding:20px}.chart-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #e2e8f0;gap:15px;flex-wrap:wrap}.chart-type-selector{display:flex;gap:10px;background:#f1f5f9;padding:4px;border-radius:6px}.chart-type-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;color:#64748b;transition:all .2s}.chart-type-button:hover{background:#fff;color:#3b82f6}.chart-type-button.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.chart-container{background:#fff;border-radius:8px;padding:20px;margin-bottom:30px;box-shadow:0 1px 3px #0000001a}.data-stats{display:flex;gap:30px;padding:15px 20px;background:#f8fafc;border-radius:6px;margin-bottom:20px;font-size:.9rem;color:#475569}.data-stats strong{color:#1e293b;font-weight:600}.data-table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 1px 3px #0000001a;border-radius:6px;overflow:hidden}.data-table thead{background:#f1f5f9}.data-table th{padding:15px;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0}.data-table td{padding:12px 15px;border-bottom:1px solid #e2e8f0;color:#1e293b}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr:last-child td{border-bottom:none}.analytics-selection-container{display:flex;gap:20px;margin-bottom:30px;align-items:flex-start}.analytics-list-section{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden;min-width:0}.analytics-selection-container>.analytics-list-section:first-child{flex:0 0 40%}.analytics-selection-container>.analytics-list-section:last-child{flex:0 0 60%}.analytics-list-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;cursor:pointer;-webkit-user-select:none;user-select:none}.analytics-list-header:hover{background:#f1f5f9}.analytics-list-header h3{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.collapse-button{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;color:#64748b;transition:color .2s}.collapse-button:hover{color:#3b82f6}.analytics-search-box{display:flex;align-items:center;gap:8px;padding:10px 15px;background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#64748b}.analytics-search-input{flex:1;border:1px solid #e2e8f0;border-radius:4px;padding:6px 10px;font-size:.85rem;outline:none;transition:border-color .2s}.analytics-search-input:focus{border-color:#3b82f6}.analytics-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:15px;max-height:350px;overflow-y:auto}.analytics-item{padding:3px 5px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:4px;cursor:pointer;transition:all .2s;font-size:.8rem;font-weight:500;color:#475569;text-align:center;word-break:break-word;min-height:36px;display:flex;align-items:center;justify-content:center}.analytics-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px)}.analytics-item.selected{background:#dbeafe;border-color:#3b82f6;color:#1e40af;font-weight:600;box-shadow:0 2px 4px #3b82f633}.analytics-item.selected:hover{background:#bfdbfe;border-color:#2563eb}@media (max-width: 768px){.analytics-selection-container{flex-direction:column}.analytics-items-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}
