.model-viewer{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1;touch-action:none}.model-viewer canvas{display:block;width:100%;height:100%;touch-action:none}.compare-viewer{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;z-index:1}.compare-panel{flex:1;position:relative;height:100%;overflow:hidden}.compare-panel.original{background:linear-gradient(135deg,#1a1a2e,#16213e)}.compare-panel.edited{background:linear-gradient(135deg,#16213e,#0f3460)}.compare-label{position:absolute;top:20px;left:50%;transform:translate(-50%);padding:8px 20px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;color:#fff;font-size:.9rem;font-weight:500;z-index:10;border:1px solid rgba(255,255,255,.1)}.compare-panel.original .compare-label{background:linear-gradient(135deg,#4f9fff4d,#00d4ff33);border-color:#4f9fff4d}.compare-panel.edited .compare-label{background:linear-gradient(135deg,#00d4ff4d,#4f9fff33);border-color:#00d4ff4d}.compare-canvas{width:100%;height:100%}.compare-canvas canvas{display:block;width:100%!important;height:100%!important}.compare-divider{width:2px;height:100%;background:linear-gradient(180deg,transparent,rgba(79,159,255,.5),transparent);z-index:5}.compare-sync-hint{position:absolute;bottom:80px;left:50%;transform:translate(-50%);padding:6px 16px;background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:#aaa;font-size:.75rem;z-index:10;display:flex;align-items:center;gap:6px}.compare-sync-hint:before{content:"🔄";font-size:.8rem}@media (max-width: 768px){.compare-viewer{flex-direction:column}.compare-panel{flex:none;height:50%;width:100%}.compare-divider{width:100%;height:2px;background:linear-gradient(90deg,transparent,rgba(79,159,255,.5),transparent)}.compare-label{font-size:.8rem;padding:6px 14px}}.overlay-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:50;pointer-events:auto;background:transparent;touch-action:none}.overlay-toolbar{position:fixed;top:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;padding:12px 20px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.1);z-index:51;box-shadow:0 8px 32px #0006;max-width:90vw;overflow-x:auto}.toolbar-section{display:flex;align-items:center;gap:10px;flex-shrink:0}.toolbar-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.toolbar-divider{width:1px;height:30px;background:#ffffff1a;flex-shrink:0}.tool-buttons{display:flex;gap:6px}.tool-btn{width:38px;height:38px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff0d;cursor:pointer;font-size:1.1rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.tool-btn:hover{background:#ffffff1a;transform:translateY(-2px)}.tool-btn.active{background:linear-gradient(135deg,#4f9fff66,#00d4ff4d);border-color:#4f9fff99;box-shadow:0 0 15px #4f9fff66}.color-palette{display:flex;gap:4px;flex-wrap:wrap;max-width:100px}.color-btn{width:22px;height:22px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:all .2s;padding:0}.color-btn:hover{transform:scale(1.2)}.color-btn.active{border-color:#fff;box-shadow:0 0 10px #ffffff80}.line-width-slider{width:70px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.line-width-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:linear-gradient(135deg,#4f9fff,#00d4ff);border-radius:50%;cursor:pointer}.line-width-value{font-size:.75rem;color:#4f9fff;min-width:20px}.action-buttons{display:flex;gap:6px}.action-btn{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#ffffff0d;cursor:pointer;font-size:1rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover:not(:disabled){background:#ffffff1a;transform:translateY(-2px)}.action-btn:disabled{opacity:.4;cursor:not-allowed}.action-btn.danger{background:#ff64641a;border-color:#ff646433}.action-btn.danger:hover{background:#ff646433}.action-btn.primary{background:#4f9fff33;border-color:#4f9fff4d}.action-btn.primary:hover{background:#4f9fff4d}.text-input-overlay{position:fixed;display:flex;gap:6px;align-items:center;background:#000000e6;padding:10px;border-radius:10px;border:1px solid rgba(79,159,255,.4);z-index:52;box-shadow:0 8px 32px #00000080;animation:popIn .2s ease}@keyframes popIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.text-input{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 12px;color:#fff;font-size:.95rem;outline:none;min-width:180px}.text-input:focus{border-color:#4f9fff99;box-shadow:0 0 10px #4f9fff33}.text-input::placeholder{color:#666}.text-confirm-btn,.text-cancel-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.text-confirm-btn{background:#2ed5734d;color:#2ed573}.text-confirm-btn:hover{background:#2ed57380}.text-cancel-btn{background:#ff64644d;color:#ff6464}.text-cancel-btn:hover{background:#ff646480}.overlay-hint{position:fixed;top:90px;left:50%;transform:translate(-50%);padding:10px 20px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;color:#fff;font-size:.85rem;z-index:51;border:1px solid rgba(255,255,255,.1);animation:fadeIn .3s ease}.close-overlay-btn{position:fixed;top:20px;right:20px;width:40px;height:40px;border:1px solid rgba(255,255,255,.2);border-radius:50%;background:#0009;color:#fff;font-size:1.2rem;cursor:pointer;z-index:51;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-overlay-btn:hover{background:#ff64644d;border-color:#ff646466;transform:rotate(90deg)}@media (max-width: 1200px){.overlay-toolbar{top:10px;padding:10px 16px;gap:12px;flex-wrap:wrap;justify-content:center}.toolbar-section{gap:8px}.toolbar-label{display:none}.color-palette{max-width:80px}.color-btn{width:18px;height:18px}.overlay-hint{top:140px}}@media (max-width: 768px){.overlay-toolbar{top:calc(56px + env(safe-area-inset-top,0px));left:10px;right:10px;transform:none;gap:8px;padding:8px}.toolbar-divider{display:none}.toolbar-section{width:auto}.overlay-hint{top:calc(130px + env(safe-area-inset-top,0px));font-size:.75rem;padding:6px 14px}.close-overlay-btn{top:calc(56px + env(safe-area-inset-top,0px));right:calc(10px + env(safe-area-inset-right,0px));width:36px;height:36px}}.face-panel{position:fixed;width:320px;max-height:80vh;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.1);z-index:1200;overflow:hidden;display:flex;flex-direction:column;transition:width .3s ease,opacity .3s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none}.face-panel.dragging{opacity:.9;box-shadow:0 8px 32px #0006;cursor:grabbing}.panel-drag-handle{cursor:grab}.panel-drag-handle:active{cursor:grabbing}.drag-icon{color:#fff6;flex-shrink:0;pointer-events:none}.face-panel-header{padding:14px 16px;background:linear-gradient(135deg,#4f9fff4d,#00d4ff1a);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.face-panel-title{font-size:1.1rem;font-weight:600;color:#4f9fff}.face-panel-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.face-panel-toggle:hover{background:#4f9fff4d;border-color:#4f9fff80}.face-panel.collapsed{width:auto;min-width:160px}.face-panel.collapsed .face-panel-header{border-bottom:none}.face-panel.collapsed .face-tabs,.face-panel.collapsed .face-content,.face-panel.collapsed .quick-actions{display:none}.face-panel-chevron{color:#4f9fff;font-size:.8rem}.face-tabs{display:flex;flex-wrap:wrap;gap:4px;padding:12px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0;max-height:100px;overflow-y:auto}.face-tab{padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#aaa;font-size:.8rem;cursor:pointer;transition:all .3s}.face-tab:hover{background:#4f9fff33;color:#fff}.face-tab.active{background:linear-gradient(135deg,#4f9fff,#00d4ff);color:#fff;border-color:transparent}.face-content{flex:1;overflow-y:auto;padding:12px;min-height:0}.face-panel-content{display:block}.morph-control{margin-bottom:12px}.morph-label{display:block;font-size:.8rem;color:#ccc;margin-bottom:6px}.slider-container{display:flex;align-items:center;gap:10px}.morph-slider{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:#ffffff1a;border-radius:3px;outline:none}.morph-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:linear-gradient(135deg,#4f9fff,#00d4ff);border-radius:50%;cursor:pointer;transition:transform .2s}.morph-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.morph-slider::-moz-range-thumb{width:16px;height:16px;background:linear-gradient(135deg,#4f9fff,#00d4ff);border-radius:50%;cursor:pointer;border:none}.morph-value{font-size:.75rem;color:#4f9fff;min-width:32px;text-align:right}.quick-actions{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.quick-btn{flex:1;padding:8px 12px;background:#4f9fff33;border:1px solid rgba(79,159,255,.3);border-radius:8px;color:#4f9fff;font-size:.8rem;cursor:pointer;transition:all .3s}.quick-btn:hover{background:#4f9fff4d;transform:translateY(-2px)}.face-content::-webkit-scrollbar,.face-tabs::-webkit-scrollbar,.panel-drawer-body::-webkit-scrollbar{width:6px}.face-content::-webkit-scrollbar-track,.face-tabs::-webkit-scrollbar-track,.panel-drawer-body::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.face-content::-webkit-scrollbar-thumb,.face-tabs::-webkit-scrollbar-thumb,.panel-drawer-body::-webkit-scrollbar-thumb{background:#4f9fff4d;border-radius:3px}.face-content::-webkit-scrollbar-thumb:hover,.face-tabs::-webkit-scrollbar-thumb:hover,.panel-drawer-body::-webkit-scrollbar-thumb:hover{background:#4f9fff80}.sculpt-panel{position:fixed;width:280px;max-height:80vh;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.1);z-index:1200;overflow:hidden;display:flex;flex-direction:column;padding:16px;transition:width .3s ease,opacity .3s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none}.sculpt-panel.dragging{opacity:.9;box-shadow:0 8px 32px #0006;cursor:grabbing}.sculpt-panel .panel-drag-handle{margin:-16px -16px 0;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1);cursor:grab}.sculpt-panel.collapsed{width:auto;min-width:160px;padding:0}.sculpt-panel.collapsed .sculpt-section,.sculpt-panel.collapsed .sculpt-divider,.sculpt-panel.collapsed .sculpt-hints{display:none}.sculpt-panel.collapsed .sculpt-header{border-bottom:none;margin:0;padding:14px 16px}.sculpt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.sculpt-title{font-size:1rem;font-weight:600;color:#4f9fff}.sculpt-toggle{display:flex;align-items:center;gap:8px;cursor:pointer}.sculpt-toggle input{display:none}.toggle-slider{width:44px;height:24px;background:#fff3;border-radius:12px;position:relative;transition:all .3s;flex-shrink:0}.toggle-slider:before{content:"";position:absolute;width:20px;height:20px;background:#fff;border-radius:50%;top:2px;left:2px;transition:all .3s}.sculpt-toggle input:checked+.toggle-slider{background:linear-gradient(135deg,#4f9fff,#00d4ff)}.sculpt-toggle input:checked+.toggle-slider:before{left:22px}.toggle-label{font-size:.75rem;color:#aaa;min-width:32px}.sculpt-section{margin-bottom:16px}.sculpt-section-title{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#ccc;margin-bottom:10px;font-weight:500}.value-display{color:#4f9fff;font-size:.75rem}.brush-types{display:grid;grid-template-columns:1fr 1fr;gap:8px}.brush-type-btn{padding:10px 8px;background:#ffffff0d;border:2px solid transparent;border-radius:8px;color:#aaa;font-size:.8rem;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:4px}.brush-type-btn:hover{background:#ffffff1a;color:#fff}.brush-type-btn.active{background:#ffffff1a;border-color:var(--brush-color, #4f9fff);color:var(--brush-color, #4f9fff);box-shadow:0 0 10px #0000004d}.sculpt-slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;background:#ffffff1a;border-radius:3px;outline:none}.sculpt-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:linear-gradient(135deg,#4f9fff,#00d4ff);border-radius:50%;cursor:pointer;transition:transform .2s}.sculpt-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.sculpt-divider{height:1px;background:#ffffff1a;margin:16px 0}.history-controls{display:flex;gap:6px}.history-btn{flex:1;padding:8px 6px;background:#4f9fff26;border:1px solid rgba(79,159,255,.2);border-radius:6px;color:#4f9fff;font-size:.75rem;cursor:pointer;transition:all .3s}.history-btn:hover:not(:disabled){background:#4f9fff40;transform:translateY(-1px)}.history-btn:disabled{opacity:.4;cursor:not-allowed}.history-btn.clear{background:#ff646426;border-color:#ff646433;color:#ff6464}.history-btn.clear:hover{background:#ff646440}.history-btn.reset{background:#ffa03c26;border-color:#ffa03c33;color:#ffa03c}.history-btn.reset:hover{background:#ffa03c40}.sculpt-hints{margin-top:8px;padding:12px;background:#ffffff0d;border-radius:8px;font-size:.75rem;color:#888}.hint{color:#4f9fff;margin-bottom:6px;font-weight:500}.hint-item{margin:3px 0;padding-left:4px}@media (max-width: 1200px){.sculpt-panel{width:240px}.face-panel{width:280px}}@media (max-width: 1024px){.panel-fab{position:fixed;z-index:1200;display:flex;align-items:center;justify-content:center;gap:4px;padding:7px 12px;border-radius:20px;background:#00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);color:#fff;font-size:.78rem;cursor:pointer;box-shadow:0 2px 10px #0003;transition:all .3s cubic-bezier(.4,0,.2,1)}.panel-fab.hidden{opacity:0;pointer-events:none;transform:scale(.8)}.panel-fab:active{transform:scale(.95)}.panel-fab-icon{font-size:1rem}.panel-fab-label{font-weight:500}.face-fab{right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px))}.sculpt-fab{left:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px))}.panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0003;z-index:1201;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.panel-drawer{position:fixed;top:auto;left:0;right:0;bottom:0;width:100%;max-width:100%;height:auto;max-height:32vh;background:#0a0a12d9;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-left:none;border-top:1px solid rgba(255,255,255,.08);border-radius:16px 16px 0 0;z-index:1202;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding-top:0;padding-bottom:env(safe-area-inset-bottom,0px)}.panel-drawer.open{transform:translateY(0)}.panel-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;gap:8px}.panel-drawer-title{font-size:1rem;font-weight:600;color:#4f9fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-drawer-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.drawer-action-btn{width:32px;height:32px;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .2s}.drawer-action-btn:hover{background:#4f9fff4d;border-color:#4f9fff80}.drawer-action-btn.active{background:#4f9fff4d;border-color:#4f9fff80;color:#4f9fff}.drawer-action-btn.close:hover{background:#ff64644d;border-color:#ff646480}.panel-drawer-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.panel-drawer-body.translucent{opacity:.35}.face-drawer .face-tabs{padding:8px;max-height:70px;gap:3px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.face-drawer .face-tab{padding:5px 10px;font-size:.75rem;border-radius:5px}.face-drawer .face-content{padding:10px;flex:1;min-height:0}.face-drawer .morph-control{margin-bottom:8px}.face-drawer .morph-label{font-size:.75rem;margin-bottom:4px}.face-drawer .morph-slider{height:5px}.face-drawer .morph-slider::-webkit-slider-thumb{width:14px;height:14px}.face-drawer .morph-value{font-size:.7rem;min-width:26px}.face-drawer .quick-actions{padding:8px;gap:6px;border-top:1px solid rgba(255,255,255,.08);flex-shrink:0}.face-drawer .quick-btn{padding:6px 10px;font-size:.75rem;border-radius:6px}.sculpt-drawer .sculpt-section{padding:0 14px;margin-bottom:12px}.sculpt-drawer .sculpt-enable-row{padding:14px;margin-bottom:8px;margin-top:4px}.sculpt-drawer .sculpt-section-title{font-size:.8rem;margin-bottom:8px}.sculpt-drawer .sculpt-slider{height:5px}.sculpt-drawer .sculpt-slider::-webkit-slider-thumb{width:14px;height:14px}.sculpt-drawer .sculpt-divider{margin:10px 14px}.sculpt-drawer .sculpt-hints{margin:6px 14px 14px;padding:10px;font-size:.72rem}.sculpt-drawer .history-controls{padding:0 14px 12px;gap:4px}.sculpt-drawer .history-btn{padding:7px 4px;font-size:.72rem}.sculpt-toggle-large{display:flex;align-items:center;gap:10px;cursor:pointer;padding:4px 0}.sculpt-toggle-large input{display:none}.sculpt-toggle-large .toggle-slider{width:48px;height:26px;background:#ffffff26;border-radius:13px;position:relative;transition:all .3s;flex-shrink:0}.sculpt-toggle-large .toggle-slider:before{content:"";position:absolute;width:22px;height:22px;background:#fff;border-radius:50%;top:2px;left:2px;transition:all .3s}.sculpt-toggle-large input:checked+.toggle-slider{background:linear-gradient(135deg,#4f9fff,#00d4ff)}.sculpt-toggle-large input:checked+.toggle-slider:before{left:24px}.sculpt-toggle-large .toggle-text{font-size:.85rem;color:#ccc;font-weight:500}.sculpt-toggle-large input:checked~.toggle-text{color:#4f9fff}}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1300;transition:opacity .5s ease}.spinner{width:60px;height:60px;border:4px solid rgba(79,159,255,.2);border-radius:50%;border-top-color:#4f9fff;animation:spin 1s ease-in-out infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1.2rem;margin-bottom:15px;color:#4f9fff}.progress-bar{width:320px;max-width:80vw;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.progress{height:100%;background:linear-gradient(90deg,#4f9fff,#00d4ff);transition:width .2s ease}.loading-stats{margin-top:16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.loading-percent{font-size:1.5rem;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.loading-detail{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center;font-size:.85rem;color:#aaa}.stat-item{display:inline-flex;align-items:center;gap:4px}.stat-label{color:#888}.stat-value{color:#fff;font-weight:500;font-variant-numeric:tabular-nums}.stat-speed{color:#00d4ff}.stat-divider{color:#fff3}.stat-hint{color:#666;font-size:.8rem}.error-message{background:#dc3545e6;padding:30px;border-radius:16px;text-align:center;max-width:500px;margin:20px}.error-title{font-size:1.5rem;margin-bottom:15px;font-weight:600;color:#fff}.error-detail{font-size:1rem;margin-bottom:20px;opacity:.9;color:#fff}.retry-btn{padding:10px 24px;background:#fff;border:none;border-radius:8px;color:#dc3545;font-size:1rem;cursor:pointer;transition:all .3s}.retry-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}@media (max-width: 768px){.progress-bar{width:260px}.loading-text{font-size:1rem}.loading-percent{font-size:1.3rem}.loading-detail{font-size:.8rem}}.info-panel{position:fixed;bottom:80px;left:20px;background:#00000073;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:14px 18px;border-radius:12px;max-width:220px;border:1px solid rgba(255,255,255,.08);z-index:1200;color:#fff}.info-title{font-size:1.1rem;margin-bottom:8px;color:#4f9fff;font-weight:600}.info-text{font-size:.8rem;line-height:1.5;margin-bottom:4px;color:#ccc}.model-info{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}@media (max-width: 1024px){.info-fab{right:12px;top:calc(56px + env(safe-area-inset-top,0px));left:auto}.info-drawer .panel-drawer-body{padding:14px}.info-fps-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.info-fps-label{font-size:.8rem;color:#888}.info-fps-value{font-size:.9rem;font-weight:600;color:#4f9fff;font-variant-numeric:tabular-nums}.info-section-title{font-size:.75rem;color:#888;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.info-divider{height:1px;background:#ffffff0f;margin:12px 0}.info-drawer .info-text{font-size:.8rem;line-height:1.6;margin-bottom:4px;color:#ccc}}.controls-bar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:10px;z-index:1200;padding:10px 20px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;border:1px solid rgba(255,255,255,.1);align-items:center}.mode-switcher{display:flex;gap:6px;background:#ffffff0d;padding:4px;border-radius:20px}.mode-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;border-radius:16px;color:#aaa;font-size:.85rem;cursor:pointer;transition:all .3s}.mode-btn:hover{background:#ffffff1a;color:#fff}.mode-btn.active{background:linear-gradient(135deg,#4f9fff,#00d4ff);color:#fff;box-shadow:0 4px 15px #4f9fff66}.mode-icon{font-size:1rem}.mode-label{font-weight:500}.controls-divider{width:1px;height:24px;background:#ffffff1a}.control-btn{background:#ffffff1a;color:#fff;border:none;padding:10px 20px;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .3s;white-space:nowrap}.control-btn:hover{background:#4f9fff80;transform:translateY(-2px)}.control-btn:active{transform:translateY(0)}.note-toggle-btn{background:#ffffff1a;border-color:#fff3}.note-toggle-btn:hover{background:#ffffff26}.note-toggle-btn.active{background:linear-gradient(135deg,#ffc1074d,#ff980033);border-color:#ffc10780;color:#ffc107;box-shadow:0 0 15px #ffc1074d}.model-upload-section{display:flex;gap:6px;align-items:center}.upload-btn{background:linear-gradient(135deg,#4f9fff4d,#00d4ff33);border-color:#4f9fff66}.upload-btn:hover:not(:disabled){background:linear-gradient(135deg,#4f9fff66,#00d4ff4d);box-shadow:0 0 15px #4f9fff4d}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.reset-model-btn{background:#ffc10733;border-color:#ffc1074d;color:#ffc107}.reset-model-btn:hover{background:#ffc1074d}.controls-fab{position:fixed;top:calc(12px + env(safe-area-inset-top,0px));right:calc(12px + env(safe-area-inset-right,0px));width:36px;height:36px;border-radius:50%;background:#00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1200;transition:all .2s;padding:0;box-shadow:0 2px 10px #0003}.controls-fab:hover{background:#4f9fff4d;border-color:#4f9fff80}.controls-fab:active{transform:scale(.95)}.controls-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000038;z-index:1201;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.controls-drawer{position:fixed;top:0;right:0;width:280px;max-width:80vw;height:100%;height:100dvh;background:#0a0a14d1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.08);z-index:1202;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}.controls-drawer.open{transform:translate(0)}.controls-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.controls-drawer-title{font-size:1rem;font-weight:600;color:#4f9fff}.controls-drawer-close{width:32px;height:32px;border-radius:8px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:all .2s}.controls-drawer-close:hover{background:#ff64644d;border-color:#ff646480}.controls-drawer-body{flex:1;overflow-y:auto;padding:12px}.drawer-section{margin-bottom:12px}.drawer-section-title{font-size:.75rem;color:#888;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.drawer-mode-switcher{display:flex;gap:8px}.drawer-mode-btn{flex:1;padding:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#ccc;font-size:.85rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.drawer-mode-btn.active{background:linear-gradient(135deg,#4f9fff,#00d4ff);border-color:transparent;color:#fff}.drawer-btn{width:100%;padding:10px 12px;margin-bottom:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:#ccc;font-size:.85rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:10px;text-align:left}.drawer-btn:hover:not(:disabled){background:#ffffff1a;color:#fff}.drawer-btn:disabled{opacity:.4;cursor:not-allowed}.drawer-btn.active-blue{background:linear-gradient(135deg,#4f9fff40,#00d4ff26);border-color:#4f9fff66;color:#4f9fff}.drawer-btn.active-yellow{background:linear-gradient(135deg,#ffc10733,#ff98001a);border-color:#ffc10766;color:#ffc107}.drawer-divider{height:1px;background:#ffffff14;margin:12px 0}@media (max-width: 1200px){.controls-bar{flex-wrap:wrap;max-width:95vw;justify-content:center;padding:8px 16px;gap:8px}.controls-divider{display:none}.mode-switcher{order:-1;width:100%;justify-content:center}.model-upload-section{order:-1}}.fps-counter{position:fixed;top:20px;right:360px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:8px 16px;border-radius:20px;font-size:.85rem;color:#4f9fff;z-index:10;border:1px solid rgba(255,255,255,.1)}@media (max-width: 1200px){.fps-counter{right:300px}}@media (max-width: 1024px){.fps-counter{top:calc(12px + env(safe-area-inset-top,0px));left:calc(12px + env(safe-area-inset-left,0px));right:auto;bottom:auto;padding:6px 12px;font-size:.75rem;border-radius:16px}}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f0f2f5;min-height:100vh;color:#333;overflow:hidden;overscroll-behavior:none}.app{position:fixed;top:0;left:0;width:100%;height:100%;height:100dvh;overflow:hidden;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}@supports (padding-top: env(safe-area-inset-top)){.app{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}@media (max-width: 768px){.landing-welcome{display:none!important}}.landing-card{transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease,border-color .35s ease!important}.landing-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #00000040!important}.landing-card-primary:hover{box-shadow:0 20px 50px #1677ff59!important;border-color:#1677ff99!important}.landing-card:hover .landing-card-icon{transform:scale(1.15) rotate(-5deg)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#00000040}.ai-center-hero-card{transition:all .35s cubic-bezier(.34,1.56,.64,1)!important;border:1px solid rgba(255,255,255,.08)!important}.ai-center-hero-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 40px #0003!important}.ai-case-scroll::-webkit-scrollbar{width:4px}.ai-case-scroll::-webkit-scrollbar-thumb{background:#0000001f;border-radius:2px}
