body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.App{display:flex;flex-direction:column}.App-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;box-shadow:0 4px 6px #0000001a;color:#fff;padding:20px}.App-header h1{font-size:2rem;font-weight:700;margin-bottom:15px;text-align:center;text-shadow:2px 2px 4px #0003}.connection-status{align-items:center;background:#fff3;border:2px solid;border-radius:20px;display:inline-flex;display:block;font-size:.9rem;font-weight:600;gap:8px;margin:0 auto 15px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.stats-bar{display:flex;gap:30px;justify-content:center;margin-top:10px}.stat{align-items:center;display:flex;flex-direction:column}.stat-label{font-size:.8rem;letter-spacing:1px;opacity:.8;text-transform:uppercase}.stat-value{font-size:1.2rem;font-weight:700;margin-top:5px}.App-main{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:40px;padding:40px 20px}.ball-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:100px;box-shadow:0 8px 32px #0003;height:700px;overflow:hidden;position:relative;width:200px}.track{background:#fff3;height:100%;width:2px}.track,.track-marker{left:50%;position:absolute;transform:translateX(-50%)}.track-marker{align-items:center;color:#fff;display:flex;font-size:.9rem;gap:10px;opacity:.6}.track-marker:before{background:#fff6;content:"";height:2px;margin-right:-15px;width:20px}.ball{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 10px 40px #667eea99,0 0 20px #764ba266,inset 0 -10px 20px #0003;display:flex;height:80px;justify-content:center;left:50%;transform:translateX(-50%);width:80px;z-index:10}.ball,.ball-glow{border-radius:50%;position:absolute}.ball-glow{animation:pulse 2s ease-in-out infinite;background:radial-gradient(circle,#667eea66 0,#0000 70%);bottom:-10px;left:-10px;right:-10px;top:-10px}@keyframes pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.ball-angle{color:#fff;font-size:1.2rem;font-weight:700;position:relative;text-shadow:0 2px 4px #0000004d;z-index:1}.sensor-data{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));max-width:800px;width:100%}.data-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:16px;box-shadow:0 4px 6px #0000001a;display:flex;gap:15px;padding:20px;transition:all .3s ease}.data-card:hover{box-shadow:0 8px 16px #0003;transform:translateY(-5px)}.data-card.highlight{animation:highlightPulse .5s ease-in-out;background:#4caf504d;border-color:#4caf50}@keyframes highlightPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.data-icon{flex-shrink:0;font-size:2.5rem}.data-content{flex:1 1}.data-label{color:#ffffffb3;font-size:.85rem;letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}.data-value{color:#fff;font-size:1.5rem;font-weight:700}.force-bar-container{max-width:600px;width:100%}.force-bar-label{color:#fff;display:flex;font-size:.9rem;font-weight:600;justify-content:space-between;margin-bottom:10px}.force-bar{background:#fff3;border-radius:20px;box-shadow:inset 0 2px 8px #0003;height:40px;overflow:hidden;width:100%}.force-bar-fill{border-radius:20px;box-shadow:0 0 20px #ffffff4d;font-weight:700;height:100%;justify-content:flex-end;padding-right:15px;transition:width .3s ease,background-color .3s ease}.force-bar-fill,.waiting{align-items:center;color:#fff;display:flex}.waiting{flex-direction:column;gap:20px;padding:40px;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.waiting p{font-size:1.1rem;opacity:.9}.waiting .hint{background:#ffffff1a;border-radius:8px;font-size:.9rem;margin-top:10px;opacity:.7;padding:10px 20px}.waiting code{background:#0000004d;border-radius:4px;color:#4caf50;font-family:Courier New,monospace;padding:4px 8px}@media (max-width:768px){.App-header h1{font-size:1.5rem}.ball-container{height:500px;width:150px}.ball{height:60px;width:60px}.sensor-data{grid-template-columns:repeat(2,1fr)}.stats-bar{gap:15px}}@media (max-width:480px){.sensor-data{grid-template-columns:1fr}.App-main{gap:20px;padding:20px 10px}}
/*# sourceMappingURL=main.20c11396.css.map*/