:root{--bg:#f4f7f4;--surface:#fff;--surface-2:#eef3ee;--surface-3:#dfe8df;--ink:#17201d;--muted:#61716a;--faint:#8b9a93;--border:#ccd8d0;--green:#0f9f6e;--green-soft:#dff7ec;--amber:#cf7a13;--amber-soft:#fff1d6;--red:#c8443e;--red-soft:#ffe4e0;--blue:#2f6ed3;--blue-soft:#e4edff;--shadow:0 20px 60px #17201d1f;--radius:8px;--font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--ink);background:var(--bg);font-family:var(--font);letter-spacing:0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.45}*{box-sizing:border-box}body{background:linear-gradient(90deg, #0f9f6e14 1px, transparent 1px), linear-gradient(#2f6ed312 1px, transparent 1px), var(--bg);background-size:36px 36px;min-width:320px;margin:0;overflow-x:hidden}html,body,#app{width:100%;max-width:100%}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}h1,h2,p{margin:0}h1{font-size:24px;font-weight:760;line-height:1.05}h2{color:var(--ink);font-size:15px;font-weight:760;line-height:1.2}svg{stroke-width:2px;width:18px;height:18px}#app{min-height:100svh}.app-shell{width:100%;max-width:1480px;min-height:100svh;margin:0 auto;padding:18px 16px 28px}.topbar{justify-content:space-between;align-items:center;gap:16px;padding:10px 0 18px;display:flex}.brand{align-items:center;gap:12px;min-width:0;display:flex}.brand-mark{border-radius:var(--radius);width:42px;height:42px;color:var(--green);background:var(--surface);border:1px solid #0f9f6e59;flex:none;place-items:center;display:grid;box-shadow:0 8px 22px #0f9f6e21}.brand-mark svg{width:22px;height:22px}.eyebrow,.label,.hud-label,.tile-title,.input-label,.meter-top span,.event-row span,.event-row time,.gesture-tile em,.webhook-state,.strip-head p{color:var(--muted);font-size:12px;font-weight:680;line-height:1.25}.eyebrow,.label,.hud-label,.input-label,.meter-top span,.gesture-tile em{text-transform:uppercase}.top-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.button,.icon-button,.preset-tab{border:1px solid var(--border);border-radius:var(--radius);min-height:40px;color:var(--ink);background:var(--surface);justify-content:center;align-items:center;gap:8px;transition:border-color .18s,background .18s,color .18s,transform .18s;display:inline-flex}.button{padding:0 14px;font-weight:720}.button:hover,.icon-button:hover,.preset-tab:hover{border-color:#0f9f6e80;transform:translateY(-1px)}.button.primary,.button.is-active{color:#073d2c;background:var(--green-soft);border-color:#0f9f6e66}.workspace{grid-template-columns:minmax(0,1.35fr) minmax(340px,.65fr);align-items:start;gap:16px;display:grid}.stage-area{min-width:0}.stage{--camera-aspect:16 / 9;width:100%;aspect-ratio:var(--camera-aspect);border-radius:var(--radius);box-shadow:var(--shadow);background:radial-gradient(circle at 18% 24%,#0f9f6e33,#0000 28%),radial-gradient(circle at 82% 72%,#cf7a1338,#0000 34%),#101817;border:1px solid #17201d2e;position:relative;overflow:hidden}.stage[data-active=true]{border-color:#0f9f6ebf}#cameraVideo,#overlayCanvas{width:100%;height:100%;position:absolute;inset:0}#cameraVideo{object-fit:contain}#overlayCanvas{z-index:2}.stage.is-mirrored #cameraVideo,.stage.is-mirrored #overlayCanvas{transform:scaleX(-1)}.stage-empty{z-index:3;color:#ffffffc7;text-align:center;background:linear-gradient(135deg,#101817d1,#10181794),repeating-linear-gradient(45deg,#ffffff0a 0 1px,#0000 1px 12px);place-content:center;gap:10px;font-weight:720;display:grid;position:absolute;inset:0}.stage-empty svg{width:42px;height:42px;margin:0 auto}.stage-empty.is-hidden{display:none}.cursor-dot{z-index:4;opacity:0;pointer-events:none;background:#0f9f6eb8;border:2px solid #fffffff0;border-radius:999px;width:26px;height:26px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 0 0 8px #0f9f6e38,0 0 32px #0f9f6ee6}.cursor-dot.is-visible{opacity:1}.hud{z-index:5;grid-template-columns:minmax(130px,1fr) 72px 72px;gap:8px;width:min(430px,100% - 24px);display:grid;position:absolute;bottom:12px;right:12px}.hud>div{border-radius:var(--radius);color:#fff;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b100fad;border:1px solid #ffffff24;min-width:0;padding:9px 10px}.hud strong{color:#fff;text-overflow:ellipsis;white-space:nowrap;font-size:15px;line-height:1.25;display:block;overflow:hidden}.hud-label{color:#ffffff9e}.signal-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:12px;display:grid}.meter{border:1px solid var(--border);border-radius:var(--radius);background:#ffffffe0;padding:12px}.meter-top{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.meter-top strong{font-size:13px}.meter-track{background:var(--surface-3);border-radius:999px;height:8px;display:block;overflow:hidden}.meter-track span{border-radius:inherit;background:linear-gradient(90deg, var(--green), var(--amber));width:0%;height:100%;transition:width .12s;display:block}.control-area{gap:12px;min-width:0;display:grid}.panel{border:1px solid var(--border);border-radius:var(--radius);background:#ffffffeb;padding:14px}.status-panel{grid-template-columns:1fr 1fr;gap:10px;display:grid}.status-line{align-items:center;gap:10px;min-width:0;display:flex}.status-line strong{text-overflow:ellipsis;white-space:nowrap;font-size:14px;display:block;overflow:hidden}.status-dot{background:var(--faint);border-radius:999px;flex:none;width:11px;height:11px}.status-dot[data-state=loading]{background:var(--amber);box-shadow:0 0 0 6px #cf7a1321}.status-dot[data-state=ready]{background:var(--green);box-shadow:0 0 0 6px #0f9f6e24}.status-dot[data-state=error]{background:var(--red);box-shadow:0 0 0 6px #c8443e24}.panel-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.panel-head>span{color:#073d2c;background:var(--green-soft);border-radius:999px;padding:4px 8px;font-size:12px;font-weight:760}.preset-tabs{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;display:grid}.preset-tab{min-height:64px;color:var(--muted);background:var(--surface-2);flex-direction:column;padding:8px 6px;font-size:12px;font-weight:760}.preset-tab svg{width:19px;height:19px}.preset-tab.is-active{color:#173e82;background:var(--blue-soft);border-color:#2f6ed373}.switch{width:46px;height:26px;display:inline-flex;position:relative}.switch input{opacity:0;position:absolute}.switch span{background:var(--surface-3);border-radius:999px;transition:background .18s;position:absolute;inset:0}.switch span:after{content:"";background:#fff;border-radius:999px;width:20px;height:20px;transition:transform .18s;position:absolute;top:3px;left:3px;box-shadow:0 2px 8px #17201d33}.switch input:checked+span{background:var(--green)}.switch input:checked+span:after{transform:translate(20px)}.input-label{margin-bottom:6px;display:block}.text-input{border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:40px;color:var(--ink);background:#fff;outline:none;padding:0 10px}.text-input:focus{border-color:#2f6ed3a6;box-shadow:0 0 0 4px #2f6ed31f}.webhook-state{margin-top:8px}.icon-button{width:34px;min-height:34px;padding:0}.icon-button.is-done{color:#073d2c;background:var(--green-soft);border-color:#0f9f6e80}.event-json{border:1px solid var(--border);border-radius:var(--radius);color:#d9fbe8;white-space:pre-wrap;background:#111816;max-height:214px;margin:0;padding:12px;font-family:JetBrains Mono,SFMono-Regular,Consolas,monospace;font-size:12px;line-height:1.45;overflow:auto}.gesture-strip,.event-log-band{border:1px solid var(--border);border-radius:var(--radius);background:#ffffffdb;margin-top:16px;padding:14px}.strip-head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.gesture-grid{grid-template-columns:repeat(11,minmax(112px,1fr));gap:8px;display:grid}.gesture-tile{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);grid-template-columns:34px minmax(0,1fr);gap:9px;min-height:104px;padding:10px;transition:border-color .16s,background .16s,transform .16s;display:grid}.gesture-tile.is-live{background:var(--green-soft);border-color:#0f9f6ea6;transform:translateY(-2px)}.tile-icon{border-radius:var(--radius);width:34px;height:34px;color:var(--blue);background:var(--blue-soft);place-items:center;display:grid}.gesture-tile.is-live .tile-icon{color:#073d2c;background:#0f9f6e2e}.gesture-tile strong{color:var(--ink);margin:4px 0 5px;font-size:13px;line-height:1.25;display:block}.gesture-tile em{font-style:normal;display:block}.event-log{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.event-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);grid-template-columns:34px minmax(0,1fr);gap:8px;min-height:70px;padding:10px;display:grid}.event-row span{border-radius:var(--radius);color:#073d2c;background:var(--green-soft);grid-row:span 3;place-items:center;width:30px;height:30px;display:grid}.event-row strong,.event-row em,.event-row time{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.event-row strong{font-size:13px}.event-row em{color:var(--muted);font-size:12px;font-style:normal}.empty-log{color:var(--muted);grid-column:1/-1}@media (width<=1220px){.workspace{grid-template-columns:1fr}.control-area{grid-template-columns:repeat(2,minmax(0,1fr))}.gesture-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.event-log{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (width<=760px){.app-shell{padding-top:10px;padding-left:9px;padding-right:9px}.topbar{flex-direction:column;align-items:stretch}.top-actions{grid-template-columns:1fr;display:grid}.button{width:100%;min-width:0;padding:0 8px}.hud{grid-template-columns:1fr 58px 58px;width:calc(100% - 16px);bottom:8px;right:8px}.hud>div{padding:7px}.hud strong{font-size:13px}.signal-row,.control-area,.status-panel,.event-log{grid-template-columns:1fr}.preset-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.preset-tab{min-height:58px;font-size:11px}.gesture-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.gesture-tile{min-height:94px}}@media (width<=460px){.gesture-grid{grid-template-columns:1fr}}
