:root{color:#1f2328;background:#f5f6f2;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--surface: #ffffff;--surface-strong: #f0f2ec;--ink: #1f2328;--muted: #687069;--line: #d8ded4;--teal: #2f6f73;--teal-dark: #24565a;--amber: #f2b84b;--red: #d34f45;--indigo: #4d64ad;--shadow: 0 10px 30px rgba(31, 35, 40, .08)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;background:#f5f6f2}button,input,select{font:inherit;letter-spacing:0}button{border:0;cursor:pointer}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.52}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.topbar{display:grid;grid-template-columns:minmax(220px,1fr) auto minmax(360px,auto);align-items:center;gap:16px;padding:14px 18px;border-bottom:1px solid var(--line);background:#f5f6f2f0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark{width:42px;height:42px;display:grid;place-items:center;border-radius:8px;background:var(--ink);color:#fff;flex:0 0 auto}.brand h1{margin:0;font-size:19px;line-height:1.15}.brand p{margin:3px 0 0;color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-strip,.top-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.status-pill,.mode-pill,.toolbar-button,.panic-button,.baud-control{min-height:38px;display:inline-flex;align-items:center;gap:8px;border-radius:8px;border:1px solid var(--line);background:var(--surface);color:var(--ink);padding:0 12px;box-shadow:0 1px #1f23280a}.status-pill,.mode-pill{font-size:13px;text-transform:capitalize}.state-connected,.mode-bridge{border-color:#2f6f7359;color:var(--teal-dark);background:#e9f3ef}.state-error,.state-unsupported,.panic-button{border-color:#d34f4559;color:#9e352e;background:#fff0ed}.state-connecting,.state-disconnecting{border-color:#f2b84b80;color:#7a5618;background:#fff8e8}.mode-repl{border-color:#4d64ad42;color:#364989;background:#eef1fb}.toolbar-button.primary{background:var(--teal);border-color:var(--teal);color:#fff}.toolbar-button:enabled:hover,.panic-button:enabled:hover,.smoke-actions button:enabled:hover,.aux-buttons button:enabled:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.baud-control{padding:0 8px 0 10px}.baud-control span{color:var(--muted);font-size:12px}.baud-control input{width:92px;min-width:0;border:0;outline:0;background:transparent;color:var(--ink)}.control-grid{display:grid;grid-template-columns:minmax(520px,1.45fr) minmax(310px,.85fr);grid-template-rows:minmax(440px,auto) minmax(260px,1fr);gap:14px;padding:14px}.keyboard-panel,.mouse-panel,.smoke-panel,.camera-panel,.serial-panel,.combo-panel{min-width:0;background:var(--surface);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.keyboard-panel{display:grid;grid-template-rows:auto 1fr;padding:14px}.mouse-panel{display:grid;grid-template-rows:auto auto auto auto;gap:16px;padding:14px}.smoke-panel{display:grid;grid-template-rows:auto auto minmax(130px,1fr);gap:12px;padding:14px}.camera-panel,.serial-panel,.combo-panel{display:grid;align-content:start;gap:10px;padding:14px}.bottom-grid{grid-column:1 / -1;display:grid;grid-template-columns:minmax(300px,.95fr) minmax(280px,1fr) minmax(300px,1fr) minmax(260px,.85fr);gap:14px;min-width:0}.panel-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--muted)}.panel-header h2{margin:0;color:var(--ink);font-size:16px;line-height:1.2}.compact-header{margin-bottom:0}.mini-status{margin-left:auto;min-height:24px;display:inline-flex;align-items:center;border-radius:999px;border:1px solid var(--line);padding:0 9px;font-size:12px;color:var(--muted);background:#f8faf6}.mini-status.good{border-color:#2f6f7359;color:var(--teal-dark);background:#e9f3ef}.keyboard-surface{min-width:0;overflow-x:auto;padding-bottom:4px}.key-row{min-width:820px;display:flex;gap:6px;margin-bottom:6px}.key-button{min-width:0;height:46px;border:1px solid #cfd7cc;border-bottom-color:#aeb8aa;border-radius:7px;background:#fafbf8;color:var(--ink);font-weight:650;box-shadow:inset 0 -2px #1f232814;touch-action:none;-webkit-user-select:none;user-select:none;white-space:nowrap}.key-button.modifier{background:#eef1fb;border-color:#4d64ad4d}.key-button.system{background:#fff8e8;border-color:#f2b84b70}.key-button.action{background:#e9f3ef;border-color:#2f6f734d}.key-button.active{background:var(--amber);border-color:#d69a25;color:#2d220f}.key-button:enabled:active,.mouse-hold-button:enabled:active{transform:translateY(1px);box-shadow:inset 0 2px #1f23281f}.joystick-wrap{display:grid;place-items:center;padding-top:6px}.joystick{width:240px;aspect-ratio:1;border-radius:50%;border:1px solid #bfc9bc;background:radial-gradient(circle at center,rgba(47,111,115,.16) 0 34%,transparent 35%),#f8faf6;position:relative;display:grid;place-items:center;touch-action:none;-webkit-user-select:none;user-select:none;box-shadow:inset 0 0 0 8px #edf1ea}.joystick.disabled{filter:grayscale(.7)}.joystick-cross{position:absolute;background:#68706940;pointer-events:none}.joystick-cross.horizontal{width:70%;height:1px}.joystick-cross.vertical{height:70%;width:1px}.joystick-thumb{width:72px;height:72px;border-radius:50%;border:10px solid #f5f6f2;background:var(--teal);box-shadow:0 12px 26px #2f6f7342;transition:transform 55ms linear;pointer-events:none}.speed-control{display:grid;grid-template-columns:auto 1fr 38px;align-items:center;gap:10px;color:var(--muted);font-size:13px}.speed-control input{accent-color:var(--teal)}.speed-control output{text-align:right;color:var(--ink);font-weight:700}.mouse-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mouse-hold-button{min-height:72px;border-radius:8px;background:var(--ink);color:#fff;font-size:18px;font-weight:750;touch-action:none;-webkit-user-select:none;user-select:none}.aux-buttons,.smoke-actions,.camera-controls,.serial-toolbar,.combo-send-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.smoke-actions{grid-template-columns:repeat(3,minmax(0,1fr))}.aux-buttons button,.smoke-actions button,.camera-controls button,.serial-toolbar button,.serial-send button,.combo-send-row button,.quick-combos button,.modifier-toggles button{min-height:42px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid var(--line);border-radius:8px;background:var(--surface-strong);color:var(--ink);white-space:nowrap}.camera-controls{grid-template-columns:minmax(0,1fr) 42px auto}.camera-controls select,.serial-baud,.serial-send input,.combo-send-row select{min-width:0;min-height:42px;border:1px solid var(--line);border-radius:8px;background:#f8faf6;color:var(--ink)}.camera-controls select,.combo-send-row select,.serial-send input{padding:0 10px}.camera-view{width:100%;aspect-ratio:16 / 10;min-height:170px;border-radius:8px;border:1px solid #cad3c6;background:#1f2328;position:relative;overflow:hidden}.camera-view video{width:100%;height:100%;object-fit:contain;display:block;background:#1f2328}.camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#cbd3cc;font-weight:650}.panel-error{color:#9e352e;background:#fff0ed;border:1px solid rgba(211,79,69,.28);border-radius:8px;padding:8px 10px;font-size:13px}.serial-toolbar{grid-template-columns:minmax(0,1fr) auto}.serial-tabs{display:flex;align-items:center;gap:6px;min-width:0;overflow-x:auto;padding-bottom:2px}.serial-tab{min-width:0;min-height:34px;display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:8px;background:#f8faf6;color:var(--muted);padding:0 9px;white-space:nowrap;flex:0 0 auto}.serial-tab.active{color:var(--ink);background:#eef1fb;border-color:#4d64ad59}.serial-tab.add{width:34px;justify-content:center;padding:0}.tab-dot{width:7px;height:7px;border-radius:50%;background:#aeb8aa;flex:0 0 auto}.tab-dot.good{background:var(--teal)}.tab-close{width:18px;height:18px;display:grid;place-items:center;border-radius:50%;color:var(--muted)}.tab-close:hover{color:#9e352e;background:#fff0ed}.serial-baud{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;padding:0 10px}.serial-baud span{color:var(--muted);font-size:12px}.serial-baud input{min-width:0;border:0;outline:0;background:transparent}.serial-port-label{color:var(--muted);font-size:12px;min-height:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-terminal{min-height:160px;max-height:240px;overflow:auto;border:1px solid #cad3c6;border-radius:8px;background:#1f2328;padding:10px}.serial-send{display:grid;grid-template-columns:minmax(0,1fr) 44px;gap:8px}.modifier-toggles,.quick-combos{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.modifier-toggles button.selected{background:#eef1fb;border-color:#4d64ad59;color:#364989;box-shadow:inset 0 0 0 1px #4d64ad1a}.combo-send-row{grid-template-columns:minmax(0,1fr) auto}.terminal-log{min-height:140px;max-height:260px;overflow:auto;border:1px solid #cad3c6;border-radius:8px;background:#1f2328;padding:10px}.log-empty{color:#cbd3cc;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace}.log-line{display:grid;grid-template-columns:58px 1fr;gap:8px;color:#edf1ea;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px;line-height:1.45;padding:2px 0}.log-line span{color:#9ea8a1}.log-line.app code,.log-line.tx code{color:#f2d68b}.log-line.rx code{color:#a7efdd}.log-line.error code{color:#ffaaa2}.log-line code{white-space:pre-wrap;word-break:break-word}.unsupported-shell{min-height:100vh;display:grid;place-items:center;padding:20px;background:#f5f6f2}.unsupported-panel{width:min(440px,100%);border:1px solid var(--line);border-radius:8px;background:var(--surface);padding:24px;box-shadow:var(--shadow)}.unsupported-panel svg{color:var(--red)}.unsupported-panel h1{margin:12px 0 6px;font-size:22px}.unsupported-panel p{margin:0;color:var(--muted)}@media (max-width: 1120px){.topbar{grid-template-columns:1fr}.status-strip,.top-actions{justify-content:flex-start}.control-grid{grid-template-columns:1fr;grid-template-rows:auto}.bottom-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 760px){.topbar{padding:12px}.control-grid{padding:10px;gap:10px}.keyboard-panel,.mouse-panel,.smoke-panel,.camera-panel,.serial-panel,.combo-panel{padding:10px}.top-actions,.status-strip{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.toolbar-button,.panic-button,.baud-control,.status-pill,.mode-pill{justify-content:center;width:100%}.baud-control input{width:84px}.smoke-actions,.aux-buttons,.bottom-grid,.camera-controls,.serial-toolbar,.combo-send-row{grid-template-columns:repeat(2,minmax(0,1fr))}.bottom-grid{grid-template-columns:1fr}.joystick{width:min(240px,78vw)}.log-line{grid-template-columns:48px 1fr}}
