:root{--xiaoer:#f2a65a;--xiaoer-soft:#ffd9ad;--dudu:#74c8c3;--dudu-soft:#c9edeb;--bg:#fff8f1;--surface:#f6efe6;--soft:#eaf4f4;--text:#4c4a48;--muted:#7a7773;--line:#4c4a4824;--panel:#fff8f1c7;--panel-strong:#fffcf7f0;--shadow:0 18px 58px #84603829;--status-color:var(--dudu);--font:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;color:var(--text);background:var(--bg);font:16px/1.5 var(--font);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-gesture-tone=error]{--status-color:#d86a5f}:root[data-gesture-tone=idle]{--status-color:var(--xiaoer)}:root[data-gesture-tone=loading]{--status-color:var(--dudu)}:root[data-gesture-tone=active],:root:not([data-gesture-tone]){--status-color:#83c985}*{box-sizing:border-box}html,body,#app{width:100%;min-width:320px;min-height:100%;margin:0}button,input{font:inherit}button{color:inherit}.app-shell{isolation:isolate;background:radial-gradient(circle at 18% 18%,#f2a65a47,#0000 25rem),radial-gradient(circle at 72% 28%,#74c8c347,#0000 28rem),radial-gradient(circle at 56% 78%,#eaf4f4d1,#0000 30rem),linear-gradient(145deg,#fff8f1 0%,#f6efe6 48%,#eaf4f4 100%);min-height:100svh;position:relative;overflow:hidden}.album-stage{min-height:100svh;position:absolute;inset:0}.three-viewport,.three-canvas{width:100%;height:100%;position:fixed;inset:0}.three-viewport{z-index:1;pointer-events:none;transition:filter .22s,opacity .22s}:root[data-preview-open=true] .three-viewport{filter:brightness(.78)blur(2px)saturate(.86);opacity:.72}.three-canvas{z-index:1;pointer-events:auto;touch-action:manipulation;display:block}.album-stage:after{z-index:2;content:"";opacity:.34;pointer-events:none;background-color:#0000;background-image:linear-gradient(90deg,#ffffff52 1px,#0000 1px),linear-gradient(#ffffff3d 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:96px 96px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 72%);mask-image:radial-gradient(circle,#000,#0000 72%)}.soft-dots{z-index:0;pointer-events:none;background-repeat:repeat;position:absolute;inset:0}.soft-dots-a{opacity:.72;background-image:radial-gradient(circle,#f2a65a61 0 1.2px,#0000 1.7px),radial-gradient(circle,#74c8c35c 0 1.3px,#0000 1.9px);background-position:16px 24px,96px 132px;background-size:138px 178px,226px 252px}.soft-dots-b{filter:blur(.3px);opacity:.58;background-image:radial-gradient(circle,#ffffffe0 0 1.4px,#0000 2px),radial-gradient(circle,#c9edebbd 0 1.6px,#0000 2.2px);background-position:58px 84px,174px 34px;background-size:282px 260px,360px 318px}.album-glow{z-index:0;aspect-ratio:1;filter:blur(48px);opacity:.48;pointer-events:none;border-radius:50%;width:min(40vw,520px);position:absolute}.album-glow-orange{background:#f2a65a80;top:7%;left:18%}.album-glow-mint{background:#74c8c37a;bottom:12%;right:18%}.stage-title{z-index:4;max-width:min(560px,100% - 420px);color:var(--text);position:absolute;top:clamp(22px,4vw,44px);left:clamp(20px,4vw,58px)}.stage-title p,.stage-title h1,.stage-title span,.panel-header p,.panel-header span,.gesture-hint p,.status-card p,.calibration-card p{margin:0}.stage-title p{color:var(--dudu);letter-spacing:.12em;font-size:.78rem;font-weight:800}.stage-title h1{letter-spacing:0;text-shadow:0 8px 26px #f2a65a33;margin-top:4px;font-size:clamp(2.4rem,5.2vw,5.9rem);font-weight:760;line-height:.96}.stage-title span{color:var(--muted);margin-top:12px;font-size:clamp(.96rem,1.6vw,1.2rem);display:block}.control-panel,.camera-preview,.fullscreen-button,.gesture-hint{z-index:5;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);border:1px solid #ffffffb8;position:fixed}.control-panel{border-radius:20px;width:min(326px,100vw - 48px);max-height:calc(100svh - 48px);padding:18px;top:24px;right:24px;overflow:auto}.panel-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:14px;padding-bottom:15px;display:flex}.panel-header p{font-size:1.08rem;font-weight:760}.panel-header span{color:var(--muted);margin-top:3px;font-size:.78rem;display:block}.panel-header i{background:radial-gradient(circle at 36% 36%, #fff, transparent 28%), linear-gradient(135deg, var(--xiaoer), var(--dudu));border-radius:50%;flex:none;width:42px;height:42px;box-shadow:0 10px 22px #74c8c347}.panel-section{padding-top:18px}.gesture-runtime-status{background:#eaf4f49e;border:1px solid #74c8c33d;border-radius:16px;margin-top:14px;padding:12px}.gesture-runtime-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.gesture-runtime-header strong{font-size:.86rem}.gesture-runtime-header button{min-height:30px;color:var(--text);cursor:pointer;background:#ffffffb3;border:1px solid #4c4a4824;border-radius:999px;padding:0 10px}.gesture-runtime-header button:disabled{cursor:wait;opacity:.58}.gesture-runtime-status dl{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px 10px;margin:10px 0 0;display:grid}.gesture-runtime-status dl div{min-width:0}.gesture-runtime-status dt,.gesture-runtime-status dd{margin:0;font-size:.7rem}.gesture-runtime-status dt{color:var(--muted)}.gesture-runtime-status dd{color:#438f8c;overflow-wrap:anywhere}.gesture-runtime-status .gesture-runtime-error{grid-column:1/-1}.panel-section h2,.advanced-panel summary,.debug-panel summary{color:var(--muted);letter-spacing:.08em;margin:0 0 12px;font-size:.77rem;font-weight:800}.preset-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.preset-button,.soft-action-button,.camera-header button,.fullscreen-button,.rotation-toggle-button,.calibration-button,.preview-test-button{cursor:pointer;background:#ffffff85;border:1px solid #4c4a481f;border-radius:999px;min-height:38px;transition:border-color .16s,background .16s,box-shadow .16s,transform .16s}.preset-button:hover,.soft-action-button:hover,.camera-header button:hover,.fullscreen-button:hover,.rotation-toggle-button:hover,.calibration-button:hover,.preview-test-button:hover{background:#ffffffd1;border-color:#74c8c38c;transform:translateY(-1px);box-shadow:0 10px 24px #74c8c329}.control-stack{gap:13px;display:grid}.control-field{color:var(--text);gap:7px;font-size:.9rem;display:grid}.control-field span{justify-content:space-between;align-items:center;gap:12px;display:flex}.control-field output{color:var(--dudu);font-variant-numeric:tabular-nums;font-size:.78rem}.control-field-toggle{grid-template-columns:1fr auto;align-items:center}.control-field-toggle input{width:18px;height:18px;accent-color:var(--dudu)}.control-field input[type=range]{width:100%;accent-color:var(--xiaoer)}.control-field input[type=color]{border:1px solid var(--line);background:#ffffff9e;border-radius:14px;width:100%;height:42px;padding:3px}.panel-actions{grid-template-columns:1fr 1fr;gap:8px;margin-top:16px;display:grid}.gesture-hint{border-radius:18px;gap:12px;max-width:min(380px,100vw - 48px);padding:13px 15px;display:flex;bottom:210px;left:clamp(20px,4vw,58px)}.status-dot{background:var(--status-color);width:10px;height:10px;box-shadow:0 0 18px var(--status-color);border-radius:50%;flex:none;margin-top:7px}.gesture-hint strong{font-size:.92rem;display:block}.gesture-hint p{color:var(--muted);font-size:.82rem}.status-card,.calibration-card,.rotation-status-card{background:#eaf4f480;border:1px solid #74c8c333;border-radius:18px;gap:9px;margin-top:14px;padding:13px;display:grid}.status-card strong,.calibration-card strong,.rotation-status-card strong,.status-card span,.calibration-card span,.rotation-status-card span{display:block}.status-card strong,.calibration-card strong,.rotation-status-card strong{font-size:.9rem}.status-card span,.calibration-card span,.rotation-status-card span,.status-card p,.calibration-card p{color:var(--muted);font-size:.78rem;line-height:1.38}.calibration-progress{background:#4c4a4814;border-radius:999px;height:6px;position:relative;overflow:hidden}.calibration-progress:after{content:"";border-radius:inherit;background:linear-gradient(90deg, var(--xiaoer), var(--dudu));transform:scaleX(var(--calibration-progress,0));transform-origin:0;transition:transform 80ms linear;position:absolute;inset:0}.advanced-panel,.debug-panel{border-top:1px solid var(--line);margin-top:14px;padding-top:14px}.advanced-panel summary,.debug-panel summary{cursor:pointer;margin-bottom:0;list-style-position:outside}.advanced-panel[open] summary,.debug-panel[open] summary{margin-bottom:12px}.debug-panel dl{gap:6px;max-height:250px;margin:12px 0 0;display:grid;overflow:auto}.debug-panel div{color:var(--muted);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;font-size:.76rem;display:grid}.debug-panel dt,.debug-panel dd{margin:0}.debug-panel dd{color:#438f8c;font-variant-numeric:tabular-nums}.preview-test-button{color:#438f8c;width:100%}.camera-preview{border-radius:18px;width:min(306px,100vw - 48px);padding:10px;transition:opacity .18s,transform .18s;bottom:24px;left:24px}:root[data-camera-hidden=true] .camera-preview{opacity:0;pointer-events:none;transform:translateY(18px)scale(.96)}.camera-header{color:var(--muted);justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;font-size:.84rem;font-weight:700;display:flex}.camera-header button{min-height:28px;padding:0 12px;font-size:.78rem}.camera-frame{aspect-ratio:4/3;background:linear-gradient(135deg,#ffd9ad52,#0000 38%),#eaf4f4b3;border:1px solid #74c8c352;border-radius:16px;min-height:168px;display:block;position:relative;overflow:hidden}.camera-frame:after{content:"";pointer-events:none;border:1px solid #74c8c36b;border-radius:16px;width:36%;height:40%;position:absolute;top:30%;left:32%;box-shadow:0 0 16px #74c8c329,inset 0 0 18px #ffffff3d}.camera-video,.camera-canvas{width:100%;height:100%;position:absolute;inset:0}.camera-video{object-fit:cover;transform:scaleX(-1)}.camera-canvas{pointer-events:none;transform:scaleX(-1)}.camera-message{color:var(--text);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff8f1c7;border:1px solid #74c8c338;border-radius:999px;padding:6px 8px;font-size:.82rem;position:absolute;bottom:10px;left:10px;right:10px}.fullscreen-button{border-radius:999px;align-items:center;gap:10px;min-width:104px;padding:0 14px;display:inline-flex;bottom:24px;right:24px}.fullscreen-button span{border:2px solid;border-radius:4px;width:15px;height:15px;box-shadow:inset 0 0 0 4px #ffffff47}.virtual-pointer{left:calc(var(--pointer-x,.5) * 100vw);top:calc(var(--pointer-y,.5) * 100vh);z-index:99998;background:conic-gradient(var(--xiaoer) calc(var(--pointer-progress,0) * 1turn), #74c8c329 0);width:44px;height:44px;opacity:var(--pointer-opacity,0);pointer-events:none;border:2px solid #74c8c38f;border-radius:50%;transition:opacity .18s,transform .16s,border-color .16s;position:fixed;transform:translate(-50%,-50%);box-shadow:0 0 18px #f2a65a3d,0 0 26px #74c8c338}.virtual-pointer:before{content:"";border-radius:inherit;background:#fff8f1d1;position:absolute;inset:5px}.virtual-pointer:after{content:"";border-radius:inherit;background:linear-gradient(135deg, var(--xiaoer), var(--dudu));position:absolute;inset:15px;box-shadow:0 0 14px #f2a65a73,0 0 18px #74c8c36b}.virtual-pointer[data-hovering=true]{border-color:#f2a65adb;box-shadow:0 0 28px #f2a65a5c,0 0 26px #74c8c342}.virtual-pointer[data-locked=true]{border-color:#74c8c3f0;transform:translate(-50%,-50%)scale(1.1);box-shadow:0 0 30px #74c8c375,0 0 28px #f2a65a57}.hover-preview{left:min(max(calc(var(--hover-preview-x,.5) * 100vw + 34px), 18px), calc(100vw - 286px));top:min(max(calc(var(--hover-preview-y,.5) * 100vh - 96px), 18px), calc(100vh - 250px));z-index:6;opacity:1;pointer-events:none;background:#fff8f1e6;border:1px solid #ffffffbd;border-radius:20px;width:268px;transition:opacity .18s,transform .18s;position:fixed;overflow:hidden;transform:translateY(0)scale(1);box-shadow:0 18px 54px #84603833}.hover-preview[aria-hidden=true]{opacity:0;transform:translateY(10px)scale(.94)}.hover-preview img{aspect-ratio:4/5;object-fit:cover;background:var(--surface);width:100%;display:block}.hover-preview div{padding:11px 13px 13px}.hover-preview strong,.hover-preview span{display:block}.hover-preview strong{font-size:.95rem}.hover-preview span{color:var(--muted);margin-top:4px;font-size:.78rem;line-height:1.35}.image-preview{z-index:99999;opacity:1;pointer-events:auto;place-items:center;padding:28px;transition:opacity .18s;display:grid;position:fixed;inset:0}.preview-modal{z-index:2147483647;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-sizing:border-box;opacity:0;pointer-events:none;background:#14121094;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.preview-modal.active{opacity:1!important;pointer-events:auto!important;display:flex!important}.image-preview[aria-hidden=true]{opacity:0;pointer-events:none}.image-preview.is-active{opacity:1;pointer-events:auto}.image-preview-backdrop{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#4c4a4857;position:absolute;inset:0}.image-preview-card{z-index:1;background:#fff8f1f5;border:1px solid #ffffffc2;border-radius:28px;width:min(760px,86vw);margin:0;transition:opacity .22s,transform .26s cubic-bezier(.18,.86,.28,1.08);position:relative;overflow:visible;transform:translateY(0)scale(1);box-shadow:0 28px 90px #4c4a4847,0 0 44px #74c8c333}.preview-content{z-index:2147483647;box-sizing:border-box;background:#fff8f1f0;border-radius:24px;width:min(86vw,960px);max-width:none;max-height:calc(100vh - 48px);padding:18px 18px 20px;animation:.32s ease-out previewPop;position:relative;overflow:hidden auto;box-shadow:0 24px 80px #4c4a4847,0 0 0 2px #f2a65a47}.image-preview[aria-hidden=true] .image-preview-card{opacity:0;transform:translateY(18px)scale(.72)}.image-preview-close,.preview-close{float:right;z-index:10;width:34px;height:34px;color:var(--text);cursor:pointer;background:#ffffffeb;border:none;border-radius:50%;position:sticky;top:0;box-shadow:0 10px 22px #4c4a481f}.image-preview-media{object-fit:contain;background:var(--surface);width:auto;max-width:100%;max-height:62vh;display:block}.preview-image-wrap{clear:both;background:#fff;border-radius:18px;justify-content:center;align-items:center;width:100%;max-height:62vh;display:flex;overflow:hidden}.preview-content img,#preview-image{object-fit:contain;background:#fff;border-radius:18px;width:auto;max-width:100%;height:auto;max-height:62vh;opacity:1!important;visibility:visible!important;display:block!important}.preview-error{color:#a34e45;text-align:center;background:#fff8f1db;border:1px dashed #d86a5f6b;border-radius:18px;place-items:center;width:100%;min-height:min(220px,48vh);padding:28px;display:grid}.preview-error[hidden]{display:none}.image-preview-copy{padding:0 6px 4px}.image-preview-copy p{color:#438f8c;letter-spacing:.08em;margin:0;font-size:.8rem;font-weight:800}.preview-text{text-align:center;margin-top:14px}#preview-title,.image-preview-copy h2{color:#4c4a48;margin:8px 0 6px;font-size:22px;line-height:1.35}#preview-desc,.image-preview-copy span{color:var(--muted);word-break:break-word;margin:0;font-size:15px;line-height:1.7}@keyframes previewPop{0%{opacity:0;transform:translateY(18px)scale(.72)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=860px){.preview-modal{padding:14px}.preview-content{border-radius:20px;width:94vw;max-height:calc(100vh - 28px);padding:14px 14px 18px}.preview-image-wrap,#preview-image{max-height:56vh}#preview-title,.image-preview-copy h2{font-size:18px}#preview-desc,.image-preview-copy span{font-size:14px;line-height:1.6}.stage-title{max-width:calc(100% - 40px)}.control-panel{width:auto;max-height:44svh;top:16px;left:16px;right:16px}.gesture-hint{max-width:none;bottom:168px;left:16px;right:16px}.camera-preview{width:min(238px,100vw - 112px);bottom:16px;left:16px}.camera-frame{min-height:120px}.fullscreen-button{justify-content:center;width:48px;min-width:48px;padding:0;font-size:0;bottom:16px;right:16px}.fullscreen-button span{width:18px;height:18px}}.stage-title{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fff8f175;border:1px solid #ffffff94;border-radius:18px;max-width:min(400px,100% - 390px);padding:12px 16px 14px;top:24px;left:28px;box-shadow:0 12px 34px #84603814}.stage-title h1{margin-top:2px;font-size:clamp(2rem,3.4vw,3.8rem);line-height:1.06}.stage-title span{color:#4c4a489e;margin-top:7px;font-size:clamp(.86rem,1.1vw,1rem)}.control-panel{scrollbar-width:thin;scrollbar-color:#74c8c36b transparent;border-radius:18px;width:320px;max-height:calc(100vh - 116px);padding:12px;top:24px;right:24px;overflow:hidden auto}.album-info-card,.friendly-status-card,.shape-section{background:#fffcf7a3;border:1px solid #4c4a481a;border-radius:14px;padding:14px}.friendly-status-card,.shape-section{margin-top:10px}.panel-header{padding-bottom:10px}.panel-header i{width:34px;height:34px}.album-mode-line,.album-tip{color:var(--muted);margin:10px 0 0;font-size:.78rem}.album-mode-line strong{color:#438f8c}.album-tip{margin-top:3px}.panel-compact-actions{grid-template-columns:1fr 1.25fr;gap:7px;margin-top:11px;display:grid}.panel-compact-actions button{min-width:0;min-height:34px;padding:0 9px;font-size:.72rem}.album-settings{border-top:1px solid var(--line);margin-top:10px;padding-top:9px}.album-settings summary,.advanced-panel summary{color:var(--muted);cursor:pointer;font-size:.74rem;font-weight:760}.album-settings[open] summary,.advanced-panel[open] summary{margin-bottom:12px}.friendly-status-heading{align-items:center;gap:8px;margin-bottom:10px;font-size:.88rem;display:flex}.friendly-status-dot{background:var(--status-color);width:8px;height:8px;box-shadow:0 0 14px var(--status-color);border-radius:50%}.friendly-status-card dl{gap:6px;margin:0;display:grid}.friendly-status-card dl div{justify-content:space-between;align-items:center;gap:12px;display:flex}.friendly-status-card dt,.friendly-status-card dd{margin:0;font-size:.76rem}.friendly-status-card dt{color:var(--muted)}.friendly-status-card dd{color:#438f8c;font-weight:700}.friendly-status-card p{border-top:1px solid var(--line);color:var(--muted);margin:10px 0 0;padding-top:9px;font-size:.74rem}.hidden-interaction-state{display:none!important}.shape-section{padding-top:14px}.shape-section h2{margin-bottom:9px}.preset-grid{gap:6px}.preset-button{min-height:34px;color:var(--muted);background:#ffffff61}.preset-button.is-active{color:#4c4a48;background:linear-gradient(135deg,#ffd9addb,#c9edebe6);border-color:#f2a65a6b;box-shadow:0 8px 18px #f2a65a26}.advanced-panel{margin:10px 4px 0;padding-top:10px}.gesture-runtime-status,.debug-panel,.status-card,.calibration-card,.panel-actions{display:none}.gesture-hint{background:#fff8f1ad;border-radius:14px;max-width:330px;padding:10px 13px;bottom:228px;box-shadow:0 12px 34px #8460381a}.gesture-hint p{font-size:.75rem}.camera-preview{border-radius:18px;width:260px;height:190px;padding:0;transition:width .18s,height .18s,opacity .18s,transform .18s;bottom:24px;left:24px;overflow:hidden}.camera-header{z-index:3;color:#fff;text-shadow:0 1px 8px #4c4a4859;margin:0;position:absolute;top:8px;left:10px;right:8px}.camera-header button{min-height:26px;color:var(--text);background:#fff8f1d6;border-color:#ffffff8f;padding:0 9px;font-size:.7rem}.camera-frame{border-radius:inherit;border:0;width:100%;height:100%;min-height:0}.camera-message{text-overflow:ellipsis;white-space:nowrap;padding:4px 7px;font-size:.68rem;bottom:9px;left:12px;right:12px;overflow:hidden}:root[data-camera-collapsed=true] .camera-preview{width:168px;height:42px}:root[data-camera-collapsed=true] .camera-frame{opacity:0;pointer-events:none}.bottom-toolbar{z-index:12;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fff8f1c7;border:1px solid #ffffffc2;border-radius:999px;gap:7px;padding:6px;display:flex;position:fixed;bottom:22px;right:24px;box-shadow:0 14px 40px #84603824}.toolbar-button{min-height:36px;color:var(--text);cursor:pointer;background:#ffffff8f;border:1px solid #4c4a481a;border-radius:999px;padding:0 13px;font-size:.76rem;font-weight:700}.toolbar-button-primary{color:#fff;background:var(--xiaoer);border-color:#0000;box-shadow:0 8px 18px #f2a65a3d}.toolbar-button:disabled{cursor:wait;opacity:.58}.toolbar-panel-toggle{display:none}.debug-drawer-backdrop{z-index:19;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#4c4a482e;transition:opacity .18s;position:fixed;inset:0}.debug-drawer{z-index:20;opacity:0;pointer-events:none;background:#fff8f1f5;border:1px solid #fffc;border-radius:18px;align-self:center;width:min(390px,100vw - 32px);max-height:70vh;padding:16px;transition:opacity .2s,transform .24s;position:fixed;top:16px;bottom:16px;right:16px;overflow-y:auto;transform:translate(calc(100% + 32px));box-shadow:0 28px 80px #4c4a4838}:root[data-debug-open=true] .debug-drawer-backdrop{opacity:1;pointer-events:auto}:root[data-debug-open=true] .debug-drawer{opacity:1;pointer-events:auto;transform:translate(0)}.debug-drawer header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px;display:flex}.debug-drawer header span,.debug-drawer header h2{margin:0}.debug-drawer header span{color:var(--dudu);letter-spacing:.08em;font-size:.68rem;font-weight:800}.debug-drawer header h2{font-size:1.08rem}.debug-drawer header button{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:999px;min-height:34px;padding:0 12px}.debug-drawer-actions{margin-bottom:12px}.debug-drawer dl{gap:5px;margin:0;display:grid}.debug-drawer dl>div{background:#eaf4f473;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(100px,1.3fr);gap:10px;padding:6px 8px;font-size:.72rem;display:grid}.debug-drawer dt,.debug-drawer dd{overflow-wrap:anywhere;margin:0}.debug-drawer dt{color:var(--muted)}.debug-drawer dd{color:#438f8c;font-variant-numeric:tabular-nums}@media (width<=860px){.stage-title{border-radius:14px;max-width:calc(100% - 24px);padding:9px 12px 10px;top:12px;left:12px}.stage-title h1{font-size:clamp(1.72rem,8vw,2.35rem)}.stage-title span{margin-top:4px;font-size:.76rem}.control-panel{opacity:0;pointer-events:none;border-radius:18px;width:auto;max-height:62svh;transition:opacity .18s,transform .24s;inset:auto 10px 72px;transform:translateY(calc(100% + 90px))}:root[data-mobile-panel-open=true] .control-panel{opacity:1;pointer-events:auto;transform:translateY(0)}.preset-grid{scroll-snap-type:x proximity;display:flex;overflow-x:auto}.preset-button{scroll-snap-align:start;flex:0 0 82px}.camera-preview{border-radius:14px;width:140px;height:105px;bottom:72px;left:12px}.camera-header{font-size:.66rem;top:5px;left:7px;right:5px}.camera-header button{min-height:22px;padding:0 6px;font-size:.62rem}.camera-message{padding:2px 4px;font-size:.56rem;bottom:5px;left:6px;right:6px}:root[data-camera-collapsed=true] .camera-preview{width:132px;height:34px}.gesture-hint{max-width:none;padding:8px 10px;bottom:184px;left:12px;right:12px}.gesture-hint strong{font-size:.78rem}.gesture-hint p{font-size:.68rem}.bottom-toolbar{right:8px;bottom:max(8px, env(safe-area-inset-bottom));border-radius:16px;gap:5px;padding:5px;left:8px;overflow-x:auto}.toolbar-button{flex:none;min-height:38px;padding:0 11px;font-size:.7rem}.toolbar-panel-toggle{display:block}.debug-drawer{border-radius:18px 18px 12px 12px;width:auto;max-height:70vh;inset:auto 8px 8px;transform:translateY(calc(100% + 16px))}:root[data-debug-open=true] .debug-drawer{transform:translateY(0)}.preview-content{overscroll-behavior:contain}}
