: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;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}.preset-button.is-active{color:#fffdf9;background:linear-gradient(135deg, var(--xiaoer), var(--dudu));border-color:#0000;box-shadow:0 12px 26px #f2a65a38}.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}}
