@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&family=JetBrains+Mono&display=swap";:root{font-family:Poppins,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0c0c0d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:radial-gradient(circle at top left,#1a1b26,#0c0c0d);background-attachment:fixed}:root{--sidebar-width: 250px;--bg-color: #080809;--panel-bg: rgba(18, 18, 23, .7);--accent-primary: #8833ff;--accent-secondary: #00ccff;--text-primary: #f8fafc;--text-secondary: #94a3b8;--border-color: rgba(255, 255, 255, .08);--success: #10b981;--error: #ef4444;--warning: #f59e0b;--info: #3b82f6}:root{font-family:Poppins,sans-serif;color-scheme:dark;background-color:var(--bg-color);color:var(--text-primary)}body{margin:0;min-height:100vh;background:radial-gradient(circle at 0% 0%,#1a1b26,#080809);background-attachment:fixed}#root{width:100%}*{box-sizing:border-box}.dashboard-layout{display:flex;min-height:100vh;width:100%}.sidebar{width:var(--sidebar-width);background:#0f0f13;border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:35px 20px;position:fixed;height:100vh;z-index:100}.sidebar-header{display:flex;align-items:center;gap:12px;margin-bottom:50px;font-weight:700;font-size:19px;color:#fff}.app-logo{width:40px;height:40px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 5px 15px #8833ff4d}.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:#475569;margin:20px 0 10px 15px;font-weight:600}.sidebar-nav{display:flex;flex-direction:column;gap:6px;flex-grow:1}.sidebar-nav button{display:flex;align-items:center;gap:12px;padding:13px 18px;border-radius:14px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px;text-align:left;font-weight:500}.sidebar-nav button:hover{background:#ffffff0a;color:#fff;transform:translate(4px)}.sidebar-nav button.active{background:#8833ff1f;color:#c084fc;font-weight:600;box-shadow:inset 0 0 0 1px #83f3}.sidebar-footer{padding-top:25px;border-top:1px solid var(--border-color)}.admin-card{display:flex;align-items:center;gap:12px;background:#ffffff08;padding:12px;border-radius:16px}.admin-avatar{width:38px;height:38px;background:var(--accent-primary);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700}.admin-info{display:flex;flex-direction:column;flex-grow:1}.admin-name{font-size:13px;font-weight:600;color:#fff}.admin-role{font-size:11px;color:var(--text-secondary)}.logout-icon-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:all .2s}.logout-icon-btn:hover{background:#ef44441a;color:var(--error)}.content{margin-left:var(--sidebar-width);flex-grow:1;padding:50px;max-width:1400px;width:100%}.top-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:50px}.breadcrumb{font-size:12px;color:var(--text-secondary);margin:0 0 8px;letter-spacing:.5px}.top-header h1{font-size:32px;margin:0;font-weight:700;letter-spacing:-1px}.header-actions{display:flex;align-items:center;gap:20px}.status-badge{background:#10b9811a;color:var(--success);font-size:12px;font-weight:600;padding:8px 16px;border-radius:30px;display:flex;align-items:center;gap:8px;border:1px solid rgba(16,185,129,.2)}.pulse{width:8px;height:8px;background:var(--success);border-radius:50%;animation:pulse 1.5s infinite}@keyframes pulse{0%{transform:scale(1);opacity:1;box-shadow:0 0 #10b98166}70%{transform:scale(1.1);opacity:1;box-shadow:0 0 0 10px #10b98100}to{transform:scale(1);opacity:1}}.time-display{font-size:14px;color:var(--text-secondary);font-weight:500}.dashboard-grid{display:flex;flex-direction:column;gap:35px}.card{border-radius:28px;padding:30px;border:1px solid var(--border-color);box-shadow:0 20px 40px -10px #0003}.card.glass{background:var(--panel-bg);backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.card h3{margin:0;font-size:18px;font-weight:600;color:#fff}.bottom-row{display:grid;grid-template-columns:1fr 1fr;gap:35px}.table-card{background:linear-gradient(135deg,#1e1f32d9,#12121cf2)!important;border:1px solid rgba(136,51,255,.2)!important;border-top:3px solid var(--accent-primary)!important;box-shadow:0 15px 30px #0006!important}.table-card th{background:#8833ff14;color:#c084fc;border-bottom:1px solid rgba(136,51,255,.15);font-weight:600}.table-card td{border-bottom:1px solid rgba(255,255,255,.04)}.table-card tbody tr:hover td{background:#8833ff0d}.table-wrapper{margin-top:10px;overflow-x:auto}.max-height-table{max-height:400px;overflow-y:auto}table{width:100%;border-collapse:collapse;text-align:left}th{padding:15px;border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-weight:500;font-size:13px;background:#0000001a}td{padding:18px 15px;border-bottom:1px solid var(--border-color);font-size:14px;color:#e2e8f0}.premium-table tr:hover{background:#ffffff05}.status-toggle-btn{background:#2d2d39;border:1px solid rgba(255,255,255,.05);color:#fca5a5;padding:6px 16px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;width:65px;transition:all .3s}.status-toggle-btn.active{background:var(--success);color:#fff;box-shadow:0 4px 12px #10b9814d}.badge{padding:5px 12px;border-radius:8px;font-size:12px;font-weight:600}.badge.warning{background:#f59e0b26;color:#fbbf24}.badge.info{background:#3b82f626;color:#60a5fa}.unit-badge{background:#94a3b81a;padding:3px 8px;border-radius:6px;font-size:11px;color:var(--text-secondary)}.mono{font-family:JetBrains Mono,monospace}.highlight{color:var(--accent-primary);font-weight:600}.date-cell{font-weight:600;font-size:13px}.time-sub{font-size:11px;color:var(--text-secondary)}.event-msg{color:#cbd5e1;font-size:13px}.input-cell input{width:80px;background:#0000004d;border:1px solid var(--border-color);color:#fff;padding:8px 12px;border-radius:10px;font-size:13px;outline:none}.input-cell input:focus{border-color:var(--accent-primary);background:#00000080}.checkbox-box{width:24px;height:24px;border:1px solid var(--border-color);border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .3s}.checkbox-box.checked{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.icon-btn{background:#ffffff0d;border:1px solid var(--border-color);width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer}.primary-btn-sm{background:var(--accent-primary);border:none;padding:8px 16px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;color:#fff}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;position:relative;overflow:hidden}.blob{position:absolute;filter:blur(100px);opacity:.1;z-index:0}.blob-1{width:500px;height:500px;background:var(--accent-primary);top:-200px;left:-200px}.blob-2{width:400px;height:400px;background:var(--accent-secondary);bottom:-150px;right:-150px}.blob-3{width:300px;height:300px;background:#f07;top:40%;right:20%}.glass-card{width:100%;max-width:420px;background:#14151ecc;-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border-radius:32px;padding:60px 45px;border:1px solid var(--border-color);z-index:10;text-align:center}.login-form{display:flex;flex-direction:column;gap:18px;margin:30px 0}.input-group{position:relative}.input-icon{position:absolute;left:16px;top:15px;color:#475569}.login-form input{width:100%;background:#0003;border:1px solid var(--border-color);padding:15px 15px 15px 50px;border-radius:16px;color:#fff;font-size:15px;outline:none}.login-btn{background:linear-gradient(135deg,var(--accent-primary) 0%,#6d28d9 100%);border:none;padding:16px;border-radius:16px;font-weight:700;color:#fff;cursor:pointer;transition:all .3s}.login-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #83f6}.spinner{width:20px;height:20px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;display:inline-block}.filter-bar{display:flex;gap:20px;align-items:center;padding:15px 30px!important;margin-bottom:5px}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-size:13px;color:var(--text-secondary);font-weight:600}.filter-group input{background:#0003;border:1px solid var(--border-color);color:#fff;padding:8px 12px;border-radius:10px;font-size:13px}.alert-border{border-left:5px solid var(--error)!important;background:#ef44440d!important}.warning-border{border-left:5px solid var(--warning)!important;background:#f59e0b0d!important}.safe-border{border-left:5px solid var(--success)!important;background:#10b9810d!important}.text-error{color:var(--error)!important}.text-warning{color:var(--warning)!important}.text-success{color:var(--success)!important}.limit-alert{background:var(--error);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;width:fit-content}.safe-badge{background:var(--success);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:4px;width:fit-content}.threshold-legend{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.monitor-grid{display:flex;flex-direction:row;flex-wrap:wrap;gap:20px}.monitor-card{flex:1 1 calc(33.333% - 20px);min-width:250px;padding:20px!important;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:10px;border-left:4px solid var(--accent-primary)!important}.monitor-label{font-size:13px;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.monitor-value-row{display:flex;align-items:baseline;gap:6px}.monitor-main-value{font-size:28px;font-weight:700;color:#fff}.monitor-unit{font-size:14px;color:var(--text-secondary)}.monitor-stats{display:flex;justify-content:space-between;border-top:1px solid var(--border-color);padding-top:10px;margin-top:5px}.stat{font-size:11px;color:var(--text-secondary)}.stat span{color:#fff;font-weight:600;display:block}.status-dot{position:absolute;top:15px;right:15px;width:8px;height:8px;border-radius:50%}.alerts-container{position:fixed;top:30px;right:30px;z-index:9999;display:flex;flex-direction:column;gap:15px;max-width:350px}.floating-alert{background:#ef4444e6!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;padding:16px 20px;border-radius:16px;display:flex;gap:15px;align-items:flex-start;box-shadow:0 10px 25px #ef44444d;position:relative;min-width:300px;border-left:5px solid rgba(255,255,255,.4);transition:background .3s}.floating-alert.alert-success{background:#10b981e6!important;box-shadow:0 10px 25px #10b9814d}.alert-icon-box{background:#fff3;padding:8px;border-radius:12px}.alert-content strong{display:block;font-size:14px;margin-bottom:2px;text-transform:uppercase;letter-spacing:.5px}.alert-content p{font-size:13px;margin:0;opacity:.9}.close-alert{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;opacity:.6;position:absolute;top:10px;right:12px}.close-alert:hover{opacity:1}.modbus-container{display:flex;flex-direction:column;gap:20px}.station-selector{display:flex;align-items:center;gap:15px;padding:15px 30px!important}.station-selector select{background:#0000004d;border:1px solid var(--border-color);color:#fff;padding:8px 12px;border-radius:10px;font-size:14px;outline:none;cursor:pointer}.table-input{background:#8833ff08;border:1px solid var(--border-color);color:#fff;padding:8px 10px;border-radius:8px;font-size:13px;width:100%;outline:none;transition:all .2s}.table-input:focus{border-color:var(--accent-primary);background:#8833ff14;box-shadow:0 0 0 2px #83f3}.alert-input{border-color:#ef44444d;color:var(--error)!important;font-weight:600}.alert-input:focus{border-color:var(--error);box-shadow:0 0 0 2px #ef444433}.premium-table select.table-input{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:30px}.modbus-table td{vertical-align:middle}.config-name{font-weight:600;color:#e2e8f0;font-size:14px}.config-desc{font-size:11px;color:var(--text-secondary);margin-top:3px}.warning-input{border-color:#f59e0b4d;color:#fbbf24!important;font-weight:600}.warning-input:focus{border-color:var(--warning);box-shadow:0 0 0 2px #f59e0b33}.device-meta{font-size:12px;color:var(--text-secondary);margin-left:8px}.save-btn{display:flex;align-items:center;gap:6px}.text-center{text-align:center}
