*{box-sizing:border-box}button{font-family:inherit}.dash-page{padding:36px;max-width:1800px;margin:0 auto;color:#1f2937;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:#f9fafb;min-height:100vh}.dash-hero{margin-bottom:24px}.dash-title{margin:0 0 6px;font-size:2rem;font-weight:700;color:#414141}.dash-subtitle{margin:0;color:#6b7280;font-size:1rem}.dash-actions{display:flex;gap:12px;flex-wrap:wrap;margin:22px 0 26px}.dash-main-btn{background:#10b981;color:#fff;padding:12px 18px;border:1px solid #10b981;border-radius:10px;cursor:pointer;min-width:190px;font-size:.92rem;font-weight:600;transition:all .18s}.dash-main-btn:hover{background:#059669;border-color:#059669}.dash-panel{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px 22px;margin-bottom:20px;box-shadow:0 1px 2px #00000008}.dash-panel-sidebar{margin-bottom:0;height:100%}.dash-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.dash-panel-title{margin:0;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;color:#535353;font-weight:600}.dash-status-box{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap}.dash-status-label{color:#6b7280;font-size:.95rem;font-weight:600}.dash-status-badge{padding:8px 14px;border-radius:999px;font-size:.78rem;font-weight:700;letter-spacing:.06em}.dash-status-badge-online{background:#d1fae5;color:#047857;border:1px solid #a7f3d0}.dash-status-badge-offline{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.dash-layout{display:grid;gap:20px;align-items:start}.dash-layout-no-detail{grid-template-columns:280px minmax(0,1fr)}.dash-layout-with-detail{grid-template-columns:280px minmax(0,1fr) 380px}.dash-sidebar,.dash-detail-sidebar{position:sticky;top:20px}.dash-content{min-width:0}.dash-panel-header-sidebar{align-items:flex-start}.dash-sidebar-counter{margin-top:6px;font-size:.82rem;color:#6b7280;font-weight:600}.dash-sidebar-search-wrap{margin-bottom:12px}.dash-device-visibility-list{display:flex;flex-direction:column;gap:10px}.dash-device-visibility-item{width:100%;text-align:left;border-radius:12px;padding:14px;border:1px solid #e5e7eb;cursor:pointer;transition:background .18s,border-color .18s,transform .18s,box-shadow .18s;position:relative}.dash-device-visibility-item:hover{transform:translateY(-1px);box-shadow:0 4px 10px #0000000a}.dash-device-visibility-item-active{background:#dcfce7;border-color:#86efac;box-shadow:inset 0 0 0 1px #16a34a14}.dash-device-visibility-item-inactive{background:#f3f4f6;border-color:#e5e7eb}.dash-device-visibility-name{font-weight:700;color:#1f2937;margin-bottom:4px}.dash-device-visibility-item-active .dash-device-visibility-name{color:#166534}.dash-device-visibility-item-inactive .dash-device-visibility-name{color:#374151}.dash-device-visibility-id{font-size:.82rem;color:#6b7280;word-break:break-word}.dash-device-visibility-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.dash-mini-status{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 8px;font-size:.68rem;font-weight:700;letter-spacing:.04em;white-space:nowrap}.dash-mini-status-online{background:#d1fae5;color:#047857;border:1px solid #a7f3d0}.dash-mini-status-offline{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.dash-devices-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;width:100%;align-items:stretch}.dash-device-card{background:#fff;border:1px solid #d1d5db;border-radius:14px;padding:22px;display:flex;flex-direction:column;gap:18px;box-shadow:0 2px 10px #0000000a;min-width:0;scroll-margin-top:20px;transition:border-color .2s,box-shadow .2s,transform .2s}.dash-device-card-compact{min-height:250px}.dash-device-card-compact .dash-component-card{height:100%;justify-content:space-between}.dash-device-card-highlighted{border-color:#34d399!important;box-shadow:0 0 0 3px #34d3992e,0 6px 18px #10b9811a}.dash-device-card-top{display:flex;flex-direction:column;gap:10px}.dash-device-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dash-device-card-title{margin:0;font-size:1.15rem;font-weight:700;color:#414141}.dash-device-edit-row{display:flex;align-items:center;gap:10px}.dash-device-meta{display:flex;flex-direction:column;gap:8px}.dash-meta-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;font-size:.92rem}.dash-meta-row:last-child{border-bottom:none}.dash-meta-row span{color:#6b7280}.dash-meta-row strong{color:#1f2937;text-align:right}.dash-device-online{color:#059669!important}.dash-device-offline{color:#dc2626!important}.dash-device-section{display:flex;flex-direction:column;gap:12px}.dash-device-section-title{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:#535353;font-weight:700}.dash-component-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:12px;transition:border-color .18s,box-shadow .18s,transform .18s;min-width:0}.dash-component-card-control{background:#f9fafb}.dash-component-card-sensor{background:#f8fafc}.dash-component-card-control:hover,.dash-component-card-sensor:hover{box-shadow:0 4px 12px #10b98112}.dash-component-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.dash-component-title{font-weight:700;color:#1f2937;line-height:1.35}.dash-component-subline{margin-top:6px}.dash-component-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.dash-component-edit-row{display:flex;align-items:center;gap:10px}.dash-badge{display:inline-flex;align-items:center;justify-content:center;min-width:58px;padding:5px 10px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.05em;border:1px solid transparent}.dash-badge-on{background:#d1fae5;color:#047857;border-color:#a7f3d0}.dash-badge-off{background:#fee2e2;color:#b91c1c;border-color:#fecaca}.dash-badge-muted{background:#f3f4f6;color:#6b7280;border-color:#e5e7eb}.dash-component-metrics{display:flex;gap:10px}.dash-component-metrics-compact{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.dash-metric-card{flex:1;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:6px;min-width:0}.dash-metric-card-highlight{border-color:#a7f3d0;background:#f0fdf4}.dash-metric-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:#6b7280}.dash-metric-value{font-size:1rem;font-weight:700;color:#111827;font-family:Courier New,monospace;word-break:break-word}.dash-empty-features{padding:14px 16px;border:1px dashed #d1d5db;border-radius:10px;color:#9ca3af;background:#f9fafb}.dash-control-row,.dash-expanded-status-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.dash-control-label{font-size:.84rem;font-weight:600;color:#4b5563}.dash-brightness-block{display:flex;flex-direction:column;gap:8px}.dash-brightness-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.dash-brightness-value{font-size:.9rem;font-weight:700;color:#059669;font-family:Courier New,monospace}.dash-text-input{width:100%;flex:1;background:#fff;color:#1f2937;border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;font-size:14px;outline:none;box-shadow:0 1px 2px #00000008}.dash-text-input:hover{border-color:#9ca3af}.dash-text-input:focus{border-color:#34d399;box-shadow:0 0 0 3px #34d3992e}.dash-icon-btn{width:32px;height:32px;border-radius:9999px;border:1px solid #10b981;background:#10b981;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin:0;flex-shrink:0;transition:all .18s}.dash-icon-btn:hover{background:#059669;border-color:#059669}.dash-icon-btn:disabled{opacity:.55;cursor:not-allowed}.dash-icon-btn-secondary{background:#2563eb;border-color:#2563eb}.dash-icon-btn-secondary:hover{background:#1d4ed8;border-color:#1d4ed8}.dash-icon-btn-danger{background:#ef4444;border-color:#ef4444}.dash-icon-btn-danger:hover{background:#dc2626;border-color:#dc2626}.dash-icon-btn-success{background:#10b981;border-color:#10b981}.dash-details-btn{background:#2563eb;color:#fff;border:1px solid #2563eb;border-radius:10px;padding:8px 12px;font-size:.84rem;font-weight:600;cursor:pointer;transition:all .18s}.dash-details-btn:hover{background:#1d4ed8;border-color:#1d4ed8}.dash-switch{position:relative;display:inline-block;width:60px;height:34px}.dash-switch input{opacity:0;width:0;height:0;position:absolute}.dash-switch-slider{position:absolute;inset:0;background-color:#cbd5e1;border-radius:34px;transition:.3s;cursor:pointer}.dash-switch-slider:before{content:"";position:absolute;height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;border-radius:50%;transition:.3s}.dash-switch input:checked+.dash-switch-slider{background-color:#10b981}.dash-switch input:checked+.dash-switch-slider:before{transform:translate(26px)}.dash-switch input:disabled+.dash-switch-slider{opacity:.7;cursor:not-allowed}.dash-range{width:100%;accent-color:#10b981;cursor:pointer}.dash-led-section{margin-top:2px;padding-top:16px;border-top:1px solid #e5e7eb}.dash-led-section-right{margin-top:8px}.dash-led-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#535353;font-weight:600;margin-bottom:12px}.dash-led-controls{display:flex;gap:10px;align-items:center}.dash-color-input{width:100%;height:44px;border:1px solid #d1d5db;border-radius:10px;padding:4px;background:#fff;cursor:pointer}.dash-led-btn{background:#10b981;color:#fff;border:1px solid #10b981;border-radius:10px;padding:11px 18px;cursor:pointer;min-width:170px;font-weight:600;transition:all .18s}.dash-led-btn:hover:not(:disabled){background:#059669;border-color:#059669}.dash-led-btn:disabled{opacity:.6;cursor:not-allowed}.dash-expanded-panel{display:flex;flex-direction:column;gap:16px}.dash-expanded-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.dash-expanded-device-name{font-size:1rem;font-weight:700;color:#1f2937}.dash-expanded-device-topic{margin-top:4px;font-size:.82rem;color:#6b7280;word-break:break-word}.dash-expanded-component-name{font-size:1.05rem;font-weight:700;color:#111827;padding-bottom:4px;border-bottom:1px solid #f3f4f6}.dash-expanded-metrics{display:grid;grid-template-columns:1fr;gap:10px}@media(max-width:1350px){.dash-layout-no-detail,.dash-layout-with-detail{grid-template-columns:260px minmax(0,1fr)}.dash-detail-sidebar{grid-column:1 / -1;position:static}}@media(max-width:1100px){.dash-layout-no-detail,.dash-layout-with-detail{grid-template-columns:240px minmax(0,1fr)}.dash-devices-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}@media(max-width:768px){.dash-page{padding:20px}.dash-actions{flex-direction:column}.dash-main-btn{width:100%}.dash-layout-no-detail,.dash-layout-with-detail{grid-template-columns:1fr}.dash-sidebar,.dash-detail-sidebar{position:static}.dash-device-card-header,.dash-device-edit-row,.dash-component-edit-row,.dash-led-controls,.dash-status-box,.dash-meta-row,.dash-control-row,.dash-brightness-header,.dash-expanded-header,.dash-expanded-status-row{flex-direction:column;align-items:stretch}.dash-meta-row strong{text-align:left}.dash-led-btn{width:100%;min-width:unset}.dash-devices-grid{grid-template-columns:1fr}.dash-component-metrics{grid-template-columns:1fr 1fr}.dash-expanded-metrics{grid-template-columns:1fr}.dash-device-visibility-top{flex-direction:column;align-items:flex-start}}.dash-detail-panel-selected{border-color:#34d399!important;box-shadow:0 0 0 3px #34d3992e,0 6px 18px #10b9811a}.dash-detail-panel-highlighted{animation:dashDetailBlink .9s ease-in-out 2}@keyframes dashDetailBlink{0%{box-shadow:0 0 0 3px #34d3992e,0 6px 18px #10b9811a;transform:scale(1)}50%{box-shadow:0 0 0 6px #34d39947,0 10px 24px #10b98129;transform:scale(1.01)}to{box-shadow:0 0 0 3px #34d3992e,0 6px 18px #10b9811a;transform:scale(1)}}.iot-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:1000}.iot-modal{background:#fff;border-radius:10px;max-width:800px;padding:20px}.iot-modal-header{display:flex;justify-content:space-between;align-items:center}.iot-modal-content{margin-top:15px}label{margin:5px}.hue-overlay{position:fixed;inset:0;background:#ffffff8c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hue-modal{background:#f9fafb;border:1px solid #d1d5db;border-radius:14px;width:min(95vw,1100px);max-height:90vh;overflow-y:auto;padding:28px 28px 32px;display:flex;flex-direction:column;gap:20px;color:#1f2937;font-family:Segoe UI,system-ui,-apple-system,sans-serif;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.hue-modal::-webkit-scrollbar{width:6px}.hue-modal::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.hue-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:3px}.hue-modal-title{font-size:1.55rem;font-weight:700;color:#414141;margin:0 0 4px}.hue-modal-sub{font-size:1.1rem;color:#6b7280}.hue-modal-sub code{background:#e5e7eb;padding:1px 6px;border-radius:4px;font-size:.8rem;color:#2563eb}.hue-close-btn{background:none;border:1px solid #cbd5e1;color:#6b7280;border-radius:50%;cursor:pointer;font-size:1rem;padding:2px;line-height:1;transition:all .18s;flex-shrink:0;width:40px;height:40px}.hue-close-btn:hover{border-color:#ef4444;color:#b91c1c;background:#fee2e2}.hue-loader{display:flex;align-items:center;gap:10px;color:#6b7280;font-size:.9rem}.hue-spinner{width:16px;height:16px;border:2px solid #cbd5e1;border-top-color:#10b981;border-radius:50%;display:inline-block;animation:hue-spin .7s linear infinite}@keyframes hue-spin{to{transform:rotate(360deg)}}.hue-section{display:flex;flex-direction:column;gap:16px}.hue-section-title{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#535353;font-weight:600;margin:0}.hue-empty{color:#9ca3af;font-size:.88rem}.hue-message{color:#dc2626;font-size:.85rem}.hue-info-grid{display:flex;gap:14px;flex-wrap:wrap}.hue-info-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:16px 22px;display:flex;flex-direction:column;gap:6px;min-width:160px;flex:1;transition:border-color .2s}.hue-info-card:hover{border-color:#10b981}.hue-info-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#6b7280}.hue-info-value{font-size:1.3rem;font-weight:700;color:#059669;font-family:Courier New,monospace}.hue-view-selector{display:flex;justify-content:space-evenly;gap:15px;flex-wrap:noWrap}.hue-view-btn{flex:1;padding:7px 18px;border:1.5px solid #cbd5e1;background:#f1f5f9;color:#374151;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .18s}.hue-view-btn:hover{border-color:#10b981;color:#047857;background:#d1fae5}.hue-view-btn.active{background:#10b981;border-color:#10b981;color:#f9fafb;font-weight:700;box-shadow:0 0 10px #10b9814d}.hue-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}.hue-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s}.hue-stat-card:hover{border-color:#10b981}.hue-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.07em;color:#6b7280}.hue-stat-value{font-size:1.1rem;font-weight:700;color:#059669;font-family:Courier New,monospace}.hue-stat-value small{font-size:.7rem;color:#9ca3af;font-weight:400}.hue-chart-scroll{overflow-x:auto}.hue-svg{display:block;width:100%;min-width:380px;background:#f1f5f9;border-radius:8px}.hue-no-data{text-align:center;padding:48px;color:#9ca3af;font-size:.9rem}.hue-table-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:18px 20px}.hue-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:.82rem;text-transform:uppercase;letter-spacing:.07em;color:#6b7280;font-weight:600}.hue-badge{background:#e5e7eb;color:#374151;padding:2px 10px;border-radius:20px;font-size:.75rem;text-transform:none;letter-spacing:0}.hue-table-scroll{overflow-x:auto}.hue-table{width:100%;border-collapse:collapse;min-width:480px;font-size:.82rem}.hue-table thead tr{border-bottom:1px solid #e5e7eb}.hue-table th{text-align:left;padding:9px 12px;font-size:.7rem;color:#6b7280;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}.hue-table td{padding:9px 12px;border-bottom:1px solid #f3f4f6;color:#1f2937;font-family:Courier New,monospace}.hue-table tbody tr:last-child td{border-bottom:none}.hue-table tbody tr:hover td{background:#f1f5f9;color:#111827}.hue-td-green{color:#059669;font-weight:600}.hue-td-muted{color:#9ca3af}.hue-td-blue{color:#2563eb}@media(max-width:600px){.hue-modal{padding:18px 14px 24px}.hue-stats{grid-template-columns:1fr 1fr}.hue-info-grid{flex-direction:column}}.hue-day-selector{display:flex;align-items:center;gap:20px;margin:10px 0;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px #00000008}.hue-day-label{font-size:13px;color:#4b5563;font-weight:600}.hue-day-select{background:#f9fafb;color:#1f2937;border:1px solid #d1d5db;border-radius:10px;padding:4px 12px;font-size:14px;outline:none;box-shadow:0 1px 2px #00000008}.hue-day-select:hover{border-color:#9ca3af;background:#fff}.hue-day-select:focus{border-color:#34d399;background:#fff;box-shadow:0 0 0 3px #34d3992e}.hue-filters-row{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.hue-collapsible-section{gap:12px}.hue-collapse-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:6px 16px;border:1px solid #d1d5db;border-radius:12px;background:#fff;color:#374151;cursor:pointer;font-size:.95rem;font-weight:700;transition:border-color .2s,background .2s,color .2s}.hue-collapse-toggle:hover{border-color:#10b981;background:#f0fdf4;color:#047857}.hue-collapse-toggle.open{border-color:#10b981;background:#ecfdf5;color:#047857}.hue-collapse-icon{font-size:1.2rem;font-weight:700;line-height:1;flex-shrink:0;padding-bottom:3px}.hue-collapse-body{display:flex;flex-direction:column;gap:16px}
