.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#0000008f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-modal-panel{width:min(420px,calc(100vw - 28px));border-radius:24px;background:radial-gradient(120% 120% at 0% 0%,#8104ce38,#8104ce00 54%),#0f1017;border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 64px #00000075;color:#ffffffeb}.login-modal-head{height:58px;padding:18px 18px 0;display:flex;justify-content:flex-end}.login-modal-close{width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.24);background:#ffffff0a;color:#ffffffe6;font-size:20px;cursor:pointer}.login-modal-close:hover{background:#ffffff1f}.login-modal-body{padding:2px 20px 26px;display:flex;flex-direction:column;gap:20px}.login-modal-title{margin:0;font-weight:600;font-size:30px;line-height:120%;letter-spacing:-.035em;text-align:center}.login-modal-description{margin:-10px auto 0;max-width:300px;font-size:14px;line-height:140%;text-align:center;color:#ffffffb8}.login-modal-subtitle{margin:-10px 0 0;color:#ffffff9e;font-size:14px;text-align:center}.login-modal-form{margin-top:0;display:flex;flex-direction:column;gap:12px}.login-modal-oauth-group{display:flex;flex-direction:column;gap:4px}.login-modal-oauth-btn{width:100%;height:50px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff05;color:#ffffffe0;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:14px;cursor:pointer}.login-modal-oauth-btn:hover:not(:disabled){background:#ffffff14}.login-modal-oauth-btn:disabled{opacity:.6;cursor:not-allowed}.login-modal-oauth-icon{width:16px;height:16px;flex-shrink:0}.login-modal-divider{display:flex;align-items:center;gap:12px}.login-modal-divider-line{flex:1;height:1px;background:#ffffff24}.login-modal-divider-text{font-size:13px;color:#ffffff6b}.login-modal-label{color:#ffffffad;font-size:14px}.login-modal-input{min-height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:#ffffffeb;padding:0 12px;outline:none}.login-modal-input:focus{border-color:#b39dffd1}.login-modal-btn{margin-top:6px;min-height:46px;border-radius:12px;font-size:14px;font-weight:600}.login-modal-links{margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:12px}.login-modal-link{background:transparent;border:none;color:#ffffffb8;text-decoration:underline;text-underline-offset:3px;cursor:pointer;padding:0;font-size:14px}.login-modal-link:hover{color:#ffffffeb}.login-modal-message{margin-top:10px;padding:9px 11px;border-radius:10px;font-size:13px}.login-modal-message.error{background:#ff4d4f29;border:1px solid rgba(255,77,79,.5);color:#ffb0b1}.login-modal-message.info{background:#b39dff29;border:1px solid rgba(179,157,255,.42);color:#dccbff}.login-modal-footer-links{margin-top:2px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;font-size:13px;color:#ffffff85}.login-modal-footer-links a{color:#ffffff8f;text-decoration:none}.login-modal-footer-links a:hover{color:#ffffffd9}.login-modal-footer-links span{width:1px;height:12px;background:#fff3}@media(max-width:640px){.login-modal-overlay{align-items:flex-end}.login-modal-panel{width:100%;max-width:none;border-radius:18px 18px 0 0;border-left:none;border-right:none;border-bottom:none}.login-modal-head{height:52px;padding:12px 14px 0}.login-modal-body{padding:0 14px 18px;gap:16px}.login-modal-title{font-size:24px}.login-modal-description,.login-modal-subtitle{font-size:13px}.login-modal-input,.login-modal-btn{min-height:44px}.login-modal-links{flex-wrap:wrap;justify-content:flex-start}.login-modal-footer-links{flex-wrap:wrap;gap:6px}.login-modal-footer-links span{display:none}}.app-sidebar{width:72px;background:radial-gradient(120% 120% at 0% 0%,#8104ce29,#8104ce00 56%),linear-gradient(180deg,#10121cf5,#0c0d14fa);border-right:1px solid rgba(255,255,255,.1);padding:14px 10px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:6px 0 24px #00000047;z-index:20}.app-sidebar-top{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%}.app-sidebar-nav,.app-sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.app-sidebar-icon{width:40px;height:40px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#ffffffe0;border:1px solid transparent;background:transparent;font-size:20px;line-height:1;cursor:pointer;transition:all .2s ease;text-decoration:none}.app-sidebar-icon:hover{background:#ffffff1a;border-color:#ffffff2e;transform:translateY(-1px)}.app-sidebar-icon.active{background:linear-gradient(180deg,#7e5aff8c,#8104ce7a);border-color:#b497ff85;box-shadow:0 8px 18px #8104ce61;color:#fff}.app-sidebar-icon.ghost{color:#ffffffa3}.app-sidebar-icon-image{width:20px;height:20px;display:block;filter:brightness(0) invert(1);opacity:.88}.app-sidebar-icon.ghost .app-sidebar-icon-image{opacity:.64}.app-sidebar-icon.active .app-sidebar-icon-image{opacity:1}@media(max-width:900px){.app-sidebar{width:100%;height:64px;flex-direction:row;justify-content:space-between;border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding:8px 12px;box-shadow:0 4px 24px #0000003d}.app-sidebar-top{flex-direction:row;justify-content:flex-start;gap:10px;width:auto}.app-sidebar-nav{flex-direction:row;gap:8px;width:auto}.app-sidebar-bottom{width:auto}.app-sidebar-icon{width:42px;height:42px;border-radius:10px}}.app-shell{display:flex;height:100%;width:100%;background:radial-gradient(circle at 12% 0%,#8104ce29,#090a1000 44%),radial-gradient(circle at 100% 100%,#b1f86414,#090a1000 44%),#07080d}.app-shell-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.app-shell-page-content{flex:1;min-height:0;padding:0;overflow:hidden}@media(max-width:900px){.app-shell{flex-direction:column}}.home-page,.placeholder-page{position:relative;overflow:hidden;background:radial-gradient(120% 120% at 8% 0%,#8104ce3d,#8104ce00 52%),radial-gradient(120% 160% at 100% 100%,#b1f86424,#b1f86400 54%),linear-gradient(180deg,#121212f5,#0c0c0cfa);border:1px solid rgba(242,242,242,.12);border-radius:16px;padding:32px;box-shadow:0 26px 52px #00000047}.home-page h2,.placeholder-page h2{margin:10px 0 12px;font-size:clamp(32px,4vw,48px);line-height:1.02;letter-spacing:-.03em;color:var(--text-primary)}.home-page p,.placeholder-page p{margin:0;max-width:720px;color:var(--text-secondary);line-height:1.6}.home-page-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;padding:6px 12px;border:1px solid rgba(177,248,100,.45);background:#b1f86424;color:#d8ffb7;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.home-page-primary-link{display:inline-block;margin-top:22px;background:#8104ce;color:#fff;border-radius:10px;border:1px solid rgba(179,157,255,.56);padding:10px 16px;font-weight:500;transition:opacity .2s ease,transform .2s ease}.home-page-primary-link:hover{opacity:.9;transform:translateY(-1px)}@media(max-width:768px){.home-page,.placeholder-page{border-radius:12px;padding:20px}.home-page-primary-link{width:100%;text-align:center;min-height:44px;display:inline-flex;align-items:center;justify-content:center}}.viewer-loading-card{width:min(360px,calc(100% - 96px));border-radius:16px;padding:18px;border:1px solid rgba(148,129,255,.48);background:radial-gradient(120% 120% at 0% 0%,#8104ce33,#8104ce00 56%),linear-gradient(180deg,#352d5dd1,#211c3ae0);box-shadow:0 26px 52px #00000052}.viewer-loading-status{margin-top:14px;min-height:40px;border-radius:12px;border:1px solid rgba(242,242,242,.2);background:#1c1c1c94;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 12px}.viewer-loading-spinner{width:16px;height:16px;border-radius:9999px;border:2px solid rgba(255,255,255,.25);border-top-color:#8104ce;animation:viewer-spin .8s linear infinite}.viewer-loading-status-text{font-size:14px;font-weight:500;color:#ffffffdb;line-height:1.5}.viewer-loading-dots{margin-top:10px;display:flex;justify-content:center;align-items:center;gap:6px}.viewer-loading-dots span{width:6px;height:6px;border-radius:9999px;background:#b1f864e6;animation:viewer-dot-pulse 1.1s ease-in-out infinite}.viewer-loading-dots span:nth-child(2){animation-delay:.14s}.viewer-loading-dots span:nth-child(3){animation-delay:.28s}@keyframes viewer-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes viewer-dot-pulse{0%,to{transform:translateY(0);opacity:.45}50%{transform:translateY(-2px);opacity:1}}@media(max-width:640px){.viewer-canvas-wrap.is-empty .viewer-disclaimer{bottom:18px}.viewer-top-right{left:12px;right:12px;width:auto;display:flex;flex-wrap:nowrap;flex-direction:row;align-items:center;justify-content:space-between;gap:10px}.viewer-top-actions{order:1;width:auto;flex:1;justify-content:flex-end;overflow-x:auto;padding-bottom:0}.viewer-auth-actions{order:0;flex:0 0 auto}.viewer-avatar{order:0;margin-left:auto}.viewer-download-btn{min-height:32px;font-size:11px;padding:0 9px}.viewer-empty-state{top:50%;width:min(84vw,400px);padding:18px 14px}.viewer-empty-state p{margin-top:10px;font-size:14px}.viewer-loading-card{width:calc(100% - 28px);padding:16px}.viewer-loading-status-text{font-size:13px}}.viewer-canvas-wrap{width:100%;height:100%;min-height:420px;position:relative;background:#0f131b}.viewer-canvas-wrap canvas{width:100%!important;height:100%!important}.viewer-top-right{position:absolute;right:20px;top:18px;z-index:6;display:flex;align-items:center;gap:10px}.viewer-top-actions{display:inline-flex;align-items:center;gap:8px;padding:0;border-radius:0;background:transparent;border:none;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.viewer-credits{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 13px;font-size:14px;color:#ffffffdb;background:#12141dc7;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.viewer-auth-actions{display:inline-flex;align-items:center;gap:10px;height:40px}.viewer-auth-login,.viewer-auth-signup{height:100%;border-radius:10px;padding:0 14px;font-size:14px;font-weight:500;cursor:pointer;border:1px solid rgba(255,255,255,.2);transition:opacity .2s ease,background .2s ease}.viewer-auth-login{background:#8104ce;color:#fff;border-color:#8104ce}.viewer-auth-signup{background:#ffffff14;color:#fffffff2}.viewer-auth-login:hover,.viewer-auth-signup:hover{opacity:.9}.viewer-auth-login:active,.viewer-auth-signup:active{opacity:.8}.viewer-avatar{width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:#8104ce;display:inline-flex;align-items:center;justify-content:center;font-size:15px;color:#fff;cursor:pointer;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.viewer-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:inherit}.viewer-avatar-login:hover{filter:brightness(1.06)}.viewer-auth-logout{height:34px;padding:0 10px;border-radius:10px;border:1px solid rgba(255,255,255,.16);background:#12141dc7;color:#ffffffe6;font-size:13px;cursor:pointer}.viewer-auth-logout:hover{background:#ffffff1a}.viewer-account-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.viewer-account-panel{position:fixed;top:82px;right:20px;width:370px;border-radius:24px;background:radial-gradient(120% 120% at 0% 0%,#8104ce33,#8104ce00 55%),#000000e6;border:1px solid rgba(255,255,255,.16);padding:20px;display:flex;flex-direction:column;gap:20px;color:#ffffffe6;box-shadow:0 22px 54px #00000073}.viewer-account-close{width:30px;height:30px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#ffffffe6;font-size:18px;line-height:1;align-self:flex-end;cursor:pointer}.viewer-account-main{display:flex;flex-direction:column;align-items:center;gap:10px}.viewer-account-avatar-wrap{position:relative}.viewer-account-avatar{width:84px;height:84px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#8104ce;color:#fff;font-size:34px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.viewer-account-avatar-image{width:100%;height:100%;object-fit:cover;border-radius:inherit}.viewer-account-avatar-edit{position:absolute;right:0;bottom:0;width:30px;height:30px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#111111e6;color:#fff;cursor:pointer}.viewer-account-file-input{display:none}.viewer-account-name-row{min-height:40px;display:flex;align-items:center;justify-content:center;gap:10px}.viewer-account-name{font-size:24px;line-height:1.2;cursor:text;color:#ffffffeb}.viewer-account-edit-name{border:0;background:transparent;color:#ffffffa8;cursor:pointer;font-size:18px}.viewer-account-name-input{border:0;background:transparent;color:#ffffffeb;font-size:24px;line-height:1.2;text-align:center;outline:none;width:100%}.viewer-account-email{font-size:14px;color:#ffffff9e}.viewer-account-signout{width:100%;height:44px;border-radius:12px;border:1px solid #8104ce;background:#8104ce;color:#fff;font-size:16px;font-weight:600;cursor:pointer}.viewer-account-signout:active{opacity:.8}.viewer-account-links{display:flex;align-items:center;justify-content:center;gap:20px;color:#ffffff80;font-size:14px}.viewer-account-links button{border:0;background:transparent;color:inherit;cursor:pointer;padding:0}.viewer-mode-tag{height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 10px;font-size:11px;letter-spacing:.08em;font-weight:700;border:1px solid rgba(255,255,255,.12);color:#ffffffd6;background:#12141dc7}.viewer-mode-tag.api{color:#b1f864;border-color:#b1f86470}.viewer-mode-tag.mock{color:#b39dff;border-color:#b39dff75}.viewer-download-btn{min-height:38px;padding:0 14px;border-radius:999px;font-size:14px;font-weight:600;letter-spacing:.01em;border:1px solid rgba(151,120,255,.58);background:linear-gradient(180deg,#8a55fff5,#6f2cdcf5);color:#fffffffa;box-shadow:0 6px 18px #6f2cdc52;transition:transform .2s ease,opacity .2s ease}.viewer-download-btn:hover:not(:disabled){transform:translateY(-1px)}.viewer-download-btn:disabled{opacity:.42}.viewer-empty-state{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:5;width:min(560px,calc(100% - 72px));border-radius:18px;padding:28px 24px;border:1px dashed rgba(179,157,255,.45);background:radial-gradient(120% 120% at 0% 0%,#8104ce29,#8104ce00 52%),linear-gradient(180deg,#2c27488f,#1b182b9e);text-align:center;box-shadow:0 28px 54px #0000004d}.viewer-empty-upload-btn{min-width:280px;height:52px;border-radius:14px;font-size:16px;font-weight:700}.viewer-empty-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.viewer-empty-example-btn{min-width:150px;height:52px;border-radius:14px;border:1px solid rgba(179,157,255,.48);background:#242039c2;color:#f0e9fff5;font-size:15px;font-weight:600;cursor:pointer;transition:border-color .2s ease,transform .2s ease,background-color .2s ease}.viewer-empty-example-btn:hover{border-color:#c7b5ffc2;background:#383058d9;transform:translateY(-1px)}.viewer-empty-example-btn:active{transform:translateY(0)}.viewer-empty-state h4{margin:0;font-size:28px;color:#ffffffeb}.viewer-empty-state p{margin:14px 0 0;font-size:15px;color:#ffffff9e;line-height:1.6}.viewer-loading-mask{position:absolute;top:0;right:0;bottom:0;left:0;z-index:7;display:flex;align-items:center;justify-content:center;background:#07090f8f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.viewer-loading-card{width:min(460px,calc(100% - 72px));border-radius:16px;padding:18px;border:1px solid rgba(148,129,255,.48);background:radial-gradient(120% 120% at 0% 0%,#8104ce33,#8104ce00 56%),linear-gradient(180deg,#352d5dd1,#211c3ae0);box-shadow:0 26px 52px #00000052}.viewer-loading-title{color:#fffffff0;font-size:16px;font-weight:600}.viewer-loading-subtitle{margin-top:6px;color:#ffffff9e;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-loading-track{margin-top:14px;height:10px;border-radius:999px;background:#ffffff1f;overflow:hidden}.viewer-loading-bar{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7c67ff,#8f5eff 58%,#9e57ff);transition:width .28s ease}.viewer-loading-percent{margin-top:8px;text-align:right;font-size:13px;color:#ffffffb8}.viewer-disclaimer{position:absolute;left:50%;bottom:4px;transform:translate(-50%);z-index:5;color:#ffffff6b;font-size:12px;white-space:nowrap}@media(max-width:1280px){.viewer-credits{font-size:13px}.viewer-empty-state h4{font-size:22px}}@media(max-width:900px){.viewer-top-right{right:12px;top:12px;gap:8px}.viewer-top-actions{flex-wrap:nowrap;justify-content:flex-end;max-width:min(88vw,460px);overflow-x:auto;scrollbar-width:none}.viewer-top-actions::-webkit-scrollbar{display:none}.viewer-download-btn{min-height:36px;font-size:13px;padding:0 12px}.viewer-auth-actions{height:36px}.viewer-auth-signup{padding:0 12px;font-size:13px}.viewer-empty-state{width:min(92vw,520px);padding:22px 18px}.viewer-empty-upload-btn,.viewer-empty-example-btn{min-width:0;width:100%;min-height:44px}.viewer-account-panel{top:74px;right:12px;width:min(420px,calc(100vw - 24px));border-radius:18px}.viewer-disclaimer{font-size:11px;bottom:6px;max-width:calc(100% - 24px);text-align:center;white-space:normal}}@media(max-width:640px){.viewer-canvas-wrap.is-empty .viewer-disclaimer{bottom:18px}.viewer-top-right{left:12px;right:12px;width:auto;display:flex;flex-wrap:nowrap;flex-direction:row;align-items:center;justify-content:space-between;gap:10px}.viewer-top-actions{order:1;width:auto;flex:1;justify-content:flex-end;overflow-x:auto;padding-bottom:0}.viewer-auth-actions{order:0;flex:0 0 auto}.viewer-avatar{order:0;margin-left:auto}.viewer-download-btn{min-height:32px;font-size:11px;padding:0 9px}.viewer-empty-state{top:50%;width:min(84vw,400px);padding:18px 14px}.viewer-empty-state p{margin-top:10px;font-size:14px}.viewer-loading-card{width:calc(100% - 28px);padding:16px}}.viewer-source-panel{position:relative;padding:18px;display:flex;flex-direction:column;gap:14px;background:radial-gradient(circle at 22% 12%,#8104ce3d,#0e0f17e0 44%),linear-gradient(180deg,#141521e6,#0d0e16f5);border-right:1px solid rgba(255,255,255,.08);overflow:hidden;width:100%;height:100%;min-height:0;border-radius:0 16px 16px 0;box-shadow:10px 0 32px #00000047}.viewer-source-panel::-webkit-scrollbar{width:0;height:0;display:none}.viewer-source-panel-header p{margin:6px 0 0;color:#ffffff8f;font-size:14px;line-height:1.55}.viewer-source-panel-header h3{margin:0;font-size:22px;line-height:1.1;letter-spacing:-.02em;color:#fffffff0}.viewer-upload-card{display:flex;flex-direction:column;gap:10px;padding:14px;border:1px solid rgba(148,129,255,.42);border-radius:12px;background:radial-gradient(120% 120% at 0% 0%,#8104ce2e,#8104ce00 56%),linear-gradient(180deg,#352d5d8f,#211c3a8f)}.viewer-upload-trigger{min-height:42px;border-radius:10px;font-size:14px;font-weight:500}.viewer-upload-trigger:disabled{opacity:.45;cursor:not-allowed}.viewer-upload-hint{color:#ffffff9e;font-size:13px}.viewer-progress-card{border-radius:14px;border:1px solid rgba(148,129,255,.24);background:linear-gradient(180deg,#2c274880,#1b182b80);box-shadow:inset 0 1px #ffffff1f;padding:10px;display:grid;grid-template-columns:72px 1fr;gap:10px;align-items:center}.viewer-progress-thumb-wrap{width:72px;height:72px}.viewer-progress-thumb{width:100%;height:100%;border-radius:10px;object-fit:cover;border:1px solid rgba(255,255,255,.16)}.viewer-progress-thumb-placeholder{background:radial-gradient(circle at 38% 34%,#c8cad6,#8d93a6 44%,#5e6170)}.viewer-progress-title{font-size:13px;text-transform:uppercase;letter-spacing:.02em;color:#ffffffd6;margin-bottom:4px}.viewer-progress-desc{color:#ffffff94;font-size:13px;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-progress-meta{margin-top:7px;display:flex;align-items:center;justify-content:space-between;color:#ffffff9e;font-size:11px}.viewer-upload-mode{border-radius:999px;padding:2px 7px;letter-spacing:.06em;border:1px solid rgba(255,255,255,.16)}.viewer-upload-mode.api{color:#b1f864;border-color:#b1f8646b}.viewer-upload-mode.mock{color:#b39dff;border-color:#b39dff70}.viewer-progress-track{width:100%;height:8px;border-radius:999px;background:#ffffff1a;overflow:hidden}.viewer-progress-bar{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7c67ff,#8f5eff 58%,#9e57ff);transition:width .28s ease}.viewer-queue-header{display:flex;align-items:center;justify-content:space-between}.viewer-queue-header h4{margin:0;font-size:13px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;color:#ffffffe6}.viewer-queue-meta{display:flex;align-items:center;gap:8px;color:#ffffff8f;font-size:13px}.viewer-queue-meta button{border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#ffffffd6;border-radius:8px;height:28px;padding:0 8px;cursor:pointer}.viewer-queue-meta button:disabled{opacity:.45;cursor:not-allowed}.viewer-task-list{display:flex;flex-direction:column;gap:8px;min-height:0;flex:1;overflow-y:auto;overscroll-behavior:contain;scrollbar-width:none;-ms-overflow-style:none}.viewer-task-list::-webkit-scrollbar{width:0;height:0;display:none}.viewer-example-list{display:flex;flex-direction:column;gap:8px}.viewer-example-item{display:grid;grid-template-columns:54px 1fr;gap:10px;align-items:center;padding:8px;border:1px solid rgba(177,248,100,.22);border-radius:12px;background:linear-gradient(180deg,#1c261c6b,#141c146b);cursor:pointer;transition:all .2s ease}.viewer-example-item:hover{border-color:#b1f8646b;background:linear-gradient(180deg,#22302280,#18231880)}.viewer-example-item.active{border-color:#b1f86494;box-shadow:inset 0 0 0 1px #b1f8643d}.viewer-example-thumb{width:54px;height:54px;object-fit:cover;border-radius:8px;border:1px solid rgba(255,255,255,.16)}.viewer-example-main{min-width:0;display:flex;flex-direction:column;gap:4px}.viewer-example-name{color:#ffffffeb;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-example-tag{font-size:12px;color:#b1f864}.viewer-selected-preview{border:1px solid rgba(148,129,255,.24);border-radius:14px;background:linear-gradient(180deg,#2c274880,#1b182b80);box-shadow:inset 0 1px #ffffff1f;padding:10px}.viewer-selected-preview-trigger{width:100%;border:0;background:transparent;padding:0;cursor:zoom-in}.viewer-selected-preview-image{width:100%;max-height:220px;object-fit:contain;border-radius:10px;border:1px solid rgba(255,255,255,.14);background:#090a10b3}.viewer-task-empty{margin:0;border:1px dashed rgba(255,255,255,.16);border-radius:12px;padding:16px 12px;color:#ffffff8f;font-size:13px;line-height:1.5}.viewer-task-item{display:grid;grid-template-columns:54px 1fr auto;gap:10px;align-items:center;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:#0b0c12a8;cursor:pointer;transition:all .2s ease}.viewer-task-item:hover{border-color:#ffffff2e;background:#12141dd1;transform:translateY(-1px);box-shadow:0 8px 22px #0003}.viewer-task-item.active{border-color:#9481ff75;box-shadow:inset 0 0 0 1px #9481ff33}.viewer-task-thumb{width:54px;height:54px;object-fit:cover;border-radius:8px;border:1px solid rgba(255,255,255,.12)}.viewer-task-main{display:flex;flex-direction:column;gap:4px;min-width:0}.viewer-task-name{width:100%;color:#ffffffe6;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-task-status{width:100%;color:#fff9;font-size:13px}.viewer-task-status.uploading,.viewer-task-status.generating{color:#b39dff}.viewer-task-status.ready{color:#b1f864}.viewer-task-status.failed{color:#ff8da2}.viewer-task-status-line{width:100%;display:inline-flex;align-items:center;gap:6px}.viewer-task-error-tip{position:relative;width:16px;height:16px;border:1px solid rgba(255,255,255,.3);border-radius:999px;background:#ffffff0f;color:#ffffffc7;font-size:11px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:help;flex:0 0 auto}.viewer-task-error-popover{position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);min-width:180px;max-width:320px;padding:8px 10px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:#0f121cfa;color:#ffffffe6;font-size:12px;line-height:1.45;white-space:normal;box-shadow:0 8px 24px #0000006b;opacity:0;pointer-events:none;z-index:30;transition:opacity .16s ease}.viewer-task-error-tip:hover .viewer-task-error-popover,.viewer-task-error-tip:focus-visible .viewer-task-error-popover{opacity:1}.viewer-task-queue-hint{width:100%;color:#ffffffad;font-size:12px;line-height:1.2}.viewer-task-track{width:100%;height:6px;border-radius:999px;background:#ffffff1a;overflow:hidden}.viewer-task-bar{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#7c67ff,#8f5eff 58%,#9e57ff);transition:width .25s ease}.viewer-task-remove{width:24px;height:24px;border:none;border-radius:999px;background:transparent;color:#ffffff8f;cursor:pointer;font-size:18px;line-height:1}.viewer-task-remove:hover{background:#ffffff14;color:#ffffffd6}.viewer-file-input{display:none}.viewer-image-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;background:#040508e6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.viewer-image-lightbox-content{width:min(92vw,1200px);height:min(88vh,900px);display:flex;align-items:center;justify-content:center;padding:14px;overflow:hidden;border-radius:14px;border:1px solid rgba(255,255,255,.22);background:radial-gradient(120% 120% at 12% 8%,#ffffff14,#fff0 60%),#090a10f0;box-shadow:0 24px 56px #0000008c}.viewer-image-lightbox-image{display:block;width:100%;height:100%;max-width:100%;max-height:100%;object-fit:contain;border-radius:10px}.viewer-image-lightbox-close{position:fixed;top:24px;right:24px;width:36px;height:36px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#08090ecc;color:#ffffffe6;font-size:24px;line-height:1;cursor:pointer}.viewer-image-lightbox-close:hover{background:#141620eb}@media(max-width:1280px){.viewer-source-panel{padding:18px 14px 14px}.viewer-source-panel-header h3{font-size:18px}}@media(max-width:900px){.viewer-source-panel{border-radius:0;border-right:none;border-top:1px solid rgba(255,255,255,.08);box-shadow:0 -8px 24px #00000038;padding:12px;gap:12px;overflow-y:auto}.viewer-source-panel-header h3{font-size:18px}.viewer-source-panel-header p{font-size:13px}.viewer-upload-trigger{min-height:44px}.viewer-task-item,.viewer-example-item{grid-template-columns:50px 1fr auto}.viewer-example-item{grid-template-columns:50px 1fr}.viewer-example-thumb,.viewer-task-thumb{width:50px;height:50px}}.viewer-page{position:relative;height:100%;overflow:hidden;background:radial-gradient(120% 140% at 0% 0%,#8104ce24,#8104ce00 48%),#0f131b}.viewer-main{width:100%;height:100%;position:relative}.viewer-panel-layer{--panel-width: 296px;position:absolute;left:0;top:0;bottom:0;right:0;width:var(--panel-width);z-index:8;pointer-events:none;overflow:hidden;transition:transform .24s ease,opacity .24s ease;transform:translate(0);opacity:1;will-change:transform,opacity}.viewer-panel-layer.hidden{transform:translate(calc(-1 * var(--panel-width) - 12px));opacity:0;pointer-events:none}.viewer-panel-layer>*{pointer-events:auto}.viewer-panel-layer.hidden>*{overflow-y:hidden}.viewer-error-banner{position:fixed;right:26px;bottom:24px;background:#ff708929;border:1px solid rgba(255,133,157,.35);color:#ffdbe3;border-radius:10px;padding:10px 12px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}@media(max-width:900px){.viewer-panel-layer{position:fixed;top:64px;right:0;bottom:0;left:0;width:100%;height:calc(100vh - 64px);z-index:40;transform:translateY(0);opacity:1;pointer-events:auto;background:#07090feb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.viewer-panel-layer.hidden{transform:translateY(100%);opacity:0;pointer-events:none}.viewer-main{width:100%;height:100%}}:root{--bg-primary: #000000;--bg-secondary: #121212;--bg-tertiary: #1c1c1c;--bg-quaternary: #292929;--bg-quinary: #303030;--bg-disabled: #2f2f2f;--bg-reversed-primary: #ffffff;--bg-reversed-secondary: #fafafa;--bg-reversed-tertiary: #f0f0f0;--bg-reversed-quaternary: #e4e4e4;--bg-reversed-quinary: #b0b0b0;--bg-reversed-disabled: #b3b3b3;--bg-overlay: rgba(0, 0, 0, .2);--modal-primary: #ffffff;--modal-secondary: #f8f8f8;--modal-primary-alpha: 88%;--modal-secondary-alpha: 88%;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .66);--text-tertiary: rgba(255, 255, 255, .5);--text-disabled: rgba(255, 255, 255, .3);--text-white: #ffffff;--text-reversed-primary: #111111;--text-reversed-secondary: rgba(17, 17, 17, .66);--text-reversed-tertiary: rgba(17, 17, 17, .5);--text-reversed-disabled: rgba(79, 79, 79, .3);--border-primary: #f2f2f2;--border-secondary: #e0e0e0;--border-reversed-primary: #1e1e1e;--border-reversed-secondary: #0f0f0f;--border-brand-primary: #8104ce;--brand-primary: #000000;--brand-midnight-pure: #1d013a;--brand-french-violet: #8104ce;--brand-lavender: #b39dff;--brand-lavender-secondary: #ece7ff;--brand-lavender-tertiary: #faf5ff;--brand-lime: #b1f864;--brand-lime-secondary: #d4ffa6;--brand-lime-tertiary: #f2ffec;--brand-lime-sun: #f56e2e;--error-color: #ff4d4f}:root[data-theme=dark],html[data-theme=dark]{--bg-primary: #ffffff;--bg-secondary: #f6f6f6;--bg-tertiary: #ededed;--bg-quaternary: #e4e4e4;--bg-quinary: #b0b0b0;--bg-disabled: #b3b3b3;--bg-reversed-primary: #000000;--bg-reversed-secondary: #121212;--bg-reversed-tertiary: #1c1c1c;--bg-reversed-quaternary: #292929;--bg-reversed-quinary: #303030;--bg-reversed-disabled: #2f2f2f;--bg-overlay: rgba(0, 0, 0, .478);--modal-primary: #000000;--modal-secondary: #040404;--modal-primary-alpha: 88%;--modal-secondary-alpha: 88%;--text-primary: #111111;--text-secondary: rgba(17, 17, 17, .66);--text-tertiary: rgba(17, 17, 17, .5);--text-disabled: rgba(79, 79, 79, .3);--text-white: #ffffff;--text-reversed-primary: #ffffff;--text-reversed-secondary: rgba(255, 255, 255, .66);--text-reversed-tertiary: rgba(255, 255, 255, .5);--text-reversed-disabled: rgba(255, 255, 255, .3);--border-primary: #1e1e1e;--border-secondary: #0f0f0f;--border-reversed-primary: #e0e0e0;--border-reversed-secondary: #cccccc;--border-brand-primary: #8104ce;--brand-primary: #ffffff;--brand-midnight-pure: #f0e1ff;--brand-french-violet: #8104ce;--brand-lavender: #b39dff;--brand-lavender-secondary: #110023;--brand-lavender-tertiary: #26004d;--brand-lime: #b1f864;--brand-lime-secondary: #1f3b00;--brand-lime-tertiary: #0a1f00;--brand-lime-sun: #f56e2e;--error-color: #ff4d4f}.themed-button{background:#8104ce;box-shadow:0 2px 3px #00000026;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;font-size:13px;line-height:160%;letter-spacing:0;text-align:center;vertical-align:middle;color:#fff;border-radius:12px;border:none}.themed-button:hover:not(.disabled):not(:disabled){background:#380076;cursor:pointer}.themed-button:active:not(.disabled):not(:disabled){background:#000;cursor:pointer}.themed-button:disabled{cursor:not-allowed}:root{--radius: .625rem;--background: oklch(1 0 0);--foreground: oklch(.145 0 0);--card: oklch(1 0 0);--card-foreground: oklch(.145 0 0);--popover: oklch(1 0 0);--popover-foreground: oklch(.145 0 0);--primary: oklch(.205 0 0);--primary-foreground: oklch(.985 0 0);--secondary: oklch(.97 0 0);--secondary-foreground: oklch(.205 0 0);--muted: oklch(.97 0 0);--muted-foreground: oklch(.556 0 0);--accent-token: oklch(.97 0 0);--accent-foreground: oklch(.205 0 0);--destructive: oklch(.577 .245 27.325);--border: oklch(.922 0 0);--input: oklch(.922 0 0);--ring: oklch(.708 0 0);--bg-canvas: #050507;--bg-panel: #0b0c10;--bg-panel-secondary: #141620;--app-text-primary: #f5f7ff;--app-text-secondary: rgba(245, 247, 255, .72);--line: #2a2e3b;--accent: var(--brand-french-violet);--accent-hover: #380076;--danger: var(--error-color);--shadow-soft: 0 8px 24px rgba(17, 17, 17, .08)}.dark{--background: oklch(.145 0 0);--foreground: oklch(.985 0 0);--card: oklch(.205 0 0);--card-foreground: oklch(.985 0 0);--popover: oklch(.205 0 0);--popover-foreground: oklch(.985 0 0);--primary: oklch(.922 0 0);--primary-foreground: oklch(.205 0 0);--secondary: oklch(.269 0 0);--secondary-foreground: oklch(.985 0 0);--muted: oklch(.269 0 0);--muted-foreground: oklch(.708 0 0);--accent-token: oklch(.269 0 0);--accent-foreground: oklch(.985 0 0);--destructive: oklch(.704 .191 22.216);--border: oklch(1 0 0 / 10%);--input: oklch(1 0 0 / 15%);--ring: oklch(.556 0 0);--bg-canvas: #050507;--bg-panel: #0b0c10;--bg-panel-secondary: #141620;--app-text-primary: #f5f7ff;--app-text-secondary: rgba(245, 247, 255, .72);--line: #2a2e3b}*{box-sizing:border-box}html,body,#root{margin:0;width:100%;height:100%;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--app-text-primary);background:#0f131b}a{color:inherit;text-decoration:none}
