.sidebar{width:260px;display:flex;flex-direction:column;height:100vh;transition:background-color .3s,color .3s,width .3s ease;border-radius:0 12px 12px 0;overflow:hidden}.sidebar-light{background-color:var(--sidebar-light);color:var(--text-light);box-shadow:2px 0 5px #0000000d}.sidebar-dark{background-color:var(--sidebar-dark);color:var(--text-dark);box-shadow:2px 0 5px #0003}.sidebar-content{display:flex;flex-direction:column;height:100%}.sidebar-header{padding:24px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;position:relative}.sidebar-logo{width:80px;height:auto;margin-bottom:15px}.sidebar-close-mobile{display:none;position:absolute;top:8px;right:8px}.sidebar-header h2{font-size:1.1rem;font-weight:600;color:var(--primary-color)}.dark-mode .sidebar-header h2{color:var(--text-dark)}.sidebar-menu{flex:1;display:flex;flex-direction:column;padding:16px 12px;overflow-y:auto}.menu-item{display:flex;align-items:center;padding:10px 16px;margin:4px 0;color:var(--text-secondary-light);text-decoration:none;border-radius:8px;transition:background-color .2s,color .2s;font-weight:500}.dark-mode .menu-item{color:var(--text-secondary-dark)}.sidebar-light .menu-item:hover{background-color:#0d6efd1a;color:var(--primary-color)}.sidebar-dark .menu-item:hover{background-color:#ffffff1a;color:#fff}.menu-item.active{background-color:var(--primary-color);color:#fff;font-weight:600}.menu-icon{margin-right:12px;display:flex;align-items:center}.menu-text{font-size:.95rem}.sidebar-footer{display:flex;justify-content:space-around;align-items:center;padding:20px 16px;margin-top:auto;border-top:1px solid var(--border-light);background-color:#00000005}.sidebar-dark .sidebar-footer{border-top:1px solid var(--border-dark);background-color:#ffffff0d}.footer-button{background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary-light);padding:12px;border-radius:10px;transition:all .3s ease;min-width:44px;min-height:44px}.dark-mode .footer-button{color:var(--text-secondary-dark)}.footer-button:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.sidebar-dark .footer-button:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.footer-button span{margin-left:5px;font-size:.8rem}@media (max-width: 992px){.sidebar{width:200px}.sidebar-header h2{font-size:1rem}.menu-text{font-size:.9rem}}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;bottom:0;height:100vh;width:260px;transform:translate(-100%);transition:transform .25s ease;z-index:1300;border-radius:0;box-shadow:2px 0 12px #0003}.sidebar-open{transform:translate(0)}.sidebar-close-mobile{display:inline-flex}.dark-mode .sidebar{border-right-color:var(--border-dark)}.sidebar-logo{width:64px;margin-bottom:10px}.sidebar-header h2,.footer-button span{display:none}}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:1200;display:none}.sidebar-backdrop.open{display:block}.MuiTextField-root .MuiOutlinedInput-root{border-radius:8px;transition:all .2s ease-in-out}.MuiTextField-root .MuiOutlinedInput-root:hover .MuiOutlinedInput-notchedOutline{border-color:#1976d2}.MuiTextField-root .MuiOutlinedInput-root.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:#1976d2;border-width:2px}.MuiTextField-root .MuiInputLabel-root.Mui-focused{color:#1976d2}.MuiInputAdornment-root .MuiSvgIcon-root{color:#666;transition:color .2s ease}.MuiInputAdornment-root .MuiIconButton-root{transition:all .2s ease}.MuiInputAdornment-root .MuiIconButton-root:hover{background-color:#0000000a}.MuiButton-root{transition:all .2s ease-in-out}@media (max-width: 359px){.MuiTypography-root{line-height:1.3}}@media (max-width: 480px){.MuiTextField-root .MuiInputBase-input{font-size:16px!important}.MuiInputLabel-root{font-size:14px!important}}@media (min-width: 481px) and (max-width: 768px){.MuiTextField-root .MuiOutlinedInput-root{border-radius:6px}}@media (min-width: 769px){.MuiTextField-root .MuiOutlinedInput-root{border-radius:8px}}.login-button:focus-visible{outline:2px solid #1976d2;outline-offset:2px}.MuiIconButton-root:focus-visible{outline:2px solid #1976d2;outline-offset:2px}@media (prefers-contrast: high){.login-card{border:2px solid #000000}.MuiTextField-root .MuiOutlinedInput-notchedOutline{border-width:2px!important}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.summary-value-card{border-radius:12px!important;padding:12px 16px;text-align:left;transition:transform .2s ease}.summary-value-card:hover{transform:translateY(-2px)}.summary-card-title{display:block;font-size:.8rem!important;margin-bottom:4px!important;font-weight:500!important}.summary-card-value-container{display:flex;align-items:baseline;gap:5px}.summary-card-value{font-weight:600!important;line-height:1.1!important;text-align:right;flex-grow:1;transition:all .3s ease}.summary-card-value.value-changed{animation:valueChange .6s ease}@keyframes valueChange{0%{transform:scale(1)}25%{transform:scale(1.1);filter:brightness(1.2)}50%{transform:scale(1.05);filter:brightness(1.1)}to{transform:scale(1);filter:brightness(1)}}.summary-card-unit{font-size:.85rem!important;font-weight:400!important}.summary-value-card.max-pm{background-color:var(--max-pm-bg-light);color:var(--max-pm-text-light)}.summary-value-card.avg-pm{background-color:var(--avg-pm-bg-light);color:var(--avg-pm-text-light)}.summary-value-card.min-pm{background-color:var(--min-pm-bg-light);color:var(--min-pm-text-light)}.summary-value-card.max-temp{background-color:var(--max-temp-bg-light);color:var(--max-temp-text-light)}.summary-value-card.avg-temp{background-color:var(--avg-temp-bg-light);color:var(--avg-temp-text-light)}.summary-value-card.min-temp{background-color:var(--min-temp-bg-light);color:var(--min-temp-text-light)}.summary-value-card.latest-pm{background-color:var(--avg-pm-bg-light);color:var(--avg-pm-text-light);border:2px solid var(--primary-color)}.summary-value-card.device-count{background-color:var(--min-pm-bg-light);color:var(--min-pm-text-light)}.dark-mode .summary-value-card.max-pm{background-color:var(--max-pm-bg-dark);color:var(--max-pm-text-dark)}.dark-mode .summary-value-card.avg-pm{background-color:var(--avg-pm-bg-dark);color:var(--avg-pm-text-dark)}.dark-mode .summary-value-card.min-pm{background-color:var(--min-pm-bg-dark);color:var(--min-pm-text-dark)}.dark-mode .summary-value-card.max-temp{background-color:var(--max-temp-bg-dark);color:var(--max-temp-text-dark)}.dark-mode .summary-value-card.avg-temp{background-color:var(--avg-temp-bg-dark);color:var(--avg-temp-text-dark)}.dark-mode .summary-value-card.min-temp{background-color:var(--min-temp-bg-dark);color:var(--min-temp-text-dark)}.dark-mode .summary-value-card.latest-pm{background-color:var(--avg-pm-bg-dark);color:var(--avg-pm-text-dark);border:2px solid var(--primary-color)}.dark-mode .summary-value-card.device-count{background-color:var(--min-pm-bg-dark);color:var(--min-pm-text-dark)}.dark-mode .summary-value-card .summary-card-unit,.dark-mode .summary-value-card .summary-card-title{color:var(--text-secondary-dark)!important}@font-face{font-family:swiper-icons;src:url(data:application/font-woff;charset=utf-8;base64,\ d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA);font-weight:400;font-style:normal}:root{--swiper-theme-color: #007aff}:host{position:relative;display:block;margin-left:auto;margin-right:auto;z-index:1}.swiper{margin-left:auto;margin-right:auto;position:relative;overflow:hidden;list-style:none;padding:0;z-index:1;display:block}.swiper-vertical>.swiper-wrapper{flex-direction:column}.swiper-wrapper{position:relative;width:100%;height:100%;z-index:1;display:flex;transition-property:transform;transition-timing-function:var(--swiper-wrapper-transition-timing-function, initial);box-sizing:content-box}.swiper-android .swiper-slide,.swiper-ios .swiper-slide,.swiper-wrapper{transform:translateZ(0)}.swiper-horizontal{touch-action:pan-y}.swiper-vertical{touch-action:pan-x}.swiper-slide{flex-shrink:0;width:100%;height:100%;position:relative;transition-property:transform;display:block}.swiper-slide-invisible-blank{visibility:hidden}.swiper-autoheight,.swiper-autoheight .swiper-slide{height:auto}.swiper-autoheight .swiper-wrapper{align-items:flex-start;transition-property:transform,height}.swiper-backface-hidden .swiper-slide{transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.swiper-3d.swiper-css-mode .swiper-wrapper{perspective:1200px}.swiper-3d .swiper-wrapper{transform-style:preserve-3d}.swiper-3d{perspective:1200px}.swiper-3d .swiper-slide,.swiper-3d .swiper-cube-shadow{transform-style:preserve-3d}.swiper-css-mode>.swiper-wrapper{overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar{display:none}.swiper-css-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:start start}.swiper-css-mode.swiper-horizontal>.swiper-wrapper{scroll-snap-type:x mandatory}.swiper-css-mode.swiper-vertical>.swiper-wrapper{scroll-snap-type:y mandatory}.swiper-css-mode.swiper-free-mode>.swiper-wrapper{scroll-snap-type:none}.swiper-css-mode.swiper-free-mode>.swiper-wrapper>.swiper-slide{scroll-snap-align:none}.swiper-css-mode.swiper-centered>.swiper-wrapper:before{content:"";flex-shrink:0;order:9999}.swiper-css-mode.swiper-centered>.swiper-wrapper>.swiper-slide{scroll-snap-align:center center;scroll-snap-stop:always}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child{margin-inline-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-horizontal>.swiper-wrapper:before{height:100%;min-height:1px;width:var(--swiper-centered-offset-after)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child{margin-block-start:var(--swiper-centered-offset-before)}.swiper-css-mode.swiper-centered.swiper-vertical>.swiper-wrapper:before{width:100%;min-width:1px;height:var(--swiper-centered-offset-after)}.swiper-3d .swiper-slide-shadow,.swiper-3d .swiper-slide-shadow-left,.swiper-3d .swiper-slide-shadow-right,.swiper-3d .swiper-slide-shadow-top,.swiper-3d .swiper-slide-shadow-bottom{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none;z-index:10}.swiper-3d .swiper-slide-shadow{background:#00000026}.swiper-3d .swiper-slide-shadow-left{background-image:linear-gradient(to left,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-right{background-image:linear-gradient(to right,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-top{background-image:linear-gradient(to top,#00000080,#0000)}.swiper-3d .swiper-slide-shadow-bottom{background-image:linear-gradient(to bottom,#00000080,#0000)}.swiper-lazy-preloader{width:42px;height:42px;position:absolute;left:50%;top:50%;margin-left:-21px;margin-top:-21px;z-index:10;transform-origin:50%;box-sizing:border-box;border:4px solid var(--swiper-preloader-color, var(--swiper-theme-color));border-radius:50%;border-top-color:transparent}.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader{animation:swiper-preloader-spin 1s infinite linear}.swiper-lazy-preloader-white{--swiper-preloader-color: #fff}.swiper-lazy-preloader-black{--swiper-preloader-color: #000}@keyframes swiper-preloader-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.swiper-free-mode>.swiper-wrapper{transition-timing-function:ease-out;margin:0 auto}.dashboard-container{padding:24px;background-color:var(--bg-light)}.chart-skeleton{display:flex;flex-direction:column;gap:12px;padding:20px;height:300px;justify-content:center}.skeleton-line{height:8px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;border-radius:4px;animation:skeleton-loading 1.5s infinite}.skeleton-line.short{width:60%}.skeleton-line.medium{width:80%}.dark-mode .skeleton-line{background:linear-gradient(90deg,#3a3f5a 25%,#4a4f6a,#3a3f5a 75%);background-size:200% 100%}@keyframes livePulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes offlineAlert{0%,to{opacity:.7}50%{opacity:1}}.connection-live{animation:livePulse 2s infinite ease-in-out}.connection-offline{animation:offlineAlert 1.5s infinite ease-in-out}.dark-mode .dashboard-container{background-color:var(--bg-dark)}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px}.chart-header h3{margin:0;color:var(--text-light);font-size:1.1rem;font-weight:600}.dark-mode .chart-header h3{color:var(--text-dark)}.pm-selector{min-width:140px;border-radius:10px!important;box-shadow:none!important;background:transparent}.time-frame-selector{min-width:380px;border-radius:10px!important;flex-wrap:wrap;box-shadow:none!important;background:transparent}.pm-toggle-btn,.time-frame-btn{font-size:.75rem!important;font-weight:600!important;padding:6px 14px!important;border-radius:10px!important;text-transform:none!important;transition:background-color .2s ease,color .2s ease,border-color .2s ease!important}.time-frame-btn{padding:6px 12px!important;min-width:50px!important;font-size:.7rem!important}.pm-toggle-btn.MuiButton-contained,.time-frame-btn.MuiButton-contained{background:#0d6efd1f!important;color:var(--primary-color, #0d6efd)!important;border:1px solid rgba(13,110,253,.25)!important;box-shadow:none!important}.pm-toggle-btn.MuiButton-outlined,.time-frame-btn.MuiButton-outlined{border-color:#00000014!important;color:var(--text-secondary-light, #6c757d)!important;background:#00000005!important}.pm-toggle-btn.MuiButton-outlined:hover,.time-frame-btn.MuiButton-outlined:hover{background:#0d6efd0f!important;border-color:#0d6efd40!important;color:var(--primary-color, #0d6efd)!important}.dark-mode .pm-toggle-btn.MuiButton-outlined,.dark-mode .time-frame-btn.MuiButton-outlined{border-color:#ffffff1f!important;color:var(--text-secondary-dark, #adb5bd)!important;background:#ffffff08!important}.dark-mode .pm-toggle-btn.MuiButton-outlined:hover,.dark-mode .time-frame-btn.MuiButton-outlined:hover{background:#0d6efd1f!important;border-color:#0d6efd59!important;color:var(--primary-color, #0d6efd)!important}@media (max-width: 768px){.chart-header{flex-direction:column;align-items:flex-start;gap:12px}.chart-header>div{align-self:stretch;justify-content:space-between}.pm-selector{min-width:120px}.time-frame-selector{min-width:unset;flex:1}.pm-toggle-btn,.time-frame-btn{font-size:.7rem!important;padding:5px 10px!important}.time-frame-btn{min-width:40px!important;font-size:.65rem!important;padding:5px 8px!important}}@media (max-width: 480px){.chart-header{gap:10px}.chart-header h3{font-size:1rem}.chart-header>div{flex-direction:column;gap:8px}.pm-selector{min-width:110px;align-self:center}.time-frame-selector{align-self:center}.pm-toggle-btn,.time-frame-btn{font-size:.65rem!important;padding:4px 8px!important}.time-frame-btn{min-width:35px!important;font-size:.6rem!important;padding:4px 6px!important}}.chart-header .MuiIconButton-root{transition:all .2s ease!important}.chart-header .MuiIconButton-root:hover{background-color:#0d6efd1a!important}.dark-mode .chart-header .MuiIconButton-root:hover{background-color:#0d6efd33!important}.chart-wrapper.panning{cursor:grabbing!important}.chart-wrapper.loading{pointer-events:none;opacity:.7}.chart-no-data,.chart-sparse-data{height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:#8080800d;border-radius:8px;border:2px dashed rgba(128,128,128,.2)}.dark-mode .chart-no-data,.dark-mode .chart-sparse-data{background:#ffffff05;border-color:#ffffff1a}.chart-status-badge,.chart-interaction-badge,.chart-sparse-badge{position:absolute;top:8px;right:8px;background:#0d6efde6;color:#fff;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:500;z-index:10;pointer-events:none;animation:fadeInBounce .3s ease-out}.chart-interaction-badge{background:#ff9800e6;top:8px;left:8px;right:auto}.chart-sparse-badge{background:#808080e6;bottom:8px;top:auto;font-size:.7rem}.dark-mode .chart-status-badge,.dark-mode .chart-interaction-badge,.dark-mode .chart-sparse-badge{background:#0d6efdf2;color:#fff}.dark-mode .chart-interaction-badge{background:#ff9800f2}.dark-mode .chart-sparse-badge{background:#969696f2}@keyframes fadeInBounce{0%{opacity:0;transform:translateY(-10px) scale(.9)}60%{opacity:1;transform:translateY(2px) scale(1.02)}to{opacity:1;transform:translateY(0) scale(1)}}.dashboard-container h1{margin-bottom:20px;font-size:2rem;color:var(--text-light)}.dark-mode .dashboard-container h1{color:var(--text-dark)}.header-swiper-container{width:100%;padding:10px 0;margin-bottom:24px;overflow:hidden;position:relative}.dark-mode .header-swiper-container{background-color:var(--bg-dark)}.header-swiper{width:100%;height:auto;cursor:grab}.header-swiper:active{cursor:grabbing}.header-swiper .swiper-wrapper{align-items:stretch;transition-timing-function:linear!important}.header-swiper .swiper-slide{width:260px!important;height:auto;display:flex;flex-shrink:0}.header-card{flex:1;width:100%;background-color:var(--card-bg-light);border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;transition:all .3s ease-in-out;border:1px solid rgba(0,0,0,.05);position:relative;overflow:hidden}.dark-mode .header-card{background-color:var(--card-bg-dark);box-shadow:0 2px 8px #0000004d;border:1px solid rgba(255,255,255,.1)}.header-card:hover{transform:translateY(-4px);box-shadow:0 6px 20px #0000001f}.dark-mode .header-card:hover{box-shadow:0 6px 20px #0006}.header-card-title{font-size:.9rem;color:var(--text-secondary-light);margin-bottom:8px;font-weight:500}.dark-mode .header-card-title{color:var(--text-secondary-dark)}.header-card-value{font-size:2.2rem;font-weight:600;margin-bottom:8px;display:flex;align-items:baseline;justify-content:right}.header-card-value-number{transition:all .3s ease}.header-card-value-number.value-changed{animation:headerValueChange .6s ease}@keyframes headerValueChange{0%{transform:scale(1)}25%{transform:scale(1.1);filter:brightness(1.2)}50%{transform:scale(1.05);filter:brightness(1.1)}to{transform:scale(1);filter:brightness(1)}}.header-card-unit{font-size:.9rem;color:var(--text-secondary-light);margin-left:6px;font-weight:400}.dark-mode .header-card-unit{color:var(--text-secondary-dark)}.header-card-update{font-size:.8rem;color:var(--text-secondary-light);display:flex;align-items:center}.dark-mode .header-card-update{color:var(--text-secondary-dark)}.header-card-update .MuiSvgIcon-root{margin-right:4px}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px}.chart-column,.info-column{display:flex;flex-direction:column;gap:24px}.chart-card,.map-card,.device-card{background-color:var(--card-bg-light);border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000000d}.dark-mode .chart-card,.dark-mode .map-card,.dark-mode .device-card{background-color:var(--card-bg-dark);box-shadow:0 2px 4px #0003}.chart-card h3{margin-bottom:16px;font-size:1.1rem;font-weight:600;color:var(--text-light)}.dark-mode .chart-card h3{color:var(--text-dark)}.chart-wrapper{height:auto;min-height:220px;position:relative;cursor:grab}.chart-wrapper:active{cursor:grabbing}.chart-wrapper canvas{border-radius:8px}.chart-card{overflow:hidden}.map-card{min-height:300px;display:flex;padding:0!important;overflow:hidden}.device-card h3{margin-bottom:16px;font-size:1.1rem;font-weight:600;color:var(--text-light);display:flex;justify-content:space-between;align-items:center}.dark-mode .device-card h3{color:var(--text-dark)}.total-devices{font-size:.9rem;font-weight:400;color:var(--text-secondary-light)}.dark-mode .total-devices{color:var(--text-secondary-dark)}.device-list{list-style:none;padding:0;margin:0;max-height:300px;overflow-y:auto}.device-list-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-light)}.dark-mode .device-list-item{border-bottom:1px solid var(--border-dark)}.device-list-item:last-child{border-bottom:none}.device-readings{display:flex;flex-direction:column;align-items:flex-end;font-size:.85rem;color:var(--text-secondary-light);flex-shrink:0}.device-readings .MuiSvgIcon-root{font-size:1rem;margin-right:4px}.device-temp{margin-bottom:2px;color:var(--text-light)}.dark-mode .device-temp{color:var(--text-dark)}table{display:none}.chart-wrapper table{display:table!important}@media (max-width: 576px){.header-grid{grid-template-columns:1fr;gap:15px}.header-card-value{font-size:1.8rem}}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr}}@media (max-width: 576px){.device-list-item{flex-direction:column;align-items:flex-start;gap:8px;position:relative;padding-left:25px}.status-dot{position:absolute;top:14px;left:0;margin-right:0;width:10px;height:10px}.device-info{margin-left:0}.device-readings{flex-direction:row;gap:15px;align-items:center;width:100%;margin-left:0;justify-content:flex-start}.device-temp,.device-battery{margin-bottom:0}}@media (max-width: 576px){.chart-wrapper{min-height:200px}.chart-card h3{font-size:1rem}}.summary-card-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.dark-mode .pm25-summary-container{border-top-color:var(--border-dark)}@media (max-width: 576px){.summary-card-row{grid-template-columns:1fr;gap:12px;margin-top:15px}.summary-value-card .summary-card-value{font-size:1.5rem!important}}@media (max-width: 992px){.dashboard-container{padding:16px}.dashboard-grid,.chart-column,.info-column{gap:16px}.map-card{min-height:250px}}@media (max-width: 576px){.dashboard-container{padding:12px}.header-swiper-container{margin-bottom:16px}.dashboard-grid,.chart-column,.info-column{gap:16px}.chart-card,.map-card,.device-card{padding:15px;border-radius:12px}.chart-card h3{font-size:1rem;margin-bottom:12px}.chart-wrapper{height:180px}.summary-card-row{flex-direction:column;align-items:stretch;gap:12px}.map-card{min-height:250px}.device-card h3{font-size:1rem;margin-bottom:12px}.total-devices{font-size:.85rem}.device-list{max-height:250px}.device-list-item{padding:10px 0}.device-name{font-size:.85rem}.device-details{font-size:.75rem}.device-readings{font-size:.8rem;gap:8px}}.mascot-page-container{display:flex;height:100vh;padding:0;background:linear-gradient(to bottom,#afeafa,#fff);overflow:hidden;position:relative;border-radius:16px}.dark-mode .mascot-page-container{background:linear-gradient(to bottom,#4a6179,var(--bg-dark))}.mascot-toolbar{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:40px 15px;background-color:var(--card-bg-light);border-radius:0 25px 25px 0;box-shadow:2px 0 5px #0000001a;gap:20px;height:fit-content;position:absolute;left:0;top:50%;transform:translateY(-50%);z-index:10}.dark-mode .mascot-toolbar{background-color:var(--card-bg-dark);box-shadow:2px 0 5px #0000004d}.toolbar-button.MuiIconButton-root{background-color:var(--primary-color);color:#fff;width:50px;height:50px;transition:background-color .2s ease,transform .2s ease}.toolbar-button.MuiIconButton-root:hover{background-color:#0b5ed7;transform:scale(1.1)}.fullscreen-close-button{position:fixed!important;top:20px;right:20px;z-index:1000;background-color:#0000004d!important;color:#fff!important;width:50px!important;height:50px!important;border-radius:50%!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease!important}.fullscreen-close-button:hover{background-color:#dc3545cc!important;transform:scale(1.1);box-shadow:0 4px 20px #dc354566}.dark-mode .fullscreen-close-button{background-color:#fff3!important}.dark-mode .fullscreen-close-button:hover{background-color:#dc3545e6!important}.mascot-main-content{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px 20px 100px;position:relative;text-align:center;overflow:hidden}.mascot-main-content:fullscreen{background:linear-gradient(to bottom,#afeafa,#fff);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;overflow-y:auto}.dark-mode .mascot-main-content:fullscreen{background:linear-gradient(to bottom,#4a6179,var(--bg-dark))}.welcome-text{margin-bottom:20px}.welcome-text .MuiTypography-h4,.welcome-text .MuiTypography-h5{color:#333;font-weight:600;margin-bottom:8px}.dark-mode .welcome-text .MuiTypography-h4,.dark-mode .welcome-text .MuiTypography-h5{color:var(--text-dark)}.welcome-text .highlight-text{color:#0b5ed7;font-weight:700}.dark-mode .welcome-text .highlight-text{color:#61dafb}.mascot-display-area{display:flex;align-items:center;justify-content:center;margin-bottom:20px;width:100%;gap:40px}.mascot-image{max-width:300px;height:auto}.pm25-circle{width:250px;height:250px;border-radius:50%;background:linear-gradient(to top right,#afeafa,#fff);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 4px 15px #0000001a;text-align:center;padding:20px;position:relative;transition:transform .3s ease,box-shadow .3s ease}.dark-mode .pm25-circle{background:linear-gradient(to top right,#5c9ead,var(--card-bg-dark));box-shadow:0 4px 15px #0000004d}@keyframes pm25-pulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes value-fade{0%{opacity:.4;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes pm25-glow{0%,to{box-shadow:0 4px 15px #0000001a}50%{box-shadow:0 6px 30px #0d6efd66,0 0 20px #0d6efd33}}@keyframes pm25-glow-dark{0%,to{box-shadow:0 4px 15px #0000004d}50%{box-shadow:0 6px 30px #5c9ead80,0 0 20px #5c9ead4d}}.pm25-circle.animating{animation:pm25-pulse .8s ease-in-out,pm25-glow .8s ease-in-out}.dark-mode .pm25-circle.animating{animation:pm25-pulse .8s ease-in-out,pm25-glow-dark .8s ease-in-out}.pm25-value.animating{animation:value-fade .6s ease-out}.pm25-label{color:var(--text-secondary-light)!important;font-weight:600!important;margin-bottom:5px!important}.dark-mode .pm25-label{color:var(--text-secondary-dark)!important}.pm25-value{color:var(--text-light)!important;font-weight:700!important;line-height:1!important}.dark-mode .pm25-value{color:var(--text-dark)!important}.pm25-unit{color:var(--text-secondary-light)!important;margin-top:5px!important}.dark-mode .pm25-unit{color:var(--text-secondary-dark)!important}.timestamp{color:#555!important;font-size:1rem!important;margin-top:20px;display:flex;align-items:center;justify-content:center;gap:8px}.dark-mode .timestamp{color:var(--text-secondary-dark)!important}.live-indicator{display:inline-flex;align-items:center;gap:6px;color:#22c55e;font-size:.9rem;font-weight:600}.live-dot{width:8px;height:8px;background-color:#22c55e;border-radius:50%;animation:live-pulse 2s infinite}@keyframes live-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}.dark-mode .live-indicator{color:#4ade80}.dark-mode .live-dot{background-color:#4ade80}.pm25-leaf-overlay{position:absolute;bottom:15px;right:-10px;width:60px;height:auto;z-index:0}.mascot-group-panel{width:280px;flex-shrink:0;height:calc(100% - 48px);margin:24px;border-radius:16px!important;background-color:var(--card-bg-light)!important;display:flex;flex-direction:column;padding:16px;overflow:hidden}.dark-mode .mascot-group-panel{background-color:var(--card-bg-dark)!important}.group-header{color:var(--text-light)!important;font-weight:600!important;margin-bottom:10px!important;text-align:center}.dark-mode .group-header{color:var(--text-dark)!important}.group-search-bar.MuiTextField-root{margin-bottom:10px}.group-search-bar .MuiOutlinedInput-root{border-radius:20px;background-color:var(--bg-light)}.dark-mode .group-search-bar .MuiOutlinedInput-root{background-color:var(--bg-dark)}.dark-mode .group-search-bar .MuiInputBase-input{color:var(--text-dark)}.dark-mode .group-search-bar .MuiInputBase-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.dark-mode .group-search-bar .MuiInputAdornment-root .MuiSvgIcon-root{color:var(--text-secondary-dark)}.group-list{flex-grow:1;overflow-y:auto;padding:0!important}.group-list-item.MuiListItem-root{padding-top:8px!important;padding-bottom:8px!important;border-bottom:1px solid var(--border-light);border-radius:8px;margin-bottom:4px}.dark-mode .group-list-item.MuiListItem-root{border-bottom:1px solid var(--border-dark)}.group-list-item:last-child{border-bottom:none}.group-list-item:hover{background-color:#0d6efd0d}.dark-mode .group-list-item:hover{background-color:#ffffff0d}.group-list-item .MuiListItemText-primary{font-size:.9rem;color:var(--text-secondary-light);font-weight:500}.dark-mode .group-list-item .MuiListItemText-primary{color:var(--text-secondary-dark)}.mascot-page-container>h1{display:none}@media (max-width: 1200px){.mascot-group-panel{width:240px}}@media (max-width: 992px){.mascot-page-container{flex-direction:column;height:auto;overflow-y:auto}.mascot-toolbar{position:static;transform:none;flex-direction:row;justify-content:center;width:100%;padding:10px 15px;border-radius:0;box-shadow:0 2px 5px #0000001a;order:1;height:auto;gap:15px}.toolbar-button.MuiIconButton-root{width:40px;height:40px}.mascot-main-content{padding:20px;order:2}.mascot-display-area{flex-direction:column;gap:25px;margin-bottom:25px}.mascot-image{max-width:200px}.pm25-circle{width:200px;height:200px}.pm25-value{font-size:3rem!important}.pm25-unit{font-size:1.1rem!important}.mascot-group-panel{width:calc(100% - 40px);margin:0 auto 20px;order:3;height:auto;max-height:40vh}}@media (max-width: 576px){.welcome-text .MuiTypography-h4{font-size:1.5rem}.welcome-text .MuiTypography-h5{font-size:1.1rem}.mascot-image{max-width:150px}.pm25-circle{width:180px;height:180px}.pm25-value{font-size:2.5rem!important}.mascot-group-panel{width:calc(100% - 30px)}.group-list-item .MuiListItemText-primary{font-size:.8rem}}.page-container{padding:20px}.page-container h1{margin-bottom:20px;font-size:2rem;color:var(--text-light)}.dark-mode .page-container h1{color:var(--text-dark)}.page-content{display:flex;flex-direction:column;gap:20px}.info-card{background-color:#fff;border-radius:10px;padding:20px;box-shadow:0 4px 12px #0000001a}.dark-mode .info-card{background-color:var(--sidebar-dark);box-shadow:0 4px 12px #0000004d}.info-card h2{margin-bottom:15px;font-size:1.5rem;color:var(--primary-color)}.info-card p{margin-bottom:10px;line-height:1.6}.map-page-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.map-page-container .page-content{flex-grow:1;display:flex;padding:0}.map-card-standalone{padding:0!important;overflow:hidden;display:flex;flex-grow:1}.device-page-container{display:flex;flex-direction:column;height:calc(100vh - 48px)}.device-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;margin-bottom:16px;background-color:var(--card-bg-light);border-radius:12px;box-shadow:0 2px 4px #0000000d}.dark-mode .device-header{background-color:var(--card-bg-dark);box-shadow:0 2px 4px #0003}.device-stats span{margin-right:24px;font-size:.95rem;font-weight:500}.device-stats .online-stat{color:var(--success-color)}.device-stats .offline-stat{color:var(--danger-color)}.search-container .MuiTextField-root{width:300px}.search-container .MuiOutlinedInput-root{border-radius:20px;background-color:var(--bg-light)}.dark-mode .search-container .MuiOutlinedInput-root{background-color:var(--bg-dark)}.dark-mode .search-container .MuiInputBase-input{color:var(--text-dark)}.dark-mode .search-container .MuiInputBase-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.dark-mode .search-container .MuiInputAdornment-root .MuiSvgIcon-root{color:var(--text-secondary-dark)}.table-paper{flex-grow:1;border-radius:12px!important;overflow:hidden;display:flex;flex-direction:column;background-color:var(--card-bg-light)}.dark-mode .table-paper{background-color:var(--card-bg-dark)}.table-container{flex-grow:1;overflow-y:auto;overflow-x:auto}.MuiTableHead-root .MuiTableRow-root{background-color:#e9ecef}.dark-mode .MuiTableHead-root .MuiTableRow-root{background-color:#3a3f5a}.MuiTableCell-head{font-weight:600!important;color:var(--text-secondary-light)!important;background-color:inherit!important;border-bottom:1px solid var(--border-light)!important}.dark-mode .MuiTableCell-head{color:var(--text-secondary-dark)!important;border-bottom:1px solid var(--border-dark)!important}.MuiTableCell-body{font-size:.875rem!important;border-bottom:1px solid var(--border-light)!important;color:var(--text-light)!important}.dark-mode .MuiTableCell-body{border-bottom:1px solid var(--border-dark)!important;color:var(--text-dark)!important}.MuiTableRow-root:last-child .MuiTableCell-body{border-bottom:none!important}.status-icon{font-size:1.5rem!important;vertical-align:middle}.status-icon.online{color:var(--success-color)}.status-icon.offline{color:var(--danger-color)}.device-page-container h1{display:none}.device-page-container .page-content{padding:0}@media (max-width: 768px){.device-header{flex-direction:column;align-items:stretch;gap:15px}.device-stats{display:flex;justify-content:space-around;text-align:center}.device-stats span{margin-right:0}.search-container .MuiTextField-root{width:100%}}@media (max-width: 576px){.device-header{padding:12px;border-radius:8px}.device-stats span{font-size:.85rem}}@media (max-width: 576px){.MuiTableCell-head,.MuiTableCell-body{padding:8px!important;font-size:.8rem!important;white-space:nowrap}.status-icon{font-size:1.2rem!important}}.group-page-container{display:flex;gap:16px;padding:16px;height:calc(100vh - 48px);background-color:var(--bg-light)}.dark-mode .group-page-container{background-color:var(--bg-dark)}.panel{background-color:var(--card-bg-light);border-radius:16px!important;padding:0;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 8px #00000014}.dark-mode .panel{background-color:var(--card-bg-dark);box-shadow:0 2px 8px #0003}.group-list-panel,.sensor-list-panel{width:250px;flex-shrink:0}.panel-title-bar{padding:10px 16px;border-top:4px solid var(--primary-color);border-radius:16px 16px 0 0}.group-list-panel .panel-title-bar,.sensor-list-panel .panel-title-bar{border-top:none}.panel-title-bar h6{color:var(--text-light)!important;font-weight:600!important;text-align:center}.dark-mode .panel-title-bar h6{color:var(--text-dark)!important}.search-input{margin:8px auto 12px!important;width:80%;display:block}.search-input .MuiOutlinedInput-root{border-radius:20px!important;background-color:var(--bg-light)}.dark-mode .search-input .MuiOutlinedInput-root{background-color:var(--bg-dark)}.dark-mode .search-input .MuiInputBase-input{color:var(--text-dark)}.dark-mode .search-input .MuiInputBase-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.dark-mode .search-input .MuiInputAdornment-root .MuiSvgIcon-root{color:var(--text-secondary-dark)}.list-header-card{padding:8px 16px!important;margin:0 16px 8px!important;background-color:#e9ecef!important;color:var(--text-secondary-light)!important;font-weight:600!important;border-radius:8px!important;text-align:center;border:none!important}.dark-mode .list-header-card{background-color:#3a3f5a!important;color:var(--text-secondary-dark)!important}.scrollable-list{flex-grow:1;overflow-y:auto;padding:0 8px 8px!important}.list-item.MuiListItemButton-root{padding:6px 12px!important;border-bottom:1px solid var(--border-light);border-radius:8px;margin-bottom:2px;transition:all .2s ease}.dark-mode .list-item.MuiListItemButton-root{border-bottom-color:var(--border-dark)}.list-item:last-child{border-bottom:none}.list-item .MuiListItemText-primary{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-light)}.dark-mode .list-item .MuiListItemText-primary{color:var(--text-dark)}.list-item.Mui-selected{background-color:#1170e31a!important}.dark-mode .list-item.Mui-selected{background-color:#1170e333!important}.list-item.Mui-selected .MuiListItemText-primary{font-weight:600;color:var(--text-light)!important}.dark-mode .list-item.Mui-selected .MuiListItemText-primary{color:var(--text-dark)!important}.map-container{height:100%;flex-shrink:0;padding:0}.device-list-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-light);color:var(--text-light)}.dark-mode .device-list-title{border-bottom-color:var(--border-dark);color:var(--text-dark)}.device-list-title .MuiTypography-caption{color:var(--text-secondary-light)}.dark-mode .device-list-title .MuiTypography-caption{color:var(--text-secondary-dark)}.device-summary-list{list-style:none;padding:0;margin:0;flex-grow:1;overflow-y:auto}.device-summary-item{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light);transition:all .2s ease;opacity:1}.dark-mode .device-summary-item{border-bottom:1px solid var(--border-dark)}.device-summary-item:last-child{border-bottom:none}.status-dot{width:10px;height:10px;border-radius:50%;margin-right:12px;flex-shrink:0}.status-dot.good{background-color:var(--success-color)}.status-dot.unhealthy{background-color:var(--danger-color)}.device-info{flex-grow:1;margin-right:10px}.device-name{display:block;font-size:.9rem;font-weight:500;color:var(--text-light);margin-bottom:2px}.dark-mode .device-name{color:var(--text-dark)}.device-details{font-size:.8rem;color:var(--text-secondary-light)}.dark-mode .device-details{color:var(--text-secondary-dark)}.device-readings{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-secondary-light);flex-shrink:0}.dark-mode .device-readings{color:var(--text-secondary-dark)}.device-temp,.device-battery{display:flex;align-items:center}.device-readings .MuiSvgIcon-root{font-size:1rem;margin-right:3px}.center-column-container{display:flex;flex-direction:column;gap:16px;flex-grow:1;overflow:hidden}.map-panel{height:45%;flex-shrink:0}.device-panel{flex-grow:1}.device-details-container{padding:12px 16px;flex-grow:1;display:flex;flex-direction:column;overflow:hidden}.summary-panel{width:250px;flex-shrink:0;padding:16px;gap:16px;align-items:stretch}.summary-header{text-align:center;color:var(--text-secondary-light);font-weight:600!important;margin-bottom:8px}.dark-mode .summary-header{color:var(--text-secondary-dark)}.summary-cards-group{display:flex;flex-direction:column;gap:12px;transition:all .3s ease}.dark-mode .summary-panel .MuiBox-root .MuiTypography-caption{color:var(--text-secondary-dark)}@media (max-width: 1200px){.group-page-container{flex-direction:column;height:auto;overflow-y:auto}.panel{width:100%!important;margin-bottom:16px;max-height:60vh}.center-column-container{order:-1;gap:16px;flex-grow:0}.summary-panel{order:3;max-height:none}.map-panel{height:300px;max-height:none}.device-panel{max-height:40vh;min-height:250px}}.content-fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.list-item .skeleton-text{margin:2px 0}.connection-indicator{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;margin-left:8px}.connection-indicator.connected{color:var(--success-color)}.connection-indicator.disconnected{color:var(--warning-color)}.panel-title-bar{display:flex;align-items:center;justify-content:space-between}@media (max-width: 768px){.group-page-container{padding:10px;gap:10px}.panel{border-radius:12px!important}.panel-title-bar{padding:8px 12px}.search-input{margin:8px 12px!important}.list-header-card{padding:6px 12px!important;margin:0 12px 6px!important}.scrollable-list{padding:0 4px 4px!important}.list-item.MuiListItemButton-root{padding:4px 10px!important}.list-item .MuiListItemText-primary{font-size:.8rem}.device-details-container{padding:10px 12px}.device-list-title{margin-bottom:6px;padding-bottom:6px}.device-summary-item{padding:8px 0;flex-wrap:wrap}.device-readings{width:100%;margin-top:5px;justify-content:flex-end}.center-column-container{gap:10px}.map-panel{height:250px}.device-panel{max-height:35vh;min-height:200px}.summary-panel{padding:12px;gap:12px}.summary-header{margin-bottom:6px}.summary-cards-group{gap:10px}.skeleton-text{height:14px}}.report-page-container{display:grid;grid-template-columns:260px 260px 300px 1fr;gap:16px;padding:16px;height:calc(100vh - 48px);background-color:var(--bg-light);overflow:hidden}.dark-mode .report-page-container{background-color:var(--bg-dark)}.report-panel{background-color:var(--card-bg-light);border-radius:16px!important;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 8px #00000014;height:100%}.dark-mode .report-panel{background-color:var(--card-bg-dark);box-shadow:0 2px 8px #0003}.report-panel-title-bar{padding:10px 16px;display:flex;align-items:center;justify-content:space-between}.report-panel-title{color:var(--text-light)!important;font-weight:600!important;text-align:center}.dark-mode .report-panel-title{color:var(--text-dark)!important}.report-search-input{margin:8px auto 12px!important;width:80%!important;display:block!important}.report-search-input .MuiOutlinedInput-root{border-radius:20px!important;background-color:var(--bg-light)}.dark-mode .report-search-input .MuiOutlinedInput-root{background-color:var(--bg-dark)}.dark-mode .report-search-input .MuiInputBase-input{color:var(--text-dark)}.dark-mode .report-search-input .MuiInputBase-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.dark-mode .report-search-input .MuiInputAdornment-root .MuiSvgIcon-root{color:var(--text-secondary-dark)}.report-list-header{padding:8px 16px!important;margin:0 16px 8px!important;background-color:#e9ecef!important;color:var(--text-secondary-light)!important;font-weight:600!important;border-radius:8px!important;text-align:center;border:none!important}.dark-mode .report-list-header{background-color:#3a3f5a!important;color:var(--text-secondary-dark)!important}.report-scrollable-list{flex-grow:1;overflow-y:auto;padding:0 8px 8px!important}.report-list-item.MuiListItemButton-root{padding:6px 12px!important;border-bottom:1px solid var(--border-light);border-radius:8px;margin-bottom:2px;transition:all .2s ease}.dark-mode .report-list-item.MuiListItemButton-root{border-bottom-color:var(--border-dark)}.report-list-item:last-child{border-bottom:none}.report-list-item .MuiListItemText-primary{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-light)}.dark-mode .report-list-item .MuiListItemText-primary{color:var(--text-dark)}.report-list-item.Mui-selected{background-color:#1170e31a!important}.dark-mode .report-list-item.Mui-selected{background-color:#1170e333!important}.report-list-item.Mui-selected .MuiListItemText-primary{font-weight:600;color:var(--text-light)!important}.dark-mode .report-list-item.Mui-selected .MuiListItemText-primary{color:var(--text-dark)!important}.report-date-panel .date-content{padding:16px;display:flex;flex-direction:column;gap:16px;height:calc(100% - 60px)}.date-picker-container{display:flex;flex-direction:column;gap:16px;flex:1}.date-summary-info{margin-top:auto;padding:12px;background-color:#1170e30a;border-radius:8px;border:1px solid rgba(17,112,227,.12)}.dark-mode .date-summary-info{background-color:#1170e314;border-color:#1170e333}.report-export-panel .export-content{padding:20px;display:flex;flex-direction:column;height:calc(100% - 60px)}.export-header{text-align:center;color:var(--text-light);font-weight:600!important;margin-bottom:20px;font-size:1.1rem!important}.dark-mode .export-header{color:var(--text-dark)}.export-settings-card{background:linear-gradient(135deg,#1170e30d,#1170e305);border:1px solid rgba(17,112,227,.15);border-radius:16px;padding:20px;margin-bottom:20px;flex:1}.dark-mode .export-settings-card{background:linear-gradient(135deg,#1170e31a,#1170e30d);border-color:#1170e340}.export-settings-title{font-weight:600!important;color:var(--text-light)!important;margin-bottom:16px!important;text-align:center}.dark-mode .export-settings-title{color:var(--text-dark)!important}.export-setting-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.05)}.dark-mode .export-setting-row{border-bottom-color:#ffffff0d}.export-setting-row:last-child{border-bottom:none;margin-bottom:0}.export-setting-label{font-weight:600;color:var(--text-light);font-size:.875rem}.dark-mode .export-setting-label{color:var(--text-dark)}.export-setting-value{color:var(--text-secondary-light);font-size:.875rem;text-align:right;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dark-mode .export-setting-value{color:var(--text-secondary-dark)}.export-actions{margin-top:auto;display:flex;flex-direction:column;gap:12px}.download-button{background:linear-gradient(135deg,#1976d2,#1565c0)!important;height:50px!important;font-size:1rem!important;font-weight:600!important;border-radius:12px!important;box-shadow:0 4px 16px #1976d24d!important;transition:all .3s ease!important;text-transform:none!important}.download-button:hover:not(:disabled){transform:translateY(-2px)!important;box-shadow:0 8px 24px #1976d266!important}.download-button:disabled{background:linear-gradient(135deg,#e0e0e0,#bdbdbd)!important;box-shadow:none!important;transform:none!important;color:#9e9e9e!important}.validation-error{background-color:#f4433614!important;border:1px solid rgba(244,67,54,.2)!important;border-radius:8px!important;padding:8px 12px!important;text-align:center!important;font-size:.8rem!important;color:#d32f2f!important}.dark-mode .validation-error{background-color:#f443361f!important;border-color:#f443364d!important;color:#f48fb1!important}@media (max-width: 1600px){.report-page-container{grid-template-columns:240px 240px 280px 1fr;gap:12px}}@media (max-width: 1400px){.report-page-container{grid-template-columns:220px 220px 260px 1fr;gap:12px;padding:12px}.export-settings-card{padding:16px}.download-button{height:46px!important;font-size:.95rem!important}}@media (max-width: 1200px){.report-page-container{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:16px;height:auto;overflow-y:auto}.report-panel{height:auto;min-height:400px}.report-date-panel{min-height:350px}.report-export-panel{min-height:300px}.date-content,.export-content{height:auto}}@media (max-width: 768px){.report-page-container{grid-template-columns:1fr;padding:8px;gap:12px}.report-panel{min-height:280px}.report-panel-title-bar{padding:8px 12px}.report-search-input{margin:6px auto 8px!important;width:85%!important}.report-list-header{padding:6px 12px!important;margin:0 12px 6px!important;font-size:.8rem!important}.report-scrollable-list{padding:0 4px 4px!important}.report-list-item.MuiListItemButton-root{padding:4px 10px!important}.report-list-item .MuiListItemText-primary{font-size:.8rem}.date-content,.export-content,.export-settings-card{padding:12px}.download-button{height:44px!important;font-size:.9rem!important}.export-setting-row{margin-bottom:8px;padding:6px 0}.export-setting-label,.export-setting-value{font-size:.8rem}}.skeleton-text{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px;height:16px;width:100%}.dark-mode .skeleton-text{background:linear-gradient(90deg,#3a3f5a 25%,#4a4f6a,#3a3f5a 75%);background-size:200% 100%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.alert-page-container{display:flex;gap:24px;height:calc(100vh - 48px);padding:24px}.alert-filters{display:flex;flex-direction:column;gap:20px;width:150px;flex-shrink:0;justify-content:center;align-items:center}.filter-button{width:100px!important;height:100px!important;border-radius:50%!important;font-size:1rem!important;font-weight:600!important;text-transform:none!important;box-shadow:0 2px 5px #00000026!important;border:2px solid transparent!important;transition:transform .2s ease,box-shadow .2s ease!important}.filter-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003!important}.filter-button.all{background-color:var(--success-color)!important;color:#fff!important}.filter-button.event{background-color:var(--primary-color)!important;color:#fff!important}.filter-button.device{background-color:var(--accent-orange)!important;color:#fff!important}.filter-button.risk{background-color:var(--danger-color)!important;color:#fff!important}.filter-button.MuiButton-outlined{background-color:var(--card-bg-light)!important;border:2px solid!important}.dark-mode .filter-button.MuiButton-outlined{background-color:var(--card-bg-dark)!important}.filter-button.all.MuiButton-outlined{color:var(--success-color)!important;border-color:var(--success-color)!important}.filter-button.event.MuiButton-outlined{color:var(--primary-color)!important;border-color:var(--primary-color)!important}.filter-button.device.MuiButton-outlined{color:var(--accent-orange)!important;border-color:var(--accent-orange)!important}.filter-button.risk.MuiButton-outlined{color:var(--danger-color)!important;border-color:var(--danger-color)!important}.alert-content{flex-grow:1;display:flex;flex-direction:column;min-width:0}.alert-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;margin-bottom:16px;background-color:var(--card-bg-light);border-radius:12px;box-shadow:0 2px 4px #0000000d}.dark-mode .alert-header{background-color:var(--card-bg-dark);box-shadow:0 2px 4px #0003}.alert-stats span{margin-right:24px;font-size:.95rem;font-weight:500}.alert-stats .read-stat{color:var(--success-color)}.alert-stats .unread-stat{color:var(--danger-color)}.alert-header .search-container .MuiTextField-root{width:300px}.alert-header .search-container .MuiOutlinedInput-root{border-radius:20px;background-color:var(--bg-light)}.dark-mode .alert-header .search-container .MuiOutlinedInput-root{background-color:var(--bg-dark)}.dark-mode .alert-header .search-container .MuiInputBase-input{color:var(--text-dark)}.dark-mode .alert-header .search-container .MuiInputBase-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.dark-mode .alert-header .search-container .MuiInputAdornment-root .MuiSvgIcon-root{color:var(--text-secondary-dark)}.alert-table-paper{flex-grow:1;border-radius:12px!important;overflow:hidden;display:flex;flex-direction:column;background-color:var(--card-bg-light)}.dark-mode .alert-table-paper{background-color:var(--card-bg-dark)}.alert-table-container{flex-grow:1;overflow-y:auto;overflow-x:auto}.alert-table-paper .MuiTableHead-root .MuiTableRow-root{background-color:#e9ecef}.dark-mode .alert-table-paper .MuiTableHead-root .MuiTableRow-root{background-color:#3a3f5a}.alert-table-paper .MuiTableCell-head{font-weight:600!important;color:var(--text-secondary-light)!important;background-color:inherit!important;border-bottom:1px solid var(--border-light)!important}.dark-mode .alert-table-paper .MuiTableCell-head{color:var(--text-secondary-dark)!important;border-bottom:1px solid var(--border-dark)!important}.alert-table-paper .MuiTableCell-body{font-size:.875rem!important;border-bottom:1px solid var(--border-light)!important;color:var(--text-light)!important}.dark-mode .alert-table-paper .MuiTableCell-body{border-bottom:1px solid var(--border-dark)!important;color:var(--text-dark)!important}.alert-table-paper .MuiTableRow-root:last-child .MuiTableCell-body{border-bottom:none!important}.alert-table-paper .status-icon{font-size:1.5rem!important;vertical-align:middle}.alert-table-paper .status-icon.read{color:var(--success-color)}.alert-table-paper .status-icon.unread{color:var(--danger-color)}.alert-page-container>h1{display:none}@media (max-width: 992px){.alert-page-container{flex-direction:column;height:auto;padding:16px}.alert-filters{flex-direction:row;width:100%;justify-content:center;gap:15px;margin-bottom:16px}.filter-button{width:80px!important;height:80px!important;font-size:.85rem!important}}@media (max-width: 768px){.alert-header{flex-direction:column;align-items:stretch;gap:15px}.alert-stats{display:flex;justify-content:space-around;text-align:center}.alert-stats span{margin-right:0}.alert-header .search-container .MuiTextField-root{width:100%}}@media (max-width: 576px){.alert-filters{gap:10px;flex-wrap:wrap}.filter-button{width:70px!important;height:70px!important;font-size:.8rem!important}.alert-header{padding:12px;border-radius:8px}.alert-stats span{font-size:.85rem}.alert-table-paper .MuiTableCell-head,.alert-table-paper .MuiTableCell-body{padding:8px!important;font-size:.8rem!important;white-space:nowrap}.alert-table-paper .status-icon{font-size:1.2rem!important}}:root{--bg-light: #f4f7fc;--card-bg-light: #ffffff;--text-light: #333333;--text-secondary-light: #6c757d;--sidebar-light: #ffffff;--border-light: #e0e0e0;--primary-color: #0d6efd;--secondary-color: #6c757d;--accent-orange: #fd7e14;--temp-color: #e83e8c;--success-color: #198754;--danger-color: #dc3545;--summary-max-bg: #e1d5e7;--summary-max-text: #6f42c1;--summary-avg-bg: #ffe8cc;--summary-avg-text: #fd7e14;--summary-min-bg: #cff4fc;--summary-min-text: #198754;--bg-dark: #1a1a2e;--card-bg-dark: #232946;--text-dark: #e0e0e0;--text-secondary-dark: #adb5bd;--sidebar-dark: #161625;--border-dark: #3a3f5a;--summary-max-bg-dark: #4b3b5f;--summary-max-text-dark: #c5a8e8;--summary-avg-bg-dark: #5c4632;--summary-avg-text-dark: #ffcc80;--summary-min-bg-dark: #2c505c;--summary-min-text-dark: #76e0a5;--min-pm-bg-dark: #224b3a;--min-pm-text-dark: #63e6be;--max-temp-bg-light: #f8a0a1;--max-temp-text-light: #ff5757;--avg-temp-bg-light: #f8d6a2;--avg-temp-text-light: #ff914d;--min-temp-bg-light: #8fd3fa;--min-temp-text-light: #1c88cf;--max-temp-bg-dark: #5c3e3e;--max-temp-text-dark: #fbb8b8;--avg-temp-bg-dark: #5c4e3e;--avg-temp-text-dark: #fccfae;--min-temp-bg-dark: #395164;--min-temp-text-dark: #a4d9fc;--max-pm-bg-light: #b2a7c7;--max-pm-text-light: #7b649f;--avg-pm-bg-light: #f8d6a2;--avg-pm-text-light: #ff914d;--min-pm-bg-light: #9cf1cb;--min-pm-text-light: #00bf63;--max-pm-bg-dark: #433e4d;--max-pm-text-dark: #c5bdd7;--avg-pm-bg-dark: #5c4e3e;--avg-pm-text-dark: #fccfae;--min-pm-bg-dark: #3b5e4d;--min-pm-text-dark: #b3f5d9}*{margin:0;padding:0;box-sizing:border-box}.app{font-family:Roboto,Noto Sans Thai,sans-serif;height:100vh;transition:background-color .3s,color .3s;background-color:var(--bg-light);color:var(--text-light)}.light-mode{background-color:var(--bg-light);color:var(--text-light)}.dark-mode{background-color:var(--bg-dark);color:var(--text-dark)}.app-container{display:flex;height:100%}.content{flex:1;padding:20px;overflow-y:auto}.mobile-menu-button{background:#00000005;border-radius:8px}@media (max-width: 768px){.content{padding:15px}}@media (max-width: 576px){.content{padding:10px}}@media (max-width: 768px){.MuiTableContainer-root{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.MuiTable-root{min-width:640px}.page-container{padding:12px}.info-card{padding:12px;border-radius:8px}.page-container h1{font-size:1.5rem;margin-bottom:12px}.page-container h2{font-size:1.25rem;margin-bottom:10px}.map-card-standalone{min-height:60vh}.chart-wrapper{min-height:220px}}
