*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{width:100vw;height:100vh;background:#000;position:relative;overflow:hidden}.app>*{pointer-events:none}.app .studio-panel,.app .background-canvas,.app .top-bar{pointer-events:auto}button[style*=fixed]{pointer-events:auto!important}.top-bar{position:fixed;top:0;left:0;right:0;height:56px;background:#191919e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px #ffffff14;display:flex;align-items:center;padding:0 24px;z-index:10002}.top-bar-logo{display:flex;align-items:center;gap:12px;text-decoration:none;cursor:pointer;transition:opacity .2s ease;flex-shrink:0;z-index:1}.top-bar-logo:hover{opacity:.8}.top-bar-logo img{height:32px;width:auto}.top-bar-logo span{color:#fff;font-size:18px;font-weight:600;letter-spacing:.5px}.top-bar-nav{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:4px}.nav-item{padding:8px 20px;color:#fff9;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;position:relative}.nav-item:hover{color:#ffffffe6}.nav-item.active{color:#4a9eff}.nav-indicator{position:absolute;bottom:0;left:0;right:0;height:3px;background:#4a9eff;border-radius:3px 3px 0 0}.top-bar-actions{position:absolute;right:24px;display:flex;align-items:center;gap:12px;z-index:1}.background-viewer{position:fixed;inset:56px 0 0;background:#0a0a0a;z-index:0}.background-canvas{width:100%;height:100%;pointer-events:auto;transform:translate(-20%)}.background-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.studio-panel{width:440px;max-height:calc(100vh - 140px);background:#282828eb;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-radius:12px;border:1px solid rgba(255,255,255,.12);box-shadow:0 20px 60px #0009;overflow:hidden;z-index:1000;pointer-events:auto}.panel-header{padding:16px 20px;background:#32323280;border-bottom:1px solid rgba(255,255,255,.05);cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;align-items:center;justify-content:space-between;gap:12px}.panel-header:active{cursor:grabbing}.panel-header-left{display:flex;align-items:center;gap:12px}.panel-header-logo{height:28px;width:auto}.panel-header-content{display:flex;flex-direction:column}.panel-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:2px}.panel-subtitle{font-size:11px;color:#ffffff80}.drag-indicator{display:flex;align-items:center;justify-content:center;color:#ffffff4d;transition:color .2s;padding:4px}.panel-header:hover .drag-indicator{color:#ffffff80}.panel-header:active .drag-indicator{color:#4a9eff99}.panel-content{padding:24px 20px;max-height:calc(100vh - 240px);overflow-y:auto}.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-track{background:#ffffff05}.panel-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.panel-content::-webkit-scrollbar-thumb:hover{background:#ffffff26}.panel-section{margin-bottom:28px}.panel-section:last-child{margin-bottom:0}.section-title{font-size:13px;font-weight:600;color:#ffffffe6;margin-bottom:12px;letter-spacing:.3px}.section-description{font-size:12px;color:#ffffff80;margin-bottom:16px;line-height:1.5}.upload-zone{border:1.5px dashed rgba(74,158,255,.25);border-radius:8px;padding:32px 16px;text-align:center;cursor:pointer;transition:all .3s;background:#4a9eff05}.upload-zone:hover{border-color:#4a9eff66;background:#4a9eff0d}.upload-zone.has-preview{padding:0;border:1.5px solid rgba(74,158,255,.3)}.upload-icon{margin-bottom:12px;display:flex;justify-content:center}.upload-text{font-size:13px;color:#ffffffb3;margin-bottom:4px}.upload-hint{font-size:11px;color:#fff6}.preview-image{width:100%;height:200px;-o-object-fit:cover;object-fit:cover;border-radius:6px}.primary-button{width:100%;padding:12px 20px;background:#4a9eff;color:#fff;font-size:13px;font-weight:600;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.primary-button:hover{background:#5ca8ff;transform:translateY(-1px)}.primary-button:active{transform:translateY(0)}.primary-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.secondary-button{padding:10px 16px;background:#ffffff14;color:#fffc;font-size:12px;font-weight:500;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.secondary-button:hover{background:#ffffff1f;border-color:#fff3}.projects-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.create-project-button{padding:8px 16px;background:#4a9eff26;color:#4a9eff;font-size:12px;font-weight:600;border:1px solid rgba(74,158,255,.3);border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.create-project-button:hover{background:#4a9eff40;border-color:#4a9eff80}.project-item{padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:6px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;transition:all .2s}.project-item:hover{background:#ffffff0d;border-color:#ffffff1a}.project-info h4{font-size:13px;color:#ffffffe6;margin-bottom:4px}.project-info p{font-size:11px;color:#fff6}.project-actions{display:flex;gap:8px}.icon-button{width:28px;height:28px;background:#ffffff0d;border:none;border-radius:4px;color:#fff9;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-button:hover{background:#ffffff1a;color:#ffffffe6}.processing-state{text-align:center;padding:32px 16px}.processing-spinner{width:48px;height:48px;margin:0 auto 16px;border:3px solid rgba(74,158,255,.2);border-top-color:#4a9eff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.processing-text{font-size:14px;color:#fffc;margin-bottom:8px}.processing-subtext{font-size:12px;color:#ffffff80}.viewer-controls{display:flex;gap:8px;margin-top:16px}.viewer-control-button{flex:1;padding:10px;background:#ffffff14;color:#fffc;font-size:12px;font-weight:500;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s;position:relative;overflow:hidden}.viewer-control-button:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#4a9eff1a,#4a9eff0d);opacity:0;transition:opacity .3s;z-index:0}.viewer-control-button>*{position:relative;z-index:1}.viewer-control-button:hover{background:#ffffff1f;border-color:#fff3;transform:translateY(-1px)}.viewer-control-button.active{background:#4a9eff33;border-color:#4a9eff66;color:#4a9eff;box-shadow:0 0 16px #4a9eff4d,inset 0 1px #ffffff1a}.viewer-control-button.active:before{opacity:1}.viewer-control-button.active svg{filter:drop-shadow(0 0 4px rgba(74,158,255,.5))}@media(max-width:1024px){.studio-panel{right:20px;width:380px}}@media(max-width:768px){.studio-panel{right:16px;left:16px;width:auto;max-width:none}.top-bar-nav{display:none}.top-bar-actions{right:16px}}.quick-action-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffb3;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.quick-action-button:hover{background:#ffffff1a;border-color:#fff3;color:#ffffffe6}.quick-action-button.active{background:#4a9eff26;border-color:#4a9eff4d;color:#4a9eff;box-shadow:0 0 12px #4a9eff33}.quick-action-button.active:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(74,158,255,.1) 0%,transparent 70%);animation:pulse 2s ease-in-out infinite;z-index:0}.quick-action-button>*{position:relative;z-index:1}@keyframes pulse{0%,to{opacity:.5;transform:scale(.95)}50%{opacity:1;transform:scale(1.05)}}.help-tips{display:flex;flex-direction:column;gap:12px;margin-top:12px}.help-tip{display:flex;align-items:center;gap:12px;padding:12px;background:#4a9eff0d;border:1px solid rgba(74,158,255,.1);border-radius:8px}.tip-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#4a9eff33;border-radius:50%;font-size:12px;font-weight:600;color:#4a9eff;flex-shrink:0}.tip-text{font-size:13px;color:#ffffffb3;line-height:1.5}.controls-hint{margin-top:16px;padding:12px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px}.hint-item{font-size:12px;color:#fff9;line-height:1.8;display:flex;align-items:center;gap:8px}.hint-item strong{color:#fffc;font-weight:500}.progress-bar-container{margin-top:20px;width:100%}.progress-bar{width:100%;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4a9eff,#6bb3ff);border-radius:3px;transition:width .3s ease}.progress-text{font-size:12px;color:#ffffff80;text-align:center}.success-overlay{position:absolute;inset:0;background:#4a9effe6;display:flex;align-items:center;justify-content:center;border-radius:12px;color:#fff}.mobile-bottom-sheet{position:fixed;bottom:0;left:0;right:0;background:#191919fa;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-radius:24px 24px 0 0;box-shadow:0 -8px 32px #0009,0 -1px #ffffff1a;z-index:1000;overflow:hidden;touch-action:none;pointer-events:auto;will-change:height,transform}.mobile-sheet-backdrop{position:fixed;inset:0;background:#00000080;z-index:999;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.sheet-handle-container{padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;pointer-events:auto}.sheet-handle{width:40px;height:5px;background:#ffffff4d;border-radius:3px;transition:all .3s cubic-bezier(.4,0,.2,1)}.sheet-handle-container:active .sheet-handle{background:#4a9eff99;transform:scaleX(1.2)}.sheet-handle-hint{font-size:12px;color:#ffffff80;font-weight:500;letter-spacing:.3px;text-align:center}.sheet-content{overflow-y:auto;max-height:calc(85vh - 80px);-webkit-overflow-scrolling:touch}.studio-panel-mobile{width:100%}.studio-panel-mobile .panel-header{padding:12px 20px;background:#28282880;border-bottom:1px solid rgba(255,255,255,.05)}.studio-panel-mobile .panel-content{padding:20px}.studio-panel-mobile .processing-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px 20px;min-height:200px}.studio-panel-mobile .processing-container .spinner{margin:0}.studio-panel-mobile .processing-container .processing-text{margin:0;text-align:center}.studio-panel-mobile .processing-container .processing-details{margin:0;font-size:13px}@media(max-width:768px){.studio-panel{display:none!important}.background-canvas{transform:none!important;width:100%;height:100%}.top-bar{padding:0 12px;height:52px}.top-bar-logo img{height:28px}.top-bar-logo span{font-size:16px}.top-bar-nav{display:none}.top-bar-actions{display:flex!important;right:12px;gap:8px}.character-studio-cta-button{display:none!important}.quick-action-button{display:flex!important;opacity:1!important;visibility:visible!important;padding:8px;min-width:36px;min-height:36px}.background-viewer{top:52px}.toast{bottom:100px;left:16px;right:16px;transform:none;max-width:none}.upload-zone{padding:24px 12px}.preview-image{height:180px}.primary-button{padding:14px 20px;font-size:14px}.viewer-controls{flex-direction:row;gap:10px}.viewer-control-button{flex:1;font-size:13px}.controls-hint{padding:14px}.hint-item{font-size:13px;line-height:2}.help-tips{gap:10px}.help-tip{padding:14px}.tip-text{font-size:14px}.panel-section{margin-bottom:24px}.section-title{font-size:14px;margin-bottom:10px}.section-description{font-size:13px;margin-bottom:14px}.studio-panel-mobile label{padding:16px!important}}@media(max-width:375px){.top-bar{padding:0 12px;height:48px}.background-viewer{top:48px}.sheet-handle-hint{font-size:11px}.studio-panel-mobile .panel-content{padding:16px}}@media(max-width:896px)and (max-height:414px)and (orientation:landscape){.mobile-bottom-sheet{max-height:90vh}.sheet-content{max-height:80vh}.upload-zone{padding:16px 12px}.preview-image{height:120px}}.progress-container{margin-top:20px;width:100%}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.progress-stage{color:#ffffffe6;font-weight:500}.progress-percentage{color:#8b5cf6;font-weight:600}.progress-bar{height:6px;background:#8b5cf633;border-radius:10px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);box-shadow:0 0 20px #8b5cf680;transition:width .3s ease}.loading-container{position:fixed;inset:0;background:#0a0a0a;display:flex;align-items:center;justify-content:center;z-index:10000}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:20px}.loading-spinner .spinner{width:56px;height:56px;border:4px solid rgba(74,158,255,.15);border-top-color:#4a9eff;border-radius:50%;animation:spin .8s linear infinite;box-shadow:0 0 20px #4a9eff4d}.loading-spinner p{font-size:15px;color:#ffffffb3;font-weight:500;letter-spacing:.3px}
