*{box-sizing:border-box;margin:0}html,body,#root{height:100%;background:#111214;color:#d6d8db;font-family:-apple-system,Helvetica Neue,sans-serif;font-size:13px}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:12px;padding:8px 14px;background:#1a1c1f;border-bottom:1px solid #2a2d31}.brand{font-weight:600;letter-spacing:.04em}.stub-badge{background:#4a3d1f;color:#e8c76a;padding:2px 8px;border-radius:10px;font-size:11px}.status{margin-left:auto;color:#8a8d92}.stage{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;background:#0a0b0c}.viewport{outline:1px solid #3a3d41}.controls{display:flex;flex-wrap:wrap;align-items:center;gap:18px;padding:10px 14px;background:#1a1c1f;border-top:1px solid #2a2d31}.group{display:flex;align-items:center;gap:6px}button{background:#26292d;color:#d6d8db;border:1px solid #34383d;border-radius:6px;padding:6px 12px;cursor:pointer}button:hover{background:#2e3237}button.active{background:#3d5a80;border-color:#4d6a90;color:#fff}button:disabled{opacity:.4;cursor:default}select,input[type=range]{accent-color:#3d5a80;background:#26292d;color:#d6d8db;border:1px solid #34383d;border-radius:6px;padding:5px 8px}.scrub{display:flex;align-items:center;gap:6px;font-size:11px;color:#8a8d92;text-transform:uppercase;letter-spacing:.08em}.focal-readout{min-width:52px;padding:5px 8px;text-align:center;font-variant-numeric:tabular-nums;font-weight:600;color:#e8ebef;background:#101214;border:1px solid #34383d;border-radius:6px}.truesize{width:120px;background:#26292d;color:#d6d8db;border:1px solid #34383d;border-radius:6px;padding:5px 8px}.exports button{background:#2f4a33;border-color:#3d5f43}.exports button:hover:not(:disabled){background:#38573d}.user{color:#8a8d92;font-size:12px}.stale-banner{display:flex;gap:10px;align-items:center;padding:8px 14px;background:#4a3d1f;color:#e8c76a}.stage{position:relative}.panel{position:absolute;top:12px;left:12px;width:280px;max-height:70%;overflow-y:auto;background:#1a1c1fee;border:1px solid #2a2d31;border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:6px}.panel.right{left:auto;right:12px;width:320px}.panel.right .row{display:flex;align-items:center;gap:6px;font-size:12px}.panel.right p{font-size:12px;line-height:1.5;margin-bottom:8px}.panel.right a{color:#7ec8ff}.muted{color:#8a8d92}.panel-head{display:flex;justify-content:space-between;align-items:center}.panel button{text-align:left}.drawer{display:flex;gap:24px;overflow-x:auto;padding:14px;background:#16181b;border-top:1px solid #2a2d31;max-height:40vh;overflow-y:auto}.drawer section{min-width:210px}.drawer h3{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#8a8d92;margin-bottom:8px}.drawer label{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.drawer .row{display:flex;align-items:center;gap:6px;margin-bottom:6px;flex-wrap:wrap}.light-row{border-top:1px solid #26292d;padding-top:6px;margin-top:6px}.people-list{display:flex;flex-direction:column;gap:4px;margin-top:8px;font-size:12px}.people-list strong{color:#8a8d92;font-size:10px;text-transform:uppercase;letter-spacing:.08em}.people-list .row{justify-content:space-between}.session-list{display:flex;flex-direction:column;gap:4px;margin-top:6px}.session-list button{text-align:left;font-size:12px}.obj-chips{position:absolute;left:16px;bottom:18px;z-index:5;display:flex;gap:6px;padding:6px;border-radius:12px;background:#16181bcc;border:1px solid #2e3238;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.obj-chips button{padding:8px 12px;border-radius:8px}.obj-chips button.active{background:#3d5a80;border-color:#4d6a90;color:#fff}.axis-pad{position:absolute;right:18px;bottom:18px;display:grid;grid-template-columns:auto auto auto;align-items:center;gap:10px;padding:12px;background:#16181bcc;border:1px solid #2e3238;border-radius:16px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:.85;z-index:5;touch-action:none;user-select:none;-webkit-user-select:none}.axis-pad:hover{opacity:1}.pad-col{display:flex;flex-direction:column;align-items:center;gap:6px}.pad-mid{gap:8px}.joy{position:relative;width:84px;height:84px;border-radius:50%;background:radial-gradient(circle at 50% 42%,#24272b,#191b1e 72%);border:1px solid #34383d;box-shadow:inset 0 2px 8px #0008;display:flex;align-items:center;justify-content:center;cursor:grab;touch-action:none}.joy:active{cursor:grabbing}.joy-knob{width:34px;height:34px;border-radius:50%;background:linear-gradient(#4a5058,#33373d);border:1px solid #565c64;box-shadow:0 2px 6px #000a;pointer-events:none;transition:transform .06s linear}.joy-label{position:absolute;bottom:-16px;font-size:9px;letter-spacing:.14em;color:#7d828a;pointer-events:none}.pad-btn{width:38px;height:38px;padding:0;font-size:16px;color:#c8ccd2;background:linear-gradient(#26292d,#1d2023);border:1px solid #34383d;border-radius:10px;touch-action:none;user-select:none;-webkit-user-select:none}.pad-btn:active{background:#3d5a80;border-color:#4d6a90}.pad-speed{grid-column:1 / -1;display:flex;justify-content:center;gap:4px;margin-top:8px}.pad-speed button{padding:4px 12px;font-size:11px;color:#8a8d92;background:#101214;border:1px solid #2e3238;border-radius:8px}.pad-speed button.active{color:#fff;background:#3d5a80;border-color:#4d6a90}.pad-dutch{grid-column:1 / -1;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px}.dutch-readout{min-width:56px;padding:8px 10px;font-variant-numeric:tabular-nums;font-size:13px;color:#c8ccd2;background:#101214;border:1px solid #2e3238;border-radius:10px}.dutch-readout:hover{border-color:#4d6a90}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100}.markup{display:flex;flex-direction:column;gap:10px;max-width:92vw;max-height:92vh}.downloads{display:flex;align-items:center;gap:14px;padding:8px 14px;background:#1d2b1f;border-top:1px solid #2f4a33;font-size:12px;flex-wrap:wrap}.downloads a{color:#8fd19a;text-decoration:none}.downloads a:hover{text-decoration:underline}.help{display:flex;width:min(860px,92vw);height:min(600px,86vh);background:#16181b;border:1px solid #2e3238;border-radius:14px;overflow:hidden}.help-nav{display:flex;flex-direction:column;gap:2px;width:210px;padding:14px 10px;background:#101214;border-right:1px solid #26292d;overflow-y:auto}.help-nav strong{padding:4px 10px 10px;letter-spacing:.06em;text-transform:uppercase;font-size:11px;color:#8a8d92}.help-nav button{text-align:left;background:none;border:none;padding:7px 10px;border-radius:7px}.help-nav button.active{background:#26292d;color:#fff}.help-body{flex:1;padding:18px 24px;overflow-y:auto;font-size:13px;line-height:1.65}.help-body h2{font-size:16px}.help-body p,.help-body ul,.help-body ol{margin-bottom:10px}.help-body ul,.help-body ol{padding-left:20px}.help-body li{margin-bottom:4px}.help-body code{background:#101214;padding:1px 5px;border-radius:4px;font-size:12px}.markup-title{letter-spacing:.04em}.markup-tools{display:flex;gap:6px;align-items:center}.markup-tools .spacer{flex:1}.markup-tools .swatch{width:26px;height:26px;border-radius:50%;padding:0}.markup-tools .swatch.active{outline:2px solid #fff}.markup-tools .primary{background:#2f4a33;border-color:#3d5f43}.markup-canvas{max-width:92vw;max-height:82vh;object-fit:contain;cursor:crosshair;border:1px solid #3a3d41}.login{display:flex;height:100%;align-items:center;justify-content:center}.login-card{width:340px;padding:32px;background:#1a1c1f;border:1px solid #2a2d31;border-radius:12px}.login-card h1{font-size:18px;font-weight:600;letter-spacing:.04em;margin-bottom:16px}.login-card form{display:flex;flex-direction:column;gap:10px}.login-card input{background:#26292d;color:#d6d8db;border:1px solid #34383d;border-radius:6px;padding:9px 12px}.login-switch{background:none;border:none;color:#7ec8ff;font-size:12px;cursor:pointer}.login-warn{color:#e8c76a;font-size:12px}.boot-loading,.boot-error{display:flex;height:100%;align-items:center;justify-content:center;color:#8a8d92}.boot-error{color:#d98080}
