:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;height:100vh;margin:0;padding:0}.app-container{display:flex;width:100%;height:100vh}.main-content{flex:1;padding:60px 0 0;overflow-y:auto;transition:margin-left .3s ease}.app-container:has(.sidebar.open) .main-content{margin-left:260px}.app-container:has(.sidebar.closed) .main-content{margin-left:80px}.app-container:has(.sidebar.open) .topbar{left:260px}.app-container:has(.sidebar.closed) .topbar{left:80px}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.sidebar{position:fixed;left:0;top:0;height:100vh;width:260px;background:#f5f5f5;display:flex;flex-direction:column;padding:0;box-shadow:2px 0 10px #0000001a;transition:transform .3s ease,width .3s ease;z-index:1000}.sidebar.closed{width:80px}.sidebar-header{height:60px;display:flex;align-items:center;justify-content:center;padding:0 1.5rem;border-bottom:1px solid rgba(0,0,0,.1);cursor:pointer;transition:background .3s ease}.sidebar-header:hover{background:#0bca4a0d}.sidebar-logo{font-size:1.8rem;font-weight:700;margin:0;text-align:center;letter-spacing:1px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:color .3s ease,font-size .3s ease;-webkit-user-select:none;user-select:none}.sidebar-logo:hover{color:#0bca4a}.sidebar.closed .sidebar-logo{font-size:1.5rem}.sidebar-nav{flex:1;overflow-y:auto;padding:1rem 0}.sidebar-menu{list-style:none;margin:0;padding:0}.sidebar-menu-item{margin:0}.sidebar-menu-title{display:flex;align-items:center;padding:1rem 1.5rem;cursor:pointer;transition:background .3s ease;gap:.75rem;color:#333;font-weight:600;-webkit-user-select:none;user-select:none}.sidebar-menu-title:hover{background:#0bca4a1a}.menu-icon{font-size:1.5rem;min-width:1.5rem;display:flex;align-items:center;justify-content:center}.menu-text{flex:1;font-size:1rem}.menu-arrow{font-size:.7rem;transition:transform .3s ease;color:#666}.menu-arrow.open{transform:rotate(180deg)}.sidebar.closed .menu-text,.sidebar.closed .menu-arrow{display:none}.sidebar.closed .sidebar-menu-title{justify-content:center;padding:1rem}.sidebar-submenu{list-style:none;margin:0;padding:0;background:#00000008}.sidebar-submenu-item{margin:0}.sidebar-submenu-link{display:flex;align-items:center;padding:.75rem 1.5rem .75rem 3rem;color:#555;text-decoration:none;transition:all .3s ease;gap:.75rem;font-size:.95rem}.sidebar-submenu-link:hover{background:#0bca4a26;color:#0bca4a}.sidebar-submenu-link.active{background:#0bca4a33;color:#0bca4a;font-weight:700;border-left:3px solid #0bca4a}.sidebar-submenu-link.active .submenu-bullet{font-weight:900;transform:scale(1.2)}.submenu-bullet{font-size:1.5rem;min-width:1rem;color:#0bca4a}.sidebar.closed .sidebar-submenu{display:none}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000000d}.sidebar-nav::-webkit-scrollbar-thumb{background:#0bca4a4d;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#0bca4a80}body.dark-mode .sidebar-submenu-link.active{background:#0bca4a40;color:#0bca4a;font-weight:700;border-left:3px solid #0bca4a}@media(max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.topbar{position:fixed;top:0;left:260px;right:0;height:60px;background:#f5f5f5;border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 8px #0000000d;z-index:999;transition:left .3s ease}.topbar-content{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 2rem}.topbar-left{flex:1}.topbar-right{position:relative}.user-profile{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;border-radius:8px;cursor:pointer;transition:background .3s ease;-webkit-user-select:none;user-select:none}.user-profile:hover{background:#0bca4a1a}.user-icon{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0bca4a,#08a03d);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.user-name{font-size:.95rem;font-weight:600;color:#333}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;color:#333;text-decoration:none;transition:background .3s ease;cursor:pointer}.dropdown-item:hover{background:#0bca4a1a}.dropdown-item.logout:hover{background:#dc35451a;color:#dc3545}.dropdown-item.logout:hover .dropdown-icon{filter:brightness(.8)}.dropdown-icon{font-size:1.2rem;min-width:1.2rem;display:flex;align-items:center;justify-content:center}.theme-icon{width:20px;height:20px;display:block}.dropdown-text{font-size:.9rem;font-weight:500}body.dark-mode{background-color:#1a1a1a;color:#fff}body.dark-mode .topbar{background:#2a2a2a;border-bottom-color:#ffffff1a}body.dark-mode .sidebar{background:#2a2a2a}body.dark-mode .sidebar-header{border-bottom-color:#ffffff1a}body.dark-mode .sidebar-logo,body.dark-mode .sidebar-menu-title{color:#fff}body.dark-mode .sidebar-menu-title:hover{background:#0bca4a33}body.dark-mode .sidebar-submenu{background:#0003}body.dark-mode .sidebar-submenu-link{color:#ccc}body.dark-mode .sidebar-submenu-link:hover{background:#0bca4a33;color:#0bca4a}body.dark-mode .user-profile:hover{background:#0bca4a33}body.dark-mode .user-name{color:#fff}body.dark-mode .user-dropdown{background:#333;border:1px solid rgba(255,255,255,.1)}body.dark-mode .dropdown-item{color:#fff}body.dark-mode .dropdown-item:hover{background:#0bca4a33}body.dark-mode .dropdown-item.logout:hover{background:#dc354533;color:#ff6b6b}body.dark-mode .dropdown-divider{background:#ffffff1a}body.dark-mode .main-content{background-color:#1a1a1a;color:#fff}@media(max-width:768px){.topbar{left:0}}.main-view{width:100%;height:100%;padding:1rem;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden}.main-view-content{flex:1;display:grid;grid-template-columns:40% 60%;gap:1rem;min-height:0;min-width:0;overflow:hidden}.cartography-section,.control-panel-section{min-height:0;min-width:0;overflow:hidden}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;color:#999;font-weight:400}.breadcrumb-item{color:#999;transition:color .3s ease;cursor:default}.breadcrumb-item:not(.active){cursor:pointer}.breadcrumb-item:not(.active):hover{color:#0bca4a}.breadcrumb-item.active{color:#666;font-weight:500}.breadcrumb-separator{color:#ccc;-webkit-user-select:none;user-select:none}.pivot-title{font-size:2rem;font-weight:700;color:#333;margin:0 0 1rem;background:linear-gradient(135deg,#0bca4a,#08a03d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pivot-content{background:#fff;border-radius:12px;padding:.5rem;box-shadow:0 2px 10px #0000001a}.pivot-content p{font-size:1.1rem;color:#666}.welcome-message{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center}.welcome-message h1{font-size:3rem;font-weight:700;color:#333;margin:0 0 1rem;background:linear-gradient(135deg,#0bca4a,#08a03d);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-message p{font-size:1.2rem;color:#666}body.dark-mode .breadcrumb-item{color:#888}body.dark-mode .breadcrumb-item:not(.active):hover{color:#0bca4a}body.dark-mode .breadcrumb-item.active{color:#ccc}body.dark-mode .breadcrumb-separator{color:#666}body.dark-mode .pivot-title{color:#fff}body.dark-mode .pivot-content{background:#2a2a2a;border:1px solid rgba(255,255,255,.1)}body.dark-mode .pivot-content p{color:#ccc}body.dark-mode .welcome-message h1{color:#fff}body.dark-mode .welcome-message p{color:#ccc}.cartography{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.cartography-header{padding:.5rem 1rem .25rem;border-bottom:none;background:transparent}.cartography-header h2{margin:0;font-size:.85rem;font-weight:500;color:#666;text-align:left}.cartography-content{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:15px 1rem 1rem;overflow:auto}.pivot-display{width:100%;display:flex;align-items:flex-start;justify-content:center}.pivot-image-container{position:relative;display:inline-block}.pivot-image{display:block;max-width:100%;height:auto;border-radius:8px}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:1.1rem}.no-sensors-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 4px 20px #00000026;text-align:center;pointer-events:none}.no-sensors-overlay p{margin:0;color:#666;font-size:1rem;font-weight:500}.context-menu{position:fixed;z-index:1000;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px 0;min-width:170px}.context-menu-item{display:block;width:100%;padding:8px 14px;background:none;border:none;text-align:left;font-size:.82rem;color:#333;cursor:pointer;transition:background .12s}.context-menu-item:hover{background:#f0f0f0}.context-menu-item--save{color:#2e7d32;font-weight:600}.context-menu-item--cancel{color:#c62828}body.dark-mode .cartography{background:#2a2a2a;border:1px solid rgba(255,255,255,.1)}body.dark-mode .cartography-header{background:transparent;border-bottom:none}body.dark-mode .cartography-header h2{color:#aaa}body.dark-mode .no-sensors-overlay{background:#2a2a2af2;border:1px solid rgba(255,255,255,.1)}body.dark-mode .no-sensors-overlay p{color:#ccc}body.dark-mode .context-menu{background:#2a2a2a;border-color:#ffffff1f}body.dark-mode .context-menu-item{color:#ddd}body.dark-mode .context-menu-item:hover{background:#3a3a3a}.sensor{position:absolute;width:32px;height:32px;cursor:pointer;z-index:10;transition:transform .2s ease}.sensor:hover{transform:scale(1.1);z-index:99999}.sensor--editing{cursor:grab}.sensor--editing:active{cursor:grabbing}.sensor--editing .sensor-icon{filter:brightness(0) invert(1) drop-shadow(0 2px 4px rgba(0,0,0,.5))}.sensor-icon{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.sensor-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:1px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.5rem;min-width:220px;z-index:999999;animation:fadeIn .2s ease;pointer-events:none}.sensor-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#fff;z-index:999999}.tooltip-header{display:flex;flex-direction:row;align-items:center;gap:8px;font-size:.7rem;width:100%}.tooltip-header>div:first-child{flex:1}.tooltip-datetime{display:flex;flex-direction:row;gap:4px}.tooltip-divider{border:none;border-top:1px solid #e0e0e0;margin:.5rem 0}.tooltip-info{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.tooltip-row{display:flex;align-items:center;justify-content:flex-start;gap:.5rem;font-size:.7rem;color:#333}.tooltip-icon{width:16px;height:16px;flex-shrink:0}.battery-low{color:#dc3545!important;font-weight:600}.battery-icon-low{filter:brightness(0) saturate(100%) invert(27%) sepia(98%) saturate(3116%) hue-rotate(346deg) brightness(90%) contrast(92%)}body.dark-mode .sensor-tooltip{background:#2a2a2a;border:1px solid rgba(255,255,255,.1)}body.dark-mode .sensor-tooltip:before{border-bottom-color:#2a2a2a}body.dark-mode .tooltip-date{color:#ccc}body.dark-mode .tooltip-icon{filter:brightness(0) invert(1)}body.dark-mode .battery-low{color:#ff6b6b!important}body.dark-mode .battery-icon-low{filter:brightness(0) saturate(100%) invert(53%) sepia(77%) saturate(2445%) hue-rotate(329deg) brightness(101%) contrast(101%)}.gateway{position:absolute;width:32px;height:32px;z-index:15;pointer-events:auto;cursor:pointer;transition:transform .2s ease}.gateway:hover{transform:scale(1.1);z-index:99999}.gateway--editing{cursor:grab}.gateway--editing:active{cursor:grabbing}.gateway--editing .gateway-icon{filter:brightness(0) invert(1) drop-shadow(0 2px 4px rgba(0,0,0,.5))}.gateway-icon{width:100%;height:100%;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.gateway-tooltip{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:5px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:.5rem;min-width:150px;z-index:999999;animation:fadeIn .2s ease;pointer-events:none}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.gateway-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#fff;z-index:999999}.tooltip-header{display:flex;flex-direction:row;justify-content:center;font-size:.7rem;color:#333}.tooltip-divider{border:none;border-top:1px solid #e0e0e0;margin:.4rem 0}.tooltip-info{display:flex;flex-direction:column;align-items:center}.tooltip-row{font-size:.75rem;font-weight:500;color:#333;text-align:center}body.dark-mode .gateway-tooltip{background:#2a2a2a;border:1px solid rgba(255,255,255,.1)}body.dark-mode .gateway-tooltip:before{border-bottom-color:#2a2a2a}body.dark-mode .tooltip-header strong{color:#fff}body.dark-mode .tooltip-divider{border-top-color:#ffffff1a}body.dark-mode .tooltip-row{color:#ccc}.control-panel{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.control-panel-header{padding:.5rem 1rem .25rem;border-bottom:none;background:transparent}.control-panel-header h2{margin:0;font-size:.85rem;font-weight:500;color:#666;text-align:left}.control-panel-content{flex:1;padding:.5rem 1rem .5rem .1rem;overflow:auto}.selected-sensors-info{padding:1rem;background:#e8f5e9;border-left:4px solid #0bca4a;border-radius:8px;margin-bottom:1rem}.selected-sensors-info p{margin:0;font-size:.95rem;font-weight:500;color:#2e7d32}.sensor-selector{position:relative;width:100%;margin-bottom:1rem}.sensor-selector-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .3s ease}.sensor-selector-header:hover{background:#f0f0f0;border-color:#0bca4a}.sensor-count{font-size:.95rem;font-weight:500;color:#333}.dropdown-arrow{font-size:.7rem;color:#666;transition:transform .3s ease}.dropdown-arrow.open{transform:rotate(180deg)}.sensor-dropdown{position:absolute;top:calc(100% + .1rem);left:0;right:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:1000;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.3rem 1rem;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.dropdown-title{font-size:.9rem;font-weight:600;color:#333}.select-all-btn{background:#0bca4a;border:none;border-radius:4px;padding:.4rem .6rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.select-all-btn:hover{background:#08a03d;transform:scale(1.05)}.list-icon{color:#fff;font-size:1rem;font-weight:700}.sensor-list{overflow-y:auto;max-height:240px}.sensor-item{display:flex;align-items:center;padding:.5rem .7rem;cursor:pointer;transition:background .2s ease;gap:.1rem}.sensor-item:hover{background:#f8f9fa}.sensor-item input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:#0bca4a}.sensor-label{flex:1;font-size:.9rem;color:#333;font-weight:500}.sensor-temp{font-size:.85rem;color:#666;font-weight:400}.low-battery-warning{padding:.2rem 0;margin-top:.5rem;font-size:.9rem;color:#dc3545;font-weight:600}.controls{display:flex;flex-direction:column;gap:2rem}.control-section{display:flex;flex-direction:column;gap:1rem}.control-section h3{margin:0;font-size:1.2rem;font-weight:600;color:#333;padding-bottom:.5rem;border-bottom:2px solid #0bca4a}.info-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8f9fa;border-radius:8px}.info-label{font-weight:500;color:#666}.info-value{font-weight:600;color:#333}.status-active{color:#0bca4a}.control-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background:linear-gradient(135deg,#0bca4a,#08a03d);border:none;border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.control-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0bca4a4d}.control-button:active{transform:translateY(0)}.empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:#999;font-size:1.1rem;text-align:center}body.dark-mode .control-panel{background:#2a2a2a;border:1px solid rgba(255,255,255,.1)}body.dark-mode .control-panel-header{background:transparent;border-bottom:none}body.dark-mode .control-panel-header h2{color:#aaa}body.dark-mode .control-section h3{color:#fff}body.dark-mode .info-item{background:#1f1f1f}body.dark-mode .info-label{color:#888}body.dark-mode .info-value{color:#ccc}body.dark-mode .empty-state{color:#888}body.dark-mode .selected-sensors-info{background:#1f3a1f;border-left-color:#0bca4a}body.dark-mode .selected-sensors-info p{color:#7cb77e}body.dark-mode .sensor-selector-header{background:#1f1f1f;border-color:#ffffff1a}body.dark-mode .sensor-selector-header:hover{background:#2a2a2a;border-color:#0bca4a}body.dark-mode .sensor-count{color:#fff}body.dark-mode .dropdown-arrow{color:#ccc}body.dark-mode .sensor-dropdown{background:#2a2a2a;border-color:#ffffff1a}body.dark-mode .dropdown-header{background:#1f1f1f;border-bottom-color:#ffffff1a}body.dark-mode .dropdown-title{color:#fff}body.dark-mode .sensor-item:hover{background:#1f1f1f}body.dark-mode .sensor-label{color:#fff}body.dark-mode .sensor-temp{color:#ccc}body.dark-mode .low-battery-warning{color:#ff6b6b}.main-accordion-container{margin-top:1.5rem;width:100%;display:flex;flex-direction:column;gap:.75rem}.accordion-section{width:100%;position:relative}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;color:#333;transition:all .3s ease}.accordion-header:hover{background:#f0f0f0;border-color:#0bca4a}.accordion-header.open{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.accordion-arrow{font-size:.7rem;color:#666;transition:transform .3s ease}.accordion-arrow.open{transform:rotate(180deg)}.accordion-content{max-height:0;overflow:hidden;transition:max-height .4s ease;background:#f8f9fa;border:1px solid #e0e0e0;border-top:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.accordion-content.open{max-height:5000px;box-shadow:0 4px 12px #0000001a}.accordion-panel{padding:1rem;background:#f8f9fa}.accordion-panel p{margin:0;color:#888;font-size:.95rem;line-height:1.6}.tabs-container{margin-top:0;width:100%;position:relative}.tabs-header{display:flex;gap:.25rem;padding:0;background:transparent;border-bottom:none;position:relative;z-index:1}.tab-button{flex:1;padding:.75rem 1.25rem;background:#e8e8e8;border:2px solid #d0d0d0;border-bottom:none;border-radius:12px 12px 0 0;font-size:.9rem;font-weight:600;color:#777;cursor:pointer;transition:all .3s ease;position:relative;letter-spacing:.3px;margin-right:4px;box-shadow:inset 0 -2px 4px #0000000d}.tab-button:before{content:"";position:absolute;top:0;left:-8px;width:8px;height:100%;background:linear-gradient(to right,transparent,rgba(0,0,0,.05));border-radius:12px 0 0}.tab-button:after{content:"";position:absolute;top:0;right:-8px;width:8px;height:100%;background:linear-gradient(to left,transparent,rgba(0,0,0,.05));border-radius:0 12px 0 0}.tab-button:hover{color:#10d957;background:#f0f0f0;transform:translateY(-3px);border-color:#10d957}.tab-button.active{color:#10d957;background:#fff;border-color:#10d957;border-width:2px;border-bottom:2px solid #ffffff;transform:translateY(0);z-index:2;box-shadow:0 -2px 8px #10d95726,inset 0 2px #10d95733;padding-bottom:calc(.75rem + 2px);margin-bottom:-2px}.tab-button.active:before,.tab-button.active:after{display:none}.tab-button.active:hover{transform:translateY(0)}.tabs-content{width:100%;background-color:#f8f9fa;border-top:2px solid #10d957;border-radius:0 0 12px 12px;position:relative}.tab-panel{animation:fadeIn .4s ease;padding:1.5rem;background:#fff;min-height:250px;border-radius:0 0 10px 10px}.tab-panel h3{margin:0 0 1.25rem;font-size:1.1rem;font-weight:700;color:#333;letter-spacing:.3px}.tab-panel p{margin:0;color:#888;font-size:.95rem;line-height:1.6}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-top:1rem}.stat-card{background:#f5f5f5;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 12px #00000014;transition:all .3s ease;cursor:pointer;position:relative}.sensor-count-badge{position:absolute;top:8px;right:8px;background:transparent;color:#0bca4a;border:2px solid #0bca4a;font-size:.7rem;font-weight:700;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:none;z-index:1}.stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px #0000001f;background:#efefef}.stat-card-empty{background:#f5f5f5;box-shadow:0 4px 12px #00000014;opacity:.6;cursor:default}.stat-card-empty:hover{transform:none;box-shadow:0 4px 12px #00000014;background:#f5f5f5}.stat-icon{font-size:2.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));display:flex;align-items:center;justify-content:center}.stat-icon img{width:2.5rem;height:2.5rem;object-fit:contain}.stat-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.85rem;font-weight:600;color:#666;letter-spacing:.5px}.stat-value{font-size:1.2rem;font-weight:700;color:#333;line-height:1}.stat-card-empty .stat-label,.stat-card-empty .stat-value{color:#666}@keyframes fadeIn{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}body.dark-mode .accordion-header{background:#1f1f1f;border-color:#ffffff1a;color:#fff}body.dark-mode .accordion-header:hover{background:#2a2a2a;border-color:#0bca4a}body.dark-mode .accordion-header.open{border-bottom-color:transparent}body.dark-mode .accordion-arrow{color:#ccc}body.dark-mode .accordion-content{background:#2a2a2a;border-color:#ffffff1a;border-top:none}body.dark-mode .accordion-content.open{box-shadow:0 4px 12px #0006}body.dark-mode .accordion-panel{background:#1f1f1f}body.dark-mode .accordion-panel p{color:#999}body.dark-mode .tabs-container,body.dark-mode .tabs-header{background:transparent}body.dark-mode .tab-button{color:#999;background:#1f1f1f;border-color:#3a3a3a;box-shadow:inset 0 -2px 4px #0003}body.dark-mode .tab-button:hover{color:#10d957;background:#2a2a2a;border-color:#10d957}body.dark-mode .tab-button.active{color:#10d957;background:#2a2a2a;border-color:#10d957;border-bottom-color:#2a2a2a;box-shadow:0 -2px 8px #10d95733,inset 0 2px #10d9574d}body.dark-mode .tabs-content{background:#1f1f1f;border:2px solid #10d957;border-radius:0 0 12px 12px;box-shadow:0 4px 12px #0006}body.dark-mode .tab-panel{background:#1f1f1f}body.dark-mode .tab-panel h3{color:#fff}body.dark-mode .tab-panel p{color:#999}body.dark-mode .stat-card{background:#3a3a3a;box-shadow:0 4px 12px #0000004d}body.dark-mode .stat-card:hover{background:#404040;box-shadow:0 6px 16px #0006}body.dark-mode .stat-label{color:#aaa}body.dark-mode .stat-value{color:#fff}body.dark-mode .stat-card-empty{background:#3a3a3a;box-shadow:0 4px 12px #0000004d}body.dark-mode .stat-card-empty:hover{background:#3a3a3a}body.dark-mode .stat-card-empty .stat-label,body.dark-mode .stat-card-empty .stat-value{color:#888}body.dark-mode .sensor-count-badge{background:transparent;color:#70ffa2;border-color:#70ffa2}.sensor-graphs{display:flex;flex-direction:column;gap:2rem;padding:0}.graph-container{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:all .3s ease}.graph-container.is-collapsed{padding:1rem}.graph-container.clickable{cursor:pointer}.graph-container:hover{box-shadow:0 4px 12px #0000001f}.graph-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;padding-bottom:0;border-bottom:2px solid transparent;transition:all .3s ease}.graph-header.is-expanded{margin-bottom:0;padding:.75rem;border-bottom:2px solid #0bca4a;margin:-1.5rem -1.5rem 0;border-radius:12px 12px 0 0}.graph-content{margin:0 -1.5rem -1.5rem;padding:1.5rem;border-radius:0 0 12px 12px}.graph-title{margin:0;font-size:1.1rem;font-weight:600;color:#333}.graph-fullscreen-btn{background:transparent;border:2px solid #0bca4a;color:#0bca4a;font-size:1.3rem;width:36px;height:36px;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;padding:0}.graph-fullscreen-btn:hover{background:#0bca4a;color:#fff;transform:scale(1.05)}.graph-accordion-header{cursor:pointer;-webkit-user-select:none;user-select:none;padding:.5rem;margin:-.5rem -.5rem .5rem;transition:background-color .2s ease}.graph-accordion-header:hover{background-color:#0bca4a0d}.graph-header-actions{display:flex;align-items:center;gap:.75rem}.graph-accordion-icon{color:#0bca4a;font-size:1rem;transition:transform .2s ease;display:inline-block}.gateway-id-text{margin-bottom:1rem;color:#666;font-size:.9rem}.no-sensors-message{display:flex;align-items:center;justify-content:center;min-height:300px;text-align:center}.no-sensors-message p{font-size:1.1rem;color:#999;margin:0}body.dark-mode .graph-container{background:#3a3a3a;box-shadow:0 2px 8px #0000004d}body.dark-mode .graph-container:hover{box-shadow:0 4px 12px #0006}body.dark-mode .graph-header{border-bottom:2px solid transparent}body.dark-mode .graph-header.is-expanded{border-bottom-color:#0bca4a}body.dark-mode .graph-title{color:#fff}body.dark-mode .graph-fullscreen-btn{border-color:#0bca4a;color:#0bca4a}body.dark-mode .graph-fullscreen-btn:hover{background:#0bca4a;color:#2a2a2a}body.dark-mode .graph-accordion-header:hover{background-color:#0bca4a1a}body.dark-mode .graph-accordion-icon{color:#0bca4a}body.dark-mode .no-sensors-message p{color:#888}body.dark-mode .gateway-id-text{color:#aaa}@media(max-width:768px){.graph-container{padding:1rem}.graph-title{font-size:1rem}.graph-fullscreen-btn{width:32px;height:32px;font-size:1.1rem}}.graph-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.graph-modal-content{background:#fff;border-radius:16px;width:95%;height:90%;max-width:1400px;max-height:900px;padding:2rem;position:relative;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.graph-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:2px solid #0bca4a;color:#0bca4a;font-size:1.5rem;font-weight:700;width:36px;height:36px;border-radius:6px;cursor:pointer;transition:all .2s ease;z-index:10;padding:0;line-height:1;display:flex;align-items:center;justify-content:center}.graph-modal-close:hover{background:#0bca4a;color:#fff;transform:scale(1.05)}.graph-modal-title{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#333;padding-bottom:1rem;border-bottom:3px solid #0bca4a}body.dark-mode .graph-modal-content{background:#2a2a2a}body.dark-mode .graph-modal-title{color:#fff}@media(max-width:768px){.graph-modal-overlay{padding:1rem}.graph-modal-content{width:100%;height:95%;padding:1.5rem}.graph-modal-title{font-size:1.2rem}.graph-modal-close{width:32px;height:32px;font-size:1.3rem}}.date-range-picker{margin-bottom:1.25rem;padding:.875rem 1rem;background:#f8f9fa;border-radius:10px;border:1px solid #e9ecef}.date-range-inputs{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap}.date-range-field{display:flex;flex-direction:column;gap:.3rem}.date-range-label{font-size:.75rem;font-weight:600;color:#555;text-transform:uppercase;letter-spacing:.04em}.date-range-input{padding:.45rem .65rem;border:1.5px solid #d0d5dd;border-radius:7px;font-size:.88rem;color:#333;background:#fff;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;outline:none}.date-range-input:focus{border-color:#0bca4a;box-shadow:0 0 0 3px #0bca4a26}.date-range-input.has-error{border-color:#e53e3e;box-shadow:0 0 0 3px #e53e3e1f}.date-range-separator{color:#aaa;font-size:1.1rem;padding-bottom:.45rem;font-weight:300}.date-range-apply-btn{padding:.45rem 1.1rem;background:#0bca4a;color:#fff;border:none;border-radius:7px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .2s ease,transform .15s ease,opacity .2s;white-space:nowrap;align-self:flex-end}.date-range-apply-btn:hover:not(:disabled){background:#09b33e;transform:translateY(-1px)}.date-range-apply-btn:active:not(:disabled){transform:translateY(0)}.date-range-apply-btn:disabled{opacity:.45;cursor:not-allowed}.date-range-error{margin:.5rem 0 0;font-size:.8rem;color:#e53e3e;font-weight:500}body.dark-mode .date-range-picker{background:#333;border-color:#444}body.dark-mode .date-range-label{color:#aaa}body.dark-mode .date-range-input{background:#2a2a2a;color:#eee;border-color:#555}body.dark-mode .date-range-input:focus{border-color:#0bca4a;box-shadow:0 0 0 3px #0bca4a33}body.dark-mode .date-range-input.has-error{border-color:#fc8181}body.dark-mode .date-range-separator{color:#666}body.dark-mode .date-range-error{color:#fc8181}@media(max-width:600px){.date-range-inputs{flex-direction:column;align-items:stretch}.date-range-separator{display:none}.date-range-apply-btn{width:100%;padding:.6rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9f4,#e8f5e9)}.login-card{background:#fff;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 8px 32px #0000001a}.login-card h1{margin:0 0 .25rem;font-size:1.8rem;font-weight:700;color:#0bca4a;text-align:center}.login-subtitle{margin:0 0 2rem;font-size:.9rem;color:#888;text-align:center}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.875rem;font-weight:600;color:#444}.form-group input[type=email],.form-group input[type=password]{padding:.75rem 1rem;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.95rem;color:#333;transition:border-color .2s;outline:none}.form-group input[type=email]:focus,.form-group input[type=password]:focus{border-color:#0bca4a}.form-group--checkbox{flex-direction:row;align-items:center}.form-group--checkbox label{display:flex;align-items:center;gap:.5rem;font-weight:500;cursor:pointer}.form-group--checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#0bca4a;cursor:pointer}.login-error{margin:0;padding:.75rem 1rem;background:#dc354514;border:1px solid rgba(220,53,69,.3);border-radius:8px;color:#dc3545;font-size:.875rem}.login-button{padding:.875rem;background:linear-gradient(135deg,#0bca4a,#08a03d);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.login-button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-button:disabled{opacity:.6;cursor:not-allowed}
