@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-base:#08090f;--bg-surface:#0e1018;--bg-elevated:#141722;--bg-card:#141722b3;--border:#ffffff12;--border-hover:#ffffff24;--text-primary:#f0f2ff;--text-secondary:#8b93b8;--text-muted:#4a5075;--indigo:#6366f1;--indigo-light:#818cf8;--indigo-dim:#6366f126;--cyan:#22d3ee;--cyan-dim:#22d3ee1f;--green:#10b981;--green-dim:#10b9811f;--amber:#f59e0b;--amber-dim:#f59e0b1f;--red:#ef4444;--red-dim:#ef44441f;--purple:#a855f7;--purple-dim:#a855f726;--grad-brand:linear-gradient(135deg, #6366f1 0%, #22d3ee 100%);--grad-card:linear-gradient(135deg, #6366f114 0%, #22d3ee0a 100%);--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 20px #00000080;--shadow-lg:0 8px 40px #0009;--shadow-glow:0 0 30px #6366f133;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--ease:cubic-bezier(.4, 0, .2, 1);--duration:.2s}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}.page-loader{min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;font-size:.875rem;display:flex}.loader-spinner{border:3px solid var(--border);border-top-color:var(--indigo);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.global-loader{z-index:9999;pointer-events:all;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.global-loader-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#08090f8c;position:absolute;inset:0}.global-loader-content{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);color:var(--text-secondary);flex-direction:column;align-items:center;gap:16px;padding:28px 36px;font-size:.875rem;display:flex;position:relative}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-bg{z-index:0;pointer-events:none;position:fixed;inset:0}.auth-bg-orb{filter:blur(80px);opacity:.35;border-radius:50%;animation:8s ease-in-out infinite float;position:absolute}.orb-1{background:radial-gradient(circle,#6366f1,#0000 70%);width:500px;height:500px;animation-delay:0s;top:-150px;left:-150px}.orb-2{background:radial-gradient(circle,#22d3ee,#0000 70%);width:400px;height:400px;animation-delay:-3s;bottom:-100px;right:-100px}.orb-3{opacity:.2;background:radial-gradient(circle,#a855f7,#0000 70%);width:300px;height:300px;animation-delay:-6s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.03)}}.auth-container{z-index:1;flex-direction:column;gap:32px;width:100%;max-width:440px;display:flex;position:relative}.auth-brand{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex}.auth-logo{filter:drop-shadow(0 0 16px #6366f180);width:56px;height:56px;animation:3s ease-in-out infinite pulse-glow}@keyframes pulse-glow{0%,to{filter:drop-shadow(0 0 16px #6366f180)}50%{filter:drop-shadow(0 0 28px #22d3ee99)}}.auth-title{background:var(--grad-brand);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:800}.auth-subtitle{color:var(--text-secondary);font-size:.875rem;font-weight:400}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-lg), inset 0 1px 0 #ffffff0d;animation:slide-up .5s var(--ease) both;padding:36px 32px}@keyframes slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.auth-card-header{margin-bottom:28px}.auth-card-header h2{color:var(--text-primary);letter-spacing:-.3px;margin-bottom:6px;font-size:1.375rem;font-weight:700}.auth-card-header p{color:var(--text-secondary);font-size:.875rem}.auth-form{flex-direction:column;gap:20px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.2px;font-size:.8125rem;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;transition:color var(--duration) var(--ease);align-items:center;display:flex;position:absolute;left:14px}.input-icon svg{width:16px;height:16px}.form-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:border-color var(--duration) var(--ease), background var(--duration) var(--ease), box-shadow var(--duration) var(--ease);background:#ffffff0a;outline:none;padding:12px 14px 12px 42px;font-size:.9rem;font-weight:400}.form-input:not(.form-select){padding-left:42px}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%238b93b8'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-left:14px}.form-input::placeholder{color:var(--text-muted)}.form-input:focus{border-color:var(--indigo);background:#6366f10f;box-shadow:0 0 0 3px #6366f126}.form-input:focus~.input-icon,.input-wrapper:focus-within .input-icon{color:var(--indigo-light)}.form-input:disabled{opacity:.5;cursor:not-allowed}.input-toggle-btn{color:var(--text-muted);transition:color var(--duration) var(--ease);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex;position:absolute;right:14px}.input-toggle-btn:hover{color:var(--text-secondary)}.input-toggle-btn svg{width:16px;height:16px}.auth-error{background:var(--red-dim);border-radius:var(--radius-sm);color:#fca5a5;animation:shake .4s var(--ease);border:1px solid #ef444440;align-items:center;gap:10px;padding:12px 14px;font-size:.85rem;display:flex}.auth-error svg{flex-shrink:0;width:16px;height:16px}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}60%{transform:translate(6px)}}.btn-primary{background:var(--grad-brand);color:#fff;border-radius:var(--radius-sm);width:100%;transition:opacity var(--duration) var(--ease), transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);border:none;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:.9rem;font-weight:600;display:inline-flex;box-shadow:0 4px 14px #6366f159}.btn-primary:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background var(--duration) var(--ease), color var(--duration) var(--ease), border-color var(--duration) var(--ease);background:#ffffff0d;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.875rem;font-weight:500;display:inline-flex}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-hover);background:#ffffff14}.btn-loading{pointer-events:none}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin}.auth-footer-note{color:var(--text-muted);text-align:center;margin-top:20px;font-size:.78rem;line-height:1.7}.dashboard-page{background:var(--bg-base);flex-direction:column;min-height:100vh;display:flex}.dashboard-header{z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);background:#08090fd9;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.dashboard-brand{align-items:center;gap:12px;display:flex}.dashboard-logo{width:32px;height:32px}.dashboard-brand-name{background:var(--grad-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.125rem;font-weight:700}.dashboard-user-info{align-items:center;gap:12px;display:flex}.user-avatar{background:var(--grad-brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:700;display:flex}.user-details{text-align:right;flex-direction:column;gap:2px;display:flex}.user-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.role-badge{letter-spacing:.3px;text-transform:uppercase;border-radius:20px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-block}.badge-purple{background:var(--purple-dim);color:#c084fc;border:1px solid #a855f74d}.badge-blue{background:var(--indigo-dim);color:var(--indigo-light);border:1px solid #6366f14d}.badge-green{background:var(--green-dim);color:#6ee7b7;border:1px solid #10b9814d}.btn-logout{color:#fca5a5;border-radius:var(--radius-sm);transition:background var(--duration) var(--ease), border-color var(--duration) var(--ease);background:#ef444414;border:1px solid #ef444433;align-items:center;gap:6px;padding:7px 14px;font-size:.8125rem;font-weight:500;display:inline-flex}.btn-logout:hover{background:#ef444424;border-color:#ef444459}.btn-logout svg{width:15px;height:15px}.dashboard-main{box-sizing:border-box;flex-direction:column;gap:28px;width:100%;min-width:0;max-width:1200px;margin:0 auto;padding:36px 32px;display:flex}.welcome-banner{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.welcome-text h1{color:var(--text-primary);letter-spacing:-.5px;font-size:1.75rem;font-weight:800;line-height:1.3}.welcome-text p{color:var(--text-secondary);margin-top:6px;font-size:.9rem}.highlight{background:var(--grad-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.welcome-banner .btn-primary{flex-shrink:0;width:auto}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color var(--duration) var(--ease), transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);animation:slide-up .5s var(--ease) both;align-items:center;gap:16px;padding:22px 24px;display:flex}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.stat-icon svg{width:20px;height:20px}.accent-indigo .stat-icon{background:var(--indigo-dim);color:var(--indigo-light)}.accent-cyan .stat-icon{background:var(--cyan-dim);color:var(--cyan)}.accent-green .stat-icon{background:var(--green-dim);color:var(--green)}.accent-amber .stat-icon{background:var(--amber-dim);color:var(--amber)}.stat-info{flex-direction:column;gap:3px;min-width:0;display:flex}.stat-value{color:var(--text-primary);font-size:1.125rem;font-weight:700}.stat-label{color:var(--text-secondary);font-size:.8rem}.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:slide-up .55s var(--ease) both;box-sizing:border-box;width:100%;min-width:0;max-width:100%;overflow:hidden}.info-card-header{border-bottom:1px solid var(--border);padding:20px 24px}.info-card-header h2{color:var(--text-primary);font-size:1rem;font-weight:600}.relay-parameters-summary{margin-bottom:20px}.relay-parameters-summary .info-card-header p{color:var(--text-secondary);margin-top:4px;font-size:.82rem}.relay-parameters-grid{box-sizing:border-box;grid-template-columns:repeat(auto-fit,minmax(min(100%,240px),1fr));gap:12px;max-width:100%;padding:20px 24px 24px;display:grid}.relay-parameter-card{border:1px solid var(--border);border-radius:var(--radius-md);overflow-wrap:anywhere;background:#ffffff08;min-width:0;padding:14px 16px}.relay-parameter-pin{color:var(--text-primary);margin-bottom:4px;font-size:.92rem;font-weight:700}.relay-parameter-meta{text-transform:uppercase;letter-spacing:.04em;color:var(--indigo-light);margin-bottom:6px;font-size:.72rem;font-weight:600}.relay-parameter-model{color:var(--text-secondary);margin-bottom:8px;font-size:.8rem}.relay-parameters-table th,.relay-parameters-table td{vertical-align:middle;padding:12px 10px}.relay-table-input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;min-width:0;color:var(--text-primary);transition:border-color var(--duration) var(--ease), background var(--duration) var(--ease);background:#ffffff0a;outline:none;padding:10px 12px;font-size:.86rem}.relay-table-input:focus{background:#ffffff0f;border-color:#6366f18c}.relay-table-input-number{min-width:88px;max-width:110px}.relay-enable-btn{border-radius:var(--radius-sm);border:1px solid var(--border);min-width:104px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease);background:#ffffff0a;padding:11px 18px;font-size:.84rem;font-weight:700}.relay-enable-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:#ffffff12}.relay-enable-btn-on{background:var(--green-dim);color:var(--green);border-color:#10b98159}.relay-enable-btn-on:hover{color:var(--green);background:#10b9812e;border-color:#10b98173}.relay-name-readonly,.relay-model-readonly{color:var(--text-primary);font-size:.86rem}.relay-parameter-value{color:var(--text-primary);font-size:.95rem;font-weight:600}.relay-parameter-behavior{color:var(--text-secondary);margin-top:6px;font-size:.78rem}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;display:grid}.info-item{border-right:1px solid var(--border);flex-direction:column;gap:6px;padding:18px 24px;display:flex}.info-item:last-child{border-right:none}.info-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.775rem;font-weight:500}.info-value{color:var(--text-primary);font-size:.9rem;font-weight:500}.status-active{color:var(--green);font-size:.825rem;font-weight:600}.coming-soon-card{background:var(--grad-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;animation:slide-up .6s var(--ease) both;flex-direction:column;align-items:center;gap:12px;padding:40px 32px;display:flex}.coming-soon-icon{font-size:2.5rem}.coming-soon-card h3{color:var(--text-primary);font-size:1.1rem;font-weight:700}.coming-soon-card p{color:var(--text-secondary);max-width:500px;font-size:.875rem;line-height:1.7}.toast{z-index:9999;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:toast-in .3s var(--ease) both;box-shadow:var(--shadow-lg);padding:14px 20px;font-size:.875rem;font-weight:500;position:fixed;bottom:32px;right:32px}.toast-success{color:#6ee7b7;background:#10b98126;border:1px solid #10b9814d}.toast-error{background:var(--red-dim);color:#fca5a5;border:1px solid #ef44444d}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fade-in .2s var(--ease) both;background:#000000b3;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:460px;max-height:calc(100vh - 48px);box-shadow:var(--shadow-lg);animation:modal-in .25s var(--ease) both;flex-direction:column;display:flex}.modal-card-wide{max-width:1100px}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:22px 26px 18px;display:flex}.modal-header h3{color:var(--text-primary);font-size:1rem;font-weight:700}.modal-close{color:var(--text-muted);transition:color var(--duration) var(--ease), background var(--duration) var(--ease);background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem}.modal-close:hover{color:var(--text-primary);background:#ffffff0d}.modal-card .auth-form{padding:22px 26px}.modal-card .form-input{padding-left:14px}.modal-error{margin:0 26px}.modal-body{min-height:0;padding:22px 26px;overflow-y:auto}.device-reading-layout{gap:20px;margin-top:24px;display:grid}.temperature-chart-card,.reading-table-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:#ffffff05;padding:18px}.temperature-chart-header,.reading-table-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;display:flex}.temperature-chart-header h4,.reading-table-header h4{color:var(--text-primary);font-size:.95rem;font-weight:700}.temperature-chart-header p,.reading-table-header p,.temperature-chart-range span{color:var(--text-secondary);font-size:.82rem}.temperature-chart-range{flex-wrap:wrap;gap:10px;display:flex}.temperature-chart{width:100%;height:auto;display:block}.temperature-chart-axis{stroke:#ffffff1f;stroke-width:1px}.temperature-chart-area{fill:url(#temperatureArea)}.temperature-chart-line{fill:none;stroke:#ff8c42;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.humidity-chart-line{fill:none;stroke:#168aad;stroke-width:3px;stroke-linecap:round;stroke-linejoin:round}.temperature-chart-point{fill:#ffe0cc;stroke:#ff8c42;stroke-width:2px}.sensor-charts-panel{gap:16px;width:100%;min-width:0;max-width:100%;display:grid}.sensor-charts-toolbar{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;min-width:0;max-width:100%;padding:14px 16px;display:flex;overflow:visible}.sensor-charts-toolbar h3{color:var(--text-primary);font-size:1rem;font-weight:700}.sensor-charts-toolbar p{color:var(--text-secondary);margin-top:4px;font-size:.82rem}.time-range-filters{flex-wrap:wrap;gap:8px;min-width:0;max-width:100%;display:flex}.time-range-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all var(--duration) var(--ease);background:#ffffff08;border-radius:999px;padding:7px 12px;font-size:.78rem;font-weight:600}.time-range-btn:hover{color:var(--text-primary);border-color:var(--border-hover);background:#ffffff0f}.time-range-btn-active{color:var(--text-primary);background:var(--indigo-dim);border-color:#6366f173;box-shadow:0 0 0 1px #6366f126}.custom-range-form{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.custom-range-field{flex-direction:column;flex:1;gap:6px;min-width:220px;display:flex}.custom-range-field .form-input{padding-left:12px}.custom-range-apply{width:auto;min-width:100px;padding:10px 18px}.sensor-charts-grid{grid-template-columns:minmax(0,1fr);gap:16px;width:100%;min-width:0;max-width:100%;display:grid}.metric-chart-card{border:1px solid var(--border);border-radius:var(--radius-lg);box-sizing:border-box;background:#ffffff05;width:100%;min-width:0;max-width:100%;padding:16px}.metric-chart-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.metric-chart-header h4{min-width:0;color:var(--text-primary);flex:180px;font-size:.92rem;font-weight:700}.metric-chart-unit{color:var(--text-muted);font-size:.78rem}.metric-chart-stats{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px 14px;margin-left:auto;display:flex}.metric-chart-stat{color:var(--text-secondary);align-items:baseline;gap:6px;font-size:.78rem;display:flex}.metric-chart-stat-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.72rem;font-weight:600}.metric-chart-stat strong{color:var(--text-primary);font-size:.84rem;font-weight:700}.metric-chart-stat-phase strong{color:var(--amber)}.metric-chart-stat-outage strong{color:var(--red)}.metric-chart-stat-relays strong{color:#22c55e}.metric-chart-relay-legend{color:var(--text-muted);padding:0 18px 14px;font-size:.76rem}.metric-chart-relay-legend span{align-items:center;gap:8px;display:inline-flex}.metric-chart-relay-dot{background:#22c55e;border-radius:999px;flex-shrink:0;width:10px;height:10px;display:inline-block}@media (width<=900px){.electricity-chart-stats,.metric-chart-stats{justify-content:flex-start;width:100%;margin-left:0}}.uplot-chart-tooltip-relays{color:#86efac;margin-top:4px;font-size:.82rem}.uplot-chart-tooltip-relays strong{color:#bbf7d0}.electricity-chart-header{align-items:flex-start}.electricity-chart-title-row{flex-wrap:wrap;flex:220px;align-items:center;gap:10px;min-width:0;display:flex}.electricity-chart-title-row h4{margin:0}.electricity-chart-stats{flex:100%;justify-content:flex-start;margin-left:0}.electricity-chart-header .electricity-status-badge{flex-shrink:0;margin-left:0}.metric-chart-container{width:100%;min-width:0;max-width:100%;min-height:180px;padding:0;position:relative;overflow:hidden}.metric-chart-container .uplot,.electricity-chart-container .uplot{max-width:100%;font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.metric-chart-container .u-wrap{max-width:100%}.uplot .u-legend,.metric-chart-container .u-legend,.electricity-chart-container .u-legend{display:none!important}.uplot-chart-tooltip{pointer-events:none;z-index:20;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid var(--border-hover);box-shadow:var(--shadow-md);color:var(--text-secondary);white-space:nowrap;padding:8px 12px;font-size:.78rem;display:none;position:absolute;top:0;left:0}.uplot-chart-tooltip-time{color:var(--text-muted);font-size:.72rem}.uplot-chart-tooltip-value{color:var(--text-primary);margin-top:4px}.uplot-chart-tooltip-value strong{font-weight:700}.uplot-chart-tooltip-gpio{color:var(--text-muted);margin-top:4px;font-size:.7rem}.electricity-status-card{grid-column:1/-1}.electricity-chart-container{min-height:200px;overflow:hidden}.electricity-chart-container .uplot{font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.electricity-chart-container .u-axis{font-size:11px}.electricity-chart-container .u-axis .u-label{fill:var(--text-secondary)}.electricity-status-badge{border:1px solid #0000;border-radius:999px;margin-left:auto;padding:6px 12px;font-size:.78rem;font-weight:700}.electricity-status-normal,.electricity-status-ok{color:var(--green);background:var(--green-dim);border-color:#10b98140}.electricity-status-warning,.electricity-status-phase_problem{color:var(--amber);background:var(--amber-dim);border-color:#f59e0b40}.electricity-status-critical,.electricity-status-outage{color:var(--red);background:var(--red-dim);border-color:#ef444440}.electricity-status-unknown{color:var(--text-secondary);border-color:var(--border);background:#ffffff0a}.electricity-status-alert{border-radius:var(--radius-md);flex-wrap:wrap;align-items:center;gap:6px 10px;margin-bottom:10px;padding:8px 12px;font-size:.8rem;display:flex}.electricity-status-alert strong{font-size:.84rem}.electricity-status-alert-warning,.electricity-status-alert-phase_problem{color:#fcd34d;background:#f59e0b1f;border:1px solid #f59e0b47}.electricity-status-alert-critical,.electricity-status-alert-outage{color:#fca5a5;background:#ef44441f;border:1px solid #ef444447}.electricity-status-alert-gpio{opacity:.9;font-size:.74rem}.electricity-status-legend{color:var(--text-secondary);flex-wrap:wrap;gap:14px;margin-top:12px;font-size:.74rem;display:flex}.electricity-status-legend span{align-items:center;gap:6px;display:inline-flex}.electricity-legend-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.electricity-legend-ok{background:var(--green)}.electricity-legend-warning{background:var(--amber)}.electricity-legend-critical{background:var(--red)}.reading-empty-state{border-radius:var(--radius-md);min-height:160px;color:var(--text-secondary);text-align:center;border:1px dashed #ffffff1f;justify-content:center;align-items:center;padding:24px;display:flex}.reading-table td,.reading-table th{white-space:nowrap}.reading-log-card .reading-table-header{margin-bottom:12px}.reading-log-scroll{border:1px solid var(--border);border-radius:var(--radius-md);max-height:520px;overflow-y:auto}.reading-log-scroll .reading-table thead th{z-index:1;background:var(--bg-elevated);position:sticky;top:0}.reading-log-sentinel{min-height:48px;color:var(--text-secondary);justify-content:center;align-items:center;padding:12px;font-size:.82rem;display:flex}.modal-footer{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.modal-footer .btn-primary{width:auto}.error-page{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.error-content{z-index:1;text-align:center;animation:slide-up .5s var(--ease) both;flex-direction:column;align-items:center;gap:16px;display:flex;position:relative}.error-code{background:var(--grad-brand);-webkit-text-fill-color:transparent;letter-spacing:-4px;opacity:.7;-webkit-background-clip:text;background-clip:text;font-size:8rem;font-weight:800;line-height:1}.error-title{color:var(--text-primary);font-size:1.75rem;font-weight:700}.error-message{color:var(--text-secondary);max-width:400px;font-size:.95rem;line-height:1.7}.error-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px;display:flex}.error-actions .btn-primary,.error-actions .btn-ghost{width:auto}.app-shell{background:var(--bg-base);grid-template-columns:280px 1fr;min-height:100vh;display:grid}.app-shell-content{min-width:0}.sidebar{border-right:1px solid var(--border);background:radial-gradient(circle at top left, #6366f129, transparent 35%), radial-gradient(circle at bottom right, #22d3ee14, transparent 30%), var(--bg-surface);flex-direction:column;gap:28px;height:100vh;padding:28px 20px;display:flex;position:sticky;top:0}.sidebar-brand{align-items:center;gap:14px;display:flex}.sidebar-caption{color:var(--text-secondary);font-size:.8rem}.sidebar-nav{flex-direction:column;gap:10px;display:flex}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:background var(--duration) var(--ease), border-color var(--duration) var(--ease), color var(--duration) var(--ease);border:1px solid #0000;align-items:center;padding:12px 14px;display:flex}.sidebar-link:hover{border-color:var(--border);color:var(--text-primary);background:#ffffff0d}.sidebar-link-active{color:var(--text-primary);background:#6366f124;border-color:#6366f147;box-shadow:inset 0 1px #ffffff0a}.sidebar-footer{flex-direction:column;gap:14px;margin-top:auto;display:flex}.sidebar-user-card{border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffff0a;align-items:center;gap:12px;padding:14px;display:flex}.sidebar-user-details{text-align:left}.sidebar-logout{justify-content:center}.mobile-topbar,.sidebar-backdrop,.sidebar-mobile-header,.sidebar-close-btn,.sidebar-brand-desktop{display:none}.page-heading{justify-content:space-between;align-items:flex-start;gap:16px;margin-top:18px;display:flex}.btn-back{border-radius:var(--radius-md);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--duration) var(--ease);background:#ffffff08;align-items:center;gap:8px;padding:8px 12px 8px 8px;font-size:.86rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-back:hover{color:var(--text-primary);border-color:var(--border-hover);background:#ffffff0f;transform:translate(-2px)}.btn-back-icon{flex-shrink:0;width:18px;height:18px}.page-heading h1{font-size:1.7rem;line-height:1.2}.page-heading p{color:var(--text-secondary);margin-top:8px}.dashboard-actions{flex-wrap:wrap;gap:12px;display:flex}.dashboard-link-button{width:auto}.management-grid{grid-template-columns:minmax(280px,420px);display:grid}.form-panel{padding:24px}.form-input-plain{padding-left:14px}.form-textarea{resize:vertical;min-height:110px}.entity-table-wrapper{-webkit-overflow-scrolling:touch;width:100%;min-width:0;max-width:100%;overflow-x:auto}.entity-table-scroll-hint{display:none}@media (width<=768px){.entity-table-scroll-hint{color:var(--text-muted);padding:8px 16px 0;font-size:.72rem;display:block}}.entity-table{border-collapse:collapse;width:100%;min-width:860px}.entity-table th,.entity-table td{text-align:left;border-bottom:1px solid var(--border);vertical-align:top;padding:16px 20px}.entity-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;font-weight:600}.entity-table td{color:var(--text-primary);font-size:.9rem}.table-actions{flex-wrap:wrap;gap:8px;display:flex}.btn-small{width:auto;padding:8px 12px;font-size:.78rem}.btn-danger{color:#fca5a5;border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef44443d}.btn-danger:hover{background:#ef444429;border-color:#ef444459}.status-inactive{color:#fca5a5;font-size:.825rem;font-weight:600}.status-online,.status-offline{align-items:center;gap:6px;font-size:12px;font-weight:700;display:inline-flex}.status-online:before,.status-offline:before{content:"";border-radius:50%;width:8px;height:8px}.status-online{color:#16803c}.status-online:before{background:#22c55e}.status-offline{color:#b42318}.status-offline:before{background:#ef4444}.empty-row{text-align:center;color:var(--text-secondary)}.detail-list{color:var(--text-primary);flex-direction:column;gap:12px;display:flex}.device-detail-summary{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:20px;padding:14px 16px;display:flex}.device-detail-summary-item{align-items:center;gap:8px;font-size:.9rem;display:flex}.device-detail-label{color:var(--text-secondary);font-weight:600}.device-details-toggle{margin-left:auto}.device-detail-panel{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff05;margin-bottom:20px;padding:16px}.device-detail-tabs{scrollbar-width:thin;gap:0;width:100%;min-width:0;max-width:100%;margin:0;padding:0;list-style:none;display:flex;overflow-x:auto}.device-detail-tab{border:1px solid var(--border);border-bottom:1px solid var(--border);border-radius:var(--radius-md) var(--radius-md) 0 0;min-width:88px;min-height:44px;color:var(--text-secondary);text-align:center;white-space:nowrap;z-index:1;transition:background var(--duration) var(--ease), color var(--duration) var(--ease);background:#ffffff08;flex:1 0 auto;justify-content:center;align-items:center;margin-right:-1px;padding:10px 14px;font-size:.8rem;font-weight:600;text-decoration:none;display:flex;position:relative}.device-detail-tab:last-child{margin-right:0}.device-detail-tab:hover:not(.device-detail-tab-active){color:var(--text-primary);background:#ffffff0f}.device-detail-tab-active{color:var(--text-primary);z-index:3;background:#ffffff0f;border-bottom-color:#ffffff0f}.device-tab-shell{width:100%;min-width:0;max-width:100%;margin-top:20px}.device-tab-content{border:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);z-index:2;box-sizing:border-box;background:#ffffff0f;width:100%;min-width:0;max-width:100%;margin-top:-1px;padding:20px;position:relative;overflow-x:hidden}.device-tab-content .reading-table-card,.device-tab-content .info-card,.device-tab-content .metric-chart-card{background:#ffffff05}.device-parameters-panel{gap:20px;width:100%;min-width:0;max-width:100%;display:grid}.device-parameters-panel form{min-width:0;max-width:100%}.device-details-panel .device-detail-panel{background:0 0;border:none;margin-bottom:0;padding:20px 24px 24px}.example-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;padding:20px 24px 24px;display:grid}.example-card{text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--duration) var(--ease), background var(--duration) var(--ease), transform var(--duration) var(--ease);background:#ffffff08;padding:16px}.example-card:hover{border-color:var(--border-hover);background:#ffffff0d;transform:translateY(-1px)}.example-title{font-size:.92rem;font-weight:600;display:block}.example-meta{color:var(--text-secondary);margin-top:8px;font-size:.78rem;display:block}.checkbox-list{border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff08;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.checkbox-item{color:var(--text-primary);align-items:flex-start;gap:10px;font-size:.9rem;display:flex}.checkbox-item input{margin-top:3px}.checkbox-item span{flex-direction:column;gap:2px;display:flex}.checkbox-meta,.helper-text{color:var(--text-secondary);font-size:.78rem}@media (width<=900px){.modal-card-wide{max-width:100%}.temperature-chart-header,.reading-table-header,.sensor-charts-toolbar{flex-direction:column;align-items:stretch}.time-range-filters{-webkit-overflow-scrolling:touch;scrollbar-width:thin;flex-wrap:nowrap;width:100%;padding-bottom:4px;overflow-x:auto}.time-range-btn{flex-shrink:0}.device-detail-tab{min-height:42px;padding:10px 12px;font-size:.74rem}.device-tab-content{padding:14px}.electricity-chart-title-row,.electricity-chart-stats,.metric-chart-stats{justify-content:flex-start;width:100%;margin-left:0}.management-grid{grid-template-columns:1fr}.modal-footer{flex-direction:column;align-items:stretch}.modal-footer .btn-primary,.modal-footer .btn-ghost{width:100%}}@media (width<=768px){html,body{overflow-x:hidden}.mobile-topbar{z-index:120;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);background:#08090feb;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.mobile-menu-btn,.sidebar-close-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--text-primary);background:#ffffff0a;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.mobile-menu-btn svg,.sidebar-close-btn svg{width:20px;height:20px}.mobile-topbar-brand{flex-direction:column;gap:2px;min-width:0;display:flex}.mobile-topbar-title{color:var(--text-primary);font-size:.95rem;font-weight:700}.mobile-topbar-caption{color:var(--text-secondary);font-size:.72rem}.sidebar-backdrop{z-index:180;cursor:pointer;background:#0000008c;border:none;display:block;position:fixed;inset:0}.app-shell{grid-template-columns:1fr;min-width:0}.app-shell-content{min-width:0;overflow-x:hidden}.sidebar{z-index:200;width:min(300px,88vw);height:100vh;transition:transform .25s var(--ease);border-right:1px solid var(--border);border-bottom:none;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transform:translate(-105%)}.sidebar.sidebar-open{box-shadow:var(--shadow-lg);transform:translate(0)}.sidebar-mobile-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.sidebar-brand-desktop{display:none}.sidebar-close-btn{display:inline-flex}.sidebar-nav{flex-flow:column}.sidebar-link{width:100%}.dashboard-main{gap:18px;padding:16px}.page-heading{flex-direction:column;margin-top:8px}.page-heading h1{font-size:1.35rem}.page-heading p{font-size:.84rem}.device-detail-summary{flex-direction:column;align-items:flex-start;gap:10px}.device-tab-shell{margin-top:14px}.device-tab-content{border-radius:0 0 var(--radius-md) var(--radius-md);padding:12px}.metric-chart-card{padding:12px}.sensor-charts-toolbar{gap:12px;padding:12px}.time-range-filters{-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scrollbar-width:none;flex-wrap:nowrap;gap:6px;width:100%;padding-bottom:6px;overflow-x:auto}.time-range-filters::-webkit-scrollbar{display:none}.time-range-btn{scroll-snap-align:start;flex-shrink:0;padding:6px 10px;font-size:.72rem}.electricity-chart-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 10px;display:grid}.electricity-chart-title-row h4{font-size:.88rem;line-height:1.3}.device-detail-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none}.device-detail-tabs::-webkit-scrollbar{display:none}.metric-chart-container .u-axis text,.electricity-chart-container .u-axis text{font-size:10px}.info-card-header{padding:14px 16px}.info-card-header h2{font-size:.95rem}.info-card-header p{font-size:.78rem;line-height:1.45}.relay-parameters-grid{grid-template-columns:1fr;padding:12px 14px 16px}.relay-parameters-summary{margin-bottom:0}.device-parameters-panel{gap:14px}.custom-range-form{flex-direction:column;align-items:stretch;padding:12px}.custom-range-field{width:100%;min-width:0}.custom-range-apply{width:100%}.entity-table{min-width:640px}.relay-parameters-table{min-width:700px}.reading-table{min-width:520px}.entity-table th,.entity-table td{padding:12px 14px;font-size:.84rem}.electricity-status-legend{flex-direction:column;align-items:flex-start;gap:8px;font-size:.72rem}.metric-chart-stat{font-size:.74rem}.metric-chart-stat-label{font-size:.64rem}.metric-chart-header h4{flex:100%}.metric-chart-relay-legend{padding:0 4px 10px;font-size:.7rem}.uplot-chart-tooltip{white-space:normal;max-width:min(260px,88vw)}.electricity-status-legend span:nth-child(n+2){display:none}.reading-log-scroll{max-height:min(60vh,480px)}.auth-card{padding:28px 20px}.error-code{font-size:5rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.info-grid{grid-template-columns:1fr 1fr}.info-item{border-right:none;border-bottom:1px solid var(--border)}.welcome-text h1{font-size:1.375rem}}@media (width<=480px){.dashboard-main{gap:14px;padding:12px}.mobile-topbar{padding:10px 12px}.page-heading h1{font-size:1.15rem}.device-detail-tab{min-width:68px;padding:8px 10px;font-size:.68rem}.time-range-btn{padding:6px 10px;font-size:.7rem}.stats-grid,.info-grid{grid-template-columns:1fr}.welcome-banner{flex-direction:column}.welcome-banner .btn-primary{width:100%}.dashboard-actions{flex-direction:column;width:100%}.dashboard-link-button,.table-actions .btn-ghost,.table-actions .btn-danger{width:100%}.relay-enable-btn{min-width:68px;padding:8px 10px;font-size:.72rem}.electricity-status-badge{padding:5px 10px;font-size:.72rem}.btn-back{padding:7px 10px 7px 7px;font-size:.8rem}.auth-container{padding:16px}.auth-card{padding:24px 16px}.auth-title{font-size:1.45rem}}.uplot,.uplot *,.uplot :before,.uplot :after{box-sizing:border-box}.uplot{width:min-content;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}.u-title{text-align:center;font-size:18px;font-weight:700}.u-wrap{-webkit-user-select:none;user-select:none;position:relative}.u-over,.u-under{position:absolute}.u-under{overflow:hidden}.uplot canvas{width:100%;height:100%;display:block;position:relative}.u-axis{position:absolute}.u-legend{text-align:center;margin:auto;font-size:14px}.u-inline{display:block}.u-inline *{display:inline-block}.u-inline tr{margin-right:16px}.u-legend th{font-weight:600}.u-legend th>*{vertical-align:middle;display:inline-block}.u-legend .u-marker{width:1em;height:1em;margin-right:4px;background-clip:padding-box!important}.u-inline.u-live th:after{content:":";vertical-align:middle}.u-inline:not(.u-live) .u-value{display:none}.u-series>*{padding:4px}.u-series th{cursor:pointer}.u-legend .u-off>*{opacity:.3}.u-select{pointer-events:none;background:#00000012;position:absolute}.u-cursor-x,.u-cursor-y{pointer-events:none;will-change:transform;position:absolute;top:0;left:0}.u-hz .u-cursor-x,.u-vt .u-cursor-y{border-right:1px dashed #607d8b;height:100%}.u-hz .u-cursor-y,.u-vt .u-cursor-x{border-bottom:1px dashed #607d8b;width:100%}.u-cursor-pt{pointer-events:none;will-change:transform;border:0 solid;border-radius:50%;position:absolute;top:0;left:0;background-clip:padding-box!important}.u-axis.u-off,.u-select.u-off,.u-cursor-x.u-off,.u-cursor-y.u-off,.u-cursor-pt.u-off{display:none}
