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}*{box-sizing:border-box;margin:0;padding:0}.App{background:linear-gradient(135deg,#1e3a8a,#0f172a);color:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100vh;overflow:hidden}.App-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0000004d;box-shadow:0 4px 6px #0000001a;flex-shrink:0;padding:1.5rem 2rem}.header-title{gap:1rem;justify-content:center;margin-bottom:.75rem}.App-header h1{font-size:2rem;margin:0;text-align:center}.header-title{justify-content:space-between;margin-bottom:1rem;width:100%}.header-actions,.header-title{align-items:center;display:flex}.header-actions{gap:.75rem}.social-link{align-items:center;background:#ffffff26;border:2px solid #ffffff4d;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;text-decoration:none;transition:all .3s ease;width:32px}.social-link:hover{background:#ffffff40;border-color:#ffffff80;transform:scale(1.1)}.social-link svg{height:18px;width:18px}.help-button{align-items:center;background:#fff3;border:2px solid #fff6;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;font-weight:700;height:32px;justify-content:center;padding:0;transition:all .3s ease;width:32px}.help-button:hover{background:#ffffff4d;transform:scale(1.1)}.status-bar{background:#ffffff1a;border-radius:10px;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin:0 auto;max-width:100%;padding:.75rem 1rem}.status-bar,.status-indicator{align-items:center;display:flex}.status-indicator{gap:.5rem}.status-dot{animation:pulse 2s infinite;border-radius:50%;height:14px;width:14px}.status-dot.online{background-color:#4ade80;box-shadow:0 0 10px #4ade80}.status-dot.offline{background-color:#f87171;box-shadow:0 0 10px #f87171}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-text{font-size:1rem;font-weight:600}.vehicle-selector{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;gap:.5rem;padding:.5rem 1rem}.vehicle-selector label{font-size:.9rem;font-weight:600;white-space:nowrap}.vehicle-dropdown{background:#0000004d;border:2px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;min-width:180px;padding:.4rem .8rem;transition:all .3s ease}.vehicle-dropdown:hover{background:#0006;border-color:#ffffff80}.vehicle-dropdown:focus{border-color:#4ade80;box-shadow:0 0 0 2px #4ade8033;outline:none}.vehicle-dropdown option{background:#1a1a2e;color:#fff}.data-info{display:flex;font-size:.9rem;gap:2rem}.filter-info{font-size:.85rem;opacity:.7}.last-update{opacity:.8}.clear-data-button{background:#f87171;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-left:auto;padding:8px 16px;transition:all .3s ease}.clear-data-button:hover{background:#ef4444;transform:scale(1.05)}.clear-data-button:active{transform:scale(.95)}.dashboard-grid{grid-gap:1rem;display:grid;flex:1 1;gap:1rem;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(2,1fr);overflow:hidden;padding:1rem 2rem}.dashboard-grid>.chart-container:first-child{grid-column:1/4;grid-row:1}.dashboard-grid>.chart-container:nth-child(2){grid-column:4/7;grid-row:1}.dashboard-grid>.chart-container:nth-child(3){grid-column:7/10;grid-row:1}.dashboard-grid>.chart-container:nth-child(4){grid-column:1/4;grid-row:2}.terminal-container{grid-column:4/7;grid-row:2}.current-values{grid-column:7/10;grid-row:2}.grid-item{background:#fff;border-radius:12px;box-shadow:0 8px 24px #0003;display:flex;flex-direction:column;min-height:0;overflow:hidden}.grid-item h2{color:#333;flex-shrink:0;font-size:1.2rem;padding:1rem 1.5rem .5rem}.chart-container{padding:1rem 1.5rem 1.5rem}.chart-header-with-info{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:.5rem}.chart-header-with-info h2{font-size:1.2rem;margin:0}.info-button{align-items:center;background:#0000;border:2px solid #3333334d;border-radius:50%;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:32px;justify-content:center;outline:none;padding:0;transition:all .3s ease;width:32px}.info-button:hover{background:#3333330d;border-color:#33333380;transform:scale(1.1)}.info-button:focus{box-shadow:none;outline:none}.chart-content{height:calc(100% - 2.5rem);width:100%}.chart-container>div:not(.chart-header-with-info){height:calc(100% - 2.5rem)!important}.no-data-chart{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px}.waiting-message{color:#666;font-style:italic;padding:2rem;text-align:center}.waiting-message p{margin:.5rem 0}.terminal-container{background:#1e1e1e;color:#d4d4d4;display:flex;flex-direction:column;font-family:Courier New,monospace;outline:none}.terminal-header{align-items:center;background:#2d2d2d;border-bottom:1px solid #3e3e3e;display:flex;justify-content:space-between;padding:12px 16px}.terminal-container h2{color:#4ade80;margin:0}.terminal-output{flex:1 1;font-size:.85rem;line-height:1.5;overflow-y:auto;padding:1rem 1.5rem;scroll-behavior:smooth}.terminal-line{animation:fadeIn .3s ease-in;margin-bottom:.25rem;white-space:pre-wrap;word-break:break-word}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.terminal-timestamp{color:#888;font-size:.8rem}.terminal-info{color:#d4d4d4}.terminal-success{color:#4ade80}.terminal-error{color:#f87171}.terminal-warning{color:#fbbf24}.play-button{align-items:center;background:#4ade80;border:none;border-radius:50%;box-shadow:0 2px 4px #0000004d;color:#1e1e1e;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;transition:all .3s ease;width:36px}.play-button:hover{background:#22c55e;transform:scale(1.1)}.play-button.running{background:#f87171}.play-button.running:hover{background:#ef4444}.terminal-footer{align-items:center;background:#252525;border-top:1px solid #3e3e3e;color:#888;display:flex;font-size:12px;font-style:italic;gap:1rem;justify-content:center;padding:8px 16px}.terminal-footer-text{flex:1 1;text-align:center}.mobile-toggle-button{background:linear-gradient(135deg,#1e3a8a,#0f172a);border:none;border-radius:6px;color:#fff;cursor:pointer;display:none;font-size:11px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase;transition:all .3s ease}.mobile-toggle-button:hover:not(:disabled){box-shadow:0 4px 8px #1e3a8a66;transform:scale(1.05)}.mobile-toggle-button:disabled{cursor:not-allowed;opacity:.5}.current-values{background:#fffffff2;padding:1rem 1.5rem 1.5rem}.values-grid-compact{grid-gap:.8rem;display:grid;gap:.8rem;grid-template-columns:repeat(3,1fr);height:calc(100% - 2.5rem);overflow-y:auto}.value-card{background:linear-gradient(135deg,#1e3a8a,#0f172a);border-radius:10px;color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:80px;padding:.8rem;text-align:center;transition:transform .2s}.value-card:hover{box-shadow:0 6px 16px #0000004d;transform:translateY(-3px)}.value-label{display:block;font-size:.8rem;font-weight:500;margin-bottom:.3rem;opacity:.9}.value-number{display:block;font-size:1.5rem;font-weight:700}.value-card.compression-stats{background:linear-gradient(135deg,#11998e,#38ef7d);border:2px solid #38ef7d4d}.value-card.compression-stats:hover{box-shadow:0 6px 20px #38ef7d66}.compression-ratio{color:#fff;text-shadow:0 2px 4px #0003}.no-data{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;display:flex;flex:1 1;flex-direction:column;justify-content:center;margin:2rem;padding:4rem;text-align:center}.no-data h2{font-size:2rem;margin-bottom:1rem}.no-data p{font-size:1.2rem;opacity:.8}@media (max-width:1200px){.App{height:auto;min-height:100vh;overflow-y:auto}.App-header h1{font-size:1.5rem}.status-bar{flex-direction:column;text-align:center}.data-info{flex-direction:column;gap:.5rem}.dashboard-grid{grid-template-columns:1fr;grid-template-rows:auto;overflow-y:visible;padding:1rem}.current-values,.dashboard-grid>.chart-container:first-child,.dashboard-grid>.chart-container:nth-child(2),.dashboard-grid>.chart-container:nth-child(3),.dashboard-grid>.chart-container:nth-child(4),.terminal-container{grid-column:1;grid-row:auto}.grid-item{min-height:350px}.mobile-toggle-button{display:block}.terminal-footer{flex-direction:column;gap:.5rem}.terminal-footer-text{display:none}.chart-container>div{height:300px!important}.values-grid-compact{grid-template-columns:repeat(2,1fr);height:auto}.terminal-output{max-height:250px}}@media (max-width:768px){.App-header{padding:1rem}.App-header h1{font-size:1.3rem}.dashboard-grid{gap:.75rem;padding:.5rem}.grid-item h2{font-size:1rem;padding:.75rem 1rem .5rem}.value-number{font-size:1.5rem}.value-label{font-size:.8rem}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:80vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:linear-gradient(135deg,#1e3a8a,#0f172a);border-bottom:2px solid #f0f0f0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:1.5rem 2rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.modal-header h2{font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:2rem;height:36px;justify-content:center;transition:background .3s ease;width:36px}.modal-close:hover{background:#fff3}.modal-body{color:#333;padding:2rem}.modal-body section{margin-bottom:1.5rem}.modal-body section:last-child{margin-bottom:0}.modal-body h3{color:#3b82f6;font-size:1.2rem;margin-bottom:.5rem}.modal-body p{color:#555;line-height:1.6;margin-bottom:.5rem}.modal-body ul{color:#555;line-height:1.8;margin-left:1.5rem}.modal-body li{margin-bottom:.5rem}.modal-body strong{color:#333}.modal-body code{background:#f5f5f5;border-radius:3px;color:#e74c3c;font-family:Courier New,monospace;padding:2px 6px}
/*# sourceMappingURL=main.ed006d9e.css.map*/