.retraining-dropdown-container{position:relative;display:inline-block}.retraining-button-group{display:flex;align-items:center;gap:.75rem}.retraining-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.last-training-info{display:flex;flex-direction:column;gap:.25rem;padding:.5rem .75rem;background-color:#f0f4f8;border-left:3px solid #17a2b8;border-radius:.25rem;font-size:.75rem;color:#495057;white-space:nowrap;min-width:fit-content}.training-timestamp{font-weight:500;color:#212529;font-size:.8rem}.training-days-ago{font-size:.7rem;color:#6c757d;font-style:italic}.retraining-button:hover:not(:disabled){background-color:#0056b3;transform:translateY(-2px);box-shadow:0 2px 8px #0056b34d}.retraining-button:active:not(:disabled){transform:translateY(0)}.retraining-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.65}.retraining-icon{font-size:1rem}.retraining-label{font-weight:600}.retraining-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background-color:#fff;border:1px solid #dee2e6;border-radius:.375rem;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:280px;overflow:hidden;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.retraining-option{display:flex;align-items:center;gap:1rem;width:100%;padding:1rem;background:none;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease;border-bottom:1px solid #f0f0f0}.retraining-option:last-child{border-bottom:none}.retraining-option:hover{background-color:#f8f9fa}.retraining-option:active{background-color:#e9ecef}.option-icon{font-size:1.5rem;min-width:2rem;text-align:center}.option-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.option-content strong{font-weight:600;color:#212529;font-size:.9rem}.option-content small{color:#6c757d;font-size:.8rem;font-weight:400}.retraining-divider{height:1px;background-color:#e9ecef}.progress-panel{position:fixed;bottom:auto;top:80px;right:2rem;width:320px;background-color:#fff;border:1px solid #dee2e6;border-radius:.5rem;box-shadow:0 4px 16px #00000026;z-index:999;padding:1rem;animation:slideInUp .3s ease}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;gap:.5rem}.progress-header h4{margin:0;font-size:.95rem;font-weight:600;color:#212529;flex:1}.progress-actions{display:flex;gap:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-button{padding:.375rem .75rem;font-size:.75rem;border:none;border-radius:.25rem;cursor:pointer;font-weight:600;transition:all .15s ease;white-space:nowrap}.stop-button{background-color:#dc3545;color:#fff}.stop-button:hover{background-color:#c82333}.stop-button:active{opacity:.8}.close-button{background-color:#6c757d;color:#fff;padding:.375rem .5rem}.close-button:hover{background-color:#5a6268}.close-button:active{opacity:.8}.progress-bar-container{width:100%;height:6px;background-color:#e9ecef;border-radius:3px;overflow:hidden;margin-bottom:1rem}.progress-bar{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease;border-radius:3px}.progress-info{font-size:.85rem}.task-counter{margin:0 0 .25rem;font-weight:600;color:#495057}.task-current{margin:0 0 .75rem;color:#6c757d;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.models-trained{background-color:#f8f9fa;border-radius:.375rem;padding:.5rem;margin-bottom:.5rem}.models-trained strong{display:block;margin-bottom:.25rem;font-size:.8rem;color:#495057}.models-trained ul{margin:0;padding-left:1.5rem;list-style:none}.models-trained li{font-size:.8rem;color:#28a745;margin:.25rem 0}.error-message{background-color:#f8d7da;color:#721c24;padding:.5rem;border-radius:.375rem;margin-top:.5rem;font-size:.8rem}.error-message strong{display:block;margin-bottom:.25rem}.error-notification{position:fixed;bottom:2rem;right:2rem;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:.375rem;padding:1rem;max-width:320px;box-shadow:0 2px 8px #0000001a;z-index:999;animation:slideInUp .3s ease}.error-close{float:right;background:none;border:none;color:#721c24;font-size:1.2rem;cursor:pointer;padding:0;margin-left:.5rem}.error-close:hover{opacity:.7}.sensors-progress{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #e9ecef}.sensors-progress small{display:block;margin-bottom:.35rem;font-size:.75rem;color:#6c757d;font-weight:500}.sensors-bar-container{width:100%;height:5px;background-color:#e9ecef;border-radius:2.5px;overflow:hidden}.sensors-bar{height:100%;background:linear-gradient(90deg,#17a2b8,#138496);transition:width .4s ease;border-radius:2.5px}@media (max-width: 640px){.progress-panel{width:calc(100vw - 2rem);max-width:100%;left:1rem;right:1rem;top:70px!important;bottom:auto}.error-notification{width:calc(100vw - 2rem);max-width:100%;left:1rem;right:1rem;bottom:1rem}.retraining-menu{min-width:250px;right:-50px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f1923;--bg-secondary: #1a2633;--bg-panel: #1e2d3d;--bg-card: #243447;--border-color: #2d4a5e;--text-primary: #e8edf2;--text-secondary: #8899aa;--text-muted: #5a6f80;--accent: #00d4ff;--accent-dim: #0098b8;--success: #00e676;--warning: #ffc107;--danger: #ff5252;--gradient-heat-low: #2196f3;--gradient-heat-mid: #ffeb3b;--gradient-heat-high: #f44336;--panel-width: 420px;--header-height: 56px;--shadow: 0 4px 20px rgba(0, 0, 0, .4);--radius: 8px;--transition: all .3s cubic-bezier(.4, 0, .2, 1);font-family:Segoe UI,system-ui,-apple-system,sans-serif}html,body,#root{height:100%;width:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent-dim)}.app-container{display:flex;flex-direction:column;height:100vh;width:100vw;position:relative}.header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 16px;z-index:1000;flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.header-center{display:flex;align-items:center;gap:12px;flex:1;justify-content:center;max-width:600px}.historical-controls{display:inline-flex;align-items:center;gap:8px}.btn-historical-clear{padding:4px 8px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:999px;font-size:11px;cursor:pointer;transition:var(--transition)}.btn-historical-clear:hover{color:var(--accent);background:#00d4ff1a}.header-right{display:flex;align-items:center;gap:16px}.language-switcher{display:flex;align-items:center;gap:6px}.language-button{width:34px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;opacity:.7;transition:var(--transition)}.language-button svg{display:block;border-radius:3px}.language-button:hover{opacity:1;border-color:var(--accent-dim)}.language-button.active{opacity:1;border-color:var(--accent);box-shadow:0 0 10px #00d4ff4d}.btn-charts{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent);color:var(--bg-primary);border:none;border-radius:var(--radius);font-weight:600;font-size:13px;cursor:pointer;transition:var(--transition)}.btn-charts:hover{background:var(--accent-dim);color:var(--text-primary)}.btn-charts.active{background:var(--accent-dim);color:var(--text-primary);box-shadow:0 0 12px #00d4ff4d}.slider-container{display:flex;flex-direction:column;align-items:center;flex:1;gap:2px;min-width:200px}.slider-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.slider-value{font-size:13px;color:var(--accent);font-weight:600;min-width:80px;text-align:center}.time-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:linear-gradient(to right,var(--gradient-heat-low),var(--accent),var(--gradient-heat-high));border-radius:2px;outline:none}.time-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 0 8px #00d4ff80}.time-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-primary)}.model-selector-group{display:flex;align-items:center;gap:12px}.model-select{padding:6px 12px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius);font-size:13px;cursor:pointer;outline:none}.model-select:focus{border-color:var(--accent)}.metrics-badge{display:flex;gap:8px;font-size:11px}.metric-item{display:flex;flex-direction:column;align-items:center;padding:2px 8px;background:var(--bg-card);border-radius:4px;border:1px solid var(--border-color)}.metric-label{color:var(--text-muted);font-size:9px;text-transform:uppercase;letter-spacing:.5px}.metric-value{color:var(--accent);font-weight:700;font-size:12px}.main-content{flex:1;position:relative;overflow:hidden}.map-container{width:100%;height:100%}.map-container .leaflet-container{width:100%;height:100%;background:var(--bg-primary)}.panel-left,.panel-right{position:absolute;top:0;height:100%;width:var(--panel-width);background:var(--bg-panel);border:1px solid var(--border-color);box-shadow:var(--shadow);z-index:900;overflow-y:auto;transition:transform .4s cubic-bezier(.4,0,.2,1)}.panel-left{left:0;border-left:none;border-top:none;border-bottom:none}.panel-left.closed{transform:translate(-100%)}.panel-right{right:0;border-right:none;border-top:none;border-bottom:none}.panel-right.closed{transform:translate(100%)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10}.panel-title{font-size:15px;font-weight:600;color:var(--text-primary)}.sensor-type-toggle{display:flex;gap:4px}.toggle-btn{padding:4px 12px;font-size:12px;font-weight:600;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.toggle-btn:hover{background:var(--bg-panel);color:var(--text-primary)}.toggle-btn.active{background:var(--accent);color:var(--bg-primary);border-color:var(--accent)}.panel-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:16px;transition:var(--transition)}.panel-close:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.panel-body{padding:16px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:16px;overflow:hidden}.card-header{padding:10px 14px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.card-body{padding:14px}.sensor-controls{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.sensor-controls input,.sensor-controls select{padding:6px 10px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;font-size:12px;outline:none}.sensor-controls input:focus,.sensor-controls select:focus{border-color:var(--accent)}.sensor-controls input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;opacity:.8}.sensor-controls input[type=datetime-local]::-webkit-calendar-picker-indicator:hover{opacity:1}.no-data-warning{display:flex;align-items:center;justify-content:center;height:100%;color:var(--warning);font-size:13px;font-weight:500;text-align:center;padding:16px}.chart-wrapper{width:100%;height:220px;position:relative}.chart-wrapper-tall{height:280px}.top-sensor-item{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color)}.top-sensor-item:last-child{border-bottom:none}.top-sensor-rank{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--bg-primary);border-radius:50%;font-size:11px;font-weight:700;margin-right:10px;flex-shrink:0}.top-sensor-name{flex:1;font-size:13px}.top-sensor-value{font-size:13px;font-weight:600;color:var(--accent)}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary)}.spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top:3px solid var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:10px}@keyframes spin{to{transform:rotate(360deg)}}.leaflet-container{font-family:inherit}.sensor-marker{display:flex;align-items:center;justify-content:center}.sensor-dot{width:14px;height:14px;border-radius:50%;background:var(--accent);border:2px solid white;box-shadow:0 0 8px #00d4ff99;cursor:pointer;transition:transform .2s}.sensor-dot:hover{transform:scale(1.4)}.sensor-dot.active{background:var(--warning);box-shadow:0 0 12px #ffc107cc;transform:scale(1.3)}.custom-popup .leaflet-popup-content-wrapper{background:var(--bg-panel);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius)}.custom-popup .leaflet-popup-tip{background:var(--bg-panel)}.tooltip-name{font-weight:600;font-size:12px;color:var(--text-primary)}.tooltip-flow{font-size:11px;color:var(--accent);margin-top:2px}.btn-calendar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--accent);cursor:pointer;transition:var(--transition);font-size:16px;flex-shrink:0}.btn-calendar:hover{background:var(--bg-secondary);border-color:var(--accent);box-shadow:0 0 8px #00d4ff33}.historical-label{font-size:11px;color:var(--text-secondary);background:var(--bg-card);padding:4px 8px;border-radius:4px;border:1px solid var(--border-color);white-space:nowrap;flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-panel);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow),0 0 40px #00d4ff1a;width:90%;max-width:420px;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);border-radius:var(--radius) var(--radius) 0 0}.modal-header h3{font-size:15px;font-weight:600;color:var(--text-primary);margin:0}.btn-close{width:24px;height:24px;background:transparent;border:none;color:var(--text-secondary);font-size:18px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-close:hover{color:var(--accent)}.modal-body{padding:20px}.datetime-group{margin-bottom:16px}.datetime-group label{display:block;font-size:12px;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.datetime-group input{width:100%;padding:8px 12px;background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;font-size:13px;font-family:inherit;transition:var(--transition)}.datetime-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 8px #00d4ff1a}.datetime-preview{background:#00d4ff14;border:1px solid rgba(0,212,255,.2);border-radius:4px;padding:12px;margin-top:16px}.datetime-preview p{font-size:12px;color:var(--text-secondary);margin:0 0 6px}.selected-datetime{font-size:14px;color:var(--accent);font-weight:600;margin:0}.modal-footer{display:flex;gap:8px;padding:16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);border-radius:0 0 var(--radius) var(--radius);justify-content:flex-end}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);font-family:inherit}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color);color:var(--text-primary)}.btn-primary{background:var(--accent);color:var(--bg-primary)}.btn-primary:hover{background:var(--accent-dim);box-shadow:0 0 12px #00d4ff4d}:root{--color-holiday: #ff9800;--color-event: #4caf50}.date-status-badge{display:inline-block;margin-left:8px;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.date-status-badge.date-holiday{background:#ff980033;color:var(--color-holiday)}.date-status-badge.date-event{background:#4caf5033;color:var(--color-event)}.date-input-wrapper{position:relative;display:flex;align-items:center;gap:8px}.date-input{flex:1}.date-input-holiday{border-color:var(--color-holiday)!important;background:#ff98000d}.date-input-event{border-color:var(--color-event)!important;background:#4caf500d}.date-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px #0003}.date-indicator-holiday{background:var(--color-holiday)}.date-indicator-event{background:var(--color-event)}.calendar-legend-container{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.calendar-legend-toggle{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:12px;cursor:pointer;transition:var(--transition);font-family:inherit;font-weight:500}.calendar-legend-toggle:hover{background:var(--border-color);color:var(--accent)}.calendar-legend{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding:12px;background:#00d4ff0d;border:1px solid rgba(0,212,255,.2);border-radius:4px}.calendar-dropdown{position:relative;width:100%}.calendar-dropdown-input{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:6px 10px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit;text-align:left}.calendar-dropdown-icon{font-size:14px;display:inline-flex;color:var(--text-secondary)}.calendar-dropdown-icon svg{display:block}.calendar-dropdown-panel{position:absolute;top:calc(100% + 6px);left:0;z-index:1200;min-width:260px;padding:12px;background:var(--bg-panel);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 12px 26px #00000040}.calendar-dropdown-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:8px}.calendar-month-label{font-size:13px;font-weight:600;text-transform:capitalize;color:var(--text-primary)}.calendar-nav-btn{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:14px}.calendar-year-select{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:4px 6px;font-size:12px;font-family:inherit}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday{text-align:center;font-size:10px;color:var(--text-secondary);font-weight:600}.calendar-day{height:30px;display:grid;place-items:center;border-radius:6px;border:1px solid transparent;background:var(--bg-card);color:var(--text-primary);font-size:12px;cursor:pointer}.calendar-day.empty{background:transparent;border:none;cursor:default}.calendar-day.today{border-color:var(--accent)}.calendar-day.selected{outline:2px solid var(--accent);outline-offset:0}.calendar-day-holiday{background:#ff980026;border-color:#ff98008c}.calendar-day-event{background:#4caf5026;border-color:#4caf508c}.time-input{min-width:110px;padding:6px 10px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;font-size:12px;font-family:inherit}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px}.legend-color{width:16px;height:16px;border-radius:3px;flex-shrink:0}.legend-holiday{background:var(--color-holiday)}.legend-event{background:var(--color-event)}@media (max-width: 768px){:root{--panel-width: 100vw}.header{padding:0 8px;gap:8px}.metrics-badge{display:none}}
