.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;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;font-weight:400;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!important;font-weight:600!important}.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:12px;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:24px;height:24px;display:block;filter:brightness(0) invert(1);opacity:.64}.app-sidebar-icon.ghost .app-sidebar-icon-image{opacity:.88}.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:8px;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{width:44px;min-width:44px;height:44px;min-height:44px}.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;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;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:650;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer}.viewer-account-signout:active,.viewer-account-signout:hover{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{display:inline-flex;align-items:center;justify-content:center;gap:8px;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,border-color .2s ease,background-color .2s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent;cursor:pointer}.viewer-download-btn:hover:not(:disabled){transform:translateY(-1px)}.viewer-download-btn:disabled{opacity:.42}.viewer-toolbar-btn-icon{width:15px;height:15px;display:block;filter:brightness(0) saturate(100%) invert(100%)}.viewer-toolbar-btn-label{white-space:nowrap;line-height:1}.viewer-download-btn-xray{border-color:#9778ff6b;background:linear-gradient(180deg,#4f3a88f5,#3f2d6df5)}.viewer-download-btn-xray.viewer-download-btn--active{border-color:#b1f8649e;background:linear-gradient(180deg,#75a13b57,#4c682457),linear-gradient(180deg,#4f3a88f5,#3f2d6df5);box-shadow:0 6px 18px #6592303d}.viewer-empty-state{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:5;width:min(480px,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:180px;height:52px;border-radius:14px!important;font-size:14px!important;font-weight:650!important}.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:1px solid rgba(179,157,255,.48);background:#242039c2;color:#f0e9fff5;border-radius:14px!important;font-family:Inter,PingFang SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px!important;font-weight:650!important;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;align-items:center;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{width:42px;min-width:42px;height:42px;min-height:42px;padding:0;border-radius:999px;gap:0;flex:0 0 auto}.viewer-toolbar-btn-label{display:none}.viewer-toolbar-btn-icon{width:18px;height:18px}.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{width:44px;height:44px;order:0;margin-left:auto}.viewer-download-btn{width:44px;min-width:44px;height:44px;min-height:44px}.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}}@media(hover:none)and (pointer:coarse){.viewer-download-btn:hover:not(:disabled){transform:none}}.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-y:auto;overscroll-behavior:contain;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:18px;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!important;font-weight:650!important}.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:13px}.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:0 0 auto;overflow:visible}.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:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-example-tag{font-size:13px;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:10px;min-width:0}.viewer-task-name{width:100%;color:#ffffffe6;font-size:14px;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:18px;height:18px;border:1px solid rgba(255,255,255,.22);border-radius:999px;background:linear-gradient(180deg,#ffffff14,#ffffff08);color:#ffffffc7;font-size:11px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:help;flex:0 0 auto;box-shadow:inset 0 1px #ffffff1f}.viewer-task-error-icon{width:18px;height:18px;opacity:.78}.viewer-global-error-popover{position:fixed;top:0;left:0;transform:translateY(-100%);padding:12px 14px;border-radius:16px;border:1px solid rgba(179,157,255,.34);background:linear-gradient(180deg,#0c0c0cf5,#1c1c1cf0),#000000eb;color:#ffffffeb;font-size:13px;line-height:1.5;white-space:normal;word-break:break-word;pointer-events:none;z-index:200;box-shadow:0 18px 42px #00000070,inset 0 1px #ffffff0f}.viewer-global-error-popover:before{content:"";position:absolute;left:calc(var(--viewer-error-arrow-left, 40px) - 6px);bottom:-7px;width:12px;height:12px;transform:rotate(45deg);border-right:1px solid rgba(179,157,255,.34);border-bottom:1px solid rgba(179,157,255,.34);background:#181818f5}.viewer-task-queue-hint{width:100%;color:#ffffffad;font-size:13px;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-scroll-top-btn{position:sticky;bottom:16px;margin-top:12px;margin-left:auto;width:52px;height:52px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;border:1px solid rgba(179,157,255,.42);background:linear-gradient(180deg,#8104ce57,#5c29c638),#10121cf0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 10px 24px #00000042,inset 0 1px #ffffff24;cursor:pointer;z-index:6;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,filter .2s ease}.viewer-scroll-top-btn:hover{border-color:#b39dffb8;box-shadow:0 14px 28px #0000004d,0 0 0 4px #8104ce1f;filter:saturate(1.12);transform:translateY(-2px)}.viewer-scroll-top-btn:active{transform:translateY(0)}.viewer-scroll-top-icon{width:18px;height:18px;opacity:.96;filter:brightness(0) saturate(100%) invert(89%) sepia(34%) saturate(630%) hue-rotate(207deg) brightness(103%) contrast(101%)}.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:10px 10px 14px;gap:10px;overflow-y:auto}.viewer-source-panel-header h3{font-size:18px}.viewer-source-panel-header p{font-size:13px;line-height:1.45}.viewer-upload-card,.viewer-selected-preview{padding:10px;border-radius:10px}.viewer-selected-preview-image{max-height:180px}.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-example-name,.viewer-task-name,.viewer-task-status{font-size:13px}.viewer-global-error-popover{padding:10px 12px;border-radius:14px}.viewer-global-error-popover:before{left:calc(var(--viewer-error-arrow-left, 36px) - 5px);bottom:-6px;width:10px;height:10px}.viewer-scroll-top-btn{width:56px;height:56px;padding:0;border-radius:15px}.viewer-scroll-top-icon{width:20px;height:20px}}.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;left:50%;bottom:24px;transform:translate(-50%);z-index:60;width:min(420px,calc(100vw - 32px));padding:12px 14px;border-radius:14px;border:1px solid rgba(179,157,255,.34);background:linear-gradient(180deg,#121212f0,#1e1e1eeb);color:#ffffffe6;text-align:center;font-size:13px;line-height:1.45;box-shadow:0 18px 40px #00000057;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@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%}.viewer-error-banner{bottom:18px;width:min(320px,calc(100vw - 24px));padding:11px 12px}}.terms-policy-wrapper{width:100%;min-height:100vh;background-color:#000;color:#fff}.terms-policy-container{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:104px 20px 40px}.terms-policy-content{max-width:800px;width:100%;background:#ffffff0d;padding:40px;border-radius:8px;box-shadow:0 4px 6px #0000001a}.terms-policy-content .loading,.terms-policy-content .error{color:#fff;text-align:center;font-size:1.2em;padding:20px}.terms-policy-content .error{color:#ff6868}.terms-policy-content h1{font-size:2em;margin:0 0 30px;color:#fff}.terms-policy-content h2{font-size:1.5em;margin:20px 0 15px;color:#b39dff}.terms-policy-content p{line-height:1.6;margin-bottom:15px;color:#ccc}.terms-policy-header{position:fixed;top:0;left:0;right:0;height:64px;padding:0 24px;display:flex;justify-content:space-between;align-items:center;background:#000c;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100}.terms-policy-wrapper .header-left{display:flex;align-items:center;gap:12px;cursor:pointer}.terms-policy-wrapper .brand-name{color:#ffffffeb;font-weight:600;font-size:18px}.terms-policy-wrapper .get-started-btn{height:36px;border-radius:20px;background:#fff;color:#111;border:none;cursor:pointer;padding:0 16px;transition:all .2s ease}.terms-policy-wrapper .get-started-btn:hover{background:#e4e4e4}@media(max-width:768px){.terms-policy-container{padding:92px 14px 24px}.terms-policy-content{padding:20px 16px}.terms-policy-content h1{font-size:1.5em;margin-bottom:18px}.terms-policy-content h2{font-size:1.2em}}: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;opacity:45%}: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}
