:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:20px}.login-card{background:#fff;border-radius:6px;box-shadow:0 4px 12px #00000026;border:1px solid #cccccc;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{color:#333;font-size:28px;font-weight:600;margin:0 0 8px}.login-header p{color:#666;font-size:18px;margin:0}.login-form{margin-bottom:30px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:18px}.form-group input{width:100%;padding:12px 16px;border:1px solid #cccccc;border-radius:4px;font-size:18px;transition:border-color .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e21a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;font-size:18px;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:#4a90e2;color:#fff;border:none;border-radius:4px;font-size:18px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.login-button:hover:not(:disabled){background:#357abd}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{border-top:1px solid #e1e5e9;padding-top:20px}.demo-accounts h3{color:#333;font-size:20px;margin:0 0 12px;text-align:center}.demo-account{background-color:#f8f9fa;padding:8px 12px;margin-bottom:8px;border-radius:6px;font-size:18px;color:#555}.demo-account:last-child{margin-bottom:0}.demo-account strong{color:#333}@media (max-width: 480px){.login-container{padding:10px}.login-card{padding:30px 20px}.login-header h1{font-size:28px}}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:998}.sidebar{position:fixed;top:0;left:-300px;width:300px;height:100vh;background:#1a1a1a;color:#fff;transition:left .3s ease;z-index:999;display:flex;flex-direction:column;box-shadow:2px 0 10px #00000080;border-right:2px solid #333333}.sidebar.open{left:0}.sidebar-header{padding:20px;border-bottom:2px solid #333333;display:flex;justify-content:space-between;align-items:center;background:#2a2a2a}.sidebar-header h2{margin:0;font-size:26px;font-weight:700;color:#fff}.close-btn{background:none;border:none;color:#fff;font-size:28px;cursor:pointer;padding:5px;border-radius:4px;transition:background-color .2s}.close-btn:hover{background:#ffffff1a}.sidebar-content{flex:1;overflow-y:auto;padding:10px 0}.menu-item{display:flex;align-items:center;padding:15px 20px;cursor:pointer;transition:all .2s ease;border-bottom:1px solid #333333;position:relative;font-weight:500}.menu-item:hover{background-color:#333;border-left:4px solid #4a90e2}.menu-item.active{background-color:#2a2a2a;border-left:4px solid #4a90e2;color:#4a90e2}.submenu-item{background-color:#1a1a1a;border-left:4px solid #666666;padding-left:40px}.submenu-item:hover{background-color:#2a2a2a;border-left-color:#4a90e2}.submenu-item.active{background-color:#2a2a2a;border-left-color:#4a90e2;color:#4a90e2}.menu-icon{font-size:24px;margin-right:15px;min-width:28px;width:28px;height:28px;background-color:#4a90e2;color:#fff;border-radius:3px;display:flex;align-items:center;justify-content:center;font-weight:700}.menu-label{font-size:22px;font-weight:500;flex:1}.expand-icon{font-size:20px;transition:transform .3s ease;margin-left:10px}.expand-icon.expanded{transform:rotate(180deg)}.submenu{background-color:#1a1a1a;border-left:4px solid #666666}@media (max-width: 768px){.sidebar{width:280px;left:-280px}.menu-item{padding:10px 15px}.menu-label{font-size:22px}.menu-icon{font-size:24px;margin-right:10px}}.page-header{background:#1a1a1a;color:#fff;padding:15px 30px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #333333;box-shadow:0 2px 8px #0000004d}.header-left{display:flex;align-items:center}.menu-toggle{background:#4a90e2;color:#fff;border:none;padding:12px 16px;font-size:22px;font-weight:700;cursor:pointer;border-radius:4px;transition:all .2s ease;margin-right:20px;border:1px solid #333333}.menu-toggle:hover{background:#357abd;border-color:#4a90e2}.header-center h1{margin:0;font-size:26px;font-weight:600;color:#fff;letter-spacing:.5px;cursor:pointer}.header-right{display:flex;align-items:center;gap:20px}.user-menu{position:relative}.user-info-button{background:transparent;color:#fff;border:1px solid #333333;padding:8px 16px;font-size:18px;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;gap:8px}.user-info-button:hover{background:#333;border-color:#4a90e2}.user-name{font-weight:500}.user-role{color:#ccc;font-size:16px}.dropdown-arrow{font-size:14px;transition:transform .3s ease}.user-info-button:hover .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;margin-top:8px}.user-details{padding:16px;border-bottom:1px solid #eee}.user-email{color:#666;font-size:18px;margin-bottom:8px}.user-role-badge{background:#4a90e2;color:#fff;padding:4px 8px;border-radius:3px;font-size:16px;font-weight:500;display:inline-block}.logout-btn{background:#e74c3c;color:#fff;border:none;padding:12px 16px;font-size:18px;font-weight:500;cursor:pointer;border-radius:0 0 8px 8px;transition:background .3s ease;width:100%}.logout-btn:hover{background:#c0392b}@media (max-width: 768px){.page-header{padding:10px 15px}.header-center h1{font-size:24px}.user-info{font-size:18px}.logout-btn{padding:8px 16px;font-size:18px}}.dashboard-container{min-height:100vh;width:100vw;background:#f5f5f5;display:flex;flex-direction:column;overflow:visible;padding-bottom:0}.dashboard-header{background:#fff;padding:15px 30px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;position:relative}.dashboard-header .header-left{display:flex;align-items:center}.dashboard-header .menu-toggle{background:#3498db;color:#fff;border:none;padding:10px 15px;border-radius:6px;cursor:pointer;font-size:28px;transition:background-color .2s;margin-right:20px}.dashboard-header .menu-toggle:hover{background:#2980b9}.dashboard-header .header-center{position:absolute;left:50%;transform:translate(-50%);text-align:center}.dashboard-header .header-center h1{margin:0;color:#333;font-size:28px;font-weight:600}.dashboard-header .header-right{display:flex;align-items:center;gap:20px}.dashboard-header .user-info{color:#666;font-size:26px}.dashboard-header .logout-button{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:26px;transition:background-color .2s}.dashboard-header .logout-button:hover{background:#c0392b}.dashboard-content{flex:1;padding:20px 30px 10px;overflow:visible;display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%;box-sizing:border-box}.dashboard-container .loading{text-align:center;padding:50px;font-size:26px;color:#666}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:20px}.stat-card{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;gap:20px;border:3px solid transparent;transition:all .3s}.stat-card:hover{box-shadow:0 2px 6px #00000026}.stat-icon{width:50px;height:50px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff;font-weight:700}.stat-icon.online{background:#2e7d32}.stat-icon.warning{background:#f57c00}.stat-icon.offline{background:#d32f2f}.stat-info h3{margin:0 0 8px;color:#333;font-size:28px;font-weight:700}.stat-info p{margin:0;color:#333;font-size:42px;font-weight:900}.systems-section h2{color:#333;margin:0 0 20px;font-size:28px;font-weight:600}.systems-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;flex:1}.system-card{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:30px;transition:all .3s;border:3px solid transparent;position:relative;overflow:hidden}.system-card:hover{box-shadow:0 3px 8px #00000026}.system-card.online{border-color:#27ae60;background:linear-gradient(135deg,#fff,#f8fff8)}.system-card.warning{border-color:#f39c12;background:linear-gradient(135deg,#fff,#fffbf0)}.system-card.offline{border-color:#e74c3c;background:linear-gradient(135deg,#fff,#fff5f5)}.system-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.system-header h3{margin:0;color:#333;font-size:28px;font-weight:700;display:flex;align-items:center;gap:10px}.system-status-indicator{width:20px;height:20px;border-radius:50%;position:relative}.system-status-indicator.online{background:#2e7d32}.system-status-indicator.warning{background:#f57c00}.system-status-indicator.offline{background:#d32f2f}.status-badge{color:#fff;padding:4px 12px;border-radius:20px;font-size:28px;font-weight:600}.system-metrics{margin-bottom:20px}.metric{display:flex;align-items:center;gap:15px;margin-bottom:20px}.dashboard-container .metric-label{width:80px;font-size:28px;color:#333;font-weight:600}.metric-bar{flex:1;height:16px;background:#ecf0f1;border-radius:8px;overflow:hidden;border:2px solid #ddd}.metric-fill{height:100%;transition:width .5s ease;position:relative}.dashboard-container .metric-value{width:60px;text-align:right;font-size:26px;color:#333;font-weight:700}.system-footer{display:flex;justify-content:space-between;align-items:center;padding-top:15px;border-top:1px solid #ecf0f1}.system-footer p{margin:0;color:#999;font-size:28px}.detail-button{background:#4a90e2;color:#fff;border:none;padding:12px 24px;border-radius:4px;cursor:pointer;font-size:26px;font-weight:600;transition:background-color .2s;box-shadow:0 2px 4px #4a90e233}.detail-button:hover{background:#357abd}.detail-button:active{background:#2c5aa0}.dashboard-container .summary-stats-grid{display:flex;width:100%!important;min-width:100%;max-width:100%;margin:16px 0 24px;padding-bottom:24px;background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #e6e6e6;border-radius:12px;box-shadow:0 6px 14px #0000000f;box-sizing:border-box;flex-wrap:nowrap;align-items:stretch;overflow:visible!important;min-height:340px}.dashboard-container .summary-stats-grid .stat-card{padding:0 16px;min-height:340px;height:100%;box-sizing:border-box;display:flex;flex-direction:column;position:relative;background:transparent;border:none;border-radius:0;box-shadow:none;overflow:visible}.equipment-location.solar-panel-1 .equipment-indicator,.equipment-location.solar-panel-2 .equipment-indicator,.equipment-location.solar-panel-3 .equipment-indicator{width:320px;min-width:320px;max-width:320px}.dashboard-container .summary-stats-grid .stat-card:not(:last-child):after{content:"";position:absolute;right:0;top:20px;bottom:20px;width:3px;background:#d0d0d0}.dashboard-container .summary-stats-grid .stat-card:not(.single-column){flex:1 1 0!important;min-width:0!important;width:auto!important;max-width:none!important;display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center;min-height:340px}.dashboard-container .summary-stats-grid .stat-card:not(.single-column) .stat-section{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center;flex:1;justify-content:center}.dashboard-container .summary-stats-grid .stat-card:not(.single-column) .stat-section .stat-title{text-align:center;width:100%;font-size:28px;font-weight:600;color:#666;margin-bottom:16px}.dashboard-container .summary-stats-grid .stat-card:not(.single-column) .stat-section .stat-values{width:100%;display:flex;flex-direction:column;gap:12px}.dashboard-container .summary-stats-grid .stat-card.single-column{flex:0 0 16%!important;min-width:240px!important;width:16%!important;max-width:none!important;display:flex!important;flex-direction:column!important;gap:0!important;overflow:visible!important;min-height:340px!important;align-self:stretch!important;justify-content:center;align-items:center;text-align:center;padding:0 16px!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-title{flex-shrink:0!important;margin-bottom:16px!important;margin-top:auto!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-values{flex:0 1 auto!important;display:flex!important;flex-direction:column!important;gap:12px!important;margin:0 0 auto!important}.dashboard-container .summary-stats-grid .stat-section{display:flex;flex-direction:column;gap:12px;flex:1;justify-content:flex-start}.dashboard-container .summary-stats-grid:hover{box-shadow:0 10px 18px #00000014}.dashboard-container .summary-stats-grid .stat-card:hover{background:#00000005}.dashboard-container .summary-stats-grid .stat-title{font-size:28px;font-weight:600;color:#666;margin-bottom:16px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;width:100%}.dashboard-container .summary-stats-grid .co2-title{color:#2e7d32;font-size:28px;font-weight:600;margin-bottom:16px}.dashboard-container .summary-stats-grid .carbon-title{color:#d32f2f;font-size:28px;font-weight:600;margin-bottom:16px}.dashboard-container .summary-stats-grid .stat-values{display:flex!important;flex-direction:column;gap:12px;flex:1 1 auto;overflow:visible;min-height:0;visibility:visible;opacity:1;width:100%}.dashboard-container .summary-stats-grid .stat-item{display:flex!important;justify-content:space-between;align-items:center;padding:10px 0;margin-bottom:0;gap:20px;visibility:visible;opacity:1;flex-shrink:0;width:100%;min-width:0}.dashboard-container .summary-stats-grid .stat-label{font-size:26px;color:#666;font-weight:500}.dashboard-container .summary-stats-grid .stat-value{font-size:28px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0;text-align:right}.dashboard-container .summary-stats-grid .co2-value{color:#2e7d32;font-weight:600}.dashboard-container .summary-stats-grid .carbon-value{color:#d32f2f;font-weight:600}.factory-layout{background:#fff;border:1px solid #cccccc;border-radius:6px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.factory-map{position:relative;background:#f5f5f5;min-height:700px;padding:10px}.factory-building{position:relative;width:100%;height:650px;background-image:url(/background.png);background-size:100% 100%;background-position:center;background-repeat:no-repeat;background-color:#f0f0f0;border:1px solid #cccccc;border-radius:6px;overflow:hidden}.equipment-location{position:absolute;z-index:10;cursor:pointer}.equipment-indicator{background:#fff;border:2px solid #4a90e2;border-radius:6px;padding:16px 20px;box-shadow:0 2px 6px #00000026;text-align:left;width:290px;min-width:290px;max-width:290px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;display:flex;align-items:center;gap:14px;box-sizing:border-box}.equipment-indicator:hover{transform:scale(1.02);box-shadow:0 3px 8px #0003}.equipment-indicator.online{border-color:#2e7d32;background:#f1f8e9}.equipment-indicator.offline{border-color:#ccc;background:#f5f5f5;color:#666}.equipment-location.solar-panel-1 .equipment-indicator.online,.equipment-location.solar-panel-2 .equipment-indicator.online,.equipment-location.solar-panel-3 .equipment-indicator.online,.equipment-location.motor-summary .equipment-indicator.online,.equipment-location.transformer .equipment-indicator.online,.equipment-location.boiler-room .equipment-indicator.online{background:#9bbb59!important;border-color:#9bbb59!important}.equipment-location.vacuum-pump .equipment-indicator,.equipment-location.dust-collector .equipment-indicator{background:#c0504d!important;border-color:#953735!important}.equipment-location.cooling-tower .equipment-indicator.online{background:#1f497d!important;color:#fff!important;border-color:#1f497d!important}.equipment-location.cooling-tower .equipment-name,.equipment-location.cooling-tower .equipment-value{color:#fff!important}.equipment-icon{width:69px;height:69px;border-radius:50%;background:#fff;border:1px solid rgba(0,0,0,.08);display:flex;align-items:center;justify-content:center;flex-shrink:0}.equipment-icon img{width:65px;height:65px;object-fit:contain}.equipment-info{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0;overflow:hidden}.equipment-name{font-size:28px;font-weight:600;color:#fff;margin-bottom:0;line-height:1.3;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equipment-capacity{font-size:20px;font-weight:500;color:#ffffffe6;margin-left:1px}.equipment-value{font-size:26px;font-weight:600;color:#fff;line-height:1.3;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.transformer{top:0%;left:0%;transform:translate(0)}.vacuum-pump{top:30%;left:0%;transform:translateY(-50%)}.boiler-room{top:50%;left:0%;transform:translateY(-50%)}.dust-collector{top:70%;left:0%;transform:translateY(-50%)}.cooling-tower{top:100%;left:0%;transform:translateY(-100%)}.solar-panel-1{top:10%;left:39%;transform:translate(-50%)}.solar-panel-2{top:10%;left:57%;transform:translate(-50%)}.solar-panel-3{top:10%;left:75%;transform:translate(-50%)}.motor-1{top:26%;left:20%;transform:translateY(-50%)}.motor-2{top:44%;left:20%;transform:translateY(-50%)}.motor-3{top:62%;left:20%;transform:translateY(-50%)}.motor-4{top:26%;left:20%;transform:translate(180px,-50%)}.motor-5{top:44%;left:20%;transform:translate(180px,-50%)}.motor-6{top:62%;left:20%;transform:translate(180px,-50%)}.motor-summary{top:50%;left:28%;transform:translate(-50%,-50%)}.summary-panel{position:absolute;bottom:100px;right:20px;background:#fff;border:1px solid #cccccc;border-radius:6px;padding:15px;min-width:350px;max-height:calc(100vh - 150px);overflow-y:auto;box-shadow:0 2px 6px #00000026;z-index:10}.summary-title{font-size:26px;font-weight:600;color:#333;margin-bottom:10px;text-align:center;border-bottom:1px solid #dddddd;padding-bottom:8px}.summary-stats{display:flex;flex-direction:column;gap:8px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.summary-label{font-size:26px;color:#666;font-weight:500}.summary-value{font-size:28px;font-weight:600;color:#333}.summary-value.ghg{color:#d32f2f}@media (max-width: 1200px){.dashboard-container .summary-stats-grid{flex-wrap:wrap}.dashboard-container .summary-stats-grid .stat-card:not(.single-column){flex:0 0 calc(50% - 8px);margin-bottom:16px}.dashboard-container .summary-stats-grid .stat-card.single-column{flex:0 0 calc(50% - 8px)}.factory-building{height:500px}.equipment-indicator{min-width:140px;padding:14px 18px}.equipment-name{font-size:26px;margin-bottom:8px}.equipment-value{font-size:28px}}@media (max-width: 768px){.dashboard-container .summary-stats-grid{flex-direction:column}.dashboard-container .summary-stats-grid .stat-card{flex:1 1 100%!important;width:100%!important;max-width:100%!important}.factory-building{height:400px}.equipment-indicator{min-width:120px;padding:12px 16px}.equipment-name{font-size:28px;margin-bottom:8px}.equipment-value{font-size:26px}.summary-panel{position:relative;margin-bottom:20px}}.factory-dashboard{background:#fff;border:2px solid #333;margin-bottom:20px}.dashboard-title{background:#333;color:#fff;padding:20px 30px;text-align:center;border-bottom:2px solid #333}.dashboard-title h2{margin:0 0 5px;font-size:28px;font-weight:700}.update-time{color:#ccc;font-size:26px;font-weight:500}.monitoring-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.monitoring-section{padding:25px;border-right:1px solid #ddd;background:#f9f9f9}.monitoring-section:last-child{border-right:none}.monitoring-section.greenhouse{background:#f0f8f0}.monitoring-section.air{background:#fff8f0}.monitoring-section.water{background:#f0f8ff}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #ccc}.section-header h3{margin:0;font-size:26px;font-weight:700;color:#333}.status-indicator{padding:4px 12px;border-radius:4px;font-size:28px;font-weight:600;text-transform:uppercase}.monitoring-data{display:flex;flex-direction:column;gap:15px}.data-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.data-label{color:#666;font-size:26px;font-weight:500}.data-value{color:#333;font-size:28px;font-weight:700}.data-value.carbon{color:#e74c3c}.overview-section{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:30px;overflow:hidden}.overview-header{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center}.overview-header h2{margin:0;font-size:28px;font-weight:700}.overview-timestamp{background:#fff3;padding:8px 16px;border-radius:20px;font-size:26px;font-weight:600}.overview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.overview-card{padding:25px;border-right:1px solid #eee;position:relative}.overview-card:last-child{border-right:none}.overview-card.greenhouse{background:linear-gradient(135deg,#f8fff8,#e8f5e8)}.overview-card.air{background:linear-gradient(135deg,#fff8f0,#fef5e7)}.overview-card.water{background:linear-gradient(135deg,#f0f8ff,#e6f3ff)}.overview-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid rgba(0,0,0,.1)}.overview-card-header h3{margin:0;font-size:26px;font-weight:700;color:#333}.status-indicator{padding:6px 12px;border-radius:15px;font-size:28px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-indicator.online{background:#27ae60;color:#fff}.status-indicator.warning{background:#f39c12;color:#fff}.status-indicator.offline{background:#e74c3c;color:#fff}.overview-stats{display:flex;flex-direction:column;gap:12px}.stat-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.stat-label{color:#666;font-size:26px;font-weight:500}.stat-value{color:#333;font-size:28px;font-weight:700}.stat-value.carbon{color:#e74c3c}.sector-section{margin-bottom:40px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;overflow:visible;min-height:auto}.sector-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center}.sector-header h2{margin:0;font-size:28px;font-weight:700}.sector-stats{background:#fff3;padding:8px 16px;border-radius:20px;font-size:26px;font-weight:600}.sector-grid{padding:30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.equipment-group{background:#f8f9fa;border-radius:8px;padding:20px;border:2px solid #e9ecef}.equipment-group h3{margin:0 0 20px;font-size:26px;font-weight:700;color:#333;display:flex;align-items:center;gap:8px}.equipment-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.equipment-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000001a;border:2px solid transparent;transition:all .3s}.equipment-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.equipment-card.online{border-color:#27ae60}.equipment-card.warning{border-color:#f39c12}.equipment-card.offline{border-color:#e74c3c}.equipment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.equipment-header h4{margin:0;font-size:28px;font-weight:600;color:#333}.efficiency-badge,.temp-badge,.rpm-badge{background:#3498db;color:#fff;padding:4px 8px;border-radius:12px;font-size:28px;font-weight:600}.temp-badge{background:#e74c3c}.rpm-badge{background:#f39c12}.status-badge{padding:4px 8px;border-radius:12px;font-size:28px;font-weight:600}.status-badge.online{background:#27ae60;color:#fff}.status-badge.warning{background:#f39c12;color:#fff}.status-badge.offline{background:#e74c3c;color:#fff}.equipment-metrics{display:flex;flex-direction:column;gap:10px}.dashboard-container .metric-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.dashboard-container .metric-row span:first-child{color:#666;font-size:26px;font-weight:500}.dashboard-container .equipment-metrics .metric-value{color:#333;font-size:28px;font-weight:700}.dashboard-container .metric-value.carbon{color:#e74c3c}@media (min-width: 1920px){.dashboard-header{padding:15px 40px;height:70px;flex-shrink:0}.header-center h1{font-size:26px}.dashboard-content{padding:20px 30px;flex:1;overflow:visible}.stats-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:15px}.systems-grid{grid-template-columns:repeat(2,1fr);gap:20px;flex:1}.system-card,.stat-card{padding:20px}}@media (min-width: 1440px) and (max-width: 1919px){.systems-grid{grid-template-columns:repeat(2,1fr);gap:18px}.stats-grid{grid-template-columns:repeat(3,1fr);gap:18px}.dashboard-container .summary-stats-grid .stat-card{min-height:320px}.dashboard-container .summary-stats-grid .stat-card.single-column{min-height:320px!important;padding:24px 16px!important;min-width:260px!important;flex:0 0 16%!important;width:16%!important;max-width:none!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-title{font-size:28px!important;font-weight:600!important;color:#666!important;margin-bottom:12px!important;text-align:center!important;width:100%!important;display:block!important;visibility:visible!important;opacity:1!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-values{flex:1 1 auto!important;display:flex!important;visibility:visible!important;opacity:1!important;height:auto!important;min-height:100px!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-item{padding:6px 0!important;font-size:26px!important;display:flex!important;visibility:visible!important;opacity:1!important}.dashboard-container .summary-stats-grid .stat-card.single-column .stat-label,.dashboard-container .summary-stats-grid .stat-card.single-column .stat-value{font-size:26px!important;display:inline-block!important;visibility:visible!important}}@media (min-width: 1024px) and (max-width: 1439px){.systems-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:15px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}}@media (max-width: 1023px){.systems-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.overview-grid{grid-template-columns:1fr}.overview-card{border-right:none;border-bottom:1px solid #eee}.overview-card:last-child{border-bottom:none}.monitoring-grid{grid-template-columns:1fr}.monitoring-section{border-right:none;border-bottom:1px solid #ddd}.monitoring-section:last-child{border-bottom:none}}.detail-container{height:100vh;width:100vw;background:#f8f9fa;display:flex;flex-direction:column;overflow:hidden}.detail-header{background:#fff;padding:15px 30px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;position:relative}.detail-header .header-left{display:flex;align-items:center}.detail-header .menu-toggle{background:#3498db;color:#fff;border:none;padding:10px 15px;border-radius:6px;cursor:pointer;font-size:24px;transition:background-color .2s;margin-right:20px}.detail-header .menu-toggle:hover{background:#2980b9}.detail-header .header-center{position:absolute;left:50%;transform:translate(-50%);text-align:center}.detail-header .header-center h1{margin:0;color:#333;font-size:24px;font-weight:600}.detail-header .status-badge{color:#fff;padding:8px 16px;border-radius:20px;font-size:26px;font-weight:600}.detail-content{flex:1;padding:20px 30px 10px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.detail-container .loading,.detail-container .error{text-align:center;padding:50px;font-size:26px;color:#666}.detail-container .error{color:#e74c3c}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px}.metric-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.metric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.metric-header h3{margin:0;color:#333;font-size:24px;font-weight:600}.metric-value{color:#333;font-size:26px;font-weight:700}.metric-bar{height:12px;background:#ecf0f1;border-radius:6px;overflow:hidden}.metric-fill{height:100%;transition:width .3s}.info-section{display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1}.info-card,.alerts-card{background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.info-card h3,.alerts-card h3{margin:0 0 20px;color:#333;font-size:26px;font-weight:600}.info-grid{display:flex;flex-direction:column;gap:15px}.info-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #ecf0f1}.info-item:last-child{border-bottom:none}.info-label{color:#666;font-size:26px;font-weight:500}.info-value{color:#333;font-size:26px;font-weight:600}.alerts-list{display:flex;flex-direction:column;gap:15px}.alert-item{padding:15px;border-radius:8px;background:#f8f9fa;border-left:4px solid #3498db}.alert-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.alert-level{color:#fff;padding:4px 8px;border-radius:4px;font-size:24px;font-weight:600}.alert-time{color:#666;font-size:24px}.alert-message{margin:0;color:#333;font-size:26px;line-height:1.4}@media (min-width: 1920px){.detail-header{padding:15px 40px;height:70px;flex-shrink:0}.detail-header .header-center h1{font-size:26px}.detail-content{padding:20px 30px 10px;flex:1;overflow-y:auto}.metrics-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:15px}.info-section{grid-template-columns:1fr 1fr;gap:20px;flex:1}.metric-card,.info-card,.alerts-card{padding:20px}}@media (min-width: 1440px) and (max-width: 1919px){.metrics-grid{grid-template-columns:repeat(4,1fr);gap:18px}.info-section{grid-template-columns:1fr 1fr;gap:18px}}@media (min-width: 1024px) and (max-width: 1439px){.metrics-grid{grid-template-columns:repeat(2,1fr);gap:15px}.info-section{grid-template-columns:1fr;gap:15px}}@media (max-width: 1023px){.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width: 768px){.info-section,.metrics-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;gap:15px;align-items:flex-start}.detail-header .header-left{flex-direction:column;align-items:flex-start;gap:10px}}.solar-detail-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5;width:100%;max-width:100%}.solar-detail-header{background:#333;color:#fff;padding:20px 30px;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid #333}.solar-detail-header .header-left,.solar-detail-header .header-right{display:flex;align-items:center;gap:15px}.header-center{flex:1;text-align:center}.header-center h1{margin:0;color:#fff;font-size:28px;font-weight:700}.solar-detail-header .menu-toggle{background:#555;color:#fff;border:none;padding:12px 16px;font-size:26px;cursor:pointer;border-radius:4px;transition:background .3s ease}.solar-detail-header .menu-toggle:hover{background:#666}.solar-detail-header .user-info{font-size:28px;font-weight:500}.solar-detail-header .logout-btn{background:#e74c3c;color:#fff;border:none;padding:10px 20px;font-size:28px;font-weight:600;cursor:pointer;border-radius:4px;transition:background .3s ease}.solar-detail-header .logout-btn:hover{background:#c0392b}.solar-detail-content{flex:1;padding:30px 30px 10px;width:100%;max-width:100%;box-sizing:border-box}.solar-detail-container .summary-stats-grid{display:flex;width:100%!important;min-width:100%;max-width:100%;margin:16px 0 24px;background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #e6e6e6;border-radius:12px;box-shadow:0 6px 14px #0000000f;overflow:hidden;box-sizing:border-box}.solar-detail-container .stat-card{flex:0 0 25%!important;min-width:0;width:25%!important;max-width:25%!important;padding:24px 28px;min-height:140px;box-sizing:border-box;display:flex;flex-direction:column;position:relative;background:transparent;border:none;border-radius:0;box-shadow:none}.solar-detail-container .stat-card:not(:last-child):after{content:"";position:absolute;right:0;top:20px;bottom:20px;width:1px;background:#e6e6e6}.solar-detail-container .summary-stats-grid:hover{box-shadow:0 10px 18px #00000014}.solar-detail-container .stat-card:hover{background:#00000005}.solar-detail-container .stat-card.single-column{display:flex;flex-direction:column;gap:8px}.solar-detail-container .stat-title{font-size:28px;font-weight:600;color:#666;margin-bottom:12px}.solar-detail-container .stat-values{display:flex;align-items:center}.solar-detail-container .stat-item{display:flex;align-items:baseline;gap:8px}.solar-detail-container .stat-value{font-size:28px;font-weight:800;color:#222;letter-spacing:-.2px;line-height:1.2}@media (max-width: 1400px){.solar-detail-container .summary-stats-grid{flex-wrap:wrap}.solar-detail-container .stat-card{flex:1 1 calc(50% - 6px);min-width:calc(50% - 6px)}.solar-detail-container .stat-card:nth-child(2):after{display:none}.solar-detail-container .stat-card:nth-child(2){border-bottom:1px solid #e6e6e6}.solar-detail-container .stat-card:nth-child(4){border-bottom:none}}@media (max-width: 768px){.solar-detail-container .summary-stats-grid{grid-template-columns:1fr;gap:16px}.solar-detail-container .stat-card{padding:18px 20px;min-height:100px}}.solar-detail-container .filter-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:flex-start}.solar-detail-container .filter-left{display:flex;flex-wrap:wrap;gap:30px;align-items:center;flex:1}.solar-detail-container .filter-right{display:flex;align-items:center;margin-left:20px}.solar-detail-container .filter-group{display:flex;align-items:center;gap:10px}.solar-detail-container .filter-group label{font-size:26px;font-weight:600;color:#333}.solar-detail-container .filter-select{padding:10px 15px;font-size:28px;border:2px solid #333;border-radius:4px;background:#fff;color:#333;cursor:pointer;min-width:150px}.solar-detail-container .filter-select option{color:#333;background:#fff}.solar-detail-container .filter-select:focus{outline:none;border-color:#3498db}.solar-detail-container .filter-date{padding:10px 15px;font-size:28px;border:2px solid #333;border-radius:4px;background:#fff;color:#333;cursor:pointer;min-width:180px;position:relative}.solar-detail-container .filter-date::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.solar-detail-container .filter-date::-webkit-datetime-edit{padding:0}.solar-detail-container .filter-date::-webkit-datetime-edit-fields-wrapper{padding:0}.solar-detail-container .filter-date::-webkit-datetime-edit-text{color:#333;padding:0 1px}.solar-detail-container .filter-date::-webkit-datetime-edit-month-field,.solar-detail-container .filter-date::-webkit-datetime-edit-day-field,.solar-detail-container .filter-date::-webkit-datetime-edit-year-field{color:#333}.solar-detail-container .filter-date:focus{outline:none;border-color:#3498db}.solar-panels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:25px;margin-bottom:30px}.solar-panel-card{background:#fff;border:3px solid #27ae60;border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000001a;transition:transform .3s ease,box-shadow .3s ease;min-height:200px}.solar-panel-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.panel-header-capacity{font-size:22px;font-weight:600;color:#777;margin-left:8px}.panel-status{padding:8px 16px;border-radius:6px;font-size:28px;font-weight:600}.panel-status.online{background:#e8f5e8;color:#27ae60;border:1px solid #27ae60}.panel-status.offline{background:#f5e8e8;color:#e74c3c;border:1px solid #e74c3c}.panel-metrics{display:flex;flex-direction:column;gap:12px}.metric-label{font-size:28px;color:#666;font-weight:500;flex-shrink:0;min-width:60px}.metric-value{font-size:26px;font-weight:700;white-space:nowrap;text-align:right;flex:1}.metric-value.generation{color:#f39c12}.metric-value.consumption{color:#3498db}.metric-value.efficiency{color:#27ae60}.metric-value.co2-reduction{color:#ff9800;font-weight:700}.metric-value.temperature{color:#e74c3c}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:25px;margin-top:30px}.solar-chart-section{background:#fff;border:2px solid #333;border-radius:8px;padding:25px;min-height:600px}.solar-chart-container{height:550px;display:flex;flex-direction:column}.solar-chart-container h3{margin:0 0 20px;font-size:26px;font-weight:700;color:#333;text-align:center;flex-shrink:0}.solar-chart-placeholder{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;padding:10px;height:480px;position:relative;overflow:hidden;flex:1}.chart-area{position:relative;height:400px;background:#fff;border:1px solid #ddd;border-radius:6px;padding:20px}.y-axis-left,.y-axis-right{position:absolute;top:20px;height:360px;display:flex;flex-direction:column;align-items:center}.y-axis-left{left:10px}.y-axis-right{right:10px}.y-label{font-size:28px;font-weight:600;color:#333;margin-bottom:10px;writing-mode:vertical-rl;text-orientation:mixed}.y-scale{display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:10px 0}.scale-item{font-size:26px;color:#666;text-align:center}.chart-content{position:absolute;inset:20px 60px 40px;height:340px}.chart-bars{display:flex;align-items:flex-end;justify-content:space-between;height:100%;gap:4px}.chart-bar-group{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;flex:1;height:100%;position:relative}.chart-bar{width:100%;border-radius:4px 4px 0 0;transition:opacity .3s ease}.chart-bar.generation{background:linear-gradient(to top,#f39c12,#e67e22);opacity:.8}.chart-bar-group:hover .chart-bar{opacity:1}.chart-line{position:absolute;inset:0;pointer-events:none}.line-point{position:absolute;transform:translate(-50%);z-index:10;pointer-events:auto}.point-dot{width:8px;height:8px;background:#27ae60;border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003}.point-value{position:absolute;top:-25px;left:50%;transform:translate(-50%);font-size:26px;color:#27ae60;font-weight:600;background:#fff;padding:2px 4px;border-radius:3px;box-shadow:0 1px 3px #0000001a;white-space:nowrap}.line-point:hover .point-dot{width:12px;height:12px;background:#2ecc71}.line-point:hover .point-value{font-size:28px;color:#2ecc71}.x-axis{position:absolute;bottom:0;left:60px;right:60px;height:30px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid #ddd;padding-top:5px;background-image:linear-gradient(to right,#e8e8e8 1px,transparent 1px);background-size:4.17% 100%}.x-label{font-size:26px;color:#666;text-align:center;flex:1}.chart-tooltip{pointer-events:none}.tooltip-content{background:#fffffff2;color:#000;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #0000004d;font-size:26px;min-width:150px}.tooltip-time{font-weight:700;font-size:28px;margin-bottom:8px;color:#000;text-align:left}.tooltip-data{display:flex;flex-direction:column;gap:6px}.tooltip-item{display:flex;justify-content:space-between;align-items:center}.tooltip-label{font-weight:500;color:#000}.tooltip-value{font-weight:700;font-size:28px;color:#000}.tooltip-value.generation,.tooltip-value.efficiency{color:#000}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:28px;font-weight:600;color:#333}@media (max-width: 1200px){.solar-panels-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.charts-grid{grid-template-columns:1fr}.solar-detail-container .filter-section{flex-direction:column;gap:15px}}@media (max-width: 900px){.charts-grid{grid-template-columns:1fr}.solar-chart-section{min-height:500px}.solar-chart-container{height:450px}.solar-chart-placeholder{height:400px;padding:8px}}@media (max-width: 768px){.solar-detail-content{padding:20px 20px 10px}.solar-panels-grid,.charts-grid{grid-template-columns:1fr}.solar-panel-card{padding:20px}.panel-header h3{font-size:28px}.metric-label{font-size:26px}.metric-value{font-size:28px}.solar-chart-section{min-height:450px}.solar-chart-container{height:400px}.solar-chart-placeholder{height:350px;padding:5px}.chart-area{height:200px}.y-axis-left,.y-axis-right{height:160px}.chart-content{height:140px}.chart-content,.x-axis{left:50px;right:50px}}.tooltip{background:#fffffff2;color:#666;padding:12px 16px;border-radius:6px;font-size:28px;border:2px solid #888;pointer-events:none;z-index:1000;box-shadow:0 2px 8px #0003}.tooltip-time{font-weight:700;margin:0 0 6px;text-align:left;color:#666;font-size:26px;border-bottom:1px solid #ddd;padding-bottom:6px}.tooltip-generation,.tooltip-efficiency,.tooltip-co2{margin:6px 0;color:#666;font-size:26px}.tooltip-co2{color:#666}.panel-checkboxes{display:flex;flex-wrap:wrap;gap:15px;margin-top:5px}.checkbox-label{display:flex;align-items:center;gap:5px;font-size:26px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.csv-download-btn{background:#4caf50;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:26px;font-weight:700;transition:background-color .3s}.csv-download-btn:hover{background:#45a049}.csv-download-btn:active{background:#3d8b40}.boiler-detail-container{min-height:100vh;width:100vw;background:#f8f9fa;display:flex;flex-direction:column;overflow:visible;padding-bottom:0;width:100%;max-width:100%}.boiler-detail-content{flex:1;padding:30px 30px 10px;width:100%;max-width:100%;box-sizing:border-box}.boiler-detail-container .filter-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:flex-start}.boiler-detail-container .filter-left{display:flex;flex-wrap:wrap;gap:30px;align-items:center;flex:1}.boiler-detail-container .filter-right{display:flex;align-items:center;margin-left:20px}.boiler-detail-container .filter-group{display:flex;align-items:center;gap:10px}.boiler-detail-container .filter-group label{font-size:26px;font-weight:600;color:#333;min-width:80px}.boiler-detail-container .filter-date{padding:10px 15px;border:2px solid #333;border-radius:4px;font-size:28px;min-width:180px;position:relative;cursor:pointer;background:#fff;color:#333}.boiler-detail-container .filter-date::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.boiler-detail-container .filter-date:focus{outline:none;border-color:#3498db}.boiler-detail-container .filter-select{padding:10px 15px;border:2px solid #333;border-radius:4px;font-size:28px;background:#fff;color:#333;cursor:pointer;min-width:150px}.boiler-detail-container .filter-select:focus{outline:none;border-color:#3498db}.boiler-detail-container .filter-select option{color:#333;background:#fff}.boiler-detail-container .boiler-checkboxes{display:flex;flex-wrap:wrap;gap:15px;margin-top:5px}.boiler-detail-container .checkbox-label{display:flex;align-items:center;gap:5px;font-size:22px;cursor:pointer;-webkit-user-select:none;user-select:none}.boiler-detail-container .checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.boiler-detail-container .csv-download-btn{background:#4caf50;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:22px;font-weight:700;transition:background-color .3s}.boiler-detail-container .csv-download-btn:hover{background:#45a049}.boiler-detail-container .csv-download-btn:active{background:#3d8b40}.left-column{display:flex;flex-direction:column;align-items:stretch;min-height:0;width:100%;min-width:0}.left-column .boiler-summary-stats-grid{flex:1;width:100%;min-width:0;align-self:stretch}.right-column{display:flex;flex-direction:column;align-items:stretch;min-height:0}.boiler-detail-container .boiler-summary-stats-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);grid-template-rows:1fr;justify-items:center;width:100%!important;min-width:0!important;max-width:100%!important;flex:1;min-height:0;margin:0;background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #e6e6e6;border-radius:12px;box-shadow:0 6px 14px #0000000f;overflow:hidden;box-sizing:border-box}.boiler-detail-container .boiler-stat-card{padding:20px 24px;box-sizing:border-box;display:flex;flex-direction:column;position:relative;background:transparent;border:none;border-radius:0;box-shadow:none;justify-content:center;align-items:center;text-align:center;width:100%;height:100%;min-width:0;max-width:none!important;flex:1 1 0!important}.boiler-detail-container .boiler-summary-stats-grid .boiler-stat-card:not(:last-child){border-right:3px solid #d0d0d0!important}.boiler-detail-container .boiler-summary-stats-grid .boiler-stat-card.single-column:not(:last-child){border-right:3px solid #d0d0d0!important}.boiler-detail-container .boiler-summary-stats-grid .boiler-stat-card:after,.boiler-detail-container .boiler-summary-stats-grid .boiler-stat-card:before{display:none!important;content:none!important}.boiler-detail-container .boiler-summary-stats-grid:hover{box-shadow:0 10px 18px #00000014}.boiler-detail-container .boiler-stat-card:hover{background:#00000005}.boiler-detail-container .boiler-stat-card.single-column{display:flex;flex-direction:column;gap:8px;justify-content:center;align-items:center;text-align:center}.boiler-detail-container .stat-title{font-size:24px;font-weight:600;color:#666;margin-bottom:12px;text-align:center;width:100%}.boiler-detail-container .stat-values{display:flex;align-items:center;justify-content:center;width:100%}.boiler-detail-container .stat-item{display:flex;align-items:center;justify-content:center;gap:8px;width:100%}.boiler-detail-container .stat-value{font-size:28px;font-weight:800;color:#222;letter-spacing:-.2px;line-height:1.2}.boiler-card{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:100%}.boiler-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #eee}.boiler-header h3{margin:0;font-size:24px;font-weight:700;color:#333}.boiler-status{padding:6px 12px;border-radius:20px;font-size:22px;font-weight:600}.boiler-status.online{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.boiler-status.offline{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.boiler-metrics{display:flex;flex-direction:column;gap:10px}.boiler-detail-container .metric-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0;gap:10px}.boiler-detail-container .metric-label{font-size:24px;font-weight:600;color:#666;flex-shrink:0;min-width:60px}.boiler-detail-container .metric-value{font-size:24px;font-weight:700;color:#333;text-align:right;flex:1;white-space:nowrap}.boiler-chart-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;width:100%}.boiler-chart-container{display:flex;flex-direction:column}.boiler-chart-container h3{margin:0 0 20px;font-size:24px;font-weight:700;color:#333;text-align:center;flex-shrink:0}.boiler-chart-placeholder{background:#f8f9fa;border:1px solid #ddd;border-radius:4px;padding:10px;width:100%;height:500px}.boiler-detail-container .tooltip{background-color:#fff!important;border:2px solid #888!important;border-radius:6px!important;padding:12px 16px!important;box-shadow:0 4px 8px #0003!important}.boiler-detail-container .tooltip-time{margin:0 0 8px;font-weight:700;font-size:22px;color:#666;border-bottom:1px solid #ddd;padding-bottom:6px}.boiler-detail-container .tooltip-lng,.boiler-detail-container .tooltip-efficiency{margin:6px 0;color:#666;font-size:22px}.boiler-detail-container .loading{text-align:center;padding:50px;font-size:22px;color:#666}@media (max-width: 768px){.boiler-detail-content{padding:20px 20px 10px}.boiler-detail-container .filter-section{flex-direction:column;gap:20px}.boiler-detail-container .filter-left{flex-direction:column;align-items:stretch;gap:15px}.boiler-detail-container .filter-right{margin-left:0;align-self:stretch}.boiler-detail-container .boiler-checkboxes{flex-direction:column;gap:10px}.two-column-layout{grid-template-columns:1fr;gap:20px}.boiler-chart-section{min-height:450px}.boiler-chart-container{height:auto}.boiler-chart-placeholder{height:400px;padding:5px}}.motor-detail-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.motor-detail-content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.motor-detail-content.sidebar-open{margin-left:250px}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:26px;color:#666}.csv-download-btn{background:#27ae60;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:26px;font-weight:600;transition:background .3s}.summary-stats-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);grid-template-rows:1fr;justify-items:center;width:100%!important;min-width:0!important;max-width:100%!important;margin:16px 0 24px;background:linear-gradient(180deg,#fff,#fafafa);border:1px solid #e6e6e6;border-radius:12px;box-shadow:0 6px 14px #0000000f;overflow:hidden;box-sizing:border-box}.summary-stats-grid .stat-card{padding:24px 28px;min-height:140px;box-sizing:border-box;display:flex;flex-direction:column;position:relative;background:transparent;border:none;border-radius:0;box-shadow:none;justify-content:center;align-items:center;text-align:center;width:100%;height:100%;min-width:0;max-width:none!important;flex:1 1 0!important}.summary-stats-grid .stat-card:not(:last-child){border-right:3px solid #d0d0d0!important}.summary-stats-grid .stat-card:after,.summary-stats-grid .stat-card:before{display:none!important;content:none!important}.stat-title{font-size:26px;font-weight:600;color:#666;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.stat-values{display:flex;flex-direction:column;gap:8px}.stat-item{display:flex;align-items:baseline;gap:8px}.stat-value{font-size:28px;font-weight:700;color:#333;line-height:1.2}.panel-checkboxes{display:flex;flex-wrap:wrap;gap:12px;margin-top:5px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:26px;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#3498db}.motor-panels-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:30px}@media (max-width: 1000px){.motor-panels-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.motor-panels-grid{grid-template-columns:1fr}}.motor-panel-card{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;min-width:0}.motor-panel-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #eee}.panel-header h3{margin:0;font-size:26px;font-weight:700;color:#333}.panel-status{padding:6px 12px;border-radius:20px;font-size:20px;font-weight:600}.panel-status.online{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.panel-status.offline{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.panel-metrics{display:flex;flex-direction:column;gap:10px}.metric-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f0f0f0;gap:10px}.metric-row:last-child{border-bottom:none}.metric-row .metric-label{font-size:26px;font-weight:600;color:#666;flex-shrink:0;min-width:80px}.metric-row .metric-value{font-size:20px;font-weight:700;color:#333;text-align:right;flex:1;white-space:nowrap}.metric-row .metric-value.carbon-value{color:#e74c3c}.motor-chart-section{background:#fff;border:2px solid #333;border-radius:8px;padding:25px;box-shadow:0 2px 4px #0000001a;margin-top:30px}.motor-chart-container{height:500px;display:flex;flex-direction:column}.motor-chart-container h3{margin:0 0 15px;font-size:26px;font-weight:700;color:#333;text-align:center;flex-shrink:0}.motor-chart-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:15px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #ddd}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:24px;height:3px;border-radius:2px}.legend-label{font-size:26px;font-weight:500;color:#333}.motor-chart-placeholder{background:#f8f9fa;border:1px solid #ddd;border-radius:8px;padding:10px 10px 30px 50px;height:400px;position:relative;overflow:hidden;flex:1}.tooltip{background-color:#fff!important;border:2px solid #888!important;border-radius:6px!important;padding:12px 16px!important;box-shadow:0 4px 8px #0003!important;font-size:20px!important}.tooltip-time{margin:0 0 8px;font-weight:700;font-size:26px;color:#666;border-bottom:1px solid #ddd;padding-bottom:6px}.tooltip p{margin:6px 0;color:#666;font-size:26px}@media (max-width: 768px){.motor-detail-content{padding:20px 20px 10px}.filter-section{flex-direction:column;gap:15px;align-items:stretch}.filter-left,.equipment-row{flex-direction:column;gap:15px}.equipment-card{flex:none;width:100%}.equipment-header h4{font-size:20px}.metric-label{font-size:26px}.metric-value{font-size:20px}}@media (max-width: 480px){.motor-detail-content{padding:15px 15px 10px}.filter-section{padding:15px}.equipment-chart{min-height:120px}}.transformer-detail-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.transformer-detail-content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.transformer-detail-content.sidebar-open{margin-left:250px}.transformer-detail-container .loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:22px;color:#666}.transformer-status-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.transformer-status-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.transformer-detail-container .filter-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border:2px solid #333;border-radius:8px;box-shadow:0 2px 4px #0000001a}.transformer-detail-container .filter-left{display:flex;flex-wrap:wrap;gap:30px;align-items:center;flex:1}.transformer-detail-container .filter-group{display:flex;align-items:center;gap:10px}.transformer-detail-container .filter-group label{font-weight:600;color:#333;font-size:26px}.transformer-detail-container .filter-group input,.transformer-detail-container .filter-group select{padding:10px 15px;border:2px solid #333;border-radius:4px;font-size:28px;background:#fff;color:#333;cursor:pointer}.transformer-detail-container .filter-group input:focus,.transformer-detail-container .filter-group select:focus{outline:none;border-color:#3498db}.transformer-detail-container .filter-group input[type=date]{position:relative;cursor:pointer}.transformer-detail-container .filter-group input[type=date]::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.transformer-detail-container .csv-download-btn{background:#27ae60;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:22px;font-weight:600;transition:background .3s}.transformer-detail-container .csv-download-btn:hover{background:#229954}.transformer-detail-container .efficiency-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;height:100%;display:flex;flex-direction:column}.transformer-detail-container .efficiency-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.transformer-detail-container .efficiency-table{overflow-x:auto;overflow-y:auto;background:#fff;border:1px solid #ddd;border-radius:4px;flex:1;display:flex;flex-direction:column;min-height:0}.transformer-detail-container .table-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;background:#f8f9fa;border-bottom:2px solid #333;min-width:600px;flex-shrink:0}.transformer-detail-container .table-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.transformer-detail-container .header-cell{padding:15px 10px;font-weight:700;color:#333;font-size:22px;text-align:center;border-right:1px solid #ddd}.transformer-detail-container .header-cell:last-child{border-right:none}.transformer-detail-container .table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;border-bottom:1px solid #eee;min-width:600px;background:#fff;flex:1}.transformer-detail-container .table-row:last-child{border-bottom:none}.transformer-detail-container .table-cell{padding:12px 10px;font-size:22px;text-align:center;border-right:1px solid #eee;display:flex;align-items:center;justify-content:center;color:#333}.transformer-detail-container .table-cell:last-child{border-right:none}.transformer-detail-container .table-row:nth-child(2n){background:#f8f9fa}.transformer-detail-container .transformer-chart-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex:1;display:flex;flex-direction:column;min-height:600px}.transformer-detail-container .transformer-chart-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.transformer-detail-container .transformer-chart-container{width:100%;height:480px;background:#fafafa;border:1px solid #ddd;border-radius:4px;padding:10px}@media (max-width: 768px){.transformer-detail-content{padding:20px 20px 10px}.transformer-detail-container .filter-section{flex-direction:column;gap:15px;align-items:stretch}.transformer-detail-container .filter-left{flex-direction:column;gap:15px}.two-column-layout{grid-template-columns:1fr;gap:20px}.status-grid{grid-template-columns:1fr}.transformer-detail-container .table-header,.transformer-detail-container .table-row{grid-template-columns:1fr;gap:10px;min-width:auto}.transformer-detail-container .header-cell,.transformer-detail-container .table-cell{border-right:none;border-bottom:1px solid #eee;text-align:left}.transformer-detail-container .transformer-chart-section{min-height:450px}.transformer-detail-container .transformer-chart-container{height:350px}}@media (max-width: 480px){.transformer-detail-content{padding:15px 15px 10px}.transformer-detail-container .filter-section,.status-grid{padding:15px}.status-item{flex-direction:column;align-items:flex-start;gap:5px}.status-item .label{font-size:22px}.status-item .value{font-size:24px}.transformer-detail-container .transformer-chart-section,.transformer-detail-container .efficiency-section{padding:15px}}.dust-collector-detail-container{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.dust-collector-detail-content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.dust-collector-detail-content.sidebar-open{margin-left:250px}.collector-checkboxes{display:flex;flex-direction:column;gap:5px;max-height:120px;overflow-y:auto;border:1px solid #ddd;border-radius:4px;padding:8px;background:#f9f9f9}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:24px;font-weight:500;color:#333;cursor:pointer;padding:2px 0}.checkbox-label input[type=checkbox]{margin:0;cursor:pointer}.status-item .label{font-weight:600;color:#333;font-size:22px}.status-item .value{font-weight:700;color:#3498db;font-size:24px}.monthly-table-header{display:grid;grid-template-columns:.9fr 1fr 1fr 1.3fr;background:#f8f9fa;border-bottom:2px solid #333;min-width:640px;flex-shrink:0}.monthly-table-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.monthly-header-cell{padding:15px 10px;font-weight:700;color:#333;font-size:22px;text-align:center;border-right:1px solid #ddd}.monthly-header-cell:last-child{border-right:none}.monthly-table-row{display:grid;grid-template-columns:.9fr 1fr 1fr 1.3fr;border-bottom:1px solid #eee;min-width:640px;background:#fff;flex:1}.monthly-table-row:last-child{border-bottom:none}.monthly-table-cell{padding:12px 10px;font-size:22px;text-align:center;border-right:1px solid #eee;display:flex;align-items:center;justify-content:center;color:#333}.monthly-table-cell:last-child{border-right:none}.monthly-table-row:nth-child(2n){background:#f8f9fa}@media (max-width: 768px){.dust-collector-detail-content{padding:20px 20px 10px}.filter-section{flex-direction:column;gap:15px;align-items:stretch}.filter-left{flex-direction:column;gap:15px}.two-column-layout{grid-template-columns:1fr;gap:20px}.status-grid{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1fr;gap:10px;min-width:auto}.header-cell,.table-cell{border-right:none;border-bottom:1px solid #eee;text-align:left}.chart-container{height:300px;padding:10px}}@media (max-width: 480px){.dust-collector-detail-content{padding:15px 15px 10px}.filter-section,.status-grid{padding:15px}.status-item{flex-direction:column;align-items:flex-start;gap:5px}.status-item .label{font-size:22px}.status-item .value{font-size:24px}.chart-section,.monthly-analysis-section{padding:15px}}.vacuum-pump-detail{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.vacuum-pump-detail-content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.vacuum-pump-detail-content.sidebar-open{margin-left:250px}.loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:22px;color:#666}.filter-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border:2px solid #333;border-radius:8px;box-shadow:0 2px 4px #0000001a}.two-column-layout{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px;align-items:stretch}.left-column{display:flex;flex-direction:column;gap:20px}.right-column{display:flex;flex-direction:column}.filter-left{display:flex;flex-wrap:wrap;gap:30px;align-items:center;flex:1}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-weight:600;color:#333;font-size:26px}.filter-group input,.filter-group select{padding:10px 15px;border:2px solid #333;border-radius:4px;font-size:28px;background:#fff;color:#333;cursor:pointer}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#3498db}.filter-group input[type=date]{position:relative;cursor:pointer}.filter-group input[type=date]::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.csv-download-btn{background:#27ae60;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:22px;font-weight:600;transition:background .3s}.csv-download-btn:hover{background:#229954}.collector-status-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.collector-status-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.status-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;transition:background-color .2s,transform .2s}.status-item:hover{background:#e9ecef;transform:translateY(-1px)}.status-item .label{font-weight:600;color:#333;font-size:22px;white-space:nowrap}.status-item .value{font-weight:700;color:#3498db;font-size:24px;white-space:nowrap}.dust-chart-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex:1;display:flex;flex-direction:column;min-height:600px}.dust-chart-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.dust-chart-container{width:100%;height:480px;background:#fafafa;border:1px solid #ddd;border-radius:4px;padding:10px;display:flex;align-items:center;justify-content:center}.monthly-analysis-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;height:100%;display:flex;flex-direction:column}.monthly-analysis-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db}.monthly-table{overflow-x:auto;overflow-y:auto;background:#fff;border:1px solid #ddd;border-radius:4px;flex:1;display:flex;flex-direction:column;min-height:0}.table-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;background:#f8f9fa;border-bottom:2px solid #333;min-width:700px;flex-shrink:0}.table-body{flex:1;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.header-cell{padding:15px 10px;font-weight:700;color:#333;font-size:22px;text-align:center;border-right:1px solid #ddd}.header-cell:last-child{border-right:none}.table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;border-bottom:1px solid #eee;min-width:700px;background:#fff;flex:1}.table-row:last-child{border-bottom:none}.table-cell{padding:12px 10px;font-size:22px;text-align:center;border-right:1px solid #eee;display:flex;align-items:center;justify-content:center;color:#333}.table-cell:last-child{border-right:none}.table-row:nth-child(2n){background:#f8f9fa}@media (max-width: 768px){.vacuum-pump-detail-content{padding:20px 20px 10px}.filter-section{flex-direction:column;gap:15px;align-items:stretch}.filter-left{flex-direction:column;gap:15px}.two-column-layout{grid-template-columns:1fr;gap:20px}.status-grid{grid-template-columns:1fr}.table-header,.table-row{grid-template-columns:1fr;gap:10px;min-width:auto}.header-cell,.table-cell{border-right:none;border-bottom:1px solid #eee;text-align:left}.dust-chart-container{height:300px;padding:10px}}@media (max-width: 480px){.vacuum-pump-detail-content{padding:15px 15px 10px}.filter-section,.status-grid{padding:15px}.status-item{flex-direction:column;align-items:flex-start;gap:5px}.status-item .label{font-size:22px}.status-item .value{font-size:24px}.dust-chart-section,.monthly-analysis-section{padding:15px}}.cooling-water-detail{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.cooling-water-detail .content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.cooling-water-detail .content.sidebar-open{margin-left:250px}.cooling-water-detail .loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:22px;color:#666}.cooling-water-detail .two-column-layout{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px;align-items:stretch}.cooling-water-detail .left-column,.cooling-water-detail .right-column{display:flex;flex-direction:column;gap:20px}.cooling-water-detail .column-filter{background:#fff;padding:15px;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:15px;flex-wrap:wrap;flex-shrink:0}.cooling-water-detail .filter-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;margin-bottom:30px;display:flex;justify-content:space-between;align-items:flex-start}.cooling-water-detail .filter-group{display:flex;align-items:center;gap:10px}.cooling-water-detail .filter-group label{font-weight:600;color:#333;font-size:26px;white-space:nowrap}.cooling-water-detail .filter-group select,.cooling-water-detail .filter-group input{padding:10px 15px;border:2px solid #333;border-radius:4px;font-size:28px;background:#fff;color:#333;cursor:pointer;transition:border-color .3s ease}.cooling-water-detail .filter-group select:focus,.cooling-water-detail .filter-group input:focus{outline:none;border-color:#3498db}.cooling-water-detail .filter-select{min-width:150px}.cooling-water-detail .filter-select option{color:#333;background:#fff}.cooling-water-detail .filter-group input[type=date]{position:relative;cursor:pointer}.cooling-water-detail .filter-group input[type=date]::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.cooling-water-detail .download-btn{background:#3498db;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-size:22px;font-weight:600;cursor:pointer;transition:background-color .3s ease;margin-left:auto}.cooling-water-detail .download-btn:hover{background:#2980b9}.cooling-water-detail .cooling-water-card{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.cooling-water-detail .cooling-water-card h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db;flex-shrink:0}.cooling-water-detail .card-content{display:flex;flex-direction:column;gap:15px}.cooling-water-detail .status-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.cooling-water-detail .status-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #3498db}.cooling-water-detail .status-item .label{font-weight:600;color:#333;font-size:22px;white-space:nowrap}.cooling-water-detail .status-item .value{font-weight:700;color:#3498db;font-size:24px}.cooling-water-detail .status-item .value.status.running{color:#27ae60}.cooling-water-detail .status-item .value.status.stopped{color:#e74c3c}.cooling-water-detail .status-item .value.status.maintenance{color:#f39c12}.cooling-water-detail .realtime-monitoring-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.cooling-water-detail .realtime-monitoring-section h3{font-size:24px;font-weight:700;color:#333;margin:0;padding-bottom:8px;border-bottom:2px solid #3498db;flex-shrink:0}.cooling-water-detail .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cooling-water-detail .realtime-filter-group{display:flex;align-items:center;gap:10px}.cooling-water-detail .realtime-filter-group label{font-weight:600;color:#333;font-size:22px}.cooling-water-detail .realtime-chart-container{margin-top:15px}.cooling-water-detail .realtime-chart{margin-top:20px;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.cooling-water-detail .realtime-chart h4{font-size:24px;font-weight:600;color:#333;margin-bottom:15px;text-align:center;flex-shrink:0}.cooling-water-detail .performance-analysis-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex-shrink:0}.cooling-water-detail .performance-analysis-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db;flex-shrink:0}.cooling-water-detail .chart-container{width:100%;height:280px;background:#fafafa;border:1px solid #ddd;border-radius:4px;padding:15px}.cooling-water-detail .monthly-analysis-section{background:#fff;border:2px solid #333;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex:1;display:flex;flex-direction:column;min-height:0}.cooling-water-detail .monthly-analysis-section h3{font-size:24px;font-weight:700;color:#333;margin-bottom:20px;padding-bottom:8px;border-bottom:2px solid #3498db;flex-shrink:0}.cooling-water-detail .monthly-table{overflow-x:auto;overflow-y:hidden;background:#fff;border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;flex:1;min-height:0}.cooling-water-detail .table-header{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;background:#f8f9fa;border-bottom:2px solid #333;min-width:700px;flex-shrink:0}.cooling-water-detail .header-cell{padding:4px 10px;font-weight:700;color:#333;font-size:22px;text-align:center;border-right:1px solid #ddd;line-height:1.2;min-height:28px;display:flex;align-items:center;justify-content:center}.cooling-water-detail .header-cell:last-child{border-right:none}.cooling-water-detail .table-body{display:flex;flex-direction:column}.cooling-water-detail .table-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 1fr;border-bottom:1px solid #eee;min-width:700px;background:#fff}.cooling-water-detail .table-row:last-child{border-bottom:none}.cooling-water-detail .table-cell{padding:4px 10px;font-size:22px;text-align:center;border-right:1px solid #eee;display:flex;align-items:center;justify-content:center;color:#333;line-height:1.2;min-height:28px}.cooling-water-detail .table-cell:last-child{border-right:none}.cooling-water-detail .table-row:nth-child(2n){background:#f8f9fa}.cooling-water-detail .custom-tooltip{background:#fff;border:2px solid #888;border-radius:6px;padding:12px 16px;box-shadow:0 4px 12px #00000026}.cooling-water-detail .tooltip-label{font-weight:700;color:#666;margin:0 0 8px;font-size:22px;border-bottom:1px solid #ddd;padding-bottom:6px}.cooling-water-detail .tooltip-item{display:flex;align-items:center;gap:8px;margin:6px 0;font-size:22px;color:#666}.cooling-water-detail .tooltip-color{width:12px;height:12px;border-radius:2px;display:inline-block}@media (max-width: 768px){.cooling-water-detail .content{margin-left:0;padding:15px}.cooling-water-detail .content.sidebar-open{margin-left:0}.cooling-water-detail .filter-section{flex-direction:column;align-items:stretch;gap:15px}.cooling-water-detail .filter-group{justify-content:space-between}.cooling-water-detail .download-btn{margin-left:0;width:100%}.cooling-water-detail .card-content{gap:10px}.cooling-water-detail .status-row{grid-template-columns:1fr;gap:10px}.cooling-water-detail .section-header{flex-direction:column;align-items:stretch;gap:15px}.cooling-water-detail .realtime-filter-group{justify-content:space-between}.cooling-water-detail .realtime-chart{padding:15px}.cooling-water-detail .two-column-layout{grid-template-columns:1fr;gap:20px}.cooling-water-detail .column-filter{flex-direction:column;align-items:stretch;gap:10px}.cooling-water-detail .cooling-water-card,.cooling-water-detail .performance-analysis-section,.cooling-water-detail .monthly-analysis-section{padding:20px}.cooling-water-detail .chart-container{height:300px;padding:10px}}@media (max-width: 480px){.cooling-water-detail .cooling-water-card h3,.cooling-water-detail .performance-analysis-section h3,.cooling-water-detail .monthly-analysis-section h3{font-size:22px}.cooling-water-detail .status-item{flex-direction:column;align-items:flex-start;gap:5px}.cooling-water-detail .status-item .label{font-size:22px}.cooling-water-detail .status-item .value{font-size:15px}.cooling-water-detail .table-header,.cooling-water-detail .table-row{min-width:600px}.cooling-water-detail .header-cell,.cooling-water-detail .table-cell{padding:10px 8px;font-size:24px}}.manual-input{display:flex;flex-direction:column;min-height:100vh;background:#f5f5f5}.content{flex:1;padding:30px 30px 10px;margin-left:0;transition:margin-left .3s ease;overflow-y:auto}.content.sidebar-open{margin-left:250px}.manual-input-container{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;overflow:hidden}.manual-input-container h2{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;margin:0;padding:25px 30px;font-size:28px;font-weight:700;text-align:center}.tab-navigation{display:flex;background:#f8f9fa;border-bottom:1px solid #e9ecef}.tab-button{flex:1;padding:15px 20px;border:none;background:transparent;color:#666;font-size:28px;font-weight:600;cursor:pointer;transition:all .3s ease;border-bottom:3px solid transparent}.tab-button:hover{background:#e9ecef;color:#333}.tab-button.active{background:#fff;color:#3498db;border-bottom-color:#3498db}.input-form{padding:30px}.input-form h3{color:#333;margin-bottom:25px;font-size:28px;font-weight:700;text-align:center;padding-bottom:10px;border-bottom:2px solid #3498db}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:22px}.form-group input{width:100%;padding:12px 15px;border:2px solid #e9ecef;border-radius:8px;font-size:28px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group input[type=date]{position:relative;cursor:pointer}.form-group input[type=date]::-webkit-calendar-picker-indicator{background:transparent;color:transparent;cursor:pointer;height:auto;inset:0;position:absolute;width:auto}.form-group .unit{display:inline-block;margin-left:10px;color:#666;font-size:22px;font-weight:500}.efficiency-display{background:#e8f5e8;border:1px solid #4caf50;border-radius:8px;padding:15px;margin:20px 0;text-align:center}.efficiency-display h4{margin:0;color:#2e7d32;font-size:22px;font-weight:700}.info-box{background:#f0f8ff;border:1px solid #3498db;border-radius:8px;padding:20px;margin:20px 0}.info-box h4{margin:0 0 15px;color:#2980b9;font-size:28px;font-weight:600}.info-box ul{margin:0;padding-left:20px;color:#333}.info-box li{margin-bottom:8px;line-height:1.5}.submit-button{width:100%;padding:15px;background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;border-radius:8px;font-size:28px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:20px}.submit-button:hover{background:linear-gradient(135deg,#229954,#27ae60);transform:translateY(-2px);box-shadow:0 4px 12px #27ae604d}.submit-button:active{transform:translateY(0)}@media (max-width: 768px){.content{margin-left:0;padding:15px}.content.sidebar-open{margin-left:0}.manual-input-container{margin:0;border-radius:8px}.manual-input-container h2{padding:20px 15px;font-size:28px}.tab-navigation{flex-direction:column}.tab-button{padding:12px 15px;font-size:22px;border-bottom:1px solid #e9ecef;border-right:none}.tab-button.active{border-bottom-color:#e9ecef;border-left:3px solid #3498db}.input-form{padding:20px 15px}.input-form h3{font-size:22px}.form-group input{padding:10px 12px;font-size:22px}.efficiency-display{padding:12px}.efficiency-display h4{font-size:28px}.info-box{padding:15px}.submit-button{padding:12px;font-size:22px}}*{margin:0;padding:0;box-sizing:border-box}html,body{min-height:100%;overflow-x:hidden;overflow-y:auto}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa}.App{height:100vh;width:100vw;display:flex;flex-direction:column}button,input{font-family:inherit}@media (min-width: 1920px){.dashboard-container,.detail-container{min-height:100vh;overflow:visible}.dashboard-content,.detail-content{min-height:calc(100vh - 70px);overflow:visible}}@media (min-width: 1440px) and (max-width: 1919px){.dashboard-content,.detail-content{padding:20px;min-height:calc(100vh - 70px);overflow:visible}.dashboard-header,.detail-header{padding:15px 25px;height:70px}}@media (min-width: 1024px) and (max-width: 1439px){.dashboard-content,.detail-content{padding:15px;min-height:calc(100vh - 60px);overflow:visible}.dashboard-header,.detail-header{padding:12px 20px;height:60px}}@media (max-width: 768px){.dashboard-content,.detail-content{padding:15px}.dashboard-header,.detail-header{padding:15px 20px}}
