:root{--bg: #141413;--bg-grid: rgba(160, 160, 150, .035);--panel: #1b1b1a;--panel-2: #141413;--panel-hi: #242422;--border: rgba(180, 180, 170, .12);--border-hi: rgba(180, 180, 170, .28);--text: #cddae2;--text-dim: #6c818d;--text-faint: #44545d;--amber: #ffb13d;--amber-dim: #b9802c;--cyan: #4fd6e8;--cyan-dim: #2f8d99;--green: #5fe39a;--red: #ff5f57;--violet: #b08bff;--pink: #ff8fc7;--mono: "JetBrains Mono", ui-monospace, monospace;--display: "Chakra Petch", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background-color:var(--bg);background-image:linear-gradient(var(--bg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px);background-size:44px 44px;color:var(--text);font-family:var(--mono);font-size:14px;-webkit-font-smoothing:antialiased;overflow-x:hidden}button{font-family:var(--display);cursor:pointer}::selection{background:var(--amber);color:#000}::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-track{background:var(--panel-2)}::-webkit-scrollbar-thumb{background:#3a3a37;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#46463f}.gate{min-height:100%;display:grid;place-items:center;padding:24px;background:#18181b}.gate-card{width:100%;max-width:460px;background:#222226;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:40px 36px 36px;box-shadow:0 24px 80px #0009}@keyframes gate-shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.gate-shake{animation:gate-shake .4s ease}.gate-logo-wrap{display:flex;justify-content:center;margin-bottom:22px}.gate-logo{width:86px;height:auto}.gate-title{font-family:var(--display);font-weight:700;font-size:26px;color:#fff;text-align:center;margin:0 0 8px;letter-spacing:.3px}.gate-sub{font-family:var(--display);font-size:13px;color:#8a8a99;text-align:center;margin-bottom:28px;line-height:1.5}.gate-field-label{display:block;font-family:var(--display);font-size:13px;font-weight:500;color:#c8c8d8;margin-bottom:8px}.gate-input{width:100%;background:#18181b;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#e8e8f0;font-family:var(--display);font-size:14px;padding:13px 16px;outline:none;transition:border-color .15s,box-shadow .15s}.gate-input-wrap{position:relative;display:flex;align-items:center}.gate-input-wrap .gate-input{padding-right:44px}.gate-eye{position:absolute;right:12px;background:none;border:none;color:#5a5a72;cursor:pointer;display:flex;align-items:center;padding:4px;transition:color .15s}.gate-eye:hover{color:#9146ff}.gate-input::placeholder{color:#4a4a5a}.gate-input:focus{border-color:#7b2fffb3}.gate-input.err{border-color:#ff5f5799;box-shadow:0 0 0 3px #ff5f571f}.gate-err{margin-top:10px;color:#ff5f57;font-family:var(--display);font-size:12px;min-height:16px}.gate-btn{display:block;width:100%;margin-top:20px;padding:14px;background:#7b2fff;border:none;border-radius:8px;color:#fff;font-family:var(--display);font-weight:700;font-size:13px;letter-spacing:2px;cursor:pointer;transition:background .15s,transform .08s,box-shadow .15s}.gate-btn:hover{background:#9146ff;box-shadow:0 4px 24px #7b2fff73}.gate-btn:active{transform:translateY(1px)}.gate-footer{margin-top:22px;display:flex;justify-content:center}.gate-link{background:none;border:none;color:#5a5a72;font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:1.5px;cursor:pointer;transition:color .15s}.gate-link:hover{color:#9146ff}.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;padding:12px 18px;border-radius:3px;border:1px solid transparent;transition:transform .08s,background .15s}.btn:active{transform:translateY(1px)}.btn-primary{width:100%;margin-top:18px;background:var(--lime);color:#fff}.btn-primary:hover{background:#7546f0}.btn-ghost{background:transparent;border-color:var(--border-hi);color:var(--text)}.btn-ghost:hover{border-color:var(--amber);color:var(--amber)}.btn-danger{background:transparent;border-color:#ff5f5773;color:var(--red)}.btn-danger:hover{background:#ff5f571f}.btn-cyan{background:var(--cyan);color:#04181b}.btn-cyan:hover{background:#74e3f2}.gate-err{margin-top:14px;color:var(--red);font-size:12px;letter-spacing:.5px;min-height:16px}.shell{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:18px;padding:12px 20px;background:#1f1f1edb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}.brand{display:flex;align-items:center;gap:12px}.brand .logo{width:30px;height:30px;display:grid;place-items:center;border:1.5px solid var(--amber);color:var(--amber);border-radius:3px;transform:rotate(45deg)}.brand .logo svg{transform:rotate(-45deg)}.brand-text{line-height:1.1}.brand-text .name{font-family:var(--display);font-weight:700;letter-spacing:2px;font-size:15px}.brand-text .tag{font-size:10px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase}.topbar-spacer{flex:1}.status-chip{display:flex;align-items:center;gap:8px;font-family:var(--display);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;padding:6px 12px;border:1px solid var(--border);border-radius:3px;color:var(--text-dim)}.status-chip .led{width:8px;height:8px;border-radius:50%;background:var(--text-faint)}.status-chip.connected{color:var(--green);border-color:#5fe39a59}.status-chip.connected .led{background:var(--green);box-shadow:0 0 10px var(--green);animation:pulse 1.6s infinite}.status-chip.connecting{color:var(--amber);border-color:#ffb13d59}.status-chip.connecting .led{background:var(--amber);animation:pulse .7s infinite}.status-chip.error{color:var(--red);border-color:#ff5f5759}.status-chip.error .led{background:var(--red)}.mini-readouts{display:flex;gap:16px}.mini{line-height:1.15;text-align:right}.mini .k{font-family:var(--display);font-size:9.5px;letter-spacing:1.5px;color:var(--text-faint);text-transform:uppercase}.mini .v{font-family:var(--mono);font-weight:700;font-size:14px;color:var(--cyan)}.main{padding:18px 20px 40px;display:flex;flex-direction:column;gap:18px}.row{display:grid;gap:18px}.row.attitude{grid-template-columns:minmax(0,1.35fr) minmax(0,1fr)}.row.charts{grid-template-columns:repeat(3,minmax(0,1fr))}@media (max-width: 1100px){.row.attitude{grid-template-columns:1fr}.row.charts{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 720px){.row.charts{grid-template-columns:1fr}.mini-readouts{display:none}}.panel{background:var(--panel);border:1px solid var(--border);border-radius:4px;position:relative}.panel-head{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--border)}.panel-head .tick{width:3px;height:13px;background:var(--amber);border-radius:2px}.panel-head h2{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--text)}.panel-head .right{margin-left:auto;font-size:11px;color:var(--text-dim);letter-spacing:1px}.panel-body{padding:14px}.cube-wrap{position:relative;height:380px}.cube-canvas{width:100%;height:100%}.cube-hint{position:absolute;bottom:10px;left:14px;font-size:10.5px;color:var(--text-faint);letter-spacing:1px}.att-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px}.att-cell{background:var(--panel-2);border:1px solid var(--border);border-radius:3px;padding:12px;text-align:center}.att-cell .k{font-family:var(--display);font-size:10px;letter-spacing:2px;color:var(--text-dim);text-transform:uppercase}.att-cell .v{font-family:var(--mono);font-weight:800;font-size:24px;margin-top:6px}.att-cell .u{font-size:11px;color:var(--text-faint)}.att-cell.pitch .v{color:var(--cyan)}.att-cell.roll .v{color:var(--amber)}.att-cell.yaw .v{color:var(--violet)}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.stat{background:var(--panel-2);border:1px solid var(--border);border-radius:3px;padding:13px 14px;position:relative;overflow:hidden}.stat:after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent, var(--cyan));opacity:.8}.stat .k{font-family:var(--display);font-size:10px;letter-spacing:1.5px;color:var(--text-dim);text-transform:uppercase}.stat .v{font-family:var(--mono);font-weight:700;font-size:22px;margin-top:6px;color:var(--text)}.stat .u{font-size:11px;color:var(--text-faint);margin-left:4px}.chart-box{height:188px}.recharts-cartesian-axis-tick text{font-family:var(--mono);font-size:10px;fill:var(--text-faint)}.recharts-tooltip-wrapper{outline:none}.tooltip{background:var(--panel-hi);border:1px solid var(--border-hi);border-radius:3px;padding:8px 10px;font-family:var(--mono);font-size:11.5px}.tooltip .row-t{display:flex;justify-content:space-between;gap:18px}.tooltip .row-t .lbl{color:var(--text-dim)}.tooltip-time{font-size:10.5px;color:var(--text-faint);letter-spacing:.5px;margin-bottom:4px;padding-bottom:3px;border-bottom:1px solid var(--border)}.raw-feed{height:230px;overflow-y:auto;font-family:var(--mono);font-size:12px;line-height:1.7;padding:4px 0}.raw-line{display:flex;gap:12px;padding:1px 14px;white-space:nowrap}.raw-line:hover{background:var(--panel-hi)}.raw-line .ts{color:var(--text-faint)}.raw-line .data{color:var(--cyan)}.raw-line.bad .data{color:var(--red)}.empty{display:grid;place-items:center;text-align:center;color:var(--text-dim);padding:30px 16px;gap:6px}.empty .big{font-family:var(--display);letter-spacing:2px;font-size:13px;text-transform:uppercase;color:var(--text-dim)}.empty .small{font-size:12px;color:var(--text-faint)}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.notice{font-size:11.5px;color:var(--text-dim);line-height:1.6;background:#ffb13d0f;border:1px solid rgba(255,177,61,.2);border-radius:3px;padding:10px 12px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.fade-in{animation:fadeIn .4s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}:root{--lime: #6637ed;--lime-border: rgba(102, 55, 237, .55)}.console{height:100vh;width:100vw;overflow:hidden;display:grid;grid-template-columns:140px repeat(4,minmax(0,1fr));grid-template-rows:repeat(3,minmax(0,1fr));grid-template-areas:"side acc  ori  vel  alt" "side mag  cam  gps  ins" "side baro raw  raw  info";gap:8px;padding:8px}.cpanel{background:var(--panel);border:1px solid rgba(255,255,255,.7);border-radius:10px;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden;box-shadow:0 0 0 1px #0000004d,inset 0 0 24px #6637ed0d}.cpanel-title{font-family:var(--display);font-size:10.5px;letter-spacing:.5px;text-align:center;color:var(--text);padding:5px 6px;flex:0 0 auto;border-bottom:1px solid rgba(102,55,237,.22);position:relative}.expand-btn{position:absolute;top:2px;right:4px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0;font-size:13px;font-weight:700;line-height:1;color:#fff;background:transparent;border:1px solid rgba(102,55,237,.3);border-radius:4px;cursor:pointer;transition:color .15s,background .15s,border-color .15s}.expand-btn:hover{color:var(--text);background:#6637ed2e;border-color:#6637ed99}.chart-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:24px}.confirm-dialog{width:min(92vw,420px);background:#1c1c20;border:1px solid rgba(255,177,61,.4);border-radius:14px;padding:28px 26px 22px;text-align:center;box-shadow:0 24px 80px #000000a6;animation:confirm-in .2s ease}@keyframes confirm-in{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}.confirm-icon{font-size:34px;color:var(--amber);line-height:1;margin-bottom:12px}.confirm-title{font-family:var(--display);font-size:18px;font-weight:700;color:#fff;margin:0 0 10px}.confirm-text{font-family:var(--display);font-size:13px;line-height:1.6;color:#b6b6c4;margin:0 0 22px}.confirm-text strong{color:#ffd089;font-weight:600}.confirm-actions{display:flex;gap:10px}.confirm-btn{flex:1;padding:11px 12px;border-radius:8px;font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.5px;cursor:pointer;transition:background .15s,transform .08s,border-color .15s}.confirm-btn:active{transform:translateY(1px)}.confirm-btn.cancel{background:transparent;border:1px solid rgba(255,255,255,.18);color:#d8d8e0}.confirm-btn.cancel:hover{background:#ffffff0f}.confirm-btn.proceed{background:var(--amber);border:1px solid var(--amber);color:#1a1206}.confirm-btn.proceed:hover{background:#ffc163}.chart-modal{width:min(90vw,1100px);height:min(82vh,720px);display:flex;flex-direction:column;background:var(--panel);border:1px solid rgba(255,255,255,.7);border-radius:12px;box-shadow:0 0 0 1px #0006,0 18px 60px #0009,inset 0 0 40px #6637ed0f;overflow:hidden}.chart-modal-head{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-family:var(--display);font-size:13px;letter-spacing:.5px;color:var(--text);border-bottom:1px solid rgba(102,55,237,.22)}.chart-modal-close{width:24px;height:24px;display:flex;align-items:center;justify-content:center;padding:0;font-size:13px;color:var(--text-dim);background:transparent;border:1px solid rgba(102,55,237,.3);border-radius:4px;cursor:pointer}.chart-modal-close:hover{color:var(--text);background:#6637ed2e;border-color:#6637ed99}.chart-modal-body{flex:1 1 auto;min-height:0;padding:10px 12px 12px}.cpanel-body{flex:1 1 auto;min-height:0;padding:4px 6px 6px;position:relative}.cpanel.p-flush .cpanel-body{padding:0}.cpanel.p-scroll .cpanel-body{overflow-y:auto}.side{display:flex;flex-direction:column;align-items:stretch;gap:7px;padding:4px 2px;overflow:hidden}.side-brand{text-align:center;margin-bottom:2px}.side-beta{font-family:var(--display);font-size:8px;letter-spacing:2px;color:var(--text-dim);margin-top:1px}.side-logo-img{width:100%;max-width:124px;height:auto;display:block;margin:0 auto}.side-logo{display:flex;justify-content:center;margin-bottom:4px}.side-name{font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:1px;color:var(--text)}.side-sub{font-family:var(--display);font-size:7px;letter-spacing:1.5px;color:var(--lime)}.side-status{display:flex;align-items:center;justify-content:center;gap:6px;font-family:var(--display);font-size:8.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--text-dim);background:transparent;border:none;padding:2px}.side-status .led{width:7px;height:7px;border-radius:50%;background:var(--text-faint)}.side-status.connected{color:var(--green)}.side-status.connected .led{background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 1.6s infinite}.side-status.connecting{color:var(--amber)}.side-status.connecting .led{background:var(--amber);animation:pulse .7s infinite}.side-status.error{color:var(--red)}.side-status.error .led{background:var(--red)}.side-btn{font-family:var(--display);font-weight:600;font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:var(--lime);border:1px solid #8a63f5;border-radius:5px;padding:7px 4px;transition:background .12s,transform .08s}.side-btn:hover{background:#7546f0}.side-btn:active{transform:translateY(1px)}.side-btn-demo{background:#fff;border-color:#fff;color:#7c4fd4}.side-btn-demo:hover{background:#e8e0ff;border-color:#e8e0ff}.side-btn-demo.active{background:#fff;border-color:#fff;color:#7c4fd4;animation:demo-pulse 2s ease-in-out infinite}@keyframes demo-pulse{0%,to{box-shadow:0 0 #b08bff00}50%{box-shadow:0 0 8px 2px #b08bff73}}.demo-label{font-family:var(--display);font-size:8px;font-weight:600;letter-spacing:1.5px;color:#7c4fd4;text-align:center;padding:2px 0;animation:demo-label-in .3s ease}@keyframes demo-label-in{0%{opacity:0}to{opacity:1}}.side-battery{display:flex;flex-direction:column;align-items:center;gap:5px;padding:8px 4px;border:1px solid var(--lime-border);border-radius:8px}.side-battery-label{font-family:var(--display);font-size:9px;letter-spacing:1.5px;color:var(--text-dim)}.side-battery-volts{font-family:var(--mono);font-weight:700;font-size:11px;color:var(--text)}.legend{margin-top:auto;display:flex;flex-direction:column;gap:6px;padding-top:8px}.legend-row{display:flex;align-items:center;gap:7px;font-size:9.5px;color:var(--text-dim)}.legend-row .sw{width:11px;height:11px;border-radius:2px;flex:0 0 auto}.side-warn{font-size:8px;color:var(--red);line-height:1.4;padding-top:6px}.ins{display:grid;grid-template-columns:1fr 1fr;gap:8px;min-height:0}.ins-cell{min-width:0}.ins-cell .cpanel-body{display:grid;place-items:center}.compass{display:flex;flex-direction:column;align-items:center;gap:2px;width:100%;height:100%}.compass-svg{width:100%;height:100%;max-height:100%}.compass-val{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--cyan)}.battery{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.batt-icon{display:flex;align-items:center}.batt-cells{display:flex;gap:3px;border:2px solid var(--text-dim);border-radius:3px;padding:3px;width:64px;height:30px}.batt-cell{flex:1;border-radius:1px;transition:background .2s}.batt-cap{width:4px;height:14px;background:var(--text-dim);border-radius:0 2px 2px 0}.batt-val{font-family:var(--mono);font-weight:700;font-size:14px}.cube-fill{width:100%;height:100%;min-height:0}.cube-fill .cube-canvas{width:100%;height:100%}.cam-video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.cam-fallback{width:100%;height:100%;display:grid;place-items:center;align-content:center;gap:4px;background:repeating-linear-gradient(45deg,#141413,#141413 8px,#1a1a18 8px,#1a1a18 16px)}.cam-fallback .big{font-family:var(--display);letter-spacing:2px;font-size:13px;color:var(--text-dim)}.cam-fallback .small{font-size:10px;color:var(--text-faint)}.gps-wrap{position:relative;width:100%;height:100%;background:#15150a}.gps-svg{width:100%;height:100%;display:block}.gps-ping{animation:pulse 1.6s infinite}.gps-readout{position:absolute;bottom:4px;left:0;right:0;text-align:center;font-family:var(--mono);font-size:9.5px;color:var(--amber);text-shadow:0 0 6px rgba(0,0,0,.9)}.raw-table{height:100%;overflow-y:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px 6px;padding:6px 8px;align-content:start}.raw-item{display:flex;align-items:baseline;gap:4px;font-family:var(--mono);font-size:10px;padding:1px 0}.raw-item .rk{color:var(--text-dim);min-width:30px}.raw-item .rv{color:#b08bff;font-weight:700;margin-left:auto}.raw-item .ru{color:var(--text-faint);font-size:8px;min-width:18px}.info-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:10px}.info-table td{padding:2px 8px;border-bottom:1px solid rgba(180,180,170,.06)}.info-table td:first-child{color:var(--text-dim)}.info-table td:last-child{text-align:right;color:var(--text);font-weight:700}@media (max-width: 900px){.console{height:auto;min-height:100vh;overflow:visible;grid-template-columns:1fr 1fr;grid-template-rows:auto;grid-template-areas:"side side" "acc ori" "vel alt" "mag cam" "gps ins" "baro baro" "raw raw" "info info"}}
