:root{--font-family-sans: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--border-radius: 12px;--border-radius-lg: 16px;--border-radius-sm: 8px;--transition-speed: .3s;--company-red: #dc3545;--company-black: #1a1a1a;--company-white: #ffffff;--company-light-gray: #f0f0f0;--company-dark-gray: #333333;--company-medium-gray: #cccccc;--water-color: #4dabf7;--water-animation-speed: 6s;--led-on-color: #4caf50;--led-off-color: #cc1b27;--state-2-color: #ffc107;--state-3-color: #17a2b8;--state-2-bg: rgba(255,193,7,.06);--state-3-bg: rgba(23,162,184,.06);--led-flash-speed: 1s;--status-on-bg-tint: rgba(76, 175, 80, .1);--status-off-bg-tint: rgba(228, 30, 43, .05);--silo-fill-color: #FFA500;--silo-fill-color-dark: #FF8C00;--silo-trickle-color: rgba(211, 211, 211, .6);--silo-trickle-color-dark: rgba(192, 192, 192, .6);--silo-height: 150px;--silo-width: 80px;--silo-trickle-speed: 1.2s;--notification-warning-bg: #fff3cd;--notification-warning-border: #ffeeba;--notification-warning-text: #856404;--notification-warning-icon: #ffc107;--notification-error-bg: #f8d7da;--notification-error-border: #f5c6cb;--notification-error-text: #721c24;--notification-error-icon: #dc3545;--notification-info-bg: #d1ecf1;--notification-info-border: #bee5eb;--notification-info-text: #0c5460;--notification-info-icon: #17a2b8;--screen-dim-color: rgba(0, 0, 0, .5);--weather-widget-bg: transparent;--weather-widget-text: var(--header-text);--weather-widget-icon-color: var(--header-text);--header-bg: transparent;--header-text: var(--text-primary-color);--header-border: var(--border-color);--widget-gap: 1.5rem;--header-height: 60px;--progress-bar-bg: #e9ecef;--progress-bar-color-low: #cc1b27;--progress-bar-color-medium: #ffc107;--progress-bar-color-high: #28a745;--box-shadow-sm: 0 2px 4px rgba(0,0,0,.05);--box-shadow-md: 0 4px 6px rgba(0,0,0,.07);--box-shadow-lg: 0 10px 15px rgba(0,0,0,.1);--gradient-primary: linear-gradient(145deg, var(--bg-secondary), var(--bg-primary));--gradient-accent: linear-gradient(145deg, var(--company-red), #e74c3c);--gradient-success: linear-gradient(145deg, #2ecc71, #27ae60);--card-bg: rgba(255, 255, 255, .05);--backdrop-blur: blur(10px);--carbon-fiber-light: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h40v40H0V0zm20 10a10 10 0 1 1 0 20 10 10 0 0 1 0-20zm0-10A20 20 0 1 0 20 40 20 20 0 0 0 20 0z' fill='%23f8f9fa' fill-opacity='0.08'/%3E%3C/svg%3E");--carbon-fiber-dark: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h40v40H0V0zm20 10a10 10 0 1 1 0 20 10 10 0 0 1 0-20zm0-10A20 20 0 1 0 20 40 20 20 0 0 0 20 0z' fill='%23262626' fill-opacity='0.08'/%3E%3C/svg%3E")}body.light-mode{--bg-primary: var(--company-light-gray);--bg-secondary: var(--company-white);--text-primary-color: var(--company-black);--text-secondary-color: var(--company-dark-gray);--border-color: #e0e0e0;--accent-color: var(--company-red);--navbar-bg: rgba(255, 255, 255, .9);--navbar-shadow: 0 2px 10px rgba(0, 0, 0, .1);--button-hover-bg: #faeaeb;--button-active-bg: var(--company-red);--button-active-text: var(--company-white);--tile-bg-color: var(--company-white);--tile-on-bg-color: #e8f5e9;--tile-off-bg-color: #faeaeb;--status-on-color: var(--led-on-color);--status-off-color: var(--led-off-color);--icon-color: var(--company-dark-gray);--mode-toggle-icon: #f39c12;--connection-connected-color: #2ecc71;--connection-disconnected-color: var(--company-red);--bg-primary-rgb: 240, 240, 240;--sensor-bg: var(--company-white);--monitor-bg: var(--company-white);--monitor-text: var(--company-black);--monitor-border: #e0e0e0;--monitor-timestamp: #555;--tank-border: var(--company-dark-gray);--tank-level-text-color: var(--company-white);--tank-label-color: var(--text-secondary-color);--status-box-border: #e0e0e0;--status-box-icon-color: var(--accent-color);--led-shadow: rgba(0, 0, 0, .2);--status-on-bg: var(--status-on-bg-tint);--status-off-bg: var(--status-off-bg-tint);--tile-time-color: var(--text-secondary-color);--silo-border-color: var(--company-dark-gray);--silo-fill: var(--silo-fill-color);--silo-level-text-color: var(--company-black);--silo-label-color: var(--text-secondary-color);--silo-trickle: var(--silo-trickle-color);--notification-close-hover: #6c757d;--weather-widget-text: var(--header-text);--weather-widget-icon-color: var(--header-text);--header-text: var(--text-primary-color);--header-border: var(--border-color);--progress-bar-bg: #e9ecef;--bg-texture: var(--carbon-fiber-light)}body.dark-mode{--bg-primary: var(--company-black);--bg-secondary: var(--company-dark-gray);--text-primary-color: var(--company-white);--text-secondary-color: var(--company-light-gray);--border-color: #444444;--accent-color: var(--company-red);--navbar-bg: rgba(26, 26, 26, .9);--navbar-shadow: 0 2px 10px rgba(0, 0, 0, .5);--button-hover-bg: #4d2528;--button-active-bg: var(--company-red);--button-active-text: var(--company-white);--tile-bg-color: var(--company-dark-gray);--tile-on-bg-color: #2f4430;--tile-off-bg-color: #4d2528;--status-on-color: #68d391;--status-off-color: #cc1b27;--icon-color: var(--company-light-gray);--mode-toggle-icon: #76e4f7;--connection-connected-color: #68d391;--connection-disconnected-color: #f87171;--bg-primary-rgb: 26, 26, 26;--sensor-bg: var(--company-dark-gray);--monitor-bg: var (--company-dark-gray);--monitor-text: var(--company-light-gray);--monitor-border: #555;--monitor-timestamp: #aaa;--tank-border: var(--company-medium-gray);--tank-level-text-color: var(--company-white);--tank-label-color: var(--text-secondary-color);--status-box-border: #555;--status-box-icon-color: var(--accent-color);--led-shadow: rgba(0, 0, 0, .5);--status-on-bg: var(--status-on-bg-tint);--status-off-bg: var(--status-off-bg-tint);--tile-time-color: var(--text-secondary-color);--silo-border-color: var(--company-medium-gray);--silo-fill: var(--silo-fill-color-dark);--silo-level-text-color: var (--company-black);--silo-label-color: var(--text-secondary-color);--silo-trickle: var(--silo-trickle-color-dark);--notification-warning-bg: #332701;--notification-warning-border: #665102;--notification-warning-text: #ffecb3;--notification-warning-icon: #ffc107;--notification-error-bg: #2c0b0e;--notification-error-border: #58151c;--notification-error-text: #f5c6cb;--notification-error-icon: #dc3545;--notification-info-bg: #052c33;--notification-info-border: #0c5460;--notification-info-text: #bee5eb;--notification-info-icon: #17a2b8;--notification-close-hover: #adb5bd;--weather-widget-text: var(--header-text);--weather-widget-icon-color: var(--header-text);--header-text: var(--text-primary-color);--header-border: var(--border-color);--progress-bar-bg: #495057;--bg-texture: var(--carbon-fiber-dark)}body{margin:0;font-family:var(--font-family-sans);background-color:var(--bg-primary);color:var(--text-primary-color);transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:var(--bg-texture);background-repeat:repeat}#app-container{display:flex;flex-direction:column;min-height:100vh}body.screen-dimmed:after{display:none}.page-header{display:none}.header-logo img{height:80px;width:auto;display:block;content:url(logo.png)}body.dark-mode .header-logo img{content:url(logo1.png)}.header-widgets{display:flex;align-items:center;gap:var(--widget-gap)}.floating-navbar{position:fixed;top:50%;left:0;transform:translateY(-50%);width:120px;padding:1rem;height:auto;background:#ffffff1a;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:var(--box-shadow-lg);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:1.2rem;z-index:900;margin:0;opacity:1;pointer-events:auto;transition:opacity .3s ease,transform .3s ease;background-image:var(--bg-texture),linear-gradient(to right,#ffffff1a,#ffffff0d)}.floating-navbar.navbar-hidden{opacity:0;pointer-events:none;transform:translate(-100%,-50%)}.nav-links{display:flex;flex-direction:column;gap:1rem;width:100%}.floating-navbar button{background-color:transparent;border:none;padding:.8rem 1rem;border-radius:var(--border-radius-sm);cursor:pointer;font-size:1.1rem;font-weight:500;color:var(--text-secondary-color);transition:background-color var(--transition-speed) ease,color var(--transition-speed) ease;display:flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.floating-navbar button:hover{background-color:var(--button-hover-bg);color:var(--text-primary-color)}.floating-navbar button.active{background-color:var(--button-active-bg);color:var(--button-active-text);font-weight:600}.floating-navbar button i{font-size:1.2rem;width:1.2em;text-align:center}.floating-navbar button span{flex-grow:1}.nav-external-link{background-color:transparent;border:none;padding:.8rem 1rem;border-radius:var(--border-radius-sm);cursor:pointer;font-size:1.1rem;font-weight:500;color:var(--text-secondary-color);text-decoration:none;display:flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1)}.nav-external-link:hover{background-color:var(--button-hover-bg);color:var(--text-primary-color)}.nav-external-link i{font-size:1.2rem;width:1.2em;text-align:center}.nav-external-link span{flex-grow:1}.nav-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:auto;width:100%;border-top:1px solid var(--border-color);padding-top:1rem}.connection-status{font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:.4rem;padding:.3rem .5rem}.connection-status i{font-size:.6rem;transition:color var(--transition-speed) ease}.connection-status.connected i,.connection-status.connected{color:var(--connection-connected-color)}.connection-status.disconnected i,.connection-status.disconnected{color:var(--connection-disconnected-color)}.mode-toggle{padding:.4rem;width:auto;height:auto;display:flex;justify-content:center;align-items:center;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;background-color:#fff3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.mode-toggle:hover{background-color:#ffffff4d}.mode-toggle i{font-size:1rem;color:var(--mode-toggle-icon);margin:0}.notification-banner{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:auto;min-width:300px;max-width:90%;padding:1rem 1.5rem;border-radius:var(--border-radius);border:1px solid;display:flex;align-items:center;gap:1rem;z-index:1100;box-shadow:0 6px 20px #0003;animation:slide-in .5s ease-out}.notification-banner.notification-warning{background-color:var(--notification-warning-bg);border-color:var(--notification-warning-border);color:var(--notification-warning-text)}.notification-banner.notification-warning .icon{color:var(--notification-warning-icon)}.notification-banner .icon{font-size:1.4rem;flex-shrink:0}.notification-banner .message{flex-grow:1;font-weight:500;font-size:1.05rem}.notification-banner .close-button{background:none;border:none;font-size:1.2rem;cursor:pointer;color:inherit;padding:.2rem .5rem;line-height:1;opacity:.7;transition:opacity .2s ease;margin-left:.5rem}.notification-banner .close-button:hover{opacity:1;color:var(--notification-close-hover)}.fade-scale-enter-active,.fade-scale-leave-active{transition:opacity .3s ease,transform .3s ease}.fade-scale-enter-from,.fade-scale-leave-to{opacity:0;transform:translate(-50%,-50%) scale(.9)}.fade-scale-enter-to,.fade-scale-leave-from{opacity:1;transform:translate(-50%,-50%) scale(1)}.weather-widget{background:var(--gradient-primary);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-radius:var(--border-radius);padding:.75rem 1.25rem;box-shadow:var(--box-shadow-sm);color:var(--header-text);display:flex;align-items:center;gap:.8rem;z-index:auto;border:none}.weather-icon i{font-size:1.5rem;color:var(--header-text)}.weather-details{display:flex;align-items:baseline;gap:.5rem}.temperature{font-size:1.1rem;font-weight:600;line-height:1}.condition{font-size:.9rem;opacity:.8;text-transform:capitalize}.weather-location-label{font-size:.9rem;font-weight:600;color:var(--header-text);margin-bottom:.5rem;text-align:center}.weather-widget-container{display:flex;flex-direction:column;align-items:center;margin-right:1.5rem}.weather-site-label{color:red;font-size:1rem;font-weight:700;margin-top:.5rem;text-align:center}.weather-details-inline{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--header-text)}.weather-details-inline .location{color:red}.date-time-widget{display:flex;flex-direction:column;align-items:center;color:var(--header-text);text-align:center}.time{font-size:1.2rem;font-weight:600;line-height:1.1}.date{font-size:.8rem;opacity:.8}.cpu-widget{display:flex;gap:1rem;color:var(--header-text);align-items:center}.cpu-item{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.cpu-item i{font-size:1rem;color:var(--accent-color)}.cpu-item span{color:var(--text-secondary-color)}.cpu-item strong{font-weight:600}.main-content{flex-grow:1;padding:.5rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box;padding-bottom:calc(var(--header-height) + 1rem)}.sensor-data-section{display:flex;flex-wrap:wrap;gap:1.5rem;background-color:var(--sensor-bg);padding:1.5rem;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000000d;margin-top:1rem;border:1px solid var(--border-color);align-items:flex-start;justify-content:space-around;background-image:var(--bg-texture)}.sensor-item{display:flex;align-items:center;gap:.75rem;color:var (--text-primary-color);font-size:.95rem}.other-sensors{display:flex;flex-direction:column;gap:.8rem;flex-grow:1;min-width:180px}.sensor-item{display:flex;align-items:center;gap:.75rem;color:var(--text-primary-color);font-size:.95rem}.sensor-item i{font-size:1.2rem;color:var(--accent-color);width:20px;text-align:center}.sensor-item span{color:var(--text-secondary-color);flex-shrink:0}.sensor-item strong{font-weight:600;min-width:50px;text-align:right}.sensor-item .led-indicator{width:12px;height:12px;margin-left:auto;margin-right:.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;position:relative;min-height:100px}.heath-page .dashboard-grid{grid-template-columns:repeat(3,1fr)}.heath-page .dashboard-grid{grid-template-columns:repeat(3,1fr)!important}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background:rgba(var(--bg-primary-rgb),.8);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);color:var(--text-secondary-color);border-radius:var(--border-radius);z-index:10;text-align:center}.loading-overlay i{margin-bottom:1rem;color:var(--accent-color)}.placeholder-tile{background-color:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--border-radius);display:flex;justify-content:center;align-items:center;min-height:100px;color:var(--text-secondary-color);font-style:italic;grid-column:1 / 5;padding:1rem;text-align:center}.page-content{background-color:var(--bg-secondary);padding:2rem;border-radius:var(--border-radius);box-shadow:0 2px 8px #0000000d;margin-bottom:2rem;border:1px solid var(--border-color);margin-top:1rem;background-image:var(--bg-texture)}.page-content h2{margin-top:0;margin-bottom:1rem;color:var(--text-primary-color);font-size:1.5rem;text-align:center;border-bottom:2px solid var(--accent-color);padding-bottom:.5rem}.page-content p{color:var(--text-secondary-color);font-size:1.1rem;margin-bottom:1.5rem}.placeholder-content{margin-top:2rem;padding:2rem;border:1px dashed var(--border-color);border-radius:8px;color:var(--text-secondary-color);text-align:center}.placeholder-content i{margin-bottom:1rem;color:var(--accent-color)}.monitor-page .message-list-container{max-height:60vh;overflow-y:auto;background-color:var(--monitor-bg);border:1px solid var(--monitor-border);border-radius:var(--border-radius);padding:1rem}.monitor-page .message-list{list-style:none;padding:0;margin:0;font-family:Courier New,Courier,monospace;font-size:.9rem;color:var(--monitor-text)}.monitor-page .message-list li{padding:.3rem .5rem;border-bottom:1px solid var(--monitor-border);display:flex;gap:1rem}.monitor-page .message-list li:last-child{border-bottom:none}.monitor-page .timestamp{color:var(--monitor-timestamp);white-space:nowrap}.monitor-page .message-content{word-break:break-all}.tile{background:var(--gradient-primary);-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);border-radius:var(--border-radius-lg);padding:1.2rem;text-align:center;box-shadow:var(--box-shadow-md);transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;justify-content:space-between;border:1px solid rgba(255,255,255,.1);border-left:5px solid transparent;min-height:100px;position:relative;background-image:var(--bg-texture),var(--gradient-primary)}.tile:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--box-shadow-lg)}.tile-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.8rem}.tile-header h3{margin:0;font-size:1rem;font-weight:600;color:var (--text-primary-color)}.icon{font-size:1.1rem;transition:color .3s ease}.tile-status span{font-size:.9rem;font-weight:500;padding:.3rem .8rem;border-radius:12px;transition:background-color .3s ease,color .3s ease}.tile.on{background-color:var(--tile-on-bg-color);border-left-color:var(--status-on-color)}.tile.on .icon{color:var(--status-on-color)}.tile.on .tile-status span{background-color:var(--status-on-color);color:var(--company-white)}.tile.off{background-color:var(--tile-off-bg-color);border-left-color:var(--status-off-color)}.tile.off .icon{color:var(--status-off-color)}.tile.off .tile-status span{background-color:var(--status-off-color);color:var(--company-white)}.tile-time{font-size:.8rem;color:var(--tile-time-color);margin-top:.8rem;display:flex;align-items:center;justify-content:center;gap:.3rem}.tile-time i{font-size:.8rem}.tile-progress-container{height:8px;background:#0000001a;border-radius:4px;overflow:hidden;margin-top:.8rem;position:relative}.tile-progress-bar{height:100%;background:var(--gradient-success);border-radius:4px;transition:width .5s cubic-bezier(.4,0,.2,1)}.tile-progress-bar.rate-low{background-color:var(--progress-bar-color-low)}.tile-progress-bar.rate-medium{background-color:var(--progress-bar-color-medium)}.tile-progress-bar.rate-high{background-color:var(--progress-bar-color-high)}.tile-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;font-weight:700;color:var(--company-white);text-shadow:1px 1px 1px rgba(0,0,0,.4)}.tile.bounce{animation:pulse 2s infinite cubic-bezier(.4,0,.2,1)}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.tile-popup-bubble{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);background-color:var(--progress-bar-color-medium);color:var(--company-white);padding:.4rem .8rem;border-radius:var(--border-radius);font-size:.8rem;font-weight:500;white-space:nowrap;box-shadow:0 2px 5px #0003;z-index:10}.tile-popup-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:var(--progress-bar-color-medium) transparent transparent transparent}body.dark-mode .tile-popup-bubble{background-color:var(--company-light-gray);color:var(--company-black)}body.dark-mode .tile-popup-bubble:after{border-top-color:var(--company-light-gray)}.page-footer{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;padding:1rem;gap:1rem;border-top:4px solid transparent;background:#ffffff0d;-webkit-backdrop-filter:var(--backdrop-blur);backdrop-filter:var(--backdrop-blur);color:var(--text-primary-color);position:fixed;bottom:0;left:0;right:0;z-index:950;border-image:linear-gradient(90deg,var(--accent-color),transparent) 1;height:70px;box-sizing:border-box;flex-wrap:nowrap;justify-content:space-around;background-image:var(--bg-texture),linear-gradient(to bottom,#ffffff0d,#ffffff05)}.page-footer>*{flex:1;text-align:center}.footer-logo{display:flex;justify-content:center;align-items:center}.footer-logo img{height:60px;width:auto;filter:drop-shadow(0 0 5px rgba(0,0,0,.5));content:url(logo.png)}body.dark-mode .footer-logo img{content:url(logo1.png)}@media (max-width: 768px){.page-footer{flex-direction:column;gap:1rem;height:auto;padding:1rem .5rem}}.auto-scroll-indicator{position:fixed;top:20px;right:20px;background:#4caf50e6;color:#fff;padding:8px 16px;border-radius:var(--border-radius);font-size:.9rem;font-weight:500;z-index:9999;display:flex;align-items:center;gap:8px;box-shadow:var(--box-shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:fadeInOut 2s ease-in-out infinite;transition:all .3s ease}.auto-scroll-indicator i{animation:pulse 1.5s ease-in-out infinite}@keyframes fadeInOut{0%,to{opacity:.7}50%{opacity:1}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}body.auto-scrolling::-webkit-scrollbar{width:0px;background:transparent}body.auto-scrolling{scrollbar-width:none;-ms-overflow-style:none}.tile.state-0{background-color:var(--tile-off-bg-color);border-left-color:var(--status-off-color)}.tile.state-0 .icon{color:var(--status-off-color)}.tile.state-0 .tile-status span{background-color:var(--status-off-color);color:var(--company-white)}.tile.state-1{background-color:var(--tile-on-bg-color);border-left-color:var(--status-on-color)}.tile.state-1 .icon{color:var(--status-on-color)}.tile.state-1 .tile-status span{background-color:var(--status-on-color);color:var(--company-white)}.tile.state-2{background-color:var(--state-2-color);color:var(--company-black);border-left-color:var(--state-2-color)}.tile.state-2 .icon{color:var(--company-black)}.tile.state-2 .tile-status span{background-color:transparent;color:var(--company-black)}.tile.state-3{background-color:var(--state-3-color);color:var(--company-white);border-left-color:var(--state-3-color)}.tile.state-3 .icon{color:var(--company-white)}.tile.state-3 .tile-status span{background-color:transparent;color:var(--company-white)}.tile-subtitle{font-size:.85rem;margin-top:.25rem;opacity:.9;font-weight:600}.overview-grid{display:flex;flex-direction:column;gap:2rem}.plant-section{background-color:var(--bg-secondary);padding:1rem;border-radius:var(--border-radius);border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000d;background-image:var(--bg-texture)}.plant-section h3{margin-top:0;margin-bottom:1rem;color:var(--text-primary-color);border-bottom:2px solid var(--accent-color);padding-bottom:.5rem}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:1.2rem;font-weight:700;color:var(--text-primary-color);padding:.5rem 1rem;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:background-color .3s ease}.collapsible-header:hover{background-color:var(--button-hover-bg)}.collapsible-header i{font-size:1rem;transition:transform .3s ease}.plant-indicators{display:flex;align-items:center;gap:.5rem;margin-left:auto;margin-right:1rem}.plant-warning-indicator{width:20px;height:20px;background-color:#ffc107;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#856404;font-size:.8rem;box-shadow:0 0 10px #ffc10780;animation:pulse 2s infinite}.lines-grid{display:grid;gap:1rem;margin-top:1rem}.cartersville-grid{grid-template-columns:repeat(3,1fr)!important;grid-template-rows:1fr;gap:1rem!important;display:grid!important}.cartersville-grid .line-box{width:100%!important;box-sizing:border-box!important;margin:0!important}.fortmill-grid{grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}.heath-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:1fr}.overview-grid .heath-grid{grid-template-columns:repeat(3,1fr)!important}.line-box{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:1rem;border-radius:var(--border-radius);font-size:1rem;font-weight:700;color:var(--company-white);transition:all .3s ease;min-height:54px;position:relative;box-shadow:var(--box-shadow-sm)}.line-box.running{background-color:var(--led-on-color)}.line-box.stopped{background-color:var(--led-off-color)}.line-box.warning{background-color:var(--progress-bar-color-medium)}.line-box.bounce{animation:warning-bounce 2s infinite}.line-box.state-0{background-color:var(--led-off-color)}.line-box.state-1{background-color:var(--led-on-color)}.line-box.state-2{background-color:var(--state-2-color);color:var(--company-black)}.line-box.state-3{background-color:var(--state-3-color);color:var(--company-white)}.line-name{font-size:.9rem;margin-bottom:.5rem;text-align:center}.line-status-indicator{display:flex;align-items:center;gap:.3rem;font-size:.8rem}.line-hours{font-weight:400;opacity:.9}.line-rate{font-size:.85rem;font-weight:600;margin-top:.3rem}.line-subtitle{display:block;font-size:.85rem;font-weight:600;margin-top:.25rem;opacity:.95}@keyframes warning-bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 1200px){.cartersville-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,1fr)}.fortmill-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.heath-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr)}}@media (max-width: 768px){.overview-grid{gap:1.5rem}.plant-section{padding:.8rem}.collapsible-header{font-size:1.1rem;padding:.4rem .8rem}.cartersville-grid,.fortmill-grid,.heath-grid{grid-template-columns:repeat(2,1fr);gap:.8rem}.line-box{padding:.8rem;min-height:47px}.line-name{font-size:.85rem}.line-status-indicator{font-size:.75rem}.line-rate{font-size:.8rem}}@media (max-width: 480px){.cartersville-grid,.fortmill-grid,.heath-grid{grid-template-columns:1fr;gap:.6rem}.line-box{padding:.6rem;min-height:40px}.line-name{font-size:.8rem;margin-bottom:.3rem}.line-status-indicator{font-size:.7rem}.line-rate{font-size:.75rem}.plant-warning-indicator{width:16px;height:16px;font-size:.7rem}}.cartersville-page .lines-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:100%;padding:1rem;box-sizing:border-box}.cartersville-page .production-section{margin-bottom:2rem;max-width:100%;overflow:hidden;padding:1rem}.air-section-wrapper{margin:2rem 0;background:linear-gradient(135deg,#87cefa14,#4682b40d);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;padding:2rem;box-shadow:0 12px 48px #00000026,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);transition:all .4s cubic-bezier(.4,0,.2,1)}.air-section-wrapper:hover{box-shadow:0 16px 64px #0003,inset 0 1px #ffffff40;transform:translateY(-2px)}.air-section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(135,206,250,.3)}.air-section-header i{font-size:2rem;color:#87ceeb;filter:drop-shadow(0 2px 8px rgba(135,206,250,.4))}.air-section-header h2{margin:0;font-size:1.8rem;font-weight:700;color:var(--text-primary-color);letter-spacing:.5px}.air-main-grid{display:grid;grid-template-columns:450px 1fr;gap:1.2rem;margin-bottom:1.2rem;align-items:start}.air-left-section{display:flex;flex-direction:column;gap:.8rem}.compressors-dryers-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.2rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}.compressors-dryers-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.equipment-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;margin-top:1rem}.equipment-item{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:16px;padding:1.1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;border:2px solid rgba(255,255,255,.15);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;min-height:85px}.equipment-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.equipment-item:hover:before{left:100%}.equipment-item:hover{transform:translateY(-6px) scale(1.03);box-shadow:0 8px 24px #00000026}.equipment-item.running{background:linear-gradient(135deg,#4caf5038,#2ecc712e);border-color:#4caf5080;box-shadow:0 6px 24px #4caf5040,0 0 30px #4caf5026;animation:equipment-pulse 3s ease-in-out infinite}@keyframes equipment-pulse{0%,to{box-shadow:0 6px 24px #4caf5040,0 0 30px #4caf5026}50%{box-shadow:0 6px 24px #4caf5059,0 0 40px #4caf5040}}.equipment-icon{width:45px;height:45px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;border:2px solid rgba(255,255,255,.2);transition:all .4s ease}.equipment-icon i{font-size:1.5rem;color:#666;transition:all .4s ease}.equipment-item.running .equipment-icon{background:#4caf5040;border-color:#4caf5080;box-shadow:0 0 20px #4caf5066}.equipment-item.compressor.running .equipment-icon i{color:#4caf50;animation:compressor-vibrate .5s ease-in-out infinite}.equipment-item.dryer.running .equipment-icon i{color:#64b5f6;animation:dryer-rotate 2s linear infinite}@keyframes compressor-vibrate{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}@keyframes dryer-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.equipment-info{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex:1}.equipment-name{font-size:.9rem;font-weight:600;color:var(--text-primary-color);text-align:center}.equipment-status-badge{padding:.3rem .7rem;border-radius:8px;font-size:.65rem;font-weight:700;letter-spacing:.5px;background:#9e9e9e40;color:#fff9;border:1px solid rgba(158,158,158,.3);transition:all .3s ease}.equipment-status-badge.active{background:#4caf504d;color:#4caf50;border-color:#4caf5080;box-shadow:0 0 15px #4caf504d}.status-light{width:12px;height:12px;border-radius:50%;background:#9e9e9e66;border:2px solid rgba(158,158,158,.5);transition:all .3s ease;box-shadow:0 0 8px #0003}.status-light.on{background:radial-gradient(circle,#4caf50,#66bb6a);border-color:#81c784;box-shadow:0 0 20px #4caf50cc,inset 0 0 8px #ffffff80;animation:light-pulse 1.5s ease-in-out infinite}@keyframes light-pulse{0%,to{box-shadow:0 0 20px #4caf50cc,inset 0 0 8px #ffffff80;transform:scale(1)}50%{box-shadow:0 0 30px #4caf50,inset 0 0 12px #ffffffb3;transform:scale(1.1)}}.air-right-section{display:flex;flex-direction:column;gap:1.2rem}.monitoring-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.monitoring-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.monitoring-display{display:flex;flex-direction:column;gap:.6rem;margin-top:.6rem}.chart-area{background:linear-gradient(135deg,#00000040,#00000026);border-radius:16px;padding:.6rem;border:1px solid rgba(255,255,255,.12);position:relative;overflow:hidden;box-shadow:inset 0 2px 8px #0000004d,0 2px 8px #0000001a;height:176px}.chart-area:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.04) 50%,transparent 70%);background-size:200% 200%;animation:chart-shimmer 4s linear infinite;border-radius:16px;pointer-events:none}@keyframes chart-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.line-chart{width:100%;height:100%;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));position:relative;z-index:2}.line-chart polyline{vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round;transition:all .3s ease}.chart-data-point{animation:data-point-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 4px currentColor)}@keyframes data-point-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.8}}.chart-labels{display:flex;justify-content:space-between;margin-top:.5rem;padding:0 .5rem;font-size:.75rem;font-weight:600;color:#ffffff80;position:relative;z-index:2}.chart-label-min,.chart-label-max{opacity:.8;text-transform:uppercase;letter-spacing:.5px}.value-display{display:flex;align-items:baseline;justify-content:center;gap:.5rem;padding:.6rem;background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-radius:14px;border:1px solid rgba(255,255,255,.18);box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffff1a;position:relative;overflow:hidden}.value-display:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at center,rgba(255,255,255,.1) 0%,transparent 70%);opacity:0;transition:opacity .3s ease}.value-display:hover:before{opacity:1}.main-value{font-size:2.2rem;font-weight:800;color:var(--text-primary-color);letter-spacing:1.5px;text-shadow:0 3px 12px rgba(0,0,0,.3);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;z-index:1}.main-value.good{color:#4caf50;text-shadow:0 3px 12px rgba(76,175,80,.5),0 0 30px rgba(76,175,80,.3),0 0 60px rgba(76,175,80,.1)}.main-value.warning{color:#ff9800;text-shadow:0 3px 12px rgba(255,152,0,.5),0 0 30px rgba(255,152,0,.3),0 0 60px rgba(255,152,0,.1);animation:value-warning-pulse 2s ease-in-out infinite}.main-value.alert{color:#f44336;text-shadow:0 3px 12px rgba(244,67,54,.5),0 0 30px rgba(244,67,54,.3),0 0 60px rgba(244,67,54,.1);animation:value-alert-pulse 1s ease-in-out infinite}@keyframes value-warning-pulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.05);filter:brightness(1.2)}}@keyframes value-alert-pulse{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.08);filter:brightness(1.3)}}.value-unit{font-size:1.2rem;font-weight:700;color:var(--text-secondary-color);opacity:.9;text-shadow:0 2px 4px rgba(0,0,0,.2);position:relative;z-index:1}.fans-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:.8rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);transition:all .3s cubic-bezier(.4,0,.2,1)}.fans-card:hover{transform:translateY(-4px);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.fans-list-compact{display:flex;flex-direction:column;gap:.5rem;margin-top:.6rem}.fan-item-compact{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:.5rem;display:flex;align-items:center;gap:.6rem;border:2px solid rgba(255,255,255,.15);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.fan-item-compact:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transition:left .5s ease}.fan-item-compact:hover:before{left:100%}.fan-item-compact:hover{transform:translate(6px);border-color:#ffffff40}.fan-item-compact.active{background:linear-gradient(135deg,#4caf5038,#2ecc712e);border-color:#4caf5080;box-shadow:0 4px 20px #4caf5033,0 0 25px #4caf501a}.fan-item-compact .fan-icon-wrapper{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;border:2px solid rgba(255,255,255,.2);transition:all .4s ease;flex-shrink:0}.fan-item-compact .fan-icon-wrapper i{font-size:.85rem;color:#666;transition:all .4s ease}.fan-item-compact.active .fan-icon-wrapper{background:#4caf5033;border-color:#4caf5080;box-shadow:0 0 15px #4caf504d}.fan-item-compact.active .fan-icon-wrapper i{color:#4caf50;animation:fan-spin-fast 1.5s linear infinite}.fan-item-compact .fan-details{flex:1;display:flex;flex-direction:column;gap:.3rem}.fan-item-compact .fan-name{font-size:.75rem;font-weight:600;color:var(--text-primary-color)}.fan-item-compact .fan-status{font-size:.65rem;font-weight:500;color:var(--text-secondary-color);opacity:.8}.fan-item-compact .fan-indicator{width:8px;height:8px;border-radius:50%;background:#9e9e9e66;border:2px solid rgba(158,158,158,.5);transition:all .3s ease;flex-shrink:0}.fan-item-compact .fan-indicator.running{background:radial-gradient(circle,#4caf50,#66bb6a);border-color:#81c784;box-shadow:0 0 16px #4caf50cc;animation:indicator-pulse 1.2s ease-in-out infinite}@media (max-width: 1400px){.air-main-grid{grid-template-columns:400px 1fr}}@media (max-width: 1200px){.cartersville-page .lines-grid{grid-template-columns:repeat(2,1fr)}.air-main-grid{grid-template-columns:1fr}}@media (max-width: 768px){.cartersville-page .lines-grid{grid-template-columns:1fr;gap:1rem;padding:0}.cartersville-page .line-tile{min-height:160px}.equipment-grid{grid-template-columns:1fr}}.dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:1rem;margin-bottom:2rem}.cartersville-page .air-status-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;padding:1rem;height:100%;flex:1;align-items:stretch;max-width:100%;overflow:hidden}.air-column{display:flex;flex-direction:column;gap:.75rem;padding:0;height:100%;justify-content:space-around}.air-column .tile{background:#ffffff0d;border-radius:15px;padding:.8rem;transition:all .3s ease;position:relative;overflow:hidden;cursor:pointer}.air-column .tile:hover{transform:translateY(-5px);box-shadow:0 10px 20px #0003}.air-column .tile .tile-header{display:flex;align-items:center;justify-content:center;gap:.4rem;margin-bottom:.4rem}.air-column .tile .tile-header h3{margin:0;font-size:.85rem;font-weight:600;color:var(--text-primary-color);white-space:nowrap}.air-column .tile .icon{font-size:.9rem}.air-column .tile .tile-status span{font-size:.8rem;font-weight:500;padding:.2rem .6rem;border-radius:8px;white-space:nowrap}.air-column .tile.on{background:#00ff0026;border-left-color:var(--led-on-color)}.air-column .tile.off{background:#ffffff0d;border-left-color:var(--led-off-color)}.air-column .tile.on .icon{color:var(--led-on-color)}.air-column .tile.off .icon{color:var(--led-off-color)}.air-column:nth-child(3) .tile,.air-column:nth-child(4) .tile{height:100%}.fan-status-grid-vertical{height:100%;display:flex;flex-direction:column;gap:.75rem;justify-content:space-around}.fan-status-container{background:#0003;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:.6rem .8rem;display:flex;align-items:center;justify-content:center;gap:.6rem;height:auto;min-height:50px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.fan-status-container.on{background:#00ff0026}.fan-status-container i{font-size:1.2rem;color:#666;transition:all .3s ease;flex-shrink:0}.fan-status-container.on i{color:#fff;animation:fan-spin 2s linear infinite}@keyframes fan-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fan-status-container .fan-name{font-size:.9rem;font-weight:500;color:var(--text-primary-color);white-space:nowrap}.room-temp-tile{display:flex;flex-direction:column;padding:1.2rem;height:100%;background:#ffffff0d;border-radius:15px}.room-temp-tile .tile-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem}.room-temp-tile .tile-header h3{margin:0;font-size:1rem;font-weight:600}.temp-chart-container{flex-grow:1;width:100%;margin:.5rem 0;height:120px}.temp-line-chart{width:100%;height:100%}.temp-line-chart polyline{opacity:.8;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}.temp-value{font-size:3.2rem;font-weight:700;color:var(--text-primary-color);text-align:center;margin-top:auto}.temp-unit{font-size:.5rem;margin-left:4px;opacity:.7}.air-pressure-tile{display:flex;flex-direction:column;padding:1.2rem;height:100%;background:#ffffff0d;border-radius:15px}.air-pressure-tile .tile-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem}.air-pressure-tile .tile-header h3{margin:0;font-size:1rem;font-weight:600}.pressure-chart-container{flex-grow:1;width:100%;margin:.5rem 0;height:120px}.pressure-line-chart{width:100%;height:100%}.pressure-line-chart polyline{color:var(--accent-color);opacity:.8;vector-effect:non-scaling-stroke;stroke-linecap:round;stroke-linejoin:round}.pressure-value{font-size:2.2rem;font-weight:700;color:var(--text-primary-color);text-align:center;margin-top:auto}.pressure-unit{font-size:1rem;margin-left:4px;opacity:.7}.water-section-wrapper{margin:2rem 0;background:linear-gradient(135deg,#1e90ff14,#0077be0d);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;padding:2rem;box-shadow:0 12px 48px #00000026,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);transition:all .4s cubic-bezier(.4,0,.2,1)}.water-section-wrapper:hover{box-shadow:0 16px 64px #0003,inset 0 1px #ffffff40;transform:translateY(-2px)}.water-section-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(30,144,255,.3)}.water-section-header i{font-size:2rem;color:#1e90ff;filter:drop-shadow(0 2px 8px rgba(30,144,255,.4))}.water-section-header h2{margin:0;font-size:1.8rem;font-weight:700;color:var(--text-primary-color);letter-spacing:.5px}.water-main-grid{display:grid;grid-template-columns:300px 1fr 350px;gap:1.5rem;min-height:400px}.water-left-section{display:flex;flex-direction:column;gap:1.5rem}.water-tank-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.5rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);flex:0 0 auto;transition:all .3s cubic-bezier(.4,0,.2,1)}.water-tank-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.tank-display{display:flex;justify-content:center;align-items:center;padding:1.5rem 0}.water-tank-modern{width:180px;height:220px;background:linear-gradient(135deg,#fff3,#ffffff1a);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:3px solid rgba(255,255,255,.35);border-radius:16px;position:relative;overflow:hidden;box-shadow:0 8px 24px #0003,inset 0 2px 8px #ffffff26;transition:all .4s cubic-bezier(.4,0,.2,1);animation:tank-glow 4s ease-in-out infinite}@keyframes tank-glow{0%,to{box-shadow:0 8px 24px #0003,inset 0 2px 8px #ffffff26}50%{box-shadow:0 8px 24px #1e90ff4d,inset 0 2px 8px #fff3,0 0 30px #1e90ff33}}.water-tank-modern:hover{transform:scale(1.05);box-shadow:0 12px 32px #1e90ff66,inset 0 2px 8px #fff3,0 0 40px #1e90ff4d;animation:tank-glow 1s ease-in-out infinite,tank-ripple 1.5s ease-out infinite}@keyframes tank-ripple{0%{box-shadow:0 12px 32px #1e90ff66,inset 0 2px 8px #fff3,0 0 40px #1e90ff4d}to{box-shadow:0 12px 32px #1e90ff33,inset 0 2px 8px #fff3,0 0 60px #1e90ff26}}.water-tank-modern .water-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(180deg,#4dabf7,#339af0,#228be6);transition:height 1s cubic-bezier(.4,0,.2,1);border-radius:0 0 12px 12px;animation:water-shimmer 3s ease-in-out infinite}.water-tank-modern .water-fill:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.15) 50%,transparent 70%);background-size:200% 200%;animation:shimmer-move 2s linear infinite}@keyframes water-shimmer{0%,to{opacity:1}50%{opacity:.95}}@keyframes shimmer-move{0%{background-position:-200% 0}to{background-position:200% 0}}.water-tank-modern .water-fill:before{content:"";position:absolute;top:-15px;left:-50%;width:200%;height:30px;background:radial-gradient(ellipse at center,rgba(255,255,255,.4) 0%,transparent 70%);border-radius:50%;animation:water-wave 3s ease-in-out infinite;z-index:5}@keyframes water-wave{0%,to{transform:translate(0) translateY(0) rotate(0)}25%{transform:translate(-20px) translateY(-4px) rotate(-2deg)}50%{transform:translate(0) translateY(-6px) rotate(0)}75%{transform:translate(20px) translateY(-4px) rotate(2deg)}}.water-tank-modern .tank-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:800;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.9),0 0 30px rgba(100,200,255,.6);z-index:10;letter-spacing:1px;animation:percentage-float 3s ease-in-out infinite}@keyframes percentage-float{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-52%) scale(1.02)}}.water-tank-modern:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle,rgba(255,255,255,.3) 2px,transparent 2px),radial-gradient(circle,rgba(255,255,255,.2) 3px,transparent 3px),radial-gradient(circle,rgba(255,255,255,.25) 2px,transparent 2px),radial-gradient(circle,rgba(255,255,255,.2) 2px,transparent 2px);background-size:50px 180px,70px 200px,60px 190px,80px 210px;background-position:10% 120%,80% 140%,40% 130%,65% 150%;animation:bubbles-rise 8s linear infinite;pointer-events:none;z-index:3;opacity:.6}@keyframes bubbles-rise{0%{background-position:10% 120%,80% 140%,40% 130%,65% 150%}to{background-position:10% -20%,80% -10%,40% -15%,65% -5%}}.chillers-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.5rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);flex:1;transition:all .3s cubic-bezier(.4,0,.2,1)}.chillers-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.chillers-display{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.chiller-unit{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-radius:14px;padding:1rem;border:2px solid rgba(255,255,255,.15);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.chiller-unit:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.chiller-unit:hover:before{left:100%}.chiller-unit.active{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5099;box-shadow:0 4px 20px #4caf5040,0 0 30px #4caf5026;animation:chiller-active-pulse 3s ease-in-out infinite}.chiller-unit.inactive{background:linear-gradient(135deg,#dc354533,#e74c3c26);border-color:#dc354566;opacity:.8}@keyframes chiller-active-pulse{0%,to{box-shadow:0 4px 20px #4caf5040,0 0 30px #4caf5026}50%{box-shadow:0 4px 20px #4caf5059,0 0 40px #4caf5040}}.chiller-name{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;font-size:1.1rem;font-weight:600;color:var(--text-primary-color)}.chiller-name i{font-size:1.2rem;color:#74c0fc;filter:drop-shadow(0 2px 4px rgba(116,192,252,.4))}.circuits{display:flex;gap:.75rem}.circuit{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem;background:#ffffff14;border-radius:10px;border:1px solid rgba(255,255,255,.15);transition:all .3s ease;font-size:.9rem;font-weight:500}.circuit i{font-size:.75rem;color:#666;transition:all .3s ease}.circuit.on{background:#4caf5033;border-color:#4caf5080}.circuit.on i{color:#4caf50;animation:circuit-pulse 2s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(76,175,80,.6))}@keyframes circuit-pulse{0%,to{opacity:1}50%{opacity:.6}}.card-header{display:flex;align-items:center;gap:.75rem;padding-bottom:.75rem;border-bottom:2px solid rgba(255,255,255,.15);font-size:1.15rem;font-weight:600;color:var(--text-primary-color)}.card-header i{font-size:1.3rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.card-header .status-indicator{margin-left:auto;padding:.35rem .8rem;border-radius:8px;font-size:.7rem;font-weight:700;letter-spacing:.8px;background:#9e9e9e40;color:#fff9;border:1px solid rgba(158,158,158,.3);transition:all .3s ease}.card-header .status-indicator.ok{background:#4caf5040;color:#4caf50;border-color:#4caf5080;box-shadow:0 0 12px #4caf504d}.card-header .status-indicator.low,.card-header .status-indicator.high{background:#f4433640;color:#f44336;border-color:#f4433680;box-shadow:0 0 12px #f443364d;animation:status-blink 1.5s ease-in-out infinite}.card-header .status-indicator.warning{background:#ff980040;color:#ff9800;border-color:#ff980080;box-shadow:0 0 12px #ff98004d;animation:status-blink 2s ease-in-out infinite}@keyframes status-blink{0%,to{opacity:1}50%{opacity:.7}}.water-center-section{display:flex;flex-direction:column;gap:1.5rem}.system-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.5rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);flex:1;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:0}.system-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem;height:calc(100% - 60px)}.metric-item{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:1.2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border:2px solid rgba(255,255,255,.15);box-shadow:0 4px 16px #00000014,inset 0 1px #ffffff1a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.metric-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent);transition:left .5s ease}.metric-item:hover:before{left:100%}.metric-item:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0000001f,inset 0 1px #ffffff26}.metric-item.good{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5080;box-shadow:0 4px 16px #4caf5033,inset 0 1px #ffffff26}.metric-item.alert{background:linear-gradient(135deg,#dc354547,#e74c3c38);border-color:#dc354599;box-shadow:0 4px 16px #dc354540,inset 0 1px #ffffff26;animation:metric-alert-pulse 2s ease-in-out infinite}@keyframes metric-alert-pulse{0%,to{box-shadow:0 4px 16px #dc354540,inset 0 1px #ffffff26,0 0 20px #dc354526;transform:scale(1)}50%{box-shadow:0 6px 24px #dc354566,inset 0 1px #fff3,0 0 35px #dc354540;transform:scale(1.03)}}.metric-label{font-size:.95rem;font-weight:500;color:var(--text-secondary-color);text-align:center;opacity:.9}.metric-value{font-size:1.8rem;font-weight:700;color:var(--text-primary-color);text-align:center;letter-spacing:.5px;text-shadow:0 2px 4px rgba(0,0,0,.1)}.water-right-section{display:flex;flex-direction:column;gap:1.5rem}.pumps-card{background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:1.5rem;box-shadow:0 6px 24px #0000001f,inset 0 1px #fff3;border:1px solid rgba(255,255,255,.2);flex:1;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:0}.pumps-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 10px 32px #0000002e,inset 0 1px #ffffff40}.pump-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.pump-item{display:flex;align-items:center;gap:.75rem;padding:.9rem 1.1rem;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;border:2px solid rgba(255,255,255,.15);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.pump-item:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,transparent,rgba(255,255,255,.05));opacity:0;transition:opacity .3s ease}.pump-item:hover:before{opacity:1}.pump-item i{font-size:1.5rem;color:#666;transition:all .4s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.pump-item span{flex:1;font-size:1.05rem;font-weight:500;color:var(--text-primary-color)}.pump-item .status-indicator{width:12px;height:12px;border-radius:50%;background:#9e9e9e80;border:2px solid rgba(158,158,158,.7);transition:all .3s ease}.pump-item.running{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5099;box-shadow:0 4px 16px #4caf5040,0 0 20px #4caf5026}.pump-item.running:hover{box-shadow:0 6px 20px #4caf5059,0 0 30px #4caf5033;transform:translate(6px)}.pump-item.running i{color:#4dabf7;animation:pump-rotate 2s linear infinite;filter:drop-shadow(0 0 10px rgba(77,171,247,.6))}@keyframes pump-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pump-item.running .status-indicator{background:#4caf50;border-color:#66bb6a;box-shadow:0 0 12px #4caf50cc;animation:status-pulse 1.5s ease-in-out infinite}@keyframes status-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.8}}.water-pressure-card{flex:0 0 auto}.water-system-display{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.pressure-display{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-radius:14px;padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;border:2px solid rgba(255,255,255,.15);transition:all .3s ease}.pressure-display.good{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5080}.pressure-display.warning{background:linear-gradient(135deg,#ffc10740,#ffb30033);border-color:#ffc10780;animation:pressure-warning-pulse 2s ease-in-out infinite}.pressure-display.alert{background:linear-gradient(135deg,#dc354547,#e74c3c38);border-color:#dc354599;animation:pressure-alert-pulse 1.5s ease-in-out infinite}@keyframes pressure-warning-pulse{0%,to{box-shadow:0 4px 16px #ffc10733,0 0 20px #ffc1071a}50%{box-shadow:0 6px 24px #ffc10759,0 0 35px #ffc10733}}@keyframes pressure-alert-pulse{0%,to{box-shadow:0 4px 16px #dc354540,0 0 20px #dc354526}50%{box-shadow:0 6px 24px #dc354566,0 0 35px #dc354540}}.pressure-label{font-size:.9rem;font-weight:500;color:var(--text-secondary-color);opacity:.9}.pressure-value{font-size:2.5rem;font-weight:800;color:var(--text-primary-color);letter-spacing:1px;text-shadow:0 2px 8px rgba(0,0,0,.15)}.pressure-unit{font-size:1rem;font-weight:600;color:var(--text-secondary-color);opacity:.85}.filter-pump-display{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border-radius:12px;padding:1rem;display:flex;align-items:center;gap:.75rem;border:2px solid rgba(255,255,255,.15);transition:all .3s ease}.filter-pump-display i{font-size:1.4rem;color:#666;transition:all .3s ease}.filter-pump-display span{flex:1;font-size:1.05rem;font-weight:500;color:var(--text-primary-color)}.filter-pump-display.running{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5099;box-shadow:0 4px 16px #4caf5040}.filter-pump-display.running i{color:#4dabf7;animation:filter-shake 1s ease-in-out infinite}@keyframes filter-shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.status-badge{padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:600;background:#9e9e9e4d;color:var(--text-secondary-color);border:1px solid rgba(158,158,158,.4);transition:all .3s ease}.filter-pump-display.running .status-badge{background:#4caf5066;color:#4caf50;border-color:#4caf5099;box-shadow:0 0 12px #4caf5066}@media (max-width: 1400px){.water-main-grid{grid-template-columns:280px 1fr 320px}}@media (max-width: 1200px){.water-main-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}.water-left-section{grid-column:1 / 2}.water-center-section{grid-column:2 / 3}.water-right-section{grid-column:1 / 3;flex-direction:row}}@media (max-width: 768px){.water-main-grid{grid-template-columns:1fr}.water-left-section,.water-center-section,.water-right-section{grid-column:1 / 2}.water-right-section{flex-direction:column}}.process-system-tile,.glycol-system-tile,.process-pumps-tile,.glycol-pumps-tile{height:100%;min-height:0;max-height:none;overflow:visible;display:flex;flex-direction:column;background:linear-gradient(135deg,#ffffff1f,#ffffff14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:18px;padding:1rem .8rem;box-shadow:0 4px 16px #0000001a,inset 0 1px #ffffff26;border:1px solid rgba(255,255,255,.18);min-width:0;justify-content:flex-start;align-items:stretch;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.process-system-tile:hover,.glycol-system-tile:hover,.process-pumps-tile:hover,.glycol-pumps-tile:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px #00000026,inset 0 1px #fff3;border-color:#ffffff40}.water-tank-container{display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%;width:100%;justify-content:center;padding:.5rem;max-height:150px;overflow:hidden}.water-column{display:flex;flex-direction:column;gap:.75rem;padding:0;height:100%;justify-content:space-around;width:100%;max-width:100%}.water-tank{width:100%;max-width:75px;height:75%;max-height:170px;background:linear-gradient(135deg,#ffffff26,#ffffff14);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:3px solid rgba(255,255,255,.3);border-radius:14px;position:relative;overflow:hidden;box-shadow:0 6px 16px #0003,inset 0 2px 4px #ffffff1a;transition:all .3s cubic-bezier(.4,0,.2,1)}.water-tank:hover{transform:scale(1.05);box-shadow:0 8px 20px #00000040,inset 0 2px 4px #ffffff26}.water-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(180deg,#4dabf7,#339af0,#228be6)!important;transition:height .8s cubic-bezier(.4,0,.2,1);border-radius:0 0 10px 10px;position:relative}.water-fill:before{content:"";position:absolute;top:-10px;left:-50%;width:200%;height:20px;background:radial-gradient(ellipse at center,rgba(255,255,255,.3) 0%,transparent 70%);border-radius:50%;animation:water-wave 3s ease-in-out infinite}@keyframes water-wave{0%,to{transform:translate(0) translateY(0)}25%{transform:translate(-10px) translateY(-2px)}75%{transform:translate(10px) translateY(-2px)}}.tank-reading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.8),0 0 20px rgba(100,200,255,.5);z-index:10;font-size:1.5rem;letter-spacing:1px;animation:tank-reading-pulse 2s ease-in-out infinite}@keyframes tank-reading-pulse{0%,to{opacity:1}50%{opacity:.85}}.tank-label{font-size:1.1rem;color:var(--text-primary-color);text-align:center;opacity:.9;width:100%;white-space:nowrap;font-weight:500;margin-top:.5rem}.water-system-tile{height:100%;min-height:0;max-height:none;overflow:visible;display:flex;flex-direction:column;background:#ffffff17;border-radius:16px;padding:.6rem .3rem .4rem;box-shadow:0 2px 12px #00000012;border:1px solid rgba(255,255,255,.13);min-width:0;justify-content:flex-start;align-items:stretch;transition:box-shadow .2s}.water-system-tile:hover{box-shadow:0 4px 16px #0000001f}.water-pressure-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:.5rem;background:linear-gradient(135deg,#3498db33,#3498db1a);border:1px solid rgba(52,152,219,.3);border-radius:12px;padding:.8rem;margin-bottom:.5rem}.pressure-label{font-size:.8rem;color:var(--text-primary-color);opacity:.9;text-align:center;margin-bottom:.2rem;font-weight:500}.pressure-value{font-size:1.8rem;font-weight:700;color:#3498db;text-align:center;margin-bottom:.2rem}.pressure-unit{font-size:.9rem;color:var(--text-primary-color);opacity:.8;text-align:center}.filter-pump-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;height:auto;min-height:60px;gap:.3rem;background:linear-gradient(135deg,#2ecc7133,#2ecc711a);border:1px solid rgba(46,204,113,.3);border-radius:12px;padding:.6rem;transition:all .3s ease}.filter-pump-tile.on{background:linear-gradient(135deg,#2ecc714d,#2ecc7133);border-color:#2ecc7180;animation:pulse-green 2s infinite}.filter-pump-tile.off{background:linear-gradient(135deg,#e74c3c33,#e74c3c1a);border-color:#e74c3c4d}.filter-pump-label{font-size:.75rem;color:var(--text-primary-color);opacity:.9;text-align:center;font-weight:500}.filter-pump-status{font-size:1.1rem;font-weight:700;text-align:center}.filter-pump-tile.on .filter-pump-status{color:#2ecc71}.filter-pump-tile.off .filter-pump-status{color:#e74c3c}@keyframes pulse-green{0%,to{box-shadow:0 0 5px #2ecc714d}50%{box-shadow:0 0 15px #2ecc7199}}.silo-status-tile{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;margin:1rem 0;box-shadow:0 8px 32px #0000001a;transition:all .3s ease}.silo-status-tile .tile-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent-color)}.silo-status-tile .tile-header i{font-size:1.5rem;color:var(--accent-color)}.silo-status-tile .tile-header h2{margin:0;color:var(--text-primary-color);font-size:1.4rem;font-weight:600}.silo-status-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:1rem;width:100%}.silo-column{display:flex;flex-direction:column;gap:.5rem}.silo-tile{background:var(--gradient-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px;transition:all .3s ease;box-shadow:var(--box-shadow-sm)}.silo-tile:hover{transform:translateY(-2px);box-shadow:var(--box-shadow-md)}.silo-header{text-align:center;margin-bottom:1rem}.silo-header h3{margin:0;color:var(--text-primary-color);font-size:1rem;font-weight:600}.silo-container{display:flex;flex-direction:column;align-items:center;width:100%}.silo-visual{display:flex;flex-direction:column;align-items:center;gap:.5rem}.silo-tank{width:60px;height:100px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px 8px 4px 4px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.silo-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(to top,var(--silo-fill-color-dark),var(--silo-fill-color));transition:height .8s ease;border-radius:0 0 4px 4px}.silo-percentage{font-size:1.1rem;font-weight:600;color:var(--text-primary-color);text-align:center;margin-top:.5rem}@media (max-width: 1200px){.silo-status-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width: 768px){.silo-status-grid{grid-template-columns:repeat(3,1fr);gap:.8rem}.silo-tile{min-height:160px;padding:.8rem}.silo-tank{width:50px;height:80px}}@media (max-width: 480px){.silo-status-grid{grid-template-columns:repeat(2,1fr)}.silo-tile{min-height:140px}}.plc-status-tile{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1rem;margin:1rem 0;box-shadow:0 8px 32px #0000001a;transition:all .3s ease}.plc-status-tile .tile-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color)}.plc-status-tile .tile-header i{font-size:1.2rem;color:var(--accent-color)}.plc-status-tile .tile-header h2{margin:0;color:var(--text-primary-color);font-size:1.2rem;font-weight:600}.plc-status-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem;width:100%}.plc-column{display:flex;flex-direction:column}.plc-tile{background:var(--gradient-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:.75rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:85px;transition:all .3s ease;box-shadow:var(--box-shadow-sm)}.plc-tile:hover{transform:translateY(-2px);box-shadow:var(--box-shadow-md)}.plc-tile.plc-online{background:linear-gradient(135deg,#4caf5033,#4caf501a);border-color:var(--led-on-color)}.plc-tile.plc-offline{background:linear-gradient(135deg,#f4433633,#f443361a);border-color:var(--led-off-color)}.plc-tile.plc-unknown{background:linear-gradient(135deg,#9e9e9e33,#9e9e9e1a);border-color:#9e9e9e}.plc-header{text-align:center;margin-bottom:.5rem}.plc-header h3{margin:0;color:var(--text-primary-color);font-size:.8rem;font-weight:600;line-height:1.1}.plc-status-indicator{display:flex;flex-direction:column;align-items:center;gap:.25rem}.plc-status-indicator i{font-size:1rem;transition:all .3s ease}.plc-status-indicator i.status-online{color:var(--led-on-color);text-shadow:0 0 10px rgba(76,175,80,.5)}.plc-status-indicator i.status-offline{color:var(--led-off-color);text-shadow:0 0 10px rgba(244,67,54,.5)}.plc-status-indicator i.status-unknown{color:#9e9e9e;text-shadow:0 0 10px rgba(158,158,158,.5)}.plc-status-text{font-size:.7rem;font-weight:600;color:var(--text-primary-color);text-align:center}@media (max-width: 1200px){.plc-status-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.plc-status-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}.plc-tile{min-height:75px;padding:.6rem}.plc-header h3{font-size:.75rem}}@media (max-width: 480px){.plc-status-grid{grid-template-columns:repeat(2,1fr)}.plc-tile{min-height:70px}.plc-header h3{font-size:.7rem}}.production-tile{margin-bottom:1rem;background:var(--tile-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;max-width:100%;overflow-x:hidden}.production-tile .tile-header{display:flex;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color)}.production-tile .tile-header i{font-size:1.5rem;color:var(--primary-color);margin-right:.75rem}.production-tile .tile-header h2{font-size:1.5rem;font-weight:600;color:var(--text-color);margin:0}.production-overview{margin-bottom:1.5rem}.production-lines-section{margin-top:1.5rem}.lines-header{font-size:1.2rem;font-weight:600;color:var(--text-color);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color)}.production-lines-grid{display:flex;flex-direction:column;gap:.5rem}.production-line-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1rem;padding:.75rem;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:6px;transition:all .2s ease;max-width:100%;overflow-x:auto}.production-line-row:hover{background:var(--tile-bg);transform:translateY(-1px)}.production-header-row{background:var(--primary-color);color:#fff;font-weight:600;font-size:.9rem}.production-header-row:hover{background:var(--primary-color);transform:none}.line-name-header,.line-data-header{text-align:center;font-weight:600}.line-name{font-weight:600;color:var(--text-color);text-align:left}.line-data{text-align:center;color:var(--text-secondary-color);font-weight:500}.production-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:1rem}.production-column{display:flex;flex-direction:column}.production-data-tile{height:120px;display:flex;flex-direction:column;justify-content:space-between;padding:1rem;background:var(--secondary-bg);border:1px solid var(--border-color);border-radius:8px;transition:all .3s ease}.production-data-tile:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:var(--tile-bg)}.production-header{text-align:center;margin-bottom:.5rem}.production-header h3{font-size:1rem;font-weight:600;color:var(--text-color);margin:0;opacity:.8}.production-value{font-size:1.8rem;font-weight:700;text-align:center;color:var(--primary-color);margin:auto 0}@media (max-width: 1024px){.production-grid{grid-template-columns:1fr;gap:.5rem}.production-data-tile{height:100px;padding:.75rem}.production-header h3{font-size:.9rem}.production-value{font-size:1.5rem}}@media (max-width: 768px){.production-tile{padding:1rem;margin-left:0;margin-right:0}.production-grid{grid-template-columns:1fr;gap:.5rem}.production-data-tile{height:80px;padding:.5rem}.production-header h3{font-size:.8rem}.production-value{font-size:1.2rem}.production-line-row{grid-template-columns:1fr;gap:.25rem;padding:.5rem}.line-name,.line-data{text-align:center;padding:.25rem 0}.production-header-row{display:none}.production-line-row:not(.production-header-row){position:relative;padding-top:1rem}.production-line-row:not(.production-header-row):before{content:attr(data-line);position:absolute;top:.25rem;left:.5rem;font-weight:600;font-size:.9rem;color:var(--primary-color)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes glow{0%{filter:brightness(1)}to{filter:brightness(1.5)}}@keyframes tempFloat{0%{transform:translateY(0)}50%{transform:translateY(-5px)}to{transform:translateY(0)}}@keyframes fanSpin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(360deg) scale(1)}}@keyframes fanRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pressurePulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.status-message{position:absolute;bottom:0;left:0;width:100%;padding:.5rem;text-align:center;font-size:.8rem;background:#0003;transform:translateY(100%);transition:transform .3s ease}.tile:hover .status-message{transform:translateY(0)}.async-error{display:none;color:var(--error-color);padding:1rem;margin:.5rem 0;border-radius:var(--border-radius-md);background:#ff00001a}.air-status-tile{visibility:visible;opacity:1;transition:opacity .3s ease-in-out}.air-status-tile.loading{visibility:hidden;opacity:0}.air-status-grid{visibility:visible;opacity:1;transition:visibility 0s,opacity .3s linear}.air-status-grid.loading{visibility:hidden;opacity:0}.loading-placeholder{display:none;justify-content:center;align-items:center;height:100%;width:100%}.loading .loading-placeholder{display:flex}.process-pumps-tile{height:100%;max-height:none;display:flex;flex-direction:column;background:#ffffff0d;border-radius:15px;padding:.3rem;overflow:visible}.process-pumps-tile .tile-header{margin-bottom:.2rem;padding:0;height:16px;min-height:16px;display:flex;align-items:center;justify-content:center}.pumps-container{display:flex;flex-direction:column;gap:.5rem;height:calc(100% - 22px)}.pump-status{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;border-radius:12px;background:linear-gradient(135deg,#ffffff14,#ffffff0a);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .4s cubic-bezier(.4,0,.2,1);height:calc((100% - 1rem) / 3);min-height:45px;border:1px solid rgba(255,255,255,.15);box-shadow:0 2px 8px #0000000f,inset 0 1px #ffffff14;position:relative;overflow:hidden}.pump-status:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,transparent,rgba(255,255,255,.05));opacity:0;transition:opacity .3s ease}.pump-status:hover:before{opacity:1}.pump-status:hover{transform:translate(4px);border-color:#ffffff40}.pump-status i{font-size:1.6rem;color:#666;transition:all .4s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.pump-status span{font-size:1.05rem;font-weight:500;transition:all .3s ease}.pump-status.on{background:linear-gradient(135deg,#4caf5040,#2ecc7133);border-color:#4caf5099;box-shadow:0 4px 16px #4caf5040,inset 0 1px #fff3,0 0 20px #4caf5026}.pump-status.on:hover{box-shadow:0 6px 20px #4caf5059,inset 0 1px #ffffff40,0 0 30px #4caf5033}.pump-status.on span{color:#4caf50;font-weight:600}.pump-status.on i{color:#4dabf7;animation:pump-spin 2s linear infinite;filter:drop-shadow(0 0 8px rgba(77,171,247,.6))}@keyframes pump-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.glycol-pumps-tile{height:100%;max-height:none;display:flex;flex-direction:column;background:#ffffff0d;border-radius:15px;padding:.3rem;overflow:visible}.glycol-pumps-tile .tile-header{margin-bottom:.25rem;padding:0;height:20px;min-height:20px;display:flex;align-items:center;justify-content:center}.process-system-tile,.glycol-system-tile{height:100%;display:flex;flex-direction:column;background:#ffffff17;border-radius:16px;padding:.6rem .3rem .4rem;box-shadow:0 2px 12px #00000012;border:1px solid rgba(255,255,255,.13);min-width:0;justify-content:flex-start;align-items:stretch;transition:box-shadow .2s}.tile-header{margin-bottom:.5rem;height:28px;min-height:28px;display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1.15rem;font-weight:600;color:var(--text-primary-color);letter-spacing:.5px;opacity:.95}.tile-header i{font-size:1.1rem}.temps-container{height:calc(100% - 20px);gap:.5rem}.temp-reading{padding:.5rem;min-height:50px}.temp-label{font-size:.9rem;margin-bottom:.25rem}.temp-value{font-size:1.2rem}.nested-tile-row{display:flex;flex-direction:row;gap:.7rem;justify-content:space-between;align-items:stretch;width:100%;margin-top:.5rem}.nested-tile{flex:1 1 0;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:.9rem .7rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;min-width:0;min-height:60px;box-shadow:0 3px 10px #00000014,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.12);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.nested-tile:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.nested-tile:hover:before{left:100%}.nested-tile:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000001f,inset 0 1px #ffffff26;border-color:#fff3}.nested-tile .temp-label{font-size:1.05rem;color:var(--text-secondary-color);margin-bottom:.3rem;font-weight:500}.nested-tile .temp-value{font-size:1.35rem;font-weight:700;color:var(--text-primary-color);letter-spacing:.5px}.glycol-system-tile .nested-tile-row{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:.4rem;justify-content:space-between;align-items:stretch;width:100%;margin-top:.2rem}.glycol-system-tile .nested-tile{flex:none;background:#ffffff12;border-radius:10px;padding:.4rem .2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:0;min-height:35px;box-shadow:0 2px 8px #0000000a}.glycol-system-tile .nested-tile .temp-label{font-size:.75rem;color:var(--text-secondary-color);margin-bottom:.1rem;font-weight:500;text-align:center}.glycol-system-tile .nested-tile .temp-value{font-size:.85rem;color:var(--text-primary-color);font-weight:600;text-align:center}.pressure-good{background:linear-gradient(135deg,#4caf5038,#2ecc712e)!important;border:1px solid rgba(76,175,80,.5)!important;box-shadow:0 2px 8px #4caf5026,inset 0 1px #ffffff1a!important}.pressure-good .temp-label{color:var(--text-secondary-color)!important}.pressure-good .temp-value{color:var(--text-primary-color)!important;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}.pressure-low{background:linear-gradient(135deg,#dc354540,#e74c3c33)!important;border:1px solid rgba(220,53,69,.5)!important;animation:modern-pressure-pulse 2s infinite!important}.pressure-low .temp-label{color:var(--text-secondary-color)!important}.pressure-low .temp-value{color:#ff6b6b!important;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}@keyframes modern-pressure-pulse{0%,to{box-shadow:0 2px 8px #dc354533,inset 0 1px #ffffff1a,0 0 15px #dc35451a;transform:scale(1)}50%{box-shadow:0 4px 16px #dc354566,inset 0 1px #ffffff26,0 0 30px #dc354533;transform:scale(1.02)}}@keyframes pressure-pulse{0%{background-color:#dc354533;box-shadow:0 0 5px #dc35454d}50%{background-color:#dc354566;box-shadow:0 0 15px #dc354599}to{background-color:#dc354533;box-shadow:0 0 5px #dc35454d}}.temp-good{background:linear-gradient(135deg,#4caf5038,#2ecc712e)!important;border:1px solid rgba(76,175,80,.5)!important;box-shadow:0 2px 8px #4caf5026,inset 0 1px #ffffff1a!important}.temp-good .temp-label{color:var(--text-secondary-color)!important}.temp-good .temp-value{color:var(--text-primary-color)!important;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}.temp-high{background:linear-gradient(135deg,#dc354540,#e74c3c33)!important;border:1px solid rgba(220,53,69,.5)!important;box-shadow:0 2px 8px #dc354526,inset 0 1px #ffffff1a!important;animation:temp-high-pulse 2s ease-in-out infinite!important}.temp-high .temp-label{color:var(--text-secondary-color)!important}.temp-high .temp-value{color:#ff6b6b!important;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.1)}@keyframes temp-high-pulse{0%,to{box-shadow:0 2px 8px #dc354526,inset 0 1px #ffffff1a}50%{box-shadow:0 4px 12px #dc35454d,inset 0 1px #ffffff26}}.glycol-system-tile .nested-tile.temp-good{background-color:#4caf5026!important;border:1px solid var(--led-on-color)!important}.glycol-system-tile .nested-tile.temp-high{background-color:#dc354526!important;border:1px solid var(--led-off-color)!important}.glycol-system-tile .nested-tile.temp-good .temp-label{color:var(--text-secondary-color)!important}.glycol-system-tile .nested-tile.temp-good .temp-value{color:var(--text-primary-color)!important}.glycol-system-tile .nested-tile.temp-high .temp-label{color:var(--text-secondary-color)!important}.glycol-system-tile .nested-tile.temp-high .temp-value{color:var(--text-primary-color)!important}.glycol-system-tile .nested-tile.pressure-good{background-color:#4caf5026!important;border:1px solid var(--led-on-color)!important}.glycol-system-tile .nested-tile.pressure-low{background-color:#dc354526!important;border:1px solid var(--led-off-color)!important;animation:pressure-pulse 2s infinite}.glycol-system-tile .nested-tile.pressure-good .temp-label{color:var(--text-secondary-color)!important}.glycol-system-tile .nested-tile.pressure-good .temp-value{color:var(--text-primary-color)!important}.glycol-system-tile .nested-tile.pressure-low .temp-label{color:var(--text-secondary-color)!important}.glycol-system-tile .nested-tile.pressure-low .temp-value{color:var(--text-primary-color)!important}.process-system-tile .nested-tile-row{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:.4rem;justify-content:space-between;align-items:stretch;width:100%;margin-top:.2rem}.process-system-tile .nested-tile{flex:none;background:#ffffff12;border-radius:10px;padding:.4rem .2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:0;min-height:35px;box-shadow:0 2px 8px #0000000a}.process-system-tile .nested-tile .temp-label{font-size:.75rem;color:var(--text-secondary-color);margin-bottom:.1rem;font-weight:500;text-align:center}.process-system-tile .nested-tile .temp-value{font-size:.85rem;color:var(--text-primary-color);font-weight:600;text-align:center}.process-system-tile .nested-tile.pressure-good{background-color:#4caf5026!important;border:1px solid var(--led-on-color)!important}.process-system-tile .nested-tile.pressure-low{background-color:#dc354526!important;border:1px solid var(--led-off-color)!important;animation:pressure-pulse 2s infinite}.process-system-tile .nested-tile.pressure-good .temp-label{color:var(--text-secondary-color)!important}.process-system-tile .nested-tile.pressure-good .temp-value{color:var(--text-primary-color)!important}.process-system-tile .nested-tile.pressure-low .temp-label{color:var(--text-secondary-color)!important}.process-system-tile .nested-tile.pressure-low .temp-value{color:var(--text-primary-color)!important}.process-system-tile .nested-tile.temp-good{background-color:#4caf5026!important;border:1px solid var(--led-on-color)!important}.process-system-tile .nested-tile.temp-high{background-color:#dc354526!important;border:1px solid var(--led-off-color)!important}.process-system-tile .nested-tile.temp-good .temp-label{color:var(--text-secondary-color)!important}.process-system-tile .nested-tile.temp-good .temp-value{color:var(--text-primary-color)!important}.process-system-tile .nested-tile.temp-high .temp-label{color:var(--text-secondary-color)!important}.process-system-tile .nested-tile.temp-high .temp-value{color:var(--text-primary-color)!important}.chillers-container{height:100%;display:flex;flex-direction:column;background:linear-gradient(135deg,#ffffff1f,#ffffff14);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:18px;padding:1rem .8rem;box-shadow:0 4px 16px #0000001a,inset 0 1px #ffffff26;border:1px solid rgba(255,255,255,.18);min-width:0;justify-content:flex-start;align-items:stretch;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative}.chillers-container:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 24px #00000026,inset 0 1px #fff3;border-color:#ffffff40}.chillers-header{margin-bottom:.5rem;height:28px;min-height:28px;display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--text-primary-color);font-size:1.15rem;font-weight:600}.chillers-header i{font-size:1rem;color:var(--text-secondary-color)}.chillers-grid{display:flex;flex-direction:column;gap:.7rem;flex:1}.chiller-tile{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:1rem .6rem;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:90px;box-shadow:0 3px 12px #00000014,inset 0 1px #ffffff1a;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid rgba(255,255,255,.15);position:relative;overflow:hidden}.chiller-tile:hover{transform:scale(1.03);box-shadow:0 5px 18px #0000001f,inset 0 1px #ffffff26}.chiller-tile.chiller-on{background:linear-gradient(135deg,#4caf5033,#2ecc7126);border:1px solid rgba(76,175,80,.5);box-shadow:0 4px 16px #4caf5033,inset 0 1px #ffffff26,0 0 20px #4caf501a;animation:chiller-pulse 3s ease-in-out infinite}.chiller-tile.chiller-off{background:linear-gradient(135deg,#dc35452e,#e74c3c1f);border:1px solid rgba(220,53,69,.4);box-shadow:0 3px 12px #dc354526,inset 0 1px #ffffff14}@keyframes chiller-pulse{0%,to{box-shadow:0 4px 16px #4caf5033,inset 0 1px #ffffff26,0 0 20px #4caf501a}50%{box-shadow:0 4px 16px #4caf504d,inset 0 1px #fff3,0 0 30px #4caf5033}}.chiller-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary-color)}.chiller-header i{font-size:.9rem;color:var(--text-secondary-color)}.circuits-container{display:flex;flex-direction:column;gap:.1rem;width:100%}.circuit-status{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary-color);justify-content:center;padding:.3rem .5rem;border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1);background:#ffffff08}.circuit-status:hover{background:#ffffff14}.circuit-status i{font-size:.8rem;transition:all .3s ease;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.circuit-status.circuit-on i{color:var(--led-on-color);animation:circuit-glow 2s ease-in-out infinite;filter:drop-shadow(0 0 6px rgba(76,175,80,.6))}.circuit-status.circuit-off i{color:var(--led-off-color);opacity:.6}.circuit-status span{font-size:.85rem;color:var(--text-secondary-color);font-weight:500}@keyframes circuit-glow{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,1fr)}}@media (max-width: 768px){.air-status-grid{grid-template-columns:repeat(5,1fr);gap:.5rem}.fan-status-grid-vertical{flex-direction:column;gap:.1rem}.fan-status-container .fan-icon{font-size:1.2rem}.fan-status-container .fan-name{font-size:.7rem}.air-pressure-tile,.room-temp-tile{padding:.6rem}.air-pressure-tile .pressure-value,.room-temp-tile .temp-value{font-size:2.2rem}}@media (max-width: 480px){.dashboard-grid{grid-template-columns:1fr}.fan-status-grid-vertical{flex-direction:column;gap:.2rem}.fan-status-container{min-height:35px;max-height:40px;padding:.2rem;width:40px;height:40px}}.bloapco-status-tile{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1rem;margin:2rem 0;box-shadow:0 8px 32px #0000001a;transition:all .3s ease;min-height:180px;overflow:hidden;position:relative;display:flex;flex-direction:column}.bloapco-status-tile:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s}.bloapco-status-tile:hover:before{transform:translate(100%)}.bloapco-status-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;flex:1;align-items:stretch;padding:0 .5rem;max-width:100%;box-sizing:border-box}.bloapco-column{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:140px;max-width:100%;box-sizing:border-box}.bloapco-tile{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:15px;padding:.8rem;width:100%;max-width:200px;height:100%;transition:all .3s ease;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;box-sizing:border-box}.bloapco-tile.bloapco-on{background:linear-gradient(135deg,#4caf5026,#4caf500d);border-color:#4caf504d;box-shadow:0 0 15px #4caf5033}.bloapco-tile.bloapco-off,.bloapco-tile.bloapco-null{background:#ffffff0d;border-color:#ffffff1a}.bloapco-tile.bloapco-partial{background:linear-gradient(135deg,#ffc10726,#ffc1070d);border-color:#ffc1074d;box-shadow:0 0 15px #ffc10733}.bloapco-tile.bloapco-override{background:linear-gradient(135deg,#ffc10740,#ffc1071a);border-color:#ffc10780;box-shadow:0 0 20px #ffc1074d;animation:pulse-yellow 2s infinite}@keyframes pulse-yellow{0%,to{box-shadow:0 0 20px #ffc1074d}50%{box-shadow:0 0 30px #ffc10780}}.bloapco-tile:hover{transform:translateY(-2px);box-shadow:0 12px 25px #00000026}.bloapco-tile .tile-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1rem;text-align:center}.bloapco-tile .tile-header i{font-size:1.2rem;color:var(--primary-color)}.bloapco-tile .tile-header h3{font-size:.9rem;font-weight:600;margin:0;color:var(--text-primary)}.bloapco-components{display:flex;flex-direction:column;gap:.8rem;align-items:center}.component-status{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;border-radius:8px;transition:all .3s ease;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);min-width:80px;justify-content:center}.component-status.on{background:#4caf5033;border-color:#4caf5066;color:var(--text-primary)}.component-status.off{background:#ffffff0d;border-color:#fff3;color:var(--text-primary)}.component-status.null{background:#2196f31a;border-color:#2196f34d;color:var(--text-primary)}.component-status i{font-size:1rem}.component-status span{font-size:.7rem;font-weight:600}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin 2s linear infinite}.fa-fan.spinning{animation:spin 1s linear infinite}.fa-cut.spinning{animation:spin .5s linear infinite}@media (max-width: 1200px){.bloapco-status-grid{grid-template-columns:repeat(3,1fr);gap:1.2rem;padding:0 .3rem}.bloapco-tile .tile-header h3{font-size:.8rem}.bloapco-tile{max-width:250px}}@media (max-width: 768px){.bloapco-status-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:0 .2rem}.bloapco-column{min-height:120px}.bloapco-tile{padding:.7rem;max-width:300px}}@media (max-width: 480px){.bloapco-status-grid{grid-template-columns:1fr;gap:.8rem;padding:0}.bloapco-column{min-height:100px}.bloapco-tile{max-width:100%;padding:.6rem}}.energy-tile{background:linear-gradient(135deg,#ffffff1f,#ffffff0f);border:1px solid rgba(255,255,255,.13);border-radius:20px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 8px 32px #0000001f}.energy-section{margin-top:1rem}.energy-header{font-size:1.2rem;font-weight:600;color:#0f0;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-color);text-align:center}.energy-grid{display:flex;flex-direction:column;gap:.5rem}.energy-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem;background:linear-gradient(135deg,#ffffff26,#ffffff14);border:1px solid rgba(255,255,255,.2);border-radius:12px;transition:all .2s ease;box-shadow:0 4px 16px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.energy-row:hover{background:linear-gradient(135deg,#fff3,#ffffff1f);transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.energy-header-row{background:var(--primary-color);color:#fff;font-weight:600;font-size:.9rem}.energy-header-row:hover{background:var(--primary-color);transform:none}.energy-item-header,.energy-value-header{text-align:center;font-weight:600}.energy-item{font-weight:600;color:var(--text-color);text-align:center}.energy-value{text-align:center;color:var(--text-secondary-color);font-weight:500}.energy-spacer{height:.5rem;border:none;background:none}@media (max-width: 768px){.energy-grid{gap:.4rem}.energy-row{padding:.6rem;grid-template-columns:2fr 1fr}.energy-header{font-size:1.1rem}}@media (max-width: 480px){.energy-tile{padding:1rem}.energy-row{padding:.5rem;gap:.5rem}.energy-item,.energy-value{font-size:.9rem}}.energy-container{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem}.energy-section{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;transition:all .3s ease}.energy-section:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.energy-section-header{padding:1rem;color:#fff;font-weight:700;text-align:center;position:relative;overflow:hidden}.energy-section-header:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);transition:transform .6s}.energy-section:hover .energy-section-header:before{transform:translate(100%)}.energy-section-header h3{margin:0;font-size:1.1rem;text-shadow:0 1px 3px rgba(0,0,0,.3);position:relative;z-index:1}.energy-table{background:#ffffff05}.energy-table-header{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem 1rem;background:#ffffff1a;border-bottom:1px solid rgba(255,255,255,.1);font-weight:700;color:#e0e0e0;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.energy-machine-header,.energy-value-header{text-align:center}.energy-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s ease;position:relative;overflow:hidden}.energy-row:hover{background:#ffffff14;transform:translate(3px)}.energy-row:last-child{border-bottom:none}.energy-row:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(135deg,#ffc107,#ff9800);transform:scaleY(0);transition:transform .3s ease}.energy-row:hover:before{transform:scaleY(1)}.energy-machine{color:#f5f5f5;font-weight:500;text-align:left;padding-left:.5rem}.energy-value{color:#ffb74d;font-weight:700;text-align:center;font-family:Courier New,monospace;font-size:1rem}@media (max-width: 1200px){.energy-container{grid-template-columns:repeat(2,1fr);gap:1rem}}@media (max-width: 768px){.energy-container{grid-template-columns:1fr}.energy-tile{padding:1rem}.energy-table-header,.energy-row{padding:.5rem;gap:.5rem}.energy-machine,.energy-value{font-size:.9rem}}.hour-meters-tile{background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 8px 32px #0000001a;transition:all .3s ease;overflow:hidden;position:relative}.hour-meters-tile:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .6s}.hour-meters-tile:hover:before{transform:translate(100%)}.hour-meters-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.hour-section{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;transition:all .3s ease}.hour-section:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026}.hour-section-header{padding:1rem;color:#fff;font-weight:700;text-align:center;position:relative;overflow:hidden}.hour-section-header:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);transition:transform .6s}.hour-section:hover .hour-section-header:before{transform:translate(100%)}.hour-section-header h3{margin:0;font-size:1.1rem;text-shadow:0 1px 3px rgba(0,0,0,.3);position:relative;z-index:1}.hour-table{background:#ffffff05}.hour-table-header{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem 1rem;background:#ffffff1a;border-bottom:1px solid rgba(255,255,255,.1);font-weight:700;color:#e0e0e0;text-transform:uppercase;font-size:.9rem;letter-spacing:.5px}.hour-machine-header,.hour-value-header{text-align:center}.hour-row{display:grid;grid-template-columns:2fr 1fr;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);transition:all .2s ease;position:relative;overflow:hidden}.hour-row:hover{background:#ffffff14;transform:translate(3px)}.hour-row:last-child{border-bottom:none}.hour-row:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:linear-gradient(135deg,#4caf50,#2e7d32);transform:scaleY(0);transition:transform .3s ease}.hour-row:hover:before{transform:scaleY(1)}.hour-machine{color:#f5f5f5;font-weight:500;text-align:left;padding-left:.5rem}.hour-value{color:#81c784;font-weight:700;text-align:center;font-family:Courier New,monospace;font-size:1rem}@media (max-width: 1200px){.hour-meters-container{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}}@media (max-width: 768px){.hour-meters-container{grid-template-columns:1fr}.hour-meters-tile{padding:1rem}.hour-table-header,.hour-row{padding:.5rem;gap:.5rem}.hour-machine,.hour-value{font-size:.9rem}}.water-system-main-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;align-items:center;justify-items:center;min-height:180px;max-height:220px;padding:.5rem}.water-pressure-tile,.water-tank-container{min-width:140px;max-width:200px;min-height:140px;max-height:200px;display:flex;align-items:center;justify-content:center}.pump-tile{min-width:110px;max-width:140px;min-height:44px;max-height:54px;margin-bottom:.6rem;font-size:1em}.tank-label-inside{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;pointer-events:none;gap:.5em}.tank-title{font-size:1em;color:#fff;font-weight:600;margin-bottom:0;text-shadow:0 2px 8px rgba(0,0,0,.28)}.tank-reading{font-size:1.5em;color:#fff;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.32);letter-spacing:1px;margin-top:0}.water-system-reorganized{display:flex;flex-direction:column;gap:1.5rem;padding:1rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.water-metrics-four-column{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:1.5rem;align-items:stretch;justify-items:center}.water-pressure-tile.large{min-width:200px;max-width:280px;min-height:300px;max-height:350px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:none!important;box-shadow:none!important;border-radius:0!important;padding:0!important;border:none!important;margin-bottom:0!important}.water-level-tile.large{min-width:200px;max-width:280px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.pump-group-column{display:flex;flex-direction:column;align-items:center;gap:1rem;min-width:200px;max-width:250px;height:100%;justify-content:flex-start}.pump-group-column h5{font-size:1.2rem;color:var(--text-primary-color);margin:0;font-weight:600;text-align:center;flex-shrink:0}.pump-column-grid{display:grid;grid-template-columns:1fr;gap:.8rem;width:100%;justify-items:center;flex:1;align-content:flex-start}.pump-tile.column-pump{min-width:140px;max-width:180px;height:auto;min-height:40px;font-size:1em;padding:.7rem .6rem;background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;transition:all .3s ease}.pump-tile.column-pump.on{background:linear-gradient(135deg,#22c55e4d,#22c55e1a);border-color:#22c55e80;box-shadow:0 0 20px #22c55e4d}.pump-tile.column-pump.off{background:#ef44441a;border-color:#ef44444d}.pump-tile.column-pump .pump-name{font-weight:600;color:var(--text-primary-color)}.pump-tile.column-pump .status{font-size:.9em;font-weight:700;color:var(--text-secondary-color)}.circular-progress{position:relative;display:flex;align-items:center;justify-content:center}.progress-ring{transform:rotate(-90deg)}.progress-ring-background{fill:none;stroke:#ffffff1a;stroke-width:8}.progress-ring-fill{fill:none;stroke:linear-gradient(135deg,#4FC3F7,#1976D2);stroke:#4fc3f7;stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 0 8px rgba(79,195,247,.4))}.progress-text{position:absolute;text-align:center;color:#fff}.progress-value{font-size:1.8rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.3);margin-bottom:.2rem}.progress-label{font-size:1rem;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.2);opacity:.9}.pressure-gauge{position:relative;display:flex;align-items:center;justify-content:center}.gauge-ring{filter:drop-shadow(0 0 8px rgba(0,230,118,.3))}.gauge-background{opacity:.3}.gauge-fill{transition:stroke-dashoffset .8s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 0 6px rgba(0,230,118,.4))}.gauge-fill.gauge-good-pressure{stroke:#00e676;filter:drop-shadow(0 0 6px rgba(0,230,118,.4))}.gauge-fill.gauge-low-pressure{stroke:#f44336;filter:drop-shadow(0 0 6px rgba(244,67,54,.4));animation:flash-red 1s infinite alternate}@keyframes flash-red{0%{stroke:#f44336;opacity:1}to{stroke:#ff1744;opacity:.7}}.gauge-pointer{transition:transform .8s cubic-bezier(.4,0,.2,1)}.gauge-text{position:absolute;text-align:center;color:#fff;top:70%;transition:color .3s ease}.gauge-text.low-pressure-text{animation:flash-text 1s infinite alternate}@keyframes flash-text{0%{color:#f44336}to{color:#ff1744}}.gauge-value{font-size:2rem;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.3);margin-bottom:.1rem}.gauge-unit{font-size:1.1rem;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.2);opacity:.9}.pumps-section{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1rem}.pump-group{display:flex;flex-direction:column;align-items:center;gap:1rem}.pump-group h5{font-size:1.2rem;color:var(--text-primary-color);margin:0;font-weight:600;text-align:center}.pump-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;width:100%;justify-items:center}.pump-tile.large-pump{min-width:120px;max-width:150px;min-height:60px;max-height:70px;font-size:1em;padding:.8rem .6rem}.pump-tile.large-pump .pump-name{font-weight:600;margin-bottom:.3rem}.pump-tile.large-pump .status{font-size:.9em;font-weight:700}@media (max-width: 1200px){.water-metrics-four-column{grid-template-columns:1fr 1fr;gap:1.5rem}}@media (max-width: 800px){.water-metrics-four-column{grid-template-columns:1fr;gap:1.5rem}.pump-column-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}}@media (max-width: 600px){.pump-column-grid{grid-template-columns:1fr;gap:.6rem}.lines-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 1200px){.lines-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 800px){.lines-grid{grid-template-columns:1fr;gap:1rem;padding:1.5rem}.line-tile{min-height:160px}}.water-tank.fullsize{width:100%;height:100%;min-width:80px;max-width:180px;margin:0 auto;position:relative;background:#ffffff1a;border-radius:24px;box-shadow:0 4px 24px #00000038;overflow:hidden;display:flex;align-items:center;justify-content:center}.water-tank.fullsize{width:100%;height:100%;min-width:0;min-height:0;aspect-ratio:2/4;margin:0 auto;position:relative;background:#ffffff1a;border-radius:24px;box-shadow:0 4px 24px #00000038;overflow:hidden;display:flex;align-items:center;justify-content:center}.water-tank.fullsize .water-fill{position:absolute;left:0;bottom:0;width:100%;border-radius:0 0 24px 24px;background:linear-gradient(180deg,#4fc3f7,#1976d2);box-shadow:0 2px 12px #2196f32e;transition:height .7s cubic-bezier(.4,0,.2,1);z-index:1}.tank-label-inside{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;pointer-events:none}.tank-title{font-size:1em;color:#fff;font-weight:600;margin-bottom:2px;text-shadow:0 2px 8px rgba(0,0,0,.28)}.tank-reading{font-size:1.5em;color:#fff;font-weight:700;text-shadow:0 2px 8px rgba(0,0,0,.32);letter-spacing:1px}.fortmill-page{padding:2rem;background-color:var(--bg-secondary);border-radius:var(--border-radius);box-shadow:var(--box-shadow-md)}.fortmill-page h2{font-size:2rem;color:var(--text-primary-color);margin:0 0 2rem;font-weight:600;text-align:center;padding-bottom:1rem;border-bottom:4px solid var(--company-red)}.production-section{margin-bottom:3rem}.lines-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding:2rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.line-tile{background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.2);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all .3s ease;min-height:180px}.line-tile.on{background:linear-gradient(135deg,#22c55e4d,#22c55e1a);border-color:#22c55e80;box-shadow:0 0 20px #22c55e4d}.line-tile.off{background:linear-gradient(135deg,#ef44444d,#ef44441a);border-color:#ef444480;box-shadow:0 0 20px #ef44444d}.line-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.line-number{font-size:1.2rem;font-weight:700;color:var(--text-primary-color)}.line-status{font-size:.9rem;font-weight:600;padding:.3rem .6rem;border-radius:var(--border-radius);background:#fff3;color:var(--text-primary-color)}.line-metrics{display:flex;flex-direction:column;gap:1rem;flex:1}.time-metric,.rate-metric{display:flex;justify-content:space-between;align-items:center;padding:.8rem;background:transparent;border-radius:var(--border-radius);border:none}.time-label,.rate-label{font-size:.9rem;color:var(--text-secondary-color);font-weight:500}.time-value,.rate-value{font-size:1.1rem;font-weight:700;color:var(--text-primary-color)}.plant-label{text-align:center;font-size:.8rem;color:var(--text-secondary-color);font-weight:500;margin-top:auto;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.2)}.air-section{margin-bottom:3rem}.air-section h3{font-size:1.5rem;color:var(--text-primary-color);margin:0 0 1.5rem;font-weight:600;text-align:center;padding-bottom:.75rem;border-bottom:3px solid var(--company-red)}.air-metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.air-metric-tile{background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;padding:.75rem;text-align:center;height:80px;display:flex;flex-direction:column;justify-content:center}.metric-header{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:.5rem}.metric-header i{font-size:1rem;color:var(--company-red)}.metric-header h4{font-size:.9rem;color:var(--text-primary-color);margin:0;font-weight:600;white-space:nowrap}.metric-value{display:flex;align-items:baseline;justify-content:center;gap:.3rem}.metric-value .value{font-size:1.3rem;font-weight:700;color:var(--text-primary-color)}.metric-value .unit{font-size:.8rem;color:var(--text-secondary-color);font-weight:500}.air-equipment-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;padding:2rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.air-equipment-grid .tile{font-size:1em}.air-equipment-grid .tile .tile-header{border-bottom:none!important;border:none!important;text-align:center!important;white-space:nowrap!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important;height:100%!important}.air-equipment-grid .tile .tile-header:after{display:none!important}.air-equipment-grid .tile .tile-header h3{font-size:1em!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;border-bottom:none!important;border:none!important;font-weight:600!important}.air-equipment-grid .tile .tile-status span{font-size:1em!important;white-space:nowrap!important}.air-equipment-grid .tile .icon{display:none!important}.chiller-section{margin-bottom:3rem}.chiller-section h3{font-size:1.5rem;color:var(--text-primary-color);margin:0 0 1.5rem;font-weight:600;text-align:center;padding-bottom:.75rem;border-bottom:3px solid var(--company-red)}.chiller-equipment-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1.5rem;padding:2rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.chiller-equipment-grid .tile{font-size:1em}.chiller-equipment-grid .tile .tile-header{border-bottom:none!important;border:none!important;text-align:center!important;white-space:nowrap!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important;height:100%!important}.chiller-equipment-grid .tile .tile-header:after{display:none!important}.chiller-equipment-grid .tile .tile-header h3{font-size:1em!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;border-bottom:none!important;border:none!important;font-weight:600!important}.chiller-equipment-grid .tile .icon{display:none!important}.chiller-equipment-grid .chiller-circuits{display:flex;justify-content:center;gap:1rem;margin-top:.5rem}.chiller-equipment-grid .circuit{display:flex;flex-direction:column;align-items:center;gap:.25rem}.chiller-equipment-grid .circuit span{font-size:.75em;font-weight:600;color:var(--text-secondary-color)}.chiller-equipment-grid .circuit.on span{color:var(--text-primary-color)}.chiller-equipment-grid .circuit-led{width:12px;height:12px;border-radius:50%;background-color:#666;transition:all .3s ease}.chiller-equipment-grid .circuit-led.on{background-color:var(--success-color, #4CAF50);box-shadow:0 0 10px #4caf5099}.water-temps-section{margin-bottom:3rem}.water-temps-section h3{font-size:1.5rem;color:var(--text-primary-color);margin:0 0 1.5rem;font-weight:600;text-align:center;padding-bottom:.75rem;border-bottom:3px solid var(--company-red)}.water-temps-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.75rem;padding:2rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;max-width:100%;overflow:hidden}.water-temps-grid .tile{font-size:1em;min-width:0;max-width:100%;overflow:hidden}.water-temps-grid .tile .tile-header{border-bottom:none!important;border:none!important;text-align:center!important;white-space:nowrap!important;overflow:hidden!important;display:flex!important;align-items:center!important;justify-content:center!important;height:auto!important;margin-bottom:.5rem!important;padding:0 .25rem}.water-temps-grid .tile .tile-header:after{display:none!important}.water-temps-grid .tile .tile-header h3{font-size:.75em!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;border-bottom:none!important;border:none!important;font-weight:600!important;margin:0!important;max-width:100%!important}.water-temps-grid .tile .icon{display:none!important}.water-temps-grid .chiller-temp-tile{display:flex;flex-direction:column;justify-content:flex-start;padding:.5rem;min-height:120px;max-width:100%;box-sizing:border-box}.water-temps-grid .temp-readings{display:flex;flex-direction:column;gap:.5rem;flex-grow:1;justify-content:center}.water-temps-grid .temp-row{display:flex;justify-content:space-between;align-items:center;padding:.3rem;border-radius:var(--border-radius);background:#ffffff0d;min-width:0}.water-temps-grid .temp-label{font-size:.7em;font-weight:600;color:var(--text-secondary-color);text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.water-temps-grid .temp-row .temp-value{font-size:.85em!important;font-weight:700!important;color:var(--text-primary-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.water-temps-grid .temp-row.temp-normal{border-left:3px solid #4CAF50;background:#4caf501a}.water-temps-grid .temp-row.temp-warning{border-left:3px solid #FFC107;background:#ffc1071a}.water-temps-grid .temp-row.temp-critical{border-left:3px solid #F44336;background:#f443361a}.water-temps-grid .temp-row.temp-unknown{border-left:3px solid #808080;background:#8080801a}.water-temps-grid .tile.temp-normal{background-color:#4caf501a;border-left:4px solid #4CAF50}.water-temps-grid .tile.temp-warning{background-color:#ffc1071a;border-left:4px solid #FFC107}.water-temps-grid .tile.temp-critical{background-color:#f443361a;border-left:4px solid #F44336}.water-temps-grid .tile.temp-unknown{background-color:#8080801a;border-left:4px solid #808080}.water-system-section{margin-bottom:3rem}.water-system-section h3{font-size:1.5rem;color:var(--text-primary-color);margin:0 0 1.5rem;font-weight:600;text-align:center;padding-bottom:.75rem;border-bottom:3px solid var(--company-red)}.water-system-main-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem;padding:.75rem;background:#2828282e;border-radius:1rem;box-shadow:0 4px 16px #0000001f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:stretch;min-height:120px;max-height:160px}.water-system-main-grid>div{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:0;padding:0}.water-pressure-tile,.water-tank-container,.pump-tile{background:#ffffff1a;border-radius:.7rem;box-shadow:0 2px 8px #00000014;padding:.5rem .4rem;margin-bottom:.5rem;width:100%;max-width:120px;transition:background .3s,box-shadow .3s}.pump-tile{display:flex;flex-direction:column;align-items:center;transition:background .4s,box-shadow .4s;cursor:pointer;font-size:.8em;min-height:38px;max-height:48px}.pump-tile.on{background:#4caf502e;box-shadow:0 0 16px 2px #4caf50}.pump-tile.off{background:#f4433621;box-shadow:0 0 12px 1px #f44336}.pump-tile .status{font-weight:700;font-size:.95em;margin-top:.3em;transition:color .4s}.pump-tile.on .status{color:#4caf50}.pump-tile.off .status{color:#f44336}.water-tank{position:relative;width:36px;height:70px;background:#c8dcff21;border-radius:.7rem;overflow:hidden;margin:0 auto .3em;border:2px solid rgba(255,255,255,.18)}.water-fill{position:absolute;left:0;bottom:0;width:100%;background:linear-gradient(180deg,#4fc3f7,#1976d2);transition:height .8s cubic-bezier(.4,2,.6,1),background .4s;border-radius:0 0 1rem 1rem}.tank-reading{position:absolute;width:100%;text-align:center;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-weight:700;font-size:.9em;text-shadow:0 2px 8px rgba(0,0,0,.18)}@media (max-width: 1000px){.water-system-main-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}}@media (max-width: 700px){.water-system-main-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;padding:1rem;gap:1rem}}@media (max-width: 1400px){.chiller-equipment-grid{grid-template-columns:repeat(5,1fr);gap:1rem}.water-temps-grid{grid-template-columns:repeat(7,1fr);gap:.5rem}.water-pumps-grid{grid-template-columns:repeat(6,1fr);gap:.75rem}.water-system-main-grid{min-height:140px;max-height:160px;grid-template-columns:1fr 1fr 1fr 1fr}}@media (max-width: 1200px){.lines-grid{grid-template-columns:repeat(2,1fr)}.air-equipment-grid,.chiller-equipment-grid{grid-template-columns:repeat(3,1fr)}.water-temps-grid{grid-template-columns:repeat(4,1fr)}.water-system-main-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:.25rem;min-height:auto;max-height:none}.process-pumps-grid,.chiller-pumps-grid{grid-template-columns:repeat(3,1fr)}.water-tank-container{height:auto}.water-pumps-grid{grid-template-columns:repeat(3,1fr)}.fortmill-page h2{font-size:1.8rem}.air-section h3{font-size:1.3rem}}@media (max-width: 768px){.fortmill-page{padding:1rem}.fortmill-page h2{font-size:1.6rem;margin-bottom:1.5rem}.air-section h3{font-size:1.2rem;margin-bottom:1rem}.lines-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.5rem}.air-metrics-grid{grid-template-columns:1fr;gap:1rem;margin-bottom:1.5rem}.air-equipment-grid,.chiller-equipment-grid,.water-temps-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.5rem}.water-system-main-grid{grid-template-columns:1fr;grid-template-rows:auto auto;gap:.25rem;padding:.5rem;min-height:auto;max-height:none}.process-pumps-grid,.chiller-pumps-grid{grid-template-columns:repeat(3,1fr);gap:.15rem}.water-tank-container{height:auto}.water-pumps-grid{grid-template-columns:repeat(2,1fr);gap:1rem;padding:1.5rem}.metric-value .value{font-size:1.1rem}.metric-value .unit{font-size:.7rem}.air-metric-tile{height:70px;padding:.5rem}.sensor-readings,.systems-grid{grid-template-columns:1fr}}@media (max-width: 480px){.fortmill-page h2{font-size:1.4rem}.air-section h3{font-size:1.1rem}.lines-grid,.air-equipment-grid,.chiller-equipment-grid,.water-temps-grid{grid-template-columns:1fr;gap:.75rem;padding:1rem}.water-system-main-grid{grid-template-columns:1fr;grid-template-rows:auto auto;gap:.25rem;padding:.4rem;min-height:auto;max-height:none}.process-pumps-grid,.chiller-pumps-grid{grid-template-columns:1fr;gap:.1rem}.water-tank-container{height:auto}.water-pumps-grid{grid-template-columns:1fr;gap:.75rem;padding:1rem}.air-metric-tile{padding:.5rem;height:60px}.metric-header h4{font-size:.8rem}.metric-header i{font-size:.9rem}.air-system-grid{grid-template-columns:1fr}}.comfort-loop-section{margin-top:2rem}.comfort-loop-section h3{color:var(--text-primary-color);font-size:1.5rem;margin-bottom:1rem;text-align:center;margin-top:0}.air-handlers-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;padding:1rem;background:#80808026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}.air-handler-tile{background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.2);padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.air-handler-header h4{color:var(--text-primary-color);font-size:1.3rem;margin:0;text-align:center;font-weight:600}.air-handler-metrics{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.comfort-loop-section .metric-tile{background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.2);padding:1rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:80px;transition:all .3s ease}.comfort-loop-section .metric-tile:hover{background:#ffffff26;border-color:#ffffff4d}.comfort-loop-section .metric-label{font-size:.9rem;color:var(--text-secondary-color);text-align:center;font-weight:500;line-height:1.2}.comfort-loop-section .metric-value{display:flex;align-items:baseline;gap:.3rem}.comfort-loop-section .metric-value .value{font-size:1.4rem;font-weight:700;color:var(--text-primary-color)}.comfort-loop-section .metric-value .unit{font-size:.9rem;color:var(--text-secondary-color);font-weight:500}@media (max-width: 1000px){.air-handlers-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 600px){.air-handler-metrics{grid-template-columns:1fr;gap:.8rem}.comfort-loop-section .metric-tile{min-height:70px}.comfort-loop-section .metric-value .value{font-size:1.2rem}}.dryer-silos-section{margin-top:2rem}.dryer-silos-section h4{color:var(--text-primary-color);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--accent-color);font-size:1.2rem}.dryer-silos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:1rem}.dryer-silo-tile{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:1rem;text-align:center;transition:all .3s ease;box-shadow:var(--box-shadow-sm)}.dryer-silo-tile:hover{transform:translateY(-2px);box-shadow:var(--box-shadow-md)}.dryer-silo-tile .silo-header h5{color:var(--text-primary-color);margin:0 0 1rem;font-size:1rem;font-weight:600}.dryer-silo-tile .silo-container{display:flex;justify-content:center;align-items:center}.dryer-silo-tile .silo-visual{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.dryer-silo-tile .silo-tank{width:96px;height:200px;background-color:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:6px;position:relative;overflow:hidden}.dryer-silo-tile .silo-fill{position:absolute;bottom:0;left:0;width:100%;background:linear-gradient(180deg,var(--silo-fill-color-dark) 0%,var(--silo-fill-color) 100%);transition:height .8s ease;border-radius:0 0 4px 4px}.dryer-silo-tile .silo-percentage{color:var(--text-primary-color);font-size:.9rem;font-weight:600;min-height:1.2rem}@media (max-width: 1200px){.dryer-silos-grid{grid-template-columns:repeat(2,1fr);gap:1.2rem}}@media (max-width: 600px){.dryer-silos-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.dryer-silo-tile{padding:.8rem}.dryer-silo-tile .silo-tank{width:40px;height:60px}.dryer-silo-tile .silo-header h5{font-size:.9rem}.dryer-silo-tile .silo-percentage{font-size:.8rem}}
