body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background-color:#f5f5f5;min-height:100vh;text-align:center}.App-header{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem}.App-header h1{font-size:2rem;font-weight:300;margin:0 0 1rem}.App-header nav{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.App-header button{background-color:#34495e;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:.5rem 1rem;transition:background-color .2s}.App-header button:hover{background-color:#4a6b8a}.App-header button.active{background-color:#3498db}main{margin:0 auto;max-width:1200px;padding:2rem}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;padding:2rem;width:90%}.modal-content h2{color:#2c3e50;margin-top:0}.form{gap:1rem}.form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-group label{color:#2c3e50;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.checkbox-group{align-items:center;flex-direction:row;gap:.5rem}.checkbox-group input[type=checkbox]{margin:0;width:auto}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-primary{background-color:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .2s}.btn-secondary:hover{background-color:#7f8c8d}.btn-danger{background-color:#e74c3c;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .2s}.btn-danger:hover{background-color:#c0392b}.btn-mark-read{background-color:#27ae60;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:.25rem .5rem;transition:background-color .2s}.btn-mark-read:hover{background-color:#229954}.facility-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:1rem}.facility-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem;transition:transform .2s,box-shadow .2s}.facility-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.facility-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.facility-header h3{color:#2c3e50;font-size:1.25rem;margin:0}.facility-info{margin-bottom:1.5rem}.facility-description{color:#666;line-height:1.5;margin-bottom:1rem}.facility-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.facility-meta{color:#999;display:flex;font-size:.9rem;justify-content:space-between}.facility-actions{display:flex;gap:.5rem}.status-badge{font-weight:600}.status-badge.active{background-color:#27ae60;color:#fff}.status-badge.inactive{background-color:#95a5a6;color:#fff}.status-badge.maintenance{background-color:#f39c12;color:#fff}.facility-detail{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.facility-detail-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.facility-detail-header h2{color:#2c3e50;margin:0}.facility-detail-content{display:flex;flex-direction:column;gap:2rem}.alerts-section,.consumption-section,.energy-summary-section,.facility-info-section,.target-section{border:1px solid #eee;border-radius:8px;padding:1.5rem}.alerts-section h3,.consumption-section h3,.energy-summary-section h3,.facility-info-section h3,.target-section h3{border-bottom:2px solid #3498db;color:#2c3e50;margin-top:0;padding-bottom:.5rem}.edit-form{display:flex;flex-direction:column;gap:1rem}.facility-info-display p{color:#666;margin:.5rem 0}.energy-summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:1rem}.energy-summary-item{background:#f8f9fa;border-radius:6px;padding:1rem;text-align:center}.energy-label{color:#2c3e50;display:block;font-weight:600;margin-bottom:.5rem}.energy-value{color:#3498db;display:block;font-size:1.5rem;font-weight:700}.target-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:1rem}.target-item{background:#f8f9fa;border-radius:6px;padding:1rem;text-align:center}.target-label{color:#2c3e50;font-weight:600}.target-label,.target-value{display:block;margin-bottom:.5rem}.target-value{color:#3498db;font-size:1.25rem}.target-achievement{color:#27ae60;display:block;font-size:1.5rem;font-weight:700}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.consumption-list{display:flex;flex-direction:column;gap:1rem}.consumption-item{background:#f8f9fa;border-left:4px solid #3498db;border-radius:6px;padding:1rem}.consumption-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.consumption-date{color:#2c3e50;font-weight:600}.consumption-data{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.5rem}.consumption-data span{background:#fff;border-radius:4px;color:#666;font-size:.9rem;padding:.25rem .5rem}.consumption-notes{color:#666;font-style:italic;margin:0}.anomaly-badge{background-color:#e74c3c;border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.alerts-list{display:flex;flex-direction:column;gap:1rem}.alert-item{background:#f8f9fa;border-left:4px solid #95a5a6;border-radius:6px;padding:1rem}.alert-item.high{border-left-color:#f39c12}.alert-item.critical{border-left-color:#e74c3c}.alert-header{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:.5rem}.alert-severity,.alert-type{background:#95a5a6;border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}.alert-severity.high{background:#f39c12}.alert-severity.critical{background:#e74c3c}.alert-date{color:#666;font-size:.9rem}.alert-message{color:#2c3e50;line-height:1.5;margin:0}.energy-chart{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.chart-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.chart-header h3{color:#2c3e50;margin:0}.chart-controls{display:flex;gap:1rem}.chart-controls label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.facility-selector{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;gap:1rem;margin-bottom:2rem;padding:1rem}.facility-selector label{color:#2c3e50;font-weight:600}.facility-selector select{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.5rem}.empty-chart{color:#666;padding:3rem;text-align:center}.chart-container{margin-top:2rem}.chart-legend{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-bottom:2rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:4px;height:20px;width:20px}.chart-bars{align-items:end;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;min-height:300px}.chart-bar-group{align-items:center;display:flex;flex-direction:column;gap:.5rem}.bar-label{word-wrap:break-word;color:#2c3e50;font-weight:600;max-width:100px;text-align:center}.bars{align-items:end;display:flex;gap:2px}.bar{background:#3498db;border-radius:4px 4px 0 0;min-height:20px;position:relative;transition:height .3s ease;width:30px}.bar.electricity{background:#4caf50}.bar.gas{background:#ff9800}.bar.water{background:#2196f3}.bar.co2{background:#9c27b0}.bar-value{background:#000c;border-radius:4px;color:#fff;font-size:.8rem;left:50%;padding:.25rem .5rem;position:absolute;top:-25px;transform:translateX(-50%);white-space:nowrap}.energy-dashboard{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:2rem}.energy-dashboard h3{border-bottom:2px solid #3498db;color:#2c3e50;margin-bottom:2rem;margin-top:0;padding-bottom:.5rem}.dashboard-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.dashboard-card{background:#f8f9fa;border:1px solid #eee;border-radius:8px;padding:1.5rem}.dashboard-card h4{border-bottom:1px solid #ddd;color:#2c3e50;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.consumption-summary{display:flex;flex-direction:column;gap:1rem}.consumption-item{align-items:center;background:#fff;border-radius:4px;display:flex;justify-content:space-between;padding:.5rem}.consumption-label{color:#2c3e50;font-weight:600}.consumption-value{color:#3498db;font-size:1.1rem;font-weight:700}.achievement-circles{display:flex;gap:1rem;justify-content:space-around}.achievement-circle{align-items:center;display:flex;flex-direction:column;gap:.5rem;height:80px;position:relative;width:80px}.achievement-progress{background:conic-gradient(from 0deg,#3498db 0deg,#3498db 0deg,#eee 0deg);border-radius:50%;height:100%;position:relative;width:100%}.achievement-progress:before{background:#fff;border-radius:50%;content:"";height:60px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:60px}.achievement-label{color:#666;font-size:.8rem;font-weight:600}.achievement-value{color:#2c3e50;font-size:1rem;font-weight:700}.alerts-summary{display:flex;flex-direction:column;gap:1rem}.alert-summary-item{align-items:center;background:#fff;border-radius:4px;display:flex;justify-content:space-between;padding:.5rem}.alert-summary-label{color:#2c3e50;font-weight:600}.alert-summary-value{color:#3498db;font-size:1.1rem;font-weight:700}.alert-summary-value.critical{color:#e74c3c}.ranking-list{display:flex;flex-direction:column;gap:.5rem}.ranking-item{grid-gap:1rem;align-items:center;background:#fff;border-radius:4px;display:grid;gap:1rem;grid-template-columns:auto 1fr auto auto;padding:.75rem}.ranking-rank{background:#3498db;border-radius:4px;color:#fff;font-size:.9rem;font-weight:700;padding:.25rem .5rem}.ranking-name{color:#2c3e50;font-weight:600}.ranking-co2,.ranking-electricity{color:#666;font-size:.9rem}.dashboard-alerts{margin-top:2rem}.dashboard-alerts h4{border-bottom:1px solid #ddd;color:#2c3e50;margin-bottom:1rem;padding-bottom:.5rem}.alert-severity-badge{border-radius:4px;color:#fff;font-size:.8rem;font-weight:600;padding:.25rem .5rem}@media (max-width:768px){.App-header nav{align-items:center;flex-direction:column}.dashboard-grid,.facility-list,.form-row{grid-template-columns:1fr}.achievement-circles{align-items:center;flex-direction:column}.chart-bars,.chart-legend{align-items:center;flex-direction:column;gap:1rem}}.empty-state{color:#666;padding:3rem;text-align:center}.empty-state p{margin:.5rem 0}@media (max-width:768px){.App{-webkit-overflow-scrolling:touch;min-height:100vh;min-height:100dvh;overflow-y:auto}.App-header{padding-left:env(safe-area-inset-left,1rem);padding-right:env(safe-area-inset-right,1rem);padding-top:env(safe-area-inset-top,1rem);position:relative}.App-header h1{font-size:1.5rem;margin-bottom:.5rem}.App-header nav{gap:.25rem}.App-header button{font-size:.9rem;min-width:80px;padding:.4rem .8rem}main{-webkit-overflow-scrolling:touch;min-height:calc(100vh - 120px);min-height:calc(100dvh - 120px);overflow-y:auto;padding:1rem 1rem env(safe-area-inset-bottom,1rem)}.card,.facility-card,button{min-height:44px;touch-action:manipulation}main::-webkit-scrollbar{display:none}main{-ms-overflow-style:none;scrollbar-width:none}.form-group input,.form-group select,.form-group textarea{font-size:16px}.modal{padding:env(safe-area-inset-top,1rem) 1rem env(safe-area-inset-bottom,1rem)}.modal-content{max-height:calc(100vh - 2rem);max-height:calc(100dvh - 2rem);overflow-y:auto}}@media (max-width:480px){.App-header h1{font-size:1.2rem}.App-header nav{flex-direction:column;gap:.5rem}.App-header button{padding:.6rem;width:100%}main{min-height:calc(100vh - 140px);min-height:calc(100dvh - 140px);padding:.5rem}.card,.facility-card{padding:1rem}}@media (max-width:768px) and (orientation:landscape){.App-header{padding:.5rem 1rem}.App-header h1{font-size:1.2rem;margin-bottom:.25rem}.App-header nav{gap:.25rem}.App-header button{font-size:.8rem;padding:.3rem .6rem}main{min-height:calc(100vh - 80px);min-height:calc(100dvh - 80px);padding:.5rem}}.production-dashboard{padding:1rem}.production-dashboard h2{color:#2c3e50;margin-bottom:2rem;text-align:center}.equipment-section,.maintenance-section,.production-lines-section{margin-bottom:2rem}.equipment-section h3,.maintenance-section h3,.production-lines-section h3{border-bottom:2px solid #3498db;color:#34495e;margin-bottom:1rem;padding-bottom:.5rem}.production-lines-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:2rem}.production-line-card{background:#fff;border-left:4px solid #3498db;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.line-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.line-header h4{color:#2c3e50;margin:0}.status-badge{border-radius:20px;font-size:.8rem;font-weight:700;padding:.25rem .75rem;text-transform:uppercase}.status-badge.running{background-color:#d4edda;color:#155724}.status-badge.stopped{background-color:#f8d7da;color:#721c24}.status-badge.maintenance{background-color:#fff3cd;color:#856404}.status-badge.setup{background-color:#d1ecf1;color:#0c5460}.line-stats{margin-bottom:1rem}.stat-row{border-bottom:1px solid #ecf0f1;display:flex;justify-content:space-between;margin-bottom:.5rem;padding:.25rem 0}.stat-row:last-child{border-bottom:none}.stat-row .stat-value{color:#2c3e50;font-weight:700}.balance-section{background-color:#f8f9fa;border-radius:6px;margin-top:1rem;padding:1rem}.balance-section h5{color:#2c3e50;margin:0 0 1rem}.balance-score{gap:1rem;margin-bottom:1rem}.balance-score,.score-circle{align-items:center;display:flex}.score-circle{background:linear-gradient(135deg,#3498db,#2ecc71);border-radius:50%;color:#fff;flex-direction:column;font-weight:700;height:80px;justify-content:center;width:80px}.score-value{font-size:1.2rem}.score-label{font-size:.7rem}.score-details{flex:1 1}.score-details div{color:#34495e;margin-bottom:.25rem}.recommendations{margin-top:1rem}.recommendations h6{color:#2c3e50;margin:0 0 .5rem}.recommendations ul{margin:0;padding-left:1.2rem}.recommendations li{color:#34495e;font-size:.9rem;margin-bottom:.25rem}.maintenance-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.maintenance-card{background:#fff;border-left:4px solid #e74c3c;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.maintenance-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.maintenance-header h4{color:#2c3e50;margin:0}.priority-badge{border-radius:20px;font-size:.8rem;font-weight:700;padding:.25rem .75rem;text-transform:uppercase}.priority-badge.critical{background-color:#f8d7da;color:#721c24}.priority-badge.high{background-color:#fff3cd;color:#856404}.priority-badge.medium{background-color:#d1ecf1;color:#0c5460}.priority-badge.low{background-color:#d4edda;color:#155724}.maintenance-details{margin-bottom:1rem}.maintenance-details div{color:#34495e;margin-bottom:.25rem}.maintenance-description{background-color:#f8f9fa;border-radius:4px;color:#2c3e50;font-size:.9rem;padding:.75rem}.equipment-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.equipment-card{background:#fff;border-left:4px solid #9b59b6;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.equipment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.equipment-header h4{color:#2c3e50;margin:0}.equipment-details div{color:#34495e;margin-bottom:.25rem}@media (max-width:768px){.equipment-grid,.maintenance-list,.production-lines-grid{grid-template-columns:1fr}.balance-score{flex-direction:column;text-align:center}.score-circle{height:60px;width:60px}.score-value{font-size:1rem}.score-label{font-size:.6rem}}
/*# sourceMappingURL=main.d495e830.css.map*/