:root,[data-theme=dark]{--surface-base: #0E0E0E;--surface-panel: #1A1A1A;--surface-hover: #252525;--border-subtle: #1F1F1F;--border-strong: #2E2E2E;--text-primary: #FFFFFF;--text-secondary: #CCCCCC;--text-muted: #777777;--accent: #0061FE;--accent-hover: #1E7BFF;--accent-tint-08: rgba(0, 97, 254, .08);--accent-tint-12: rgba(0, 97, 254, .14);--success: #34C759;--warn: #FF9500;--danger: #FF3B30;--shadow-sm: 0 2px 10px rgba(0, 0, 0, .4);--shadow-md: 0 8px 24px rgba(0, 0, 0, .5);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .65);--shadow-backdrop: rgba(0, 0, 0, .55);--bg-0: var(--surface-base);--bg-1: var(--surface-base);--bg-2: var(--surface-base);--bg-3: var(--surface-panel);--bg-4: var(--surface-panel);--bg-5: var(--surface-panel);--bg-hover: var(--surface-hover);--bg-active: var(--surface-hover);--bg-input: var(--surface-panel);--bg-select: var(--surface-panel);--bg-toolbar: var(--surface-panel);--border-soft: var(--border-subtle);--border-medium: var(--border-strong);--text-tertiary: var(--text-secondary);--text-dim: var(--text-muted);--text-faint: var(--text-muted);color-scheme:dark}[data-theme=light]{--surface-base: #F3F3F3;--surface-panel: #FFFFFF;--surface-hover: #ECECEC;--border-subtle: #E5E5E5;--border-strong: #CCCCCC;--text-primary: #0A0A0A;--text-secondary: #333333;--text-muted: #888888;--accent: #0061FE;--accent-hover: #0052D9;--accent-tint-08: rgba(0, 97, 254, .08);--accent-tint-12: rgba(0, 97, 254, .14);--success: #34C759;--warn: #FF9500;--danger: #FF3B30;--shadow-sm: 0 2px 10px rgba(0, 0, 0, .06);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .12);--shadow-backdrop: rgba(0, 0, 0, .15);--bg-0: var(--surface-base);--bg-1: var(--surface-base);--bg-2: var(--surface-base);--bg-3: var(--surface-panel);--bg-4: var(--surface-panel);--bg-5: var(--surface-panel);--bg-hover: var(--surface-hover);--bg-active: var(--surface-hover);--bg-input: var(--surface-panel);--bg-select: var(--surface-panel);--bg-toolbar: var(--surface-panel);--border-soft: var(--border-subtle);--border-medium: var(--border-strong);--text-tertiary: var(--text-secondary);--text-dim: var(--text-muted);--text-faint: var(--text-muted);color-scheme:light}html,body{background:var(--surface-base);color:var(--text-secondary);transition:background-color .15s ease}body{margin:0;font-family:Space Grotesk,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-2);color:var(--text-tertiary)}.home{min-height:100vh;background:var(--bg-0);display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif;-webkit-font-smoothing:antialiased}.home-nav{display:flex;justify-content:space-between;align-items:center;padding:20px 40px;position:sticky;top:0;z-index:10;background:var(--bg-toolbar);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.home-logo{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.5px}.home-nav-right{display:flex;align-items:center;gap:12px}.home-btn{display:inline-flex;align-items:center;gap:8px;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600;border-radius:6px;padding:8px 20px;cursor:pointer;transition:all .15s;text-decoration:none;border:none;letter-spacing:.01em}.home-btn-primary{background:var(--text-primary);color:var(--bg-0)}.home-btn-primary:hover{background:var(--text-secondary);transform:translateY(-1px)}.home-btn-ghost{background:none;color:var(--text-muted);padding:8px 12px}.home-btn-ghost:hover{color:var(--text-primary)}.home-btn-outline{background:none;border:1px solid var(--border-medium);color:var(--text-tertiary)}.home-btn-outline:hover{border-color:var(--border-strong);color:var(--text-primary);transform:translateY(-1px)}.home-btn-outline:hover svg{transform:translate(3px)}.home-btn-outline svg{transition:transform .15s}.home-btn-lg{padding:12px 28px;font-size:14px;border-radius:8px}.home-hero{display:flex;align-items:center;justify-content:center;min-height:80vh;padding:60px 40px 80px}.home-hero-inner{text-align:center;max-width:700px}.home-eyebrow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:24px}.home-title{font-size:clamp(42px,7vw,76px);font-weight:500;line-height:1.05;color:var(--text-primary);margin-bottom:24px;letter-spacing:-.03em}.home-title em{font-style:italic;font-weight:400}.home-subtitle{font-size:16px;line-height:1.7;color:var(--text-muted);max-width:440px;margin:0 auto 40px}.home-hero-actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.home-tools{padding:100px 40px;max-width:1100px;margin:0 auto;width:100%}.home-section-header{text-align:center;margin-bottom:56px}.home-section-eyebrow{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--text-dim);margin-bottom:12px}.home-section-title{font-size:clamp(28px,4vw,40px);font-weight:500;color:var(--text-primary);letter-spacing:-.02em}.home-tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border-subtle);border-radius:12px;overflow:hidden}@keyframes home-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.home-tool-card{padding:40px 36px;background:var(--bg-2);display:flex;flex-direction:column;gap:8px;transition:background .2s;animation:home-card-in .3s cubic-bezier(.16,1,.3,1) both}.home-tool-card:hover{background:var(--bg-4)}.home-tool-tag{font-size:10px;font-weight:700;letter-spacing:.15em;color:var(--accent);text-transform:uppercase}.home-tool-name{font-size:24px;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.home-tool-desc{font-size:14px;line-height:1.6;color:var(--text-muted);max-width:320px}.home-features{padding:80px 40px;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.home-features-grid{display:grid;grid-template-columns:repeat(4,1fr);max-width:1100px;margin:0 auto;gap:40px}.home-feature{text-align:left}.home-feature-num{font-size:11px;font-weight:600;color:var(--text-faint);letter-spacing:.05em;display:block;margin-bottom:16px}.home-feature-title{font-size:18px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;letter-spacing:-.01em}.home-feature-desc{font-size:13px;line-height:1.7;color:var(--text-muted)}.home-cta-section{padding:100px 40px;text-align:center}.home-cta-title{font-size:clamp(28px,4vw,40px);font-weight:500;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.02em}.home-cta-desc{font-size:15px;color:var(--text-muted);margin-bottom:32px}.home-footer{display:flex;justify-content:space-between;align-items:center;padding:24px 40px;border-top:1px solid var(--border-subtle)}.home-footer-logo{font-size:14px;font-weight:600;color:var(--text-faint)}.home-footer-copy{font-size:11px;color:var(--text-faint)}@media(max-width:768px){.home-nav{padding:16px 20px}.home-hero{padding:40px 20px 60px;min-height:70vh}.home-tools{padding:60px 20px}.home-tools-grid{grid-template-columns:1fr}.home-tool-card{padding:28px 24px}.home-features{padding:60px 20px}.home-features-grid{grid-template-columns:repeat(2,1fr);gap:32px}.home-cta-section{padding:60px 20px}.home-footer{padding:20px}}@media(max-width:480px){.home-features-grid{grid-template-columns:1fr}.home-hero-actions{flex-direction:column}}@media(prefers-reduced-motion:reduce){.home-tool-card{animation:none}.home-btn:hover{transform:none}.home-btn-outline:hover svg{transform:none}}.auth{display:flex;min-height:100vh}.auth-left{flex:1;background:var(--bg-2);display:flex;flex-direction:column;padding:32px 48px}.auth-back{font-size:13px;color:var(--text-muted);transition:color .2s;align-self:flex-start}.auth-back:hover{color:var(--text-tertiary)}.auth-left-content{flex:1;display:flex;flex-direction:column;justify-content:center;max-width:320px}.auth-left-content h1{font-family:Space Grotesk,sans-serif;font-size:52px;font-weight:400;line-height:1.08;color:var(--text-secondary);margin-bottom:16px;letter-spacing:-.02em}.auth-left-content p{font-size:14px;color:var(--text-muted);line-height:1.7}.auth-right{flex:1;background:var(--bg-5);display:flex;align-items:center;justify-content:center;padding:48px}.auth-form-wrap{width:100%;max-width:340px}.auth-form-wrap h2{font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:36px}.auth-error{font-size:13px;color:var(--accent);margin-bottom:24px;padding-left:12px;border-left:2px solid var(--accent)}.auth-form-wrap form{display:flex;flex-direction:column}.auth-form-wrap label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;margin-top:24px}.auth-form-wrap label:first-of-type{margin-top:0}.auth-form-wrap input{width:100%;padding:0 0 12px;background:transparent;border:none;border-bottom:1px solid var(--border-medium);color:var(--text-secondary);font-size:15px;font-family:inherit;outline:none;transition:border-color .3s;border-radius:0;-webkit-appearance:none}.auth-form-wrap input:focus{border-bottom-color:var(--accent)}.auth-form-wrap input::placeholder{color:var(--text-faint)}.auth-btn{margin-top:36px;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:100px;font-size:14px;font-weight:500;letter-spacing:.02em;transition:background .3s}.auth-btn:hover:not(:disabled){background:var(--accent-hover)}.auth-btn:disabled{opacity:.35}.auth-alt{margin-top:32px;text-align:center;font-size:13px;color:var(--text-muted)}.auth-alt a{color:var(--accent);border-bottom:1px solid var(--border-medium);padding-bottom:1px;transition:border-color .2s}.auth-alt a:hover{border-color:var(--accent)}@media(max-width:768px){.auth{flex-direction:column}.auth-left{min-height:220px;padding:24px}.auth-left-content h1{font-size:36px}.auth-right{padding:32px 24px}}.sidebar{width:220px;height:100%;background:var(--bg-2);display:flex;flex-direction:column;border-right:1px solid var(--border-subtle);flex-shrink:0;transition:width .2s cubic-bezier(.16,1,.3,1),background-color .15s;overflow:hidden;will-change:width;font-family:Space Grotesk,sans-serif}.sidebar.collapsed{width:56px}.sb-logo-row{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;min-height:48px}.sidebar.collapsed .sb-logo-row{padding:16px 0 12px;justify-content:center;width:56px}.sb-logo{font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700;color:var(--text-secondary);white-space:nowrap;letter-spacing:-.3px}.sidebar.collapsed .sb-logo{display:none}.sb-collapse-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-dim);display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .1s,background-color .1s;flex-shrink:0}.sb-collapse-btn:hover{color:var(--text-tertiary);background:var(--bg-active)}.sb-collapse-icon{width:18px;height:18px}.sb-close{display:none;background:none;border:none;font-size:18px;color:var(--text-dim);line-height:1;padding:0;cursor:pointer;transition:color .1s}.sb-close:hover{color:var(--text-tertiary)}.sb-nav{display:flex;flex-direction:column;gap:8px;padding:0 8px}.sidebar.collapsed .sb-nav{padding:0;gap:10px;align-items:center}.sb-nav-btn{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:8px 12px;background:none;border:none;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s;font-family:Space Grotesk,sans-serif;white-space:nowrap;overflow:hidden}.sidebar.collapsed .sb-nav-btn{width:40px;height:40px;padding:0;justify-content:center;gap:0;border-radius:6px}.sb-nav-btn:hover{background:var(--bg-hover);color:var(--text-tertiary)}.sb-nav-btn.active{background:var(--bg-active);color:var(--text-primary);font-weight:600}.sb-nav-btn.active .sb-nav-icon{color:var(--accent)}.sb-nav-icon{width:20px;height:20px;min-width:20px;flex-shrink:0;color:currentColor}.sb-nav-label{opacity:1;transition:opacity .15s}.sidebar.collapsed .sb-nav-label{display:none}.sb-spacer{flex:1}.sb-theme-toggle{display:flex;align-items:center;gap:10px;width:calc(100% - 16px);margin:0 8px 8px;padding:8px 12px;background:none;border:none;border-radius:6px;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden}.sb-theme-toggle:hover{background:var(--bg-hover);color:var(--text-tertiary)}.sb-theme-icon{width:20px;height:20px;min-width:20px;flex-shrink:0;color:currentColor}.sidebar.collapsed .sb-theme-toggle{width:40px;height:40px;padding:0;justify-content:center;gap:0;margin:0 0 8px}.sidebar.collapsed .sb-theme-label{display:none}.sb-bottom{border-top:1px solid var(--border-subtle);padding:8px}.sidebar.collapsed .sb-bottom{padding:8px 0;display:flex;justify-content:center}.sb-user-menu{position:relative}.sb-user-btn{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;background:none;border:none;border-radius:6px;cursor:pointer;transition:background .1s;font-family:Space Grotesk,sans-serif}.sb-user-btn:hover{background:var(--bg-hover)}.sb-avatar{width:26px;height:26px;min-width:26px;border-radius:50%;background:var(--bg-active);border:1px solid var(--border-soft);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.sb-email{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left}.sidebar.collapsed .sb-email{display:none}.sb-user-dropdown{position:absolute;bottom:calc(100% + 6px);left:0;right:0;background:var(--bg-toolbar);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-soft);border-radius:8px;padding:4px;box-shadow:var(--shadow-md);z-index:60}.sb-dropdown-email{padding:8px 10px;font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-dropdown-sep{height:1px;background:var(--border-subtle);margin:2px 6px}.sb-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:none;border:none;border-radius:4px;font-family:Space Grotesk,sans-serif;font-size:12px;color:var(--text-tertiary);cursor:pointer;transition:background .1s,color .1s;text-align:left}.sb-dropdown-item:hover{background:var(--bg-active)}.sb-dropdown-logout:hover{color:var(--accent)}.sb-user-backdrop{position:fixed;inset:0;z-index:55}.sb-overlay{display:none}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .22s cubic-bezier(.16,1,.3,1);width:220px!important;will-change:transform}.sidebar.open{transform:translate(0)}.sb-close{display:block}.sb-collapse-btn{display:none}.sb-overlay{display:block;position:fixed;inset:0;background:var(--shadow-backdrop);z-index:90;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}}.ws{width:100%;height:100%;display:flex;flex-direction:column;background:#fff;color:var(--text-tertiary);font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;overflow:hidden}.ws-toolbar{height:54px;background:#fff;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 12px;gap:6px;flex-shrink:0;z-index:20}.ws-tb-group{display:flex;align-items:center;gap:2px}.ws-tb-spacer{flex:1}.ws-tb-sep{color:var(--text-dim);font-size:12px;margin:0 2px;user-select:none}.ws-tb-sep-v{width:1px;height:18px;background:var(--border-medium);margin:0 6px}.ws-tb-btn-text{background:none;border:none;padding:6px 10px;font:inherit;font-size:12px;font-weight:500;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:background .1s,color .1s}.ws-tb-btn-text:hover{background:var(--bg-active);color:var(--text-primary)}.ws-tb-btn-text.on{color:var(--text-primary)}.ws-search-wrap{position:relative}.ws-search-menu{position:absolute;top:calc(100% + 6px);right:0;display:flex;align-items:center;gap:6px;padding:6px;background:#fff;border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-lg);z-index:30}.ws-search-clear{height:28px;padding:0 10px;background:transparent;border:none;border-radius:6px;font:inherit;font-size:11px;color:var(--text-secondary);cursor:pointer}.ws-search-clear:hover{background:var(--bg-active);color:var(--text-primary)}.ws-tb-search{height:28px;width:240px;padding:0 10px;background:var(--bg-active);border:1px solid transparent;border-radius:6px;font:inherit;font-size:12px;color:var(--text-primary);outline:none;transition:border-color .1s}.ws-tb-search::placeholder{color:var(--text-dim)}.ws-tb-search:focus{border-color:var(--accent);background:var(--surface-panel)}.ws-tb-chip{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;background:none;border:1px solid transparent;border-radius:6px;font:inherit;font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer}.ws-tb-chip:hover,.ws-tb-chip.on{background:var(--bg-active);color:var(--text-primary)}.ws-tb-chip-dot{width:8px;height:8px;border-radius:50%}.ws-tb-icon{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer}.ws-tb-icon:hover{background:var(--bg-active);color:var(--text-primary)}.ws-tb-icon.on{background:var(--bg-active);color:var(--accent)}.ws-tb-btn-primary{height:28px;padding:0 14px;background:var(--accent);color:#fff;border:none;border-radius:6px;font:inherit;font-size:12px;font-weight:600;cursor:pointer}.ws-tb-btn-primary:hover{filter:brightness(1.05)}.ws-new-wrap{position:relative}.ws-new-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-lg);padding:4px;z-index:30}.ws-new-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:none;border:none;border-radius:6px;font:inherit;font-size:12px;color:var(--text-primary);cursor:pointer;text-align:left}.ws-new-item:hover{background:var(--bg-active)}.ws-new-dot{width:8px;height:8px;border-radius:50%}.ws-body{flex:1;display:flex;min-height:0}.ws-main{flex:1;overflow-y:auto;padding:24px 28px 48px;scrollbar-width:none;-ms-overflow-style:none}.ws-main::-webkit-scrollbar{width:0;height:0;display:none}.ws-side{width:260px;flex-shrink:0;border-left:1px solid var(--border-subtle);background:#fff;padding:20px 18px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.ws-side::-webkit-scrollbar{width:0;height:0;display:none}.ws-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:18px 12px}.ws-card{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;padding:8px 6px;border-radius:8px;background:transparent;border:1px solid transparent;transition:background .1s,border-color .1s}.ws-card:hover{background:var(--bg-active)}.ws-card.selected,.ws-card.drag-over{background:var(--bg-active);border-color:var(--accent)}.ws-card-thumb{width:100%;aspect-ratio:4 / 3;display:flex;align-items:center;justify-content:center;background:#fafbfc;border:1px solid var(--border-subtle);border-radius:6px;margin-bottom:8px;position:relative;overflow:hidden}.ws-card-folder .ws-card-thumb{background:transparent;border:none}.ws-card-name{font-size:12px;font-weight:500;color:var(--text-primary);width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-palette-strip{position:absolute;inset:auto 0 0;height:24%;display:flex}.ws-pin-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--accent)}.ws-pin-dot.inline{position:static;display:inline-block;margin-left:6px}.ws-list{width:100%;border:1px solid var(--border-subtle);border-radius:8px;background:#fff;overflow:hidden}.ws-list-head,.ws-list-row{display:grid;grid-template-columns:1fr 100px 120px;align-items:center;padding:8px 14px;font-size:12px}.ws-list-head{background:#fafbfc;border-bottom:1px solid var(--border-subtle);color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.6px;font-size:10px}.ws-list-row{border-bottom:1px solid var(--border-subtle);cursor:pointer;color:var(--text-primary)}.ws-list-row:last-child{border-bottom:none}.ws-list-row:hover{background:var(--bg-active)}.ws-list-row.selected{background:var(--bg-active);color:var(--text-primary)}.ws-list-row.drag-over{background:var(--bg-active)}.ws-list-col-name{display:flex;align-items:center;gap:10px;min-width:0}.ws-list-col-name span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-list-col-kind{color:var(--text-secondary)}.ws-list-col-time{color:var(--text-muted);font-variant-numeric:tabular-nums}.ws-side-head{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px;word-break:break-word}.ws-side-meta{font-size:11px;color:var(--text-muted);margin-bottom:16px}.ws-side-thumb{height:120px;display:flex;align-items:center;justify-content:center;background:#fafbfc;border:1px solid var(--border-subtle);border-radius:8px;margin-bottom:16px}.ws-side-details{border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:10px 0;margin-bottom:16px}.ws-side-detail-row{display:flex;justify-content:space-between;gap:10px;font-size:11px;color:var(--text-secondary);padding:4px 0;font-variant-numeric:tabular-nums}.ws-side-detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600;flex-shrink:0}.ws-side-actions{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.ws-side-actions-row{flex-direction:row;gap:6px}.ws-side-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-muted);border:1px solid var(--border-medium);border-radius:6px;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.ws-side-icon:hover{background:var(--bg-active);color:var(--text-primary)}.ws-side-icon.on{color:var(--accent);border-color:var(--accent)}.ws-side-icon.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ws-side-icon.primary:hover{filter:brightness(1.05)}.ws-side-icon.danger{color:#d33;border-color:#dd33334d}.ws-side-icon.danger:hover{background:#dd333314;color:#d33}.ws-side-btn{height:30px;padding:0 12px;background:transparent;border:1px solid var(--border-medium);border-radius:6px;font:inherit;font-size:12px;font-weight:500;color:var(--text-primary);cursor:pointer;text-align:left}.ws-side-btn:hover{background:var(--bg-active)}.ws-side-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.ws-side-btn.primary:hover{filter:brightness(1.05)}.ws-side-btn.danger{color:#d33;border-color:#dd33334d}.ws-side-btn.danger:hover{background:#dd333314}.ws-filter-wrap{position:relative}.ws-filter-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:160px;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-lg);padding:4px;z-index:30}.ws-new-item.on{background:var(--bg-active);color:var(--text-primary)}.ws-side-hint{font-size:11px;color:var(--text-dim);line-height:1.5}.ws-side-empty{text-align:center;padding-top:24px}.ws-side-empty-title{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.ws-side-empty-sub{font-size:11px;color:var(--text-muted)}.ws-empty{text-align:center;padding:80px 16px}.ws-empty-title{font-size:14px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.ws-empty-sub{font-size:12px;color:var(--text-muted)}.ws-menu-backdrop{position:fixed;inset:0;z-index:40}.ws-context-menu{position:fixed;z-index:41;min-width:140px;padding:4px;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:8px;box-shadow:var(--shadow-lg)}.ws-context-menu button{display:block;width:100%;padding:7px 12px;background:transparent;border:none;border-radius:6px;text-align:left;font:inherit;font-size:12px;color:var(--text-primary);cursor:pointer}.ws-context-menu button:hover{background:var(--bg-active)}.ws-context-menu-danger{color:#d33!important}.ws-spin{display:inline-block;width:10px;height:10px;border:1.5px solid var(--text-dim);border-top-color:var(--accent);border-radius:50%;animation:ws-spin .6s linear infinite;vertical-align:-1px}@keyframes ws-spin{to{transform:rotate(360deg)}}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.sn{background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:6px;min-width:180px;max-width:220px;font-family:Space Grotesk,sans-serif;cursor:grab;overflow:hidden;transition:border-color .12s,box-shadow .12s}.sn:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.react-flow__node.selected .sn{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-tint-12),var(--shadow-md)}.sn.sn-off{opacity:.25}.sn.sn-off:hover{opacity:.4}.sn-top{display:flex;align-items:center;gap:6px;padding:6px 10px 4px}.sn-tag{font-size:8px;font-weight:700;color:var(--accent);background:var(--accent-tint-08);padding:1px 5px;border-radius:2px;letter-spacing:.8px;line-height:14px;flex-shrink:0}.sn-name{font-size:11px;font-weight:600;color:var(--text-primary);letter-spacing:.3px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sn-off-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0;opacity:.6}.sn-body{display:flex;gap:8px;padding:2px 10px 8px;align-items:flex-start}.sn-thumb{width:40px;height:40px;border-radius:3px;background:var(--surface-panel);border:1px solid var(--border-subtle);flex-shrink:0;image-rendering:auto}.sn-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.sn-desc{font-size:9px;font-weight:500;color:var(--text-muted);line-height:1.3}.sn-file{font-size:9px;font-weight:500;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sn-dim{font-size:9px;font-weight:600;color:var(--text-muted);font-variant-numeric:tabular-nums;letter-spacing:.3px}.sn-params{font-size:8px;font-weight:600;color:var(--text-muted);letter-spacing:.3px}.sn-preset{font-size:8px;font-weight:500;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sn-changes{display:flex;flex-wrap:wrap;gap:3px;padding:4px 10px 7px;border-top:1px solid var(--border-subtle)}.sn-change{display:flex;align-items:center;gap:2px;background:var(--surface-panel);border-radius:2px;padding:1px 4px;line-height:1}.sn-change-key{font-size:7px;font-weight:600;color:var(--text-muted);letter-spacing:.3px;text-transform:uppercase}.sn-change-val{font-size:8px;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.2px}.sn-val-pos{color:var(--success)}.sn-val-neg{color:var(--warn)}.sn-default{padding:3px 10px 6px;font-size:8px;font-weight:500;color:var(--border-strong);letter-spacing:.3px;border-top:1px solid var(--border-subtle)}.sn-h{width:8px!important;height:8px!important;border-radius:50%!important;cursor:crosshair!important;pointer-events:all!important;transition:all .12s!important}.sn-h-in{background:var(--surface-panel)!important;border:1.5px solid var(--text-muted)!important;top:14px!important}.sn-h-in:hover{border-color:var(--accent)!important;background:var(--accent)!important;box-shadow:0 0 6px var(--accent-tint-12)!important}.sn-h-2{top:28px!important}.sn-h-out{background:var(--text-muted)!important;border:1.5px solid var(--text-muted)!important;top:14px!important}.sn-h-out:hover{background:var(--accent)!important;border-color:var(--accent)!important;box-shadow:0 0 6px var(--accent-tint-12)!important}.react-flow__node.selected .sn-h-in{border-color:var(--text-muted)!important}.react-flow__node.selected .sn-h-out{background:var(--text-secondary)!important;border-color:var(--text-secondary)!important}.ce{display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif}.ce-tabs{display:flex;align-items:center;gap:2px;padding:8px 12px;border-bottom:1px solid var(--border-subtle)}.ce-tab{flex:1;padding:6px 0;border:none;background:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s}.ce-tab:hover,.ce-tab-active{background:var(--surface-hover)}.ce-tab-active .ce-dot{transform:scale(1.3);box-shadow:0 0 0 2px #fff3}.ce-dot{width:10px;height:10px;border-radius:50%;transition:transform .1s,box-shadow .1s}.ce-reset{width:22px;height:22px;min-width:22px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;flex-shrink:0;transition:color .1s,background .1s;margin-left:4px}.ce-reset:hover{color:var(--text-secondary);background:var(--surface-hover)}.ce-reset:disabled{opacity:.2;cursor:default}.ce-reset:disabled:hover{color:var(--text-muted);background:none}.ce-canvas-wrap{position:relative;margin:0 12px;border-radius:4px;overflow:hidden;background:var(--surface-base);border:1px solid var(--border-subtle)}.ce-canvas-wrap:before{content:"";display:block;padding-bottom:100%}.ce-canvas{position:absolute;top:0;left:0;width:100%;height:100%;cursor:crosshair;display:block}.ce-zones{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:space-between;padding:4px 8px;pointer-events:none}.ce-zone{font-size:8px;font-weight:500;color:var(--text-muted);opacity:.5;letter-spacing:.3px;text-transform:uppercase}.ce-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 12px 8px}.ce-point-count{font-size:10px;font-weight:500;color:var(--text-muted);letter-spacing:0}.ce-drag-val{font-size:11px;font-weight:600;color:var(--text-secondary);font-variant-numeric:tabular-nums}.ce-section,.ce-section-header,.ce-section-body,.ce-section-title,.ce-channels,.ce-ch-btn,.ce-ch-active,.ce-canvas-section{display:none!important}.sv-container{position:relative;width:100%;height:100%;overflow:hidden;background-color:var(--surface-base);background-image:radial-gradient(circle,var(--border-strong) 1px,transparent 1px);background-size:24px 24px}.sv-dragover{background-color:var(--accent-tint-12)}.sv-dragover:after{content:"";position:absolute;inset:8px;border:2px dashed var(--border-strong);border-radius:12px;pointer-events:none;z-index:10}.sv-canvas{position:absolute;inset:0;width:100%;height:100%}.sv-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;z-index:5;user-select:none;pointer-events:auto}.sv-empty-icon{width:48px;height:48px;border:1px solid var(--border-strong);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-muted);margin-bottom:16px;background:var(--surface-panel)}.sv-empty h3{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:500;color:var(--text-primary);margin:0 0 8px}.sv-empty p{font-family:Space Grotesk,sans-serif;font-size:14px;color:var(--text-muted);margin:0;max-width:320px;text-align:center;line-height:1.5}.sv-zoom-badge{position:absolute;bottom:12px;left:12px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-secondary);background:var(--surface-panel);backdrop-filter:blur(4px);border:1px solid var(--border-strong);padding:3px 8px;border-radius:6px;pointer-events:none;z-index:10}:root{--ssp-bg: var(--surface-panel);--ssp-bg-header: var(--surface-panel);--ssp-bg-input: var(--surface-base);--ssp-bg-hover: var(--surface-hover);--ssp-border: var(--border-subtle);--ssp-border-hover: var(--border-strong);--ssp-border-focus: var(--accent);--ssp-text: var(--text-secondary);--ssp-text-dim: var(--text-muted);--ssp-text-label: var(--text-muted);--ssp-text-muted: var(--text-muted);--ssp-accent: var(--accent);--ssp-font: "Space Grotesk", sans-serif;--ssp-radius: 4px;--ssp-pad-x: 12px;--ssp-font-label: 11px;--ssp-font-value: 11px;--ssp-font-title: 13px;--ssp-font-section: 13px;--ssp-row-height: 26px}.ssp{width:100%;display:flex;flex-direction:column;font-family:var(--ssp-font);overflow:hidden}.ssp-header{display:flex;align-items:center;gap:8px;padding:8px var(--ssp-pad-x);background:var(--ssp-bg-header);border-bottom:.5px solid var(--border-subtle);flex-shrink:0;min-height:40px;box-sizing:border-box;user-select:none;transition:background .1s}.ssp-header:hover{background:var(--border-subtle)}.ssp-collapse-arrow{font-size:10px;line-height:1;color:var(--text-muted);width:12px;flex-shrink:0;user-select:none;text-align:center;transition:color .15s}.ssp-header:hover .ssp-collapse-arrow{color:var(--text-secondary)}.ssp-title{font-size:var(--ssp-font-title);font-weight:600;color:var(--text-secondary);letter-spacing:0;text-transform:none;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ssp-bypassed-module .ssp-title{color:var(--ssp-text-muted);text-decoration:line-through}.ssp-bypassed-module .ssp-body{opacity:.35;pointer-events:none}.ssp-header-actions{display:flex;gap:4px;align-items:center;flex-shrink:0}.ssp-toggle{position:relative;display:inline-block;width:28px;height:16px;flex-shrink:0;background:var(--border-strong);border:1px solid var(--border-subtle);border-radius:999px;cursor:pointer;padding:0;transition:background .15s,border-color .15s;vertical-align:middle}.ssp-toggle-knob{position:absolute;top:1px;left:1px;width:12px;height:12px;border-radius:50%;background:var(--surface-panel);box-shadow:var(--shadow-sm);transition:transform .15s cubic-bezier(.16,1,.3,1),background .15s;pointer-events:none}.ssp-toggle-on{background:var(--accent);border-color:var(--accent)}.ssp-toggle-on .ssp-toggle-knob{transform:translate(12px);background:var(--surface-panel)}.ssp-toggle:hover:not(.ssp-toggle-on){background:var(--border-strong);filter:brightness(1.1)}.ssp-reset-icon{width:22px;height:22px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;border-radius:var(--ssp-radius);flex-shrink:0;transition:color .1s,background .1s}.ssp-reset-icon:hover{color:var(--text-secondary);background:var(--surface-hover)}.ssp-reset-icon:active{transform:scale(.92)}.ssp-close-btn{width:22px;height:22px;border-radius:var(--ssp-radius);background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:14px;line-height:1;transition:background .1s,color .1s}.ssp-close-btn:hover{background:var(--surface-hover);color:var(--text-secondary)}.ssp-body{overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;-ms-overflow-style:none;scrollbar-width:none}.ssp-body::-webkit-scrollbar{display:none}.ssp-empty{display:flex;align-items:center;justify-content:center;color:var(--ssp-text-muted);font-size:var(--ssp-font-label);padding:20px var(--ssp-pad-x);text-align:center}.ssp-section{border-bottom:.5px solid var(--border-subtle);margin:0;padding:0}.ssp-section:last-child{border-bottom:none}.ssp-section-header{display:flex;align-items:center;gap:8px;padding:8px var(--ssp-pad-x);cursor:pointer;user-select:none;min-height:40px;box-sizing:border-box;background:var(--surface-panel);border-bottom:none;transition:background .1s}.ssp-section-header:hover{background:var(--border-subtle)}.ssp-section-header:before{content:"";width:10px;height:10px;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M3 2l4 3-4 3z' fill='%23666'/></svg>");background-repeat:no-repeat;background-position:center;transform:rotate(90deg);transition:transform .15s,filter .15s}.ssp-section-header[data-open=false]:before,.ssp-section[data-open=false]>.ssp-section-header:before,.ssp-section.ssp-collapsed>.ssp-section-header:before{transform:rotate(0)}.ssp-section-header:hover:before{filter:brightness(1.6)}.ssp-section-title{font-size:var(--ssp-font-section);font-weight:600;color:var(--text-secondary);text-transform:none;letter-spacing:0;flex:1}.ssp-inline-reset{width:14px;height:14px;border:none;background:none;color:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;border-radius:3px;flex-shrink:0;transition:color .1s,background .1s}.ssp-section-header:hover .ssp-inline-reset,.ssp-slider-row:hover .ssp-inline-reset{color:var(--text-muted)}.ssp-inline-reset:hover{color:var(--text-secondary)!important;background:var(--surface-hover)}.ssp-section-body{padding:10px var(--ssp-pad-x) 14px;display:flex;flex-direction:column;gap:6px}.ssp-slider-row{display:flex;align-items:center;gap:8px;min-height:var(--ssp-row-height);padding:3px 0}.ssp-slider-label{flex:0 0 80px;font-size:var(--ssp-font-label);font-weight:500;color:var(--text-muted);letter-spacing:.1px;text-transform:none;user-select:none;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ssp-slider-row .ssp-slider{flex:1 1 auto;min-width:0}.ssp-slider-row .ssp-num-input{flex:0 0 54px;margin-left:auto}.ssp-slider{flex:1;width:100%;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-medium);border-radius:2px;outline:none;cursor:pointer;min-width:0;padding:0;margin:0}.ssp-slider::-webkit-slider-runnable-track{height:3px;background:var(--border-medium);border-radius:2px}.ssp-slider::-moz-range-track{height:3px;background:var(--border-medium);border-radius:2px}.ssp-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--border-subtle);border:2px solid var(--text-muted);cursor:pointer;margin-top:-5px;transition:border-color .1s}.ssp-slider::-webkit-slider-thumb:hover{border-color:var(--accent)}.ssp-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--border-subtle);border:2px solid var(--text-muted);cursor:pointer}.ssp-slider::-moz-range-thumb:hover{border-color:var(--accent)}.ssp-num-input{display:flex;align-items:center;border:1px solid var(--border-subtle);border-radius:4px;background:var(--surface-base);min-width:48px;max-width:56px;height:22px;transition:border-color .1s,background .1s}.ssp-num-input:hover{background:var(--surface-hover);border-color:var(--border-strong)}.ssp-num-input:focus-within{border-color:var(--accent)}.ssp-num-val{font-family:var(--ssp-font);font-size:var(--ssp-font-value);color:var(--text-secondary);border:none;background:transparent;outline:none;width:100%;padding:0 6px;text-align:center;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.ssp-num-val::-webkit-outer-spin-button,.ssp-num-val::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.ssp-select{flex:1;min-width:0;height:26px;padding:0 22px 0 8px;background:var(--surface-base);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:var(--ssp-radius);font-family:var(--ssp-font);font-size:var(--ssp-font-value);font-weight:500;cursor:pointer;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 6px center;transition:border-color .1s,background .1s;box-sizing:border-box}.ssp-select:hover{border-color:var(--border-strong)}.ssp-select:focus{border-color:var(--accent)}.ssp-select option{background:var(--surface-panel);color:var(--text-secondary)}.ssp-colors{display:flex;flex-direction:column;gap:6px}.ssp-color-row{display:grid;grid-template-columns:64px minmax(0,1fr) auto;align-items:center;gap:10px;min-height:var(--ssp-row-height);padding:3px 0}.ssp-color-label{font-size:var(--ssp-font-label);font-weight:500;color:var(--text-muted);letter-spacing:.1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ssp-color-row input[type=color]{width:22px;height:22px;padding:0;border:1px solid var(--border-subtle);border-radius:var(--ssp-radius);cursor:pointer;background:none;flex-shrink:0;justify-self:end;grid-column:3;transition:border-color .1s}.ssp-color-row input[type=color]:hover{border-color:var(--border-strong)}.ssp-color-row input[type=color]::-webkit-color-swatch-wrapper{padding:1px}.ssp-color-row input[type=color]::-webkit-color-swatch{border:none;border-radius:2px}.ssp-info{display:flex;flex-direction:column;gap:3px;padding:2px 0}.ssp-info-row{font-size:var(--ssp-font-label);color:var(--text-muted)}.ssp-bc-section{padding:10px var(--ssp-pad-x) 14px;display:flex;flex-direction:column;gap:6px}.ssp-bc-row{display:grid;grid-template-columns:64px minmax(0,1fr) auto;align-items:center;gap:10px;min-height:24px}.ssp-bc-label{font-size:var(--ssp-font-label);font-weight:500;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ssp-bc-value{font-size:var(--ssp-font-value);color:var(--text-secondary);font-weight:500;text-align:right;padding-right:2px;font-variant-numeric:tabular-nums}.ssp-bc-divider{height:.5px;background:var(--border-subtle);margin:4px 0}.ssp-bc-row .ssp-select{height:22px;padding:0 20px 0 6px}.ssp-bc-row .ssp-num-input{height:22px;min-width:46px;max-width:50px}.ssp-bc-row .ssp-num-val{font-size:var(--ssp-font-value);padding:0 5px}.ssp-film{display:flex;flex-direction:column}.ssp-film-active{padding:10px var(--ssp-pad-x);display:flex;align-items:center;gap:10px;border-bottom:.5px solid var(--border-subtle)}.ssp-film-active-bar{width:36px;height:20px;border-radius:3px;flex-shrink:0;border:1px solid var(--border-subtle)}.ssp-film-active-info{display:flex;flex-direction:column;gap:1px;min-width:0}.ssp-film-active-name{font-size:11px;font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ssp-film-active-pack{font-size:9px;color:var(--text-muted)}.ssp-film-controls{padding:10px var(--ssp-pad-x) 14px;display:flex;flex-direction:column;gap:6px;border-bottom:.5px solid var(--border-subtle)}.ssp-film-packs{display:flex;flex-direction:column;padding:6px var(--ssp-pad-x) 10px}.ssp-film-pack-header{display:flex;align-items:center;gap:6px;width:100%;padding:6px 0;border:none;background:none;font-family:var(--ssp-font);font-size:var(--ssp-font-label);font-weight:600;color:var(--text-muted);cursor:pointer;text-align:left;transition:color .1s}.ssp-film-pack-header:hover{color:var(--text-secondary)}.ssp-film-pack-open{color:var(--accent)}.ssp-film-pack-has-active .ssp-film-pack-name{color:var(--text-secondary)}.ssp-film-pack-arrow{font-size:9px;color:var(--text-muted);width:10px;flex-shrink:0}.ssp-film-pack-name{flex:1}.ssp-film-pack-count{font-size:9px;color:var(--text-muted);background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:8px;padding:1px 6px;font-weight:600}.ssp-film-preset-list{display:flex;flex-direction:column;gap:2px;padding:0 0 6px 8px}.ssp-film-preset{display:flex;align-items:center;gap:8px;width:100%;padding:5px 8px;border:1px solid transparent;border-radius:var(--ssp-radius);background:transparent;font-family:var(--ssp-font);cursor:pointer;text-align:left;transition:background .1s,border-color .1s}.ssp-film-preset:hover{background:var(--surface-hover);border-color:var(--border-subtle)}.ssp-film-preset-active{background:var(--accent-tint-08);border-color:var(--accent)}.ssp-film-preset-active:hover{background:var(--accent-tint-12)}.ssp-film-preset-swatch{width:28px;height:14px;border-radius:2px;flex-shrink:0;border:1px solid var(--border-subtle)}.ssp-film-preset-text{flex:1;min-width:0}.ssp-film-preset-name{font-size:var(--ssp-font-label);font-weight:500;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ssp-film-preset-active .ssp-film-preset-name{color:var(--text-secondary);font-weight:600}.ssp-film-preset-check{font-size:11px;color:var(--accent);flex-shrink:0;font-weight:700}.snp{position:absolute;top:8px;left:8px;width:220px;max-height:calc(100% - 16px);background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-md);z-index:60;font-family:Space Grotesk,sans-serif;display:flex;flex-direction:column;overflow:hidden}.snp-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-strong);flex-shrink:0}.snp-title{font-size:13px;font-weight:600;color:var(--text-primary)}.snp-close{width:20px;height:20px;border-radius:4px;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:14px;transition:background-color .1s,color .1s}.snp-close:hover{background:var(--surface-hover);color:var(--text-primary)}.snp-body{flex:1;min-height:0;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:var(--text-muted) transparent}.snp-body::-webkit-scrollbar{width:4px}.snp-body::-webkit-scrollbar-track{background:transparent}.snp-body::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:2px}.snp-category{border-bottom:1px solid var(--border-strong)}.snp-category:last-child{border-bottom:none}.snp-cat-label{padding:7px 8px 3px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.snp-filter-list{padding:0 4px 4px;display:flex;flex-direction:column;gap:2px}.snp-filter-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:none;border:none;border-radius:8px;cursor:pointer;transition:background .08s;text-align:left;font-family:Space Grotesk,sans-serif}.snp-filter-btn:hover{background:var(--surface-hover)}.snp-filter-info{display:flex;flex-direction:column;min-width:0}.snp-filter-name{font-size:12px;font-weight:500;color:var(--text-secondary)}.snp-filter-desc{font-size:11px;color:var(--text-muted)}.st{position:absolute;top:8px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;z-index:55;pointer-events:none}.st>*{pointer-events:auto}.sh-bt-add{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--surface-panel);font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .12s;letter-spacing:.2px}.sh-bt-add svg{color:var(--accent);transition:transform .15s}.sh-bt-add:hover{background:var(--surface-hover);border-color:var(--border-strong);color:var(--text-secondary)}.sh-bt-add:hover svg{transform:scale(1.15)}.sh-bt-add-active{background:var(--surface-hover);border-color:var(--accent);color:var(--text-primary)}.sh-bt-add:active{transform:scale(.97)}.sh-bt-group{display:flex;align-items:center;gap:0;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:6px;overflow:hidden}.sh-bt-sep{width:1px;height:16px;background:var(--border-subtle);flex-shrink:0}.sh-bt-btn{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:0;transition:color .12s,background .12s}.sh-bt-btn:hover{color:var(--text-primary);background:var(--surface-hover)}.sh-bt-btn:active{transform:scale(.92)}.sh-bt-btn:disabled{opacity:.2;cursor:default}.sh-bt-btn:disabled:hover{background:none;color:var(--text-muted)}.npm-overlay{position:fixed;inset:0;z-index:10000;background:var(--shadow-backdrop);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);animation:overlayFade .18s cubic-bezier(.16,1,.3,1) both}.npm-overlay.npm-closing{animation:overlayFadeOut .12s cubic-bezier(.4,0,.2,1) forwards}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}@keyframes overlayFadeOut{0%{opacity:1}to{opacity:0}}.npm-modal{width:720px;min-height:340px;background:var(--bg-5);border-radius:16px;display:flex;overflow:hidden;box-shadow:var(--shadow-lg);animation:npm-in .18s cubic-bezier(.16,1,.3,1) both;will-change:transform,opacity,filter}@keyframes npm-in{0%{opacity:0;transform:scale(.96) translateY(4px);filter:blur(4px)}to{opacity:1;transform:scale(1) translateY(0);filter:blur(0px)}}.npm-modal.npm-closing{animation:npm-out .12s cubic-bezier(.4,0,.2,1) forwards}@keyframes npm-out{0%{opacity:1;transform:scale(1) translateY(0);filter:blur(0px)}to{opacity:0;transform:scale(.98) translateY(2px);filter:blur(4px)}}.npm-left{flex:1;padding:32px;display:flex;flex-direction:column}.npm-logo{width:36px;height:36px;border-radius:10px;background:var(--text-primary);color:var(--bg-5);font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.npm-title{font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:600;color:var(--text-secondary);margin:0 0 24px}.npm-form{display:flex;flex-direction:column;flex:1}.npm-label{font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.npm-input{width:100%;padding:10px 14px;border:1px solid var(--border-medium);border-radius:10px;background:var(--bg-input);color:var(--text-secondary);font-family:Space Grotesk,sans-serif;font-size:14px;outline:none;transition:border-color .15s;box-sizing:border-box}.npm-input:focus{border-color:var(--accent)}.npm-input::placeholder{color:var(--text-faint)}.npm-actions{display:flex;gap:8px;margin-top:auto;padding-top:24px}.npm-btn{font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:600;padding:9px 20px;border:none;border-radius:8px;cursor:pointer;transition:background .12s,opacity .12s,transform .12s}.npm-btn:active:not(:disabled){transform:scale(.97)}.npm-btn:disabled{opacity:.4;cursor:default}.npm-btn-cancel{background:var(--border-medium);color:var(--text-tertiary)}.npm-btn-cancel:hover{background:var(--border-strong)}.npm-btn-create{background:var(--accent);color:#fff}.npm-btn-create:hover{background:var(--accent-hover)}.npm-btn-create:disabled:hover{background:var(--accent)}.npm-app-brand{font-family:Space Grotesk,sans-serif;font-size:24px;font-weight:700;color:var(--text-secondary);margin:0 0 24px;letter-spacing:-.3px}.npm-app-desc{font-family:Space Grotesk,sans-serif;font-size:9px;color:var(--text-faint);line-height:1.5;margin:12px 0 0;padding-top:12px;border-top:1px solid var(--border-soft)}.npm-right{flex:1;background:var(--bg-2);overflow:hidden;position:relative}.npm-banner{width:100%;height:100%;object-fit:cover;display:block}.npm-banner-caption{position:absolute;bottom:0;left:0;right:0;padding:32px 16px 14px;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 100%);display:flex;flex-direction:column;gap:2px}.npm-banner-caption-line{font-family:Space Grotesk,sans-serif;font-size:10px;color:#fff9;line-height:1.4}.npm-banner-caption-line:last-child{color:#fffc;font-weight:500}.sph{width:100%;height:100%;background:var(--surface-base);font-family:Space Grotesk,sans-serif;display:flex;flex-direction:column;overflow-y:auto}.sph-header{text-align:center;padding:48px 40px 24px;flex-shrink:0}.sph-brand{font-size:20px;font-weight:600;color:var(--text-primary)}.sph-subtitle{font-size:12px;color:var(--text-muted);margin-top:4px}.sph-content{flex:1;max-width:700px;margin:0 auto;padding:0 24px 48px;width:100%;box-sizing:border-box}.sph-section{margin-bottom:36px}.sph-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sph-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}.sph-new-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border-strong);border-radius:10px;overflow:hidden}.sph-new-card{background:var(--surface-panel);border:none;border-radius:0;padding:16px;cursor:pointer;transition:background .15s;display:flex;flex-direction:row;align-items:center;gap:12px;font-family:Space Grotesk,sans-serif}.sph-new-card:hover{background:var(--surface-hover)}.sph-new-card-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-muted);transition:color .15s}.sph-new-card-icon svg{width:20px;height:20px}.sph-new-card:hover .sph-new-card-icon{color:var(--accent)}.sph-card-photo .sph-new-card-icon{color:var(--text-muted)}.sph-new-card-name{font-size:12px;font-weight:600;color:var(--text-secondary);transition:color .15s}.sph-new-card:hover .sph-new-card-name{color:var(--text-primary)}.sph-new-card-desc{font-size:11px;color:var(--text-muted);line-height:1.4}.sph-card-import{align-items:center}.sph-card-import .sph-new-card-icon{color:var(--text-muted)}.sph-projects-list{display:flex;flex-direction:column}.sph-project-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-bottom:1px solid var(--border-strong);cursor:pointer;transition:background .1s;border-top:none;border-left:none;border-right:none;background:none;width:100%;text-align:left;font-family:Space Grotesk,sans-serif}.sph-project-row:last-child{border-bottom:none}.sph-project-row:hover{background:var(--surface-panel)}.sph-project-thumb{width:40px;height:28px;border-radius:4px;border:1px solid var(--border-strong);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;font-weight:600;color:var(--text-muted);background:var(--surface-panel);overflow:hidden}.sph-project-thumb img{width:100%;height:100%;object-fit:cover}.sph-project-info{flex:1;min-width:0}.sph-project-name{font-size:12px;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sph-project-meta{font-size:11px;color:var(--text-muted);margin-top:2px}.sph-project-actions{display:flex;gap:4px;opacity:0;transition:opacity .1s}.sph-project-row:hover .sph-project-actions{opacity:1}.sph-project-action-btn{background:none;border:none;padding:4px;cursor:pointer;color:var(--text-muted);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .1s}.sph-project-action-btn:hover{color:var(--text-secondary)}.sph-project-action-btn.sph-action-delete:hover{color:var(--accent)}.sph-project-action-icon{width:14px;height:14px}.sph-empty{text-align:center;padding:24px;color:var(--text-muted);font-size:12px}.sph-rename-input{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--surface-hover);border:1px solid var(--accent);border-radius:4px;padding:2px 6px;outline:none;flex:1;min-width:0}.pal-page{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-1);font-family:Space Grotesk,sans-serif;overflow:hidden;position:relative}.pal-toolbar{height:54px;min-height:54px;display:flex;align-items:center;padding:0 10px 0 12px;background:var(--surface-panel);border-bottom:1px solid var(--border-subtle);z-index:20;gap:2px;flex-shrink:0}.pal-main{flex:1;display:flex;min-height:0;background:var(--bg-2)}.pal-rail{width:44px;background:var(--surface-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;flex-shrink:0}.pal-rail-btn{width:34px;height:34px;border:none;background:transparent;color:var(--text-muted);border-radius:5px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .1s,color .1s}.pal-rail-btn svg{width:19px;height:19px}.pal-rail-btn:hover{background:var(--border-subtle);color:var(--text-secondary)}.pal-rail-btn-active{background:var(--border-subtle);color:var(--accent)}.pal-center{flex:1 1 0;min-width:0;min-height:0;display:flex;align-items:stretch;justify-content:center;padding:24px;overflow:hidden}.pal-center>.pal-strips{flex:1 1 auto;width:100%;max-width:720px;height:100%;border-radius:10px;overflow:hidden;box-shadow:var(--shadow-md)}.pal-center>.pal-center-panel{flex:1 1 auto;width:100%;height:100%;min-width:0;min-height:0;background:var(--bg-3);border:1px solid var(--border-soft);border-radius:10px;overflow:hidden;position:relative;display:flex;flex-direction:column}.pal-center>.pal-center-panel>*{flex:1 1 auto;min-height:0}.pal-right-col{flex:0 0 280px;width:280px;min-width:280px;max-width:280px;background:var(--surface-panel);border-left:1px solid var(--border-subtle);overflow-x:hidden;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none}.pal-right-col::-webkit-scrollbar{display:none}.pal-right-col .st-section,.pal-right-col .st-section-body{max-width:100%;box-sizing:border-box;overflow-x:hidden}.pal-right-col .st-section{border-bottom:.5px solid var(--border-subtle)}.pal-right-col .st-section:last-child{border-bottom:none}.st-section-body .cck-panel,.st-section-body .grd-panel,.st-section-body .hfn-panel,.st-section-body .bls-panel,.st-section-body .shb-panel,.st-section-body .iex-panel,.st-section-body .cpk-panel{padding:0!important;margin:0!important;max-width:100%!important;width:100%!important;background:transparent!important;border:none!important}.st-section-body .cck-header,.st-section-body .grd-header,.st-section-body .hfn-header,.st-section-body .bls-header,.st-section-body .shb-header,.st-section-body .iex-header,.st-section-body .cpk-header{display:none!important}.st-section-body,.st-section-body *{box-sizing:border-box;max-width:100%!important;min-width:0}.st-section-body input,.st-section-body select,.st-section-body textarea,.st-section-body img,.st-section-body canvas{width:auto;max-width:100%!important;box-sizing:border-box}.st-section-body [style*="display: flex"],.st-section-body [class*=-row],.st-section-body [class*=-inputs],.st-section-body [class*=-swatches]{flex-wrap:wrap;min-width:0}.st-section-body .cck-inputs{flex-direction:column!important;gap:10px!important}.st-section-body .cck-color-input{width:100%!important;min-width:0!important}.st-section-body .cck-preview{width:100%!important;min-width:0!important;max-width:100%!important}.st-section-body .cck-swap{align-self:center!important}.st-section-body .grd-preview{width:100%!important;height:96px!important;border-radius:6px!important;border:1px solid var(--border-soft)!important;margin:0 0 12px!important;box-sizing:border-box!important}.st-section-body .grd-type-row{display:flex!important;gap:2px!important;padding:2px!important;background:var(--bg-3)!important;border:1px solid var(--border-soft)!important;border-radius:6px!important;margin:0 0 12px!important}.st-section-body .grd-type-btn{flex:1 1 0!important;height:26px!important;padding:0!important;background:transparent!important;border:none!important;border-radius:4px!important;color:var(--text-muted)!important;font-size:11px!important;font-weight:500!important;cursor:pointer!important;transition:background .1s,color .1s!important}.st-section-body .grd-type-btn:hover{color:var(--text-tertiary)!important}.st-section-body .grd-type-btn.active{background:var(--bg-active)!important;color:var(--text-primary)!important}.st-section-body .grd-angle-row{display:flex!important;align-items:center!important;gap:10px!important;height:26px!important;margin:0 0 14px!important}.st-section-body .grd-angle-row>label{font-size:11px!important;font-weight:500!important;color:var(--text-muted)!important;min-width:48px!important;flex-shrink:0!important}.st-section-body .grd-angle-row input[type=range]{flex:1!important;height:3px!important;-webkit-appearance:none!important;appearance:none!important;background:var(--border-medium)!important;border-radius:2px!important;outline:none!important;cursor:pointer!important;min-width:0!important;padding:0!important;margin:0!important}.st-section-body .grd-angle-row input[type=range]::-webkit-slider-runnable-track{height:3px!important;background:var(--border-medium)!important;border-radius:2px!important}.st-section-body .grd-angle-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none!important;width:12px!important;height:12px!important;border-radius:50%!important;background:var(--bg-5)!important;border:2px solid var(--text-muted)!important;cursor:pointer!important;margin-top:-5px!important;transition:border-color .1s!important}.st-section-body .grd-angle-row input[type=range]::-webkit-slider-thumb:hover{border-color:var(--accent)!important}.st-section-body .grd-angle-val{font-size:11px!important;color:var(--text-tertiary)!important;min-width:36px!important;text-align:right!important;font-variant-numeric:tabular-nums!important;flex-shrink:0!important}.st-section-body .grd-track-section{width:100%!important;margin:0 0 12px!important}.st-section-body .grd-track{position:relative!important;width:100%!important;height:22px!important;border-radius:4px!important;border:1px solid var(--border-soft)!important;box-sizing:border-box!important;cursor:pointer!important}.st-section-body .grd-stop{position:absolute!important;top:50%!important;width:4px!important;height:26px!important;transform:translate(-50%,-50%)!important;border-radius:2px!important;border:1px solid #fff!important;box-shadow:0 0 0 1px #00000080,0 1px 3px #0006!important;cursor:ew-resize!important;box-sizing:border-box!important}.st-section-body .grd-stop.selected{border-color:var(--accent)!important;box-shadow:0 0 0 1px #00000080,0 0 0 2px #0061fe4d,0 1px 3px #0006!important}.st-section-body .grd-stop-edit{display:grid!important;grid-template-columns:28px 1fr 52px 26px!important;gap:6px!important;align-items:center!important;margin:0 0 14px!important}.st-section-body .grd-stop-edit>label{display:none!important}.st-section-body .grd-stop-remove{width:26px!important;height:26px!important;padding:0!important;background:transparent!important;border:1px solid var(--border-medium)!important;border-radius:4px!important;color:var(--text-muted)!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;transition:background .1s,color .1s,border-color .1s!important}.st-section-body .grd-stop-remove:hover:not(:disabled){background:var(--accent-tint-08)!important;color:var(--accent)!important;border-color:#0061fe59!important}.st-section-body .grd-stop-remove:disabled{opacity:.35!important;cursor:not-allowed!important}.st-section-body .grd-stop-edit input[type=color]{width:28px!important;height:26px!important;padding:0!important;background:transparent!important;border:1px solid var(--border-medium)!important;border-radius:4px!important;cursor:pointer!important;min-width:0!important}.st-section-body .grd-stop-hex{width:100%!important;height:26px!important;padding:0 8px!important;background:var(--bg-3)!important;border:1px solid var(--border-medium)!important;border-radius:4px!important;color:var(--text-tertiary)!important;font-family:SF Mono,Menlo,Consolas,monospace!important;font-size:11px!important;outline:none!important;min-width:0!important}.st-section-body .grd-stop-hex:focus{border-color:var(--accent)!important}.st-section-body .grd-stop-pos{width:100%!important;height:26px!important;padding:0 6px!important;background:var(--bg-3)!important;border:1px solid var(--border-medium)!important;border-radius:4px!important;color:var(--text-tertiary)!important;font-size:11px!important;outline:none!important;text-align:right!important;min-width:0!important;font-variant-numeric:tabular-nums!important}.st-section-body .grd-stop-pos:focus{border-color:var(--accent)!important}.st-section-body .grd-export-btn{width:100%!important;height:32px!important;margin-top:10px!important;background:var(--bg-5)!important;color:var(--text-tertiary)!important;border:1px solid var(--border-medium)!important;border-radius:5px!important;font-size:11px!important;font-weight:500!important;cursor:pointer!important}.st-section-body .grd-export-btn:hover{background:var(--bg-active)!important;color:var(--text-primary)!important}.st-section-body .grd-output{position:relative!important;margin:0!important}.st-section-body .grd-output textarea{display:block!important;width:100%!important;min-height:96px!important;padding:10px 72px 10px 12px!important;font-family:SF Mono,Menlo,Consolas,monospace!important;font-size:10.5px!important;line-height:1.55!important;color:var(--text-tertiary)!important;background:var(--bg-3)!important;border:1px solid var(--border-soft)!important;border-radius:6px!important;resize:none!important;outline:none!important;box-sizing:border-box!important;white-space:pre-wrap!important;word-break:normal!important;overflow-wrap:break-word!important;overflow:auto!important;scrollbar-width:none!important;-ms-overflow-style:none!important}.st-section-body .grd-output textarea::-webkit-scrollbar{display:none!important}.st-section-body .grd-output textarea:focus{border-color:var(--border-medium)!important}.st-section-body .grd-copy-btn{position:absolute!important;top:6px!important;right:6px!important;height:22px!important;padding:0 10px!important;background:var(--surface-hover)!important;color:var(--text-tertiary)!important;border:1px solid var(--border-medium)!important;border-radius:4px!important;font-family:Space Grotesk,sans-serif!important;font-size:10px!important;font-weight:500!important;letter-spacing:.3px!important;cursor:pointer!important;transition:background .1s,color .1s,border-color .1s!important}.st-section-body .grd-copy-btn:hover{background:var(--surface-hover)!important;color:var(--text-primary)!important;border-color:var(--border-strong)!important}.st-section-body .grd-copy-btn.copied{background:var(--accent-tint-12)!important;color:var(--accent)!important;border-color:#0061fe4d!important}.st-section-body .grd-stop,.st-section-body .grd-stop-handle{flex-shrink:0}.st-section-body .hfn-base-row input[type=text],.st-section-body .hfn-hex-input{flex:1 1 0!important;min-width:0!important;max-width:100%!important}.st-section-body .hfn-wheel,.st-section-body .hfn-swatches,.st-section-body .hfn-types,.st-section-body .iex-drop,.st-section-body .iex-preview,.st-section-body .iex-swatches,.st-section-body .shb-grid,.st-section-body .shb-row,.st-section-body .bls-grid,.st-section-body .bls-row{width:100%!important;max-width:100%!important;box-sizing:border-box!important}.st-section-body .cpk-panel,.st-section-body .cpk-saturation,.st-section-body .cpk-hue{width:100%!important;max-width:100%!important}.pal-gen{display:flex;flex-direction:column;gap:8px}.pal-gen-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:36px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.2px;cursor:pointer;font-family:inherit;transition:background .1s}.pal-gen-primary:hover{background:var(--accent-hover)}.pal-gen-primary svg{flex-shrink:0}.pal-gen-label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-weight:500}.pal-gen-input,.pal-gen-select{background:var(--bg-2);color:var(--text-tertiary);border:1px solid var(--border-medium);border-radius:5px;height:30px;padding:0 10px;font-size:12px;font-family:inherit;outline:none;transition:border-color .1s}.pal-gen-input:focus,.pal-gen-select:focus{border-color:var(--accent)}.pal-gen-select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:26px}.pal-gen-count{display:flex;align-items:center;background:var(--bg-2);border:1px solid var(--border-medium);border-radius:5px;height:30px;padding:0 4px}.pal-gen-count-btn{width:28px;height:26px;background:transparent;border:none;color:var(--text-tertiary);font-size:14px;cursor:pointer;border-radius:4px;font-family:inherit}.pal-gen-count-btn:hover:not(:disabled){background:var(--bg-active);color:var(--text-primary)}.pal-gen-count-btn:disabled{color:var(--text-faint);cursor:not-allowed}.pal-gen-count-val{flex:1;text-align:center;font-size:12px;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.pal-gen-tip{font-size:10px;color:var(--text-dim);line-height:1.5;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-subtle)}.pal-gen-tip kbd{background:var(--bg-5);border:1px solid var(--border-medium);border-radius:3px;padding:1px 5px;font-family:inherit;font-size:10px;color:var(--text-tertiary)}.pal-tb-btn-primary{width:auto!important;padding:0 12px!important;height:30px!important;background:var(--bg-5)!important;color:var(--text-tertiary)!important;border-radius:5px!important;font-size:12px}.pal-tb-btn-primary:hover{background:var(--bg-active)!important;color:var(--text-primary)!important}.pal-toolbar-left,.pal-toolbar-center,.pal-toolbar-right{display:flex;align-items:center;gap:2px}.pal-toolbar-left{flex:0 0 auto}.pal-toolbar-center{flex:1 1 auto;justify-content:center}.pal-toolbar-right{flex:0 0 auto}.pal-tb-btn{display:flex;align-items:center;justify-content:center;gap:5px;width:34px;height:32px;padding:0;background:none;border:none;border-radius:0;color:var(--text-dim);font-family:Space Grotesk,sans-serif;font-size:11px;cursor:pointer;transition:background .1s,color .1s}.pal-tb-btn:hover{background:var(--bg-active);color:var(--text-tertiary)}.pal-tb-btn:disabled{opacity:.35;cursor:default}.pal-tb-btn:disabled:hover{background:transparent;border-color:transparent}.pal-tb-label{font-size:12px}.pal-tb-title{font-size:12px;color:var(--text-tertiary);font-weight:500;padding:0 8px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pal-tb-sep{width:1px;height:14px;background:var(--border-medium);margin:0 2px}.pal-tb-hint{font-size:11px;color:var(--text-dim)}.pal-tb-hint kbd{display:inline-block;padding:1px 5px;background:var(--bg-5);border:1px solid var(--border-soft);border-radius:3px;font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-muted)}.pal-tb-count-group{display:flex;align-items:center;gap:0;border:1px solid var(--border-subtle);border-radius:6px;overflow:hidden}.pal-tb-count-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;transition:background-color .1s,color .1s;font-family:Space Grotesk,sans-serif}.pal-tb-count-btn:hover{background:var(--bg-hover);color:var(--text-secondary)}.pal-tb-count-btn:disabled{opacity:.25;cursor:default}.pal-tb-count-btn:disabled:hover{background:none;color:var(--text-muted)}.pal-tb-count{font-size:11px;font-weight:600;color:var(--text-tertiary);min-width:20px;text-align:center}.pal-tb-color-input{width:140px;height:32px;padding:0 8px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-active);font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--text-tertiary);outline:none;transition:border-color .15s}.pal-tb-color-input::placeholder{color:var(--text-dim)}.pal-tb-color-input:focus{border-color:var(--accent)}.pal-tb-select{height:32px;padding:0 20px 0 8px;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-active);font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--text-tertiary);outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center}.pal-tb-select:focus{border-color:var(--accent)}.pal-export-wrap{position:relative}.pal-export-menu{position:absolute;top:calc(100% + 6px);right:0;display:flex;flex-direction:column;min-width:120px;background:var(--bg-toolbar);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-medium);border-radius:8px;box-shadow:var(--shadow-md);padding:4px;z-index:100}.pal-export-item{padding:8px 12px;background:none;border:none;border-radius:5px;font-family:Space Grotesk,sans-serif;font-size:12px;color:var(--text-tertiary);cursor:pointer;text-align:left;transition:background .1s}.pal-export-item:hover{background:var(--bg-hover);color:var(--text-secondary)}.pal-browse-page{width:100%;height:100%;background:var(--bg-1);overflow-y:auto}.pal-browse-header{position:sticky;top:0;z-index:10;padding:12px 16px;background:var(--bg-1);border-bottom:1px solid var(--border-subtle)}.pal-browse-back{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background-color .1s,color .1s}.pal-browse-back:hover{color:var(--text-secondary);background:var(--bg-hover)}.pal-layerstyle-page{width:100%;height:100%;background:var(--bg-1);display:flex;flex-direction:column}.pal-layerstyle-page .png-container{flex:1;min-height:0}.pal-tool-tabs{display:flex;align-items:center;gap:0;padding:0 8px;border-bottom:1px solid var(--border-subtle);overflow-x:auto;flex-shrink:0}.pal-tool-tabs::-webkit-scrollbar{display:none}.pal-tool-tab{display:flex;align-items:center;gap:6px;padding:10px 16px;border:none;border-bottom:2px solid transparent;background:none;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:500;color:var(--text-dim);cursor:pointer;transition:color .12s,border-bottom-color .12s;white-space:nowrap;border-radius:0}.pal-tool-tab:hover{color:var(--text-tertiary)}.pal-tool-tab-active{color:var(--text-tertiary);border-bottom-color:var(--accent)}.pal-tool-tab-icon{width:14px;height:14px;display:flex;align-items:center}.pal-tool-tab-icon svg{width:14px;height:14px}.pal-strips{flex:1;display:flex;flex-direction:row;overflow:hidden;position:relative}.pal-strips-compact{flex:none;height:160px;min-height:160px}.pal-strips-hidden{display:none}.pal-tool-panel{flex:1;overflow-y:auto;padding:20px;min-height:0}.pal-tool-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-dim);font-size:12px}.pal-strip{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;cursor:pointer;transition:flex .22s cubic-bezier(.16,1,.3,1),box-shadow .2s,transform .15s cubic-bezier(.16,1,.3,1),filter .15s;user-select:none;min-width:0;will-change:transform}.pal-strip:hover{transform:scaleX(1.02);filter:brightness(1.04)}.pal-strip-selected{box-shadow:inset 0 0 0 3px var(--accent)}.pal-strip-dragover{box-shadow:inset 4px 0 0 0 var(--accent)}.pal-strip-drag{position:absolute;top:12px;left:50%;transform:translate(-50%);opacity:0;cursor:grab;transition:opacity .2s;padding:4px}.pal-strip:hover .pal-strip-drag{opacity:.6}.pal-strip-drag:active{cursor:grabbing}.pal-strip-info{display:flex;flex-direction:column;align-items:center;gap:4px;z-index:1}.pal-hex-label{font-size:16px;font-weight:600;letter-spacing:.5px;text-shadow:0 1px 4px rgba(0,0,0,.3);cursor:text}.pal-hsl-label{font-size:11px;opacity:.6;text-shadow:0 1px 3px rgba(0,0,0,.3)}.pal-hex-input{width:100px;text-align:center;font-size:16px;font-weight:600;font-family:Space Grotesk,sans-serif;letter-spacing:.5px;background:#0003;border:1px solid;border-radius:4px;padding:2px 6px;outline:none}.pal-strip-controls{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;gap:4px;opacity:0;transition:opacity .2s}.pal-strip:hover .pal-strip-controls{opacity:1}.pal-ctrl-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:4px;cursor:pointer;transition:opacity .15s;padding:0;opacity:.5}.pal-ctrl-btn:hover{opacity:1}.pal-add-btn{width:0;padding:0;border:none;background:transparent;color:var(--accent);font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:width .2s,opacity .2s;overflow:hidden;z-index:5;font-family:Space Grotesk,sans-serif;position:relative}.pal-add-btn:before{content:"";position:absolute;inset:0;background:var(--accent-tint-08)}.pal-strips:hover .pal-add-btn:hover{width:28px;opacity:1}.pal-strips:hover .pal-add-btn{width:4px;opacity:.3}.pph{width:100%;height:100%;background:var(--bg-1);overflow-y:auto;font-family:Space Grotesk,sans-serif}.pph-header{padding:48px 40px 24px;text-align:center}.pph-brand{font-size:22px;font-weight:600;color:var(--text-secondary);letter-spacing:-.3px}.pph-subtitle{font-size:12px;color:var(--text-muted);margin-top:6px}.pph-content{max-width:700px;margin:0 auto;padding:0 24px 48px}.pph-section{margin-bottom:32px}.pph-section-header{margin-bottom:12px}.pph-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.pph-tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-subtle);border-radius:6px;overflow:hidden}@media(max-width:900px){.pph-tools-grid{grid-template-columns:repeat(2,1fr)}}@keyframes pph-card-enter{0%{opacity:0;transform:translateY(4px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0px)}}.pph-tool-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-5);border:none;cursor:pointer;transition:background .15s,transform .15s cubic-bezier(.16,1,.3,1),box-shadow .15s;font-family:Space Grotesk,sans-serif;text-align:left;animation:pph-card-enter .18s cubic-bezier(.16,1,.3,1) both;will-change:transform,opacity}.pph-tool-card:nth-child(1){animation-delay:0ms}.pph-tool-card:nth-child(2){animation-delay:30ms}.pph-tool-card:nth-child(3){animation-delay:60ms}.pph-tool-card:nth-child(4){animation-delay:90ms}.pph-tool-card:nth-child(5){animation-delay:.12s}.pph-tool-card:nth-child(6){animation-delay:.15s}.pph-tool-card:nth-child(7){animation-delay:.18s}.pph-tool-card:nth-child(8){animation-delay:.21s}.pph-tool-card:hover{background:var(--bg-active);transform:translateY(-1px)}.pph-tool-card:active{transform:scale(.97)}.pph-tool-icon{flex-shrink:0;width:20px;height:20px;color:var(--text-dim)}.pph-tool-icon svg{width:20px;height:20px}.pph-tool-card:hover .pph-tool-icon{color:var(--accent)}.pph-tool-info{min-width:0}.pph-tool-name{font-size:12px;font-weight:600;color:var(--text-tertiary);margin-bottom:2px}.pph-tool-card:hover .pph-tool-name{color:var(--text-secondary)}.pph-tool-desc{font-size:11px;color:var(--text-dim);line-height:1.3}.pph-quick-row{display:flex;gap:8px}.pph-quick-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:none;border:1px solid var(--border-subtle);border-radius:8px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background-color .12s,border-color .12s,color .12s}.pph-quick-btn:hover{background:var(--bg-hover);border-color:var(--border-soft);color:var(--text-tertiary)}.pph-quick-btn svg{color:var(--text-dim)}.pph-empty{font-size:12px;color:var(--text-dim);padding:16px 0}.pph-projects-list{display:flex;flex-direction:column;gap:2px}.pph-project-head,.pph-project-row{display:grid;grid-template-columns:minmax(0,1fr) 120px 90px 100px;align-items:center;gap:12px;padding:8px 12px}.pph-project-head{padding:6px 12px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-subtle);margin-bottom:2px}.pph-project-row{background:var(--bg-5);border:1px solid var(--border-subtle);border-radius:8px;cursor:pointer;transition:background-color .15s,border-color .15s,transform .15s cubic-bezier(.16,1,.3,1),box-shadow .15s}.pph-project-row:hover{background:var(--bg-active);border-color:var(--border-soft);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.pph-project-row:active{transform:scale(.99)}.pph-project-swatches{display:flex;gap:2px;flex-shrink:0}.pph-swatch{width:20px;height:20px;border-radius:4px}.pph-project-preview{width:108px;height:20px;border-radius:4px;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center}.pph-project-preview-icon{background:var(--surface-hover);color:var(--text-muted)}.pph-project-preview-img img{width:100%;height:100%;object-fit:cover;display:block}.pph-project-name-col{min-width:0}.pph-project-name{font-size:12px;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.pph-project-count,.pph-project-date,.pph-project-time{font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}.pph-rename-input{font-size:12px;font-family:Space Grotesk,sans-serif;background:var(--bg-5);border:1px solid var(--accent);border-radius:4px;color:var(--text-secondary);padding:2px 6px;outline:none}.pph-project-actions{display:flex;gap:4px}.pph-action-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:6px;color:var(--text-muted);cursor:pointer;padding:0;transition:background-color .15s,border-color .15s,color .15s}.pph-action-btn:hover{background:var(--bg-hover);border-color:var(--border-soft);color:var(--text-tertiary)}.pph-action-delete:hover{color:var(--accent);border-color:var(--accent)}@media(prefers-reduced-motion:reduce){.pph-tool-card{animation:none}.pph-tool-card:hover,.pph-project-row:hover,.pal-strip:hover{transform:none}}.hslp{display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif}.hslp-section{border-bottom:1px solid var(--border-subtle)}.hslp-section:last-child{border-bottom:none}.hslp-section-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;min-height:40px;box-sizing:border-box;background:var(--surface-panel);border-bottom:1px solid var(--border-subtle)}.hslp-section-title{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:none;letter-spacing:0}.hslp-section-body{padding:8px 12px 10px;display:flex;flex-direction:column;gap:6px}.hslp-tabs{display:flex;gap:4px;align-items:center}.hslp-tab{padding:4px;border:none;border-radius:4px;background:none;cursor:pointer;transition:background .1s;display:flex;align-items:center;justify-content:center;flex:1}.hslp-tab:hover,.hslp-tab-active{background:var(--surface-hover)}.hslp-tab-active .hslp-dot{transform:scale(1.3);box-shadow:0 0 0 2px #fff3}.hslp-dot{width:10px;height:10px;border-radius:50%;transition:transform .1s,box-shadow .1s}.hslp-sliders{display:flex;flex-direction:column;gap:4px}.hslp-slider-row{display:flex;align-items:center;gap:6px;height:26px}.hslp-slider-label{font-size:11px;font-weight:500;color:var(--text-muted);min-width:72px;flex-shrink:0;text-transform:none;letter-spacing:0}.hslp-slider{flex:1;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-strong);border-radius:2px;outline:none;cursor:pointer;min-width:0;padding:0;margin:0}.hslp-slider::-webkit-slider-runnable-track{height:3px;background:var(--border-strong);border-radius:2px}.hslp-slider::-moz-range-track{height:3px;background:var(--border-strong);border-radius:2px}.hslp-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--surface-panel);border:2px solid var(--text-muted);cursor:pointer;margin-top:-5px;transition:border-color .1s}.hslp-slider::-webkit-slider-thumb:hover{border-color:var(--accent)}.hslp-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--surface-panel);border:2px solid var(--text-muted);cursor:pointer}.hslp-slider::-moz-range-thumb:hover{border-color:var(--accent)}.hslp-num-input{display:flex;align-items:center;border:1px solid var(--border-subtle);border-radius:4px;background:var(--surface-panel);min-width:48px;max-width:56px;height:22px;transition:border-color .1s,background .1s}.hslp-num-input:hover{background:var(--surface-hover);border-color:var(--border-strong)}.hslp-num-val{font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--text-secondary);width:100%;text-align:center;font-variant-numeric:tabular-nums;padding:0 6px}.hw{display:flex;flex-direction:column;height:100%;min-height:0;font-family:Space Grotesk,sans-serif;background:var(--surface-base)}.hw-header-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;min-height:40px;box-sizing:border-box;flex-shrink:0;background:var(--surface-panel);border-bottom:1px solid var(--border-subtle)}.hw-title{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:none;letter-spacing:0}.hw-modes{display:flex;gap:0;background:var(--surface-panel);border-radius:4px;border:1px solid var(--border-subtle);overflow:hidden}.hw-mode-btn{padding:4px 10px;font-size:10px;font-weight:600;font-family:Space Grotesk,sans-serif;background:transparent;color:var(--text-muted);border:none;border-right:1px solid var(--border-subtle);cursor:pointer;text-transform:none;letter-spacing:0;transition:background .12s,color .12s}.hw-mode-btn:last-child{border-right:none}.hw-mode-btn:hover{color:var(--text-secondary);background:var(--surface-hover)}.hw-mode-btn-active{background:var(--surface-hover);color:var(--text-primary)}.hw-canvas-area{flex:1;min-height:0;padding:3px 4px 2px;display:flex;flex-direction:column}.hw-canvas-wrap{flex:1;min-height:40px;position:relative;border-radius:2px;overflow:hidden;background:var(--surface-base);cursor:crosshair}.hw-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}.hw-info-bar{display:flex;align-items:center;gap:6px;padding:2px 8px 4px;flex-shrink:0;min-height:16px;background:var(--surface-base);border-top:1px solid var(--border-subtle)}.hw-info-label{font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:0;text-transform:none}.hw-info-val{font-size:11px;font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:0}.hw-r{color:#e66}.hw-g{color:#6c6}.hw-b{color:#66e}.hw-l{color:#888}.hw-info-clip-s{font-size:9px;font-weight:700;color:#0c0c0c;background:#38f;border-radius:2px;padding:1px 4px;line-height:14px}.hw-info-clip-h{font-size:9px;font-weight:700;color:#0c0c0c;background:#fc0;border-radius:2px;padding:1px 4px;line-height:14px}.hw-desc{font-size:10px;color:var(--text-muted);padding:4px 12px 8px;line-height:1.3}.ba{position:absolute;inset:0;z-index:15;pointer-events:auto;cursor:col-resize}.ba-divider{position:absolute;top:0;bottom:0;width:1.5px;background:#fff9;transform:translate(-50%);z-index:2;cursor:col-resize}.ba-divider:before{content:"";position:absolute;inset:0 -10px}.ba-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:40px;background:#fffc;border-radius:3px;transition:height .15s}.ba-divider:hover .ba-handle{height:52px}.ba-label{position:absolute;top:10px;font-family:Space Grotesk,sans-serif;font-size:9px;font-weight:600;color:#ffffff80;pointer-events:none;z-index:3;letter-spacing:1.5px}.filmstrip{flex-shrink:0;background:var(--surface-panel);display:flex;flex-direction:column;overflow:hidden;user-select:none;-webkit-user-select:none;transition:box-shadow .15s}.filmstrip-dragover{box-shadow:inset 0 0 0 2px var(--accent)}.filmstrip-bar{display:flex;align-items:center;gap:8px;padding:4px 12px;border-bottom:1px solid var(--border-strong);flex-shrink:0;margin-bottom:10px;position:relative}.filmstrip-count{font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--accent)}.filmstrip-bar-label{font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filmstrip-bar-spacer{flex:1}.fs-processing{display:inline-flex;align-items:center;gap:6px;margin-left:8px}.fs-processing-bar{width:80px;height:6px;background:var(--border-strong);border-radius:3px;overflow:hidden;display:block}.fs-processing-fill{display:block;height:6px;background:var(--accent);border-radius:3px;transition:width .3s ease}.fs-processing-text{font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums}.fs-link-status{display:inline-flex;align-items:center;gap:8px;margin-right:4px}.fs-link-item{display:inline-flex;align-items:center;gap:3px;font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;color:var(--text-muted);font-variant-numeric:tabular-nums}.fs-link-btn{background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;color:var(--warn);transition:background .1s}.fs-link-btn:hover{background:var(--surface-hover)}.fs-link-toggle{background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;color:var(--text-muted);transition:background .1s}.fs-link-toggle:hover{background:var(--surface-hover)}.fs-processing-done{font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;color:var(--success);margin-left:8px;animation:fs-ready-fade .3s ease}@keyframes fs-ready-fade{0%{opacity:0}to{opacity:1}}.filmstrip-bar-actions{display:flex;gap:4px;flex-shrink:0}.fs-bar-btn{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;padding:4px 12px;border:1px solid var(--border-strong);border-radius:5px;background:var(--surface-panel);color:var(--text-secondary);cursor:pointer;transition:background .1s,color .1s,border-color .1s;white-space:nowrap}.fs-bar-btn:hover{background:var(--surface-hover);border-color:var(--text-muted);color:var(--text-secondary)}.fs-bar-btn-danger{color:var(--danger);border-color:var(--border-strong)}.fs-bar-btn-danger:hover{background:var(--surface-hover);border-color:var(--danger);color:var(--danger)}.fs-hide-btn-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:22px;height:22px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0;transition:color .1s,background .1s}.fs-hide-btn-center:hover{color:var(--text-secondary);background:var(--border-strong)}.filmstrip-scroll{flex:1;min-height:0;display:flex;gap:6px;padding:10px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scroll-snap-type:x proximity;-ms-overflow-style:none;scrollbar-width:none;align-items:center}.filmstrip-scroll::-webkit-scrollbar{display:none}.filmstrip-thumb{flex-shrink:0;border:3px solid transparent;border-radius:6px;background:var(--surface-panel);cursor:pointer;padding:0;margin:4px 0;overflow:hidden;transition:border-color .12s,box-shadow .15s cubic-bezier(.16,1,.3,1),transform .15s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;position:relative;box-sizing:border-box;will-change:transform;scroll-snap-align:center}.filmstrip-thumb:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-2px) scale(1.02)}.filmstrip-thumb-active{border-color:var(--accent);box-shadow:0 1px 8px var(--accent-tint-12)}.filmstrip-thumb-active:hover{border-color:var(--accent)}.fs-remove-btn{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:12px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:4;opacity:0;transition:opacity .12s,background .12s;padding:0}.filmstrip-thumb:hover .fs-remove-btn{opacity:1}.fs-remove-btn:hover{background:var(--accent)}.filmstrip-img-wrap{overflow:hidden;background:var(--surface-base);border-radius:4px 4px 0 0;width:100%;aspect-ratio:1;position:relative}.fs-stars-overlay{position:absolute;bottom:0;left:0;right:0;text-align:center;font-size:12px;color:var(--warn);padding:12px 0 4px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);pointer-events:none;letter-spacing:1px}.filmstrip-img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}.filmstrip-placeholder{width:100%;aspect-ratio:4 / 3;background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.filmstrip-img-wrap.loading{background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fs-tier-ribbon{position:absolute;top:0;right:6px;z-index:3;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));opacity:.85;pointer-events:none;line-height:0}.fs-checkbox{position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:4px;border:1.5px solid rgba(255,255,255,.6);background:#00000040;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3;padding:0;line-height:1;transition:background .1s,border-color .1s}.fs-checkbox:hover{background:#0006;border-color:#fff}.fs-checkbox-checked{background:var(--accent);border-color:var(--accent)}.fs-checkbox-checked:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.filmstrip-thumb-selected{outline:2px solid var(--accent);outline-offset:-2px}.fs-stars-inline{text-align:center;font-size:15px;color:var(--text-primary);line-height:1;padding:3px 0;letter-spacing:1px}.fs-ctx{position:fixed;z-index:1000;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-md);padding:6px 0;min-width:160px;font-family:Space Grotesk,sans-serif;animation:ctxEnter .12s cubic-bezier(.16,1,.3,1)}@keyframes ctxEnter{0%{opacity:0;transform:translateY(-4px) scale(.96);filter:blur(4px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0px)}}.fs-ctx-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;padding:4px 12px 2px}.fs-ctx-sep{height:0;border-top:1px solid var(--border-strong);margin:4px 0}.fs-ctx-stars{display:flex;align-items:center;gap:2px;padding:2px 12px 4px}.fs-ctx-star{background:none;border:none;font-size:14px;color:var(--text-muted);cursor:pointer;padding:2px;line-height:1;transition:color .1s;border-radius:4px}.fs-ctx-star:hover{color:var(--text-primary);background:var(--border-strong)}.fs-ctx-star-filled{color:var(--text-primary)}.fs-ctx-star:first-child{font-size:11px;color:var(--text-muted);margin-right:2px}.fs-ctx-star:first-child:hover{color:var(--accent);background:var(--surface-hover)}.fs-ctx-colors{display:flex;flex-direction:column}.fs-ctx-color,.fs-ctx-color-none{display:flex;align-items:center;gap:8px;width:100%;padding:5px 12px;border:none;background:none;font-family:Space Grotesk,sans-serif;font-size:12px;color:var(--text-secondary);cursor:pointer;text-align:left;transition:background .1s}.fs-ctx-color:hover,.fs-ctx-color-none:hover{background:var(--surface-hover)}.fs-ctx-color-active{background:var(--accent-tint-12);color:var(--text-primary);font-weight:600}.fs-ctx-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.fs-ctx-danger{color:var(--accent)}.fs-ctx-danger:hover{background:var(--surface-hover);color:var(--danger)}.fs-ctx-disabled{opacity:.35;cursor:default}.fs-ctx-disabled:hover{background:none}.filmstrip-name{padding:4px 4px 6px;font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.filmstrip-thumb-active .filmstrip-name{color:var(--text-primary);font-weight:600}.filmstrip-count-loading{animation:countPulse 1.2s ease-in-out infinite}@keyframes countPulse{0%,to{opacity:1}50%{opacity:.5}}.filmstrip-thumb-skeleton{pointer-events:none;border-color:transparent}.filmstrip-skeleton-img{width:100%;height:100%;border-radius:4px 4px 0 0;background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite}.filmstrip-skeleton-name{height:8px;margin:5px 8px 6px;border-radius:4px;background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite;animation-delay:.15s}@media(prefers-reduced-motion:reduce){.filmstrip-thumb:hover{transform:none}.fs-ctx{animation:none}}.rq-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:4px;color:var(--text-muted);font-size:12px}.rq-empty-hint{font-size:11px;color:var(--text-muted)}.rq-container{display:flex;flex-direction:column;height:100%;font-family:Space Grotesk,sans-serif;position:absolute;inset:0;z-index:20;background:var(--surface-base)}.rq-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0;background:var(--surface-panel)}.rq-header-title{font-size:11px;font-weight:600;color:var(--text-muted)}.rq-header-actions{display:flex;gap:4px;align-items:center}.rq-batch-select{height:24px;padding:0 18px 0 6px;border:1px solid var(--border-subtle);border-radius:4px;background:var(--surface-panel);font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-muted);cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L4 4L7 1' stroke='%23555' stroke-width='1.2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 4px center}.rq-batch-select:disabled{opacity:.3}.rq-clear-btn{padding:4px 10px;border:1px solid var(--border-subtle);border-radius:4px;background:none;font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .1s}.rq-clear-btn:hover{color:var(--text-secondary);border-color:var(--border-strong)}.rq-clear-btn:disabled{opacity:.3;cursor:default}.rq-render-btn{display:flex;align-items:center;gap:5px;padding:5px 14px;border:none;border-radius:4px;background:var(--accent);font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:#fff;cursor:pointer;transition:background .1s}.rq-render-btn:hover{background:var(--accent-hover)}.rq-render-btn:disabled{opacity:.5;cursor:default}.rq-list{flex:1;overflow-y:auto;overflow-x:hidden;-ms-overflow-style:none;scrollbar-width:none}.rq-list::-webkit-scrollbar{display:none}.rq-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border-subtle);transition:background .1s;min-height:48px}.rq-item:hover{background:var(--surface-hover)}.rq-item-active{background:var(--accent-tint-08)}.rq-item-done{opacity:.45}.rq-item-error{background:#ff3b300f}.rq-item-num{font-size:11px;font-weight:600;color:var(--text-muted);min-width:20px;text-align:center;flex-shrink:0}.rq-item-thumb{width:48px;height:32px;border-radius:3px;overflow:hidden;flex-shrink:0;background:var(--surface-panel)}.rq-item-thumb img{width:100%;height:100%;object-fit:cover;display:block}.rq-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.rq-item-name{font-size:12px;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rq-item-size{font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums}.rq-item-select{height:28px;padding:0 20px 0 8px;border:1px solid var(--border-subtle);border-radius:4px;background:var(--surface-panel);font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:500;color:var(--text-secondary);cursor:pointer;outline:none;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L4 4L7 1' stroke='%23555' stroke-width='1.2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;flex-shrink:0}.rq-item-select:focus{border-color:var(--border-strong)}.rq-item-select:disabled{opacity:.4;cursor:default}.rq-item-status{font-size:11px;font-weight:600;min-width:32px;text-align:center;flex-shrink:0}.rq-item-remove{width:24px;height:24px;border:none;background:none;color:var(--text-muted);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .1s,background .1s;flex-shrink:0}.rq-item-remove:hover{color:var(--accent);background:var(--accent-tint-08)}.rq-item-remove:disabled{opacity:.3;cursor:default}.cv{width:100%;height:100%;display:flex;flex-direction:column;background:var(--surface-base);font-family:Space Grotesk,sans-serif;overflow:hidden}.cv-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;flex-shrink:0;border-bottom:1px solid var(--border-strong);background:var(--surface-panel)}.cv-back-btn{width:28px;height:28px;border:1px solid var(--border-strong);border-radius:6px;background:var(--surface-panel);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:background .1s,color .1s}.cv-back-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.cv-albums{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.cv-album-pill{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--surface-panel);border:1px solid transparent;border-radius:12px;padding:4px 10px;cursor:pointer;transition:background-color .12s,color .12s,border-color .12s}.cv-album-pill:hover{background:var(--surface-hover);color:var(--text-secondary)}.cv-album-pill-active{background:var(--text-primary);color:var(--surface-base)}.cv-album-pill-active:hover{background:var(--text-secondary);color:var(--surface-base)}.cv-album-pill-add{border:1px dashed var(--text-muted);background:none}.cv-album-pill-add:hover{border-color:var(--text-muted);background:var(--surface-panel)}.cv-album-input-wrap{display:flex;align-items:center;gap:2px}.cv-album-input{font-family:Space Grotesk,sans-serif;font-size:12px;padding:4px 8px;border:1px solid var(--border-strong);border-radius:12px;outline:none;width:100px;background:var(--surface-panel);color:var(--text-secondary)}.cv-album-input:focus{border-color:var(--accent)}.cv-album-input-btn{font-size:12px;width:22px;height:22px;border:none;border-radius:50%;background:var(--text-primary);color:var(--surface-base);cursor:pointer;display:flex;align-items:center;justify-content:center}.cv-import-btn{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;color:var(--surface-base);background:var(--text-primary);border:none;border-radius:8px;padding:6px 12px;cursor:pointer;flex-shrink:0;transition:background .12s}.cv-import-btn:hover{background:var(--text-secondary)}.cv-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer}.cv-empty-icon{width:48px;height:48px;border:1px solid var(--border-strong);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-muted);margin-bottom:12px;background:var(--surface-panel)}.cv-empty h3{font-size:16px;font-weight:500;color:var(--text-secondary);margin:0 0 6px}.cv-empty p{font-size:12px;color:var(--text-muted);margin:0}.cv-grid{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;align-content:start;-ms-overflow-style:none;scrollbar-width:none}.cv-grid::-webkit-scrollbar{display:none}.cv-card{background:var(--surface-panel);border:2px solid transparent;border-radius:10px;overflow:hidden;cursor:pointer;padding:0;text-align:left;transition:border-color .12s,box-shadow .12s}.cv-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.cv-card-active{border-color:var(--accent);box-shadow:0 2px 12px var(--accent-tint-12)}.cv-card-thumb{width:100%;aspect-ratio:1;background:var(--surface-panel);overflow:hidden}.cv-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.cv-card-placeholder{width:100%;height:100%;background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:cv-shimmer 1.5s infinite}@keyframes cv-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cv-card-info{padding:6px 8px;display:flex;flex-direction:column;gap:2px}.cv-card-name{font-size:12px;font-weight:600;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cv-card-dim{font-size:11px;color:var(--text-muted)}.cv-list{flex:1;overflow-y:auto;overflow-x:hidden;-ms-overflow-style:none;scrollbar-width:none}.cv-list::-webkit-scrollbar{display:none}.cv-list-header{display:flex;align-items:center;padding:6px 14px;border-bottom:1px solid var(--border-strong);background:var(--surface-panel);position:sticky;top:0;z-index:2}.cv-list-header .cv-list-col{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.cv-list-row{display:flex;align-items:center;padding:5px 14px;border:none;border-bottom:1px solid var(--border-strong);background:var(--surface-panel);cursor:pointer;width:100%;text-align:left;transition:background .1s;font-family:Space Grotesk,sans-serif}.cv-list-row:hover{background:var(--surface-hover)}.cv-list-row-active{background:var(--accent-tint-12);border-left:3px solid var(--accent)}.cv-list-col{font-size:12px;color:var(--text-secondary)}.cv-list-col-thumb{width:40px;flex-shrink:0;margin-right:10px}.cv-list-col-name{flex:1;font-weight:500;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cv-list-col-dim{width:90px;flex-shrink:0}.cv-list-col-album{width:80px;flex-shrink:0}.cv-list-col-date{width:80px;flex-shrink:0;font-size:11px;color:var(--text-muted)}.cv-list-thumb-img{width:36px;height:36px;border-radius:4px;object-fit:cover;display:block}.cv-list-thumb-empty{width:36px;height:36px;border-radius:4px;background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:cv-shimmer 1.5s infinite}.cb{display:flex;flex-direction:column;width:100%;height:100%;background:var(--surface-base);color:var(--text-secondary);font-family:Space Grotesk,sans-serif;overflow:hidden;position:relative;transition:box-shadow .15s}.cb-dragover{box-shadow:inset 0 0 0 2px var(--accent)}.cb-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface-panel);border-bottom:1px solid var(--border-subtle);flex-shrink:0;z-index:10}.cb-back-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;transition:color .1s}.cb-back-btn:hover{color:var(--text-primary)}.cb-vbtn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:13px;transition:color .1s,background .1s}.cb-vbtn:hover{color:var(--text-secondary);background:var(--surface-hover)}.cb-vbtn-on{color:var(--accent)}.cb-back-btn{padding:4px 6px}.cb-view-toggle{display:flex;gap:2px;background:var(--surface-panel);border-radius:4px;padding:2px}.cb-view-btn{border:none;background:transparent;border-radius:3px;padding:4px 6px}.cb-view-btn-active{background:var(--accent);color:#fff}.cb-view-btn-active:hover{background:var(--accent-hover)}.cb-search{background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);font-family:inherit;font-size:11px;padding:5px 8px;width:140px;outline:none;transition:border-color .15s}.cb-search::placeholder{color:var(--text-muted)}.cb-search:focus{border-color:var(--accent)}.cb-select{background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-secondary);font-family:inherit;font-size:11px;padding:4px 6px;outline:none;cursor:pointer}.cb-select:focus{border-color:var(--accent)}.cb-select option{background:var(--surface-panel);color:var(--text-secondary)}.cb-sort-dir{padding:4px 6px}.cb-analyze-btn{padding:4px 10px;font-weight:500}.cb-analyzing{opacity:.6;cursor:wait}.cb-count{margin-left:auto;font-size:11px;color:var(--text-muted);white-space:nowrap}.cb-sep{width:1px;height:14px;background:var(--surface-hover);flex-shrink:0}.cb-analysis-info{display:flex;gap:4px;align-items:center}.cb-ai-badge{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;white-space:nowrap}.cb-ai-issue,.cb-ai-dup{background:var(--surface-hover);color:var(--text-secondary)}.cb-ai-ok{background:var(--surface-hover);color:var(--text-muted)}.cb-keep-rate{display:flex;align-items:center;gap:6px}.cb-keep-label{font-size:10px;color:var(--text-muted);white-space:nowrap}.cb-keep-slider{width:80px;height:4px;-webkit-appearance:none;appearance:none;background:var(--border-strong);border-radius:2px;outline:none;cursor:pointer}.cb-keep-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent);cursor:pointer}.cb-keep-value{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:28px;font-variant-numeric:tabular-nums}.cb-analyze{background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:10px;font-weight:600;padding:4px 10px;transition:all .1s}.cb-analyze:hover{color:var(--text-secondary);border-color:var(--border-strong)}.cb-analyze-progress{display:flex;align-items:center;gap:8px;min-width:160px}.cb-analyze-bar{flex:1;height:4px;background:var(--border-subtle);border-radius:2px;overflow:hidden;min-width:80px}.cb-analyze-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .3s ease}.cb-analyze-text{font-size:11px;font-weight:600;color:var(--text-secondary);white-space:nowrap;font-variant-numeric:tabular-nums}.cb-analyze-eta{font-size:10px;color:var(--text-muted);white-space:nowrap}@keyframes cb-indeterminate{0%{transform:translate(-100%)}50%{transform:translate(100%)}to{transform:translate(-100%)}}.cb-dup-strip{position:absolute;top:0;left:0;right:0;height:3px;background:var(--warn)}.cb-right{display:flex;align-items:center;gap:6px}.cb-batch-count{font-size:11px;font-weight:600;color:var(--accent);white-space:nowrap}.cb-batch-group{display:flex;align-items:center;gap:3px}.cb-bstar{background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer;padding:2px;transition:color .1s}.cb-bstar:hover{color:var(--warn)}.cb-bstar:first-child{color:var(--text-muted);font-size:11px}.cb-bstar:first-child:hover{color:var(--accent)}.cb-bdot{width:12px;height:12px;border-radius:50%;border:none;cursor:pointer;padding:0;transition:transform .1s}.cb-bdot:hover{transform:scale(1.25)}.cb-bbtn{background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:10px;font-weight:500;padding:4px 10px;transition:all .1s}.cb-bbtn:hover{color:var(--text-secondary);border-color:var(--border-strong)}.cb-bbtn-danger{color:var(--accent);border-color:var(--accent)}.cb-bbtn-danger:hover{background:var(--surface-hover)}.cb-bbtn-export{color:var(--accent);border-color:var(--accent)}.cb-bbtn-export:hover{background:var(--accent-tint-08);color:var(--accent-hover)}.cb-rename-input{background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:4px;color:var(--text-secondary);font-family:inherit;font-size:11px;padding:3px 6px;width:100px;outline:none}.cb-rename-input:focus{border-color:var(--accent)}.cb-grid{overflow-y:auto;flex:1;position:relative}.cb-card{display:flex;flex-direction:column;background:var(--surface-panel);border:2px solid transparent;border-radius:6px;cursor:pointer;overflow:hidden;transition:border-color .15s,background .15s;box-sizing:border-box}.cb-card:hover{background:var(--surface-hover)}.cb-card-selected{border-color:var(--accent)}.cb-card-active{box-shadow:0 0 0 1px var(--accent)}.cb-thumb-wrap{position:relative;width:100%;flex:1;min-height:0;overflow:hidden;background:var(--surface-base)}.cb-thumb{width:100%;height:100%;object-fit:contain;display:block}.cb-thumb-loading{background:linear-gradient(90deg,var(--surface-panel) 25%,var(--surface-hover) 50%,var(--surface-panel) 75%);background-size:200% 100%;animation:cb-shimmer 1.5s infinite}@keyframes cb-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.cb-thumb-placeholder{width:100%;height:100%}.cb-check{position:absolute;top:6px;left:6px;cursor:pointer;opacity:0;transition:opacity .15s;line-height:0}.cb-card:hover .cb-check,.cb-card-selected .cb-check{opacity:1}.cb-label-dot{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;border:1px solid rgba(0,0,0,.3)}.cb-tier-ribbon{position:absolute;top:0;right:22px;z-index:3;filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));opacity:.85;pointer-events:none;line-height:0}.cb-health{display:inline-flex;align-items:center;gap:8px;margin-left:8px;padding-left:8px;border-left:1px solid var(--surface-hover)}.cb-health-item{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--text-muted);font-variant-numeric:tabular-nums}.cb-health-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.cb-health-missing{cursor:pointer;color:var(--accent)}.cb-health-missing:hover{text-decoration:underline}.cb-badge-row{position:absolute;bottom:0;left:0;right:0;display:flex;gap:4px;padding:14px 6px 5px;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 100%);pointer-events:none}.cb-badge-icon{color:#ffffffbf;display:inline-flex;align-items:center;gap:4px;pointer-events:auto;cursor:default;position:relative}.cb-badge-label{font-family:Space Grotesk,sans-serif;font-size:9px;font-weight:500;color:#ffffffbf;white-space:nowrap;max-width:0;overflow:hidden;opacity:0;transition:max-width .2s ease,opacity .15s ease}.cb-card:hover .cb-badge-label{max-width:80px;opacity:1}.cb-dup-border{position:absolute;inset:0;border:2px dashed rgba(255,149,0,.5);border-radius:inherit;pointer-events:none}.cb-card-footer{padding:4px 6px 5px;display:flex;align-items:center;justify-content:space-between;gap:4px}.cb-stars-overlay{position:absolute;bottom:0;left:0;right:0;display:flex;justify-content:center;padding:14px 0 4px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent);pointer-events:auto}.cb-stars{display:inline-flex;gap:1px}.cb-star{cursor:pointer;transition:transform .1s}.cb-star:hover{transform:scale(1.2)}.cb-filename{padding:5px 6px;font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cb-list{flex:1;overflow-y:auto;padding:0 12px 12px}.cb-list-header{display:flex;align-items:center;gap:0;padding:8px 4px;border-bottom:1px solid var(--border-subtle);position:sticky;top:0;background:var(--surface-base);z-index:5;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.cb-lh-sortable{cursor:pointer}.cb-lh-sortable:hover{color:var(--text-muted)}.cb-lh-check{width:28px;flex-shrink:0}.cb-lh-thumb{width:56px;flex-shrink:0}.cb-lh-name{flex:2;min-width:120px;padding:0 8px}.cb-lh-dims{width:100px;flex-shrink:0;padding:0 4px}.cb-lh-rating{width:80px;flex-shrink:0;padding:0 4px}.cb-lh-label{width:40px;flex-shrink:0;text-align:center}.cb-lh-sharp{width:80px;flex-shrink:0;padding:0 4px}.cb-lh-score{width:50px;flex-shrink:0;padding:0 4px}.cb-lh-issues{width:140px;flex-shrink:0;padding:0 4px}.cb-lh-date{width:100px;flex-shrink:0;padding:0 4px}.cb-list-row{display:flex;align-items:center;padding:4px;border-bottom:1px solid var(--surface-base);cursor:pointer;transition:background .12s;font-size:11px}.cb-list-row:hover{background:var(--surface-panel)}.cb-list-row-selected{background:var(--accent-tint-08)}.cb-list-row-active{box-shadow:inset 3px 0 0 var(--accent)}.cb-lr-check{width:28px;flex-shrink:0;cursor:pointer;line-height:0;display:flex;align-items:center;justify-content:center}.cb-lr-thumb{width:56px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cb-lr-thumb img{width:48px;height:32px;object-fit:cover;border-radius:3px;display:block}.cb-lr-name{flex:2;min-width:120px;padding:0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary)}.cb-lr-dims{width:100px;flex-shrink:0;padding:0 4px;color:var(--text-muted);font-size:10px}.cb-lr-rating{width:80px;flex-shrink:0;padding:0 4px}.cb-lr-label{width:40px;flex-shrink:0;text-align:center;color:var(--text-muted);font-size:10px}.cb-lr-sharp{width:80px;flex-shrink:0;padding:0 4px}.cb-lr-score{width:50px;flex-shrink:0;padding:0 4px}.cb-cull-score{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums}.cb-lr-issues{width:140px;flex-shrink:0;padding:0 4px}.cb-lr-tags{display:flex;gap:6px;flex-wrap:wrap}.cb-lr-tag{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--text-muted);white-space:nowrap}.cb-lr-tag svg{color:var(--text-muted);flex-shrink:0}.cb-lr-date{width:100px;flex-shrink:0;padding:0 4px;color:var(--text-muted);font-size:10px}.cb-sharpness-na{font-size:10px;color:var(--text-muted)}.cb-sharpness-bar{display:inline-flex;align-items:center;width:100%}.cb-sharpness-track{width:100%;max-width:60px;height:4px;background:var(--border-subtle);border-radius:2px;overflow:hidden}.cb-sharpness-fill{height:100%;border-radius:2px;transition:width .2s}.cb-analysis-dots{display:inline-flex;gap:3px;align-items:center}.cb-analysis-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.cb-grid::-webkit-scrollbar,.cb-list::-webkit-scrollbar{width:6px}.cb-grid::-webkit-scrollbar-track,.cb-list::-webkit-scrollbar-track{background:transparent}.cb-grid::-webkit-scrollbar-thumb,.cb-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.cb-grid::-webkit-scrollbar-thumb:hover,.cb-list::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.crop-overlay{position:absolute;inset:0;z-index:40;pointer-events:none;user-select:none;-webkit-user-select:none}.crop-dark{position:absolute;background:#0000008c;pointer-events:auto;transition:left .2s cubic-bezier(.16,1,.3,1),top .2s cubic-bezier(.16,1,.3,1),width .2s cubic-bezier(.16,1,.3,1),height .2s cubic-bezier(.16,1,.3,1)}.crop-border{position:absolute;border:1.5px solid #FFF;box-shadow:0 0 0 1px #0000004d;cursor:move;pointer-events:auto;box-sizing:border-box;transition:left .2s cubic-bezier(.16,1,.3,1),top .2s cubic-bezier(.16,1,.3,1),width .2s cubic-bezier(.16,1,.3,1),height .2s cubic-bezier(.16,1,.3,1)}.crop-grid-h,.crop-grid-v{position:absolute;background:#ffffff40;pointer-events:none}.crop-grid-h{left:0;right:0;height:1px}.crop-grid-v{top:0;bottom:0;width:1px}.crop-handle{position:absolute;width:10px;height:10px;background:#fff;border:1px solid rgba(0,0,0,.3);border-radius:2px;pointer-events:auto;z-index:2;box-shadow:0 1px 3px #0003;transition:left .2s cubic-bezier(.16,1,.3,1),top .2s cubic-bezier(.16,1,.3,1)}.crop-handle-nw{cursor:nw-resize}.crop-handle-ne{cursor:ne-resize}.crop-handle-se{cursor:se-resize}.crop-handle-sw{cursor:sw-resize}.crop-handle-n{cursor:n-resize}.crop-handle-s{cursor:s-resize}.crop-handle-w{cursor:w-resize}.crop-handle-e{cursor:e-resize}.crop-overlay.crop-dragging .crop-dark,.crop-overlay.crop-dragging .crop-border,.crop-overlay.crop-dragging .crop-handle{transition:none}.crop-handle:hover{background:var(--accent);border-color:var(--accent)}.ct{position:absolute;top:42px;left:50%;transform:translate(-50%);z-index:45;display:flex;align-items:center;gap:0;background:var(--surface-panel);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-strong);border-radius:10px;padding:3px 6px;box-shadow:var(--shadow-sm);font-family:Space Grotesk,sans-serif;user-select:none;-webkit-user-select:none}.ct-group{display:flex;align-items:center;gap:2px}.ct-sep{width:1px;height:20px;background:var(--border-strong);margin:0 6px;flex-shrink:0}.ct-pill{padding:3px 8px;border:none;border-radius:5px;background:none;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.ct-pill:hover{background:var(--surface-hover);color:var(--text-secondary)}.ct-pill-active{background:var(--text-primary);color:var(--surface-base)}.ct-pill-active:hover{background:var(--text-secondary);color:var(--surface-base)}.ct-btn{padding:4px 8px;border:none;border-radius:5px;background:none;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:background .1s,color .1s;white-space:nowrap}.ct-btn:hover{background:var(--surface-hover);color:var(--text-secondary)}.ct-btn-active{background:var(--border-strong);color:var(--text-primary)}.ct-btn svg{width:14px;height:14px}.ct-btn-done{background:var(--text-primary);color:var(--surface-base);padding:4px 12px}.ct-btn-done:hover{background:var(--text-secondary);color:var(--surface-base)}.ct-btn-cancel{color:var(--text-muted)}.ct-btn-cancel:hover{color:var(--danger);background:var(--surface-hover)}.ct-straighten{gap:6px}.ct-label{font-size:11px;color:var(--text-muted);white-space:nowrap}.ct-slider{width:80px;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-strong);border-radius:2px;outline:none}.ct-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--text-primary);cursor:pointer}.ct-value{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:36px;text-align:right}.ct-straighten-group{gap:6px}.ct-straighten-slider{cursor:pointer;flex-shrink:0;border-radius:4px;touch-action:none}.ct-straighten-slider:hover rect{fill:var(--accent)}.ct-straighten-slider:active{cursor:grabbing}.studio{width:100%;height:100%;display:flex;flex-direction:column;background:var(--border-subtle);color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;overflow:hidden}.st-toolbar{height:54px;background:var(--surface-panel);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 10px 0 12px;gap:0;flex-shrink:0;z-index:20}.st-modal-backdrop{position:fixed;inset:0;background:var(--shadow-backdrop);backdrop-filter:blur(3px);z-index:2000;display:flex;align-items:center;justify-content:center}.st-modal{background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-lg);color:var(--text-secondary);font-size:12px}.st-main-col{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;position:relative}.st-pages{display:flex;align-items:stretch;gap:0;height:42px;background:var(--surface-base);border-bottom:1px solid var(--border-subtle);padding:0 6px 0 0;flex-shrink:0;overflow-x:auto;overflow-y:hidden;z-index:15;scrollbar-width:none;-ms-overflow-style:none}.st-pages::-webkit-scrollbar{display:none}.st-pages-gutter{display:none}.st-page-tab{display:flex;align-items:center;padding:0 18px;min-width:110px;max-width:260px;font-size:12px;color:var(--text-muted);cursor:pointer;border:none;background:transparent;border-right:1px solid var(--border-subtle);user-select:none;flex-shrink:0;white-space:nowrap}.st-page-tab:hover{background:var(--surface-hover);color:var(--text-secondary)}.st-page-tab-active{background:var(--surface-panel);color:var(--text-primary)}.st-page-tab-name{text-overflow:ellipsis;overflow:hidden}.st-page-tab-input{font-size:11px;color:var(--text-primary);background:var(--bg-2);border:1px solid var(--accent);border-radius:3px;padding:2px 6px;outline:none;width:120px;font-family:inherit}.st-page-add{display:flex;align-items:center;justify-content:center;width:26px;background:transparent;border:none;color:var(--text-dim);cursor:pointer;margin-left:2px;border-radius:3px}.st-page-add:hover{background:var(--bg-active);color:var(--text-primary)}.st-tb-group{display:flex;align-items:center;gap:2px;background:none;border:none;border-radius:0;overflow:visible;flex-shrink:0}.st-tb-btn{width:40px;height:38px;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;border-radius:6px;transition:background .1s,color .1s}.st-tb-btn svg{width:17px;height:17px}.st-tb-btn-sm{width:28px;height:30px}.st-tb-btn:hover{background:var(--bg-active);color:var(--text-primary)}.st-tb-btn:active{transform:scale(.93)}.st-tb-active{background:var(--bg-active);color:var(--accent)}.st-tb-btn-text{width:auto;min-width:0;padding:0 14px;font-size:12px;font-weight:600;letter-spacing:.1px;color:var(--text-secondary)}.st-tb-btn-text:hover{color:var(--text-primary)}.st-tb-sep{width:1px;height:16px;background:var(--border-medium);flex-shrink:0;margin:0 6px}.st-tb-info{font-size:11px;font-weight:500;color:var(--text-dim);letter-spacing:.2px}.st-tb-zoom{width:38px;min-width:38px;background:none;border:none;color:var(--text-muted);font-family:inherit;font-size:11px;font-weight:600;text-align:center;padding:0;outline:none;cursor:pointer;font-variant-numeric:tabular-nums;transition:color .1s}.st-tb-zoom:hover{color:var(--text-secondary)}.st-tb-zoom:focus{color:var(--text-primary);cursor:text}.st-align-row{display:flex;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:5px;padding:2px;gap:2px;transition:border-color .1s}.st-align-row:hover{border-color:var(--border-medium)}.st-align-btn{flex:1;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:3px;color:var(--text-muted);cursor:pointer;padding:0;transition:background .1s,color .1s}.st-align-btn:hover{background:var(--bg-active);color:var(--text-primary)}.st-align-btn:active{background:var(--border-medium);color:var(--text-primary)}.st-align-btn-active,.st-align-btn-active:hover{background:var(--accent-tint-12);color:var(--accent)}.st-ctx{position:fixed;z-index:1000;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:6px;padding:4px;min-width:180px;box-shadow:var(--shadow-md)}.st-ctx button{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:none;border:none;border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:12px;padding:6px 10px;cursor:pointer;transition:background .08s,color .08s}.st-ctx button:hover{background:var(--bg-active);color:var(--text-primary)}.st-ctx button:disabled{color:var(--text-dim);cursor:default}.st-ctx button:disabled:hover{background:none;color:var(--text-dim)}.st-ctx-sep{height:1px;background:var(--bg-active);margin:4px 2px}.st-ctx-sub{position:relative}.st-ctx-sub>button:after{content:"›";color:var(--text-dim);font-size:14px;margin-left:auto;line-height:1}.st-ctx-sub:hover>button{background:var(--bg-active);color:var(--text-primary)}.st-ctx-sub:hover>button:after{color:var(--text-primary)}.st-ctx-submenu{display:none;position:absolute;left:100%;top:-5px;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:6px;padding:4px;min-width:180px;box-shadow:var(--shadow-md);margin-left:2px;max-height:calc(100vh - 24px);overflow-y:auto}.st-ctx-sub:hover .st-ctx-submenu{display:block}.st-ctx-flip-left .st-ctx-submenu{left:auto;right:100%;margin-left:0;margin-right:2px}.st-ctx-check{display:inline-block;width:14px;color:var(--accent);font-weight:700;text-align:center;flex-shrink:0}.st-ctx-shortcut{margin-left:auto;padding-left:16px;color:var(--text-dim);font-size:11px;font-variant-numeric:tabular-nums}.st-ctx-header{padding:6px 10px 4px;font-size:10px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px}.st-ctx-cancel{color:var(--text-dim)!important}.st-main{flex:1;display:flex;min-height:0;position:relative}.st-tools-rail{width:48px;background:var(--surface-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;flex-shrink:0}.st-tool-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:5px;padding:0;transition:background .1s,color .1s}.st-tool-btn svg{width:19px;height:19px}.st-tool-btn:hover{background:var(--border-subtle);color:var(--text-secondary)}.st-tool-btn-active{background:var(--bg-active);color:var(--accent)}.st-tools-sep{width:28px;height:1px;background:var(--bg-active);margin:5px 0}.st-left-rail{width:44px;background:var(--surface-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;flex-shrink:0}.st-right-rail{width:44px;background:var(--surface-panel);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;flex-shrink:0}.st-rail-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-dim);cursor:pointer;border-radius:5px;padding:0;transition:background .1s,color .1s}.st-rail-btn svg{width:19px;height:19px}.st-rail-btn:hover{background:var(--border-subtle);color:var(--text-tertiary)}.st-rail-btn-active{background:var(--border-subtle);color:var(--accent)}.st-left{position:absolute;top:8px;right:330px;width:260px;max-height:calc(100vh - 80px);background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:8px;display:flex;flex-direction:column;flex-shrink:0;z-index:20;box-shadow:var(--shadow-md);overflow:hidden}.st-panel-title{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;padding:14px 16px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.st-layers{flex:1;min-height:0;overflow-y:auto;padding:0;-ms-overflow-style:none;scrollbar-width:none}.st-layers::-webkit-scrollbar{display:none}.st-layer{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-tertiary);border-bottom:1px solid var(--bg-3);transition:background .12s;min-height:36px;box-sizing:border-box}.st-layer:hover{background:var(--border-subtle)}.st-layer-sel{background:var(--accent-tint-08);box-shadow:inset 3px 0 0 var(--accent)}.st-layer-icon{font-size:12px;color:var(--text-dim);width:16px;text-align:center;flex-shrink:0;display:flex;align-items:center;justify-content:center}.st-layer-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;outline:none;border-radius:2px;padding:0 2px}.st-layer-name[contenteditable=true]{background:var(--bg-4);border:1px solid var(--accent);color:var(--text-primary)}.st-layer-hidden{opacity:.4}.st-layer-locked .st-layer-name{color:var(--text-dim)}.st-layer-actions{display:flex;gap:2px;margin-left:auto;visibility:hidden}.st-layer:hover .st-layer-actions,.st-layer-locked .st-layer-actions,.st-layer-hidden .st-layer-actions{visibility:visible}.st-layer-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px;line-height:0;display:flex;align-items:center;justify-content:center;transition:color .1s}.st-layer-btn:hover{color:var(--text-secondary)}.st-layer-btn svg{display:block}.st-layer-drop{background:var(--accent-tint-08)}.st-layer-drop-before{box-shadow:inset 0 2px 0 var(--accent)!important}.st-layer-drop-after{box-shadow:inset 0 -2px 0 var(--accent)!important}.st-layer-drop-into{box-shadow:inset 0 0 0 2px var(--accent)!important;background:var(--accent-tint-12)!important}.st-layer[draggable]{cursor:grab}.st-layer[draggable]:active{cursor:grabbing;opacity:.5}.st-layer-arrow{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:8px;width:14px;height:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:color .1s}.st-layer-arrow:hover{color:var(--text-secondary)}.st-layer-arrow-pad{width:14px;flex-shrink:0}.st-layer-search{padding:8px 10px;border-bottom:1px solid var(--border-subtle)}.st-layer-search input{width:100%;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:11px;font-weight:500;padding:6px 8px;outline:none;box-sizing:border-box;transition:border-color .1s,background .1s}.st-layer-search input:hover{background:var(--bg-active);border-color:var(--text-faint)}.st-layer-search input:focus{border-color:var(--accent);background:var(--border-subtle)}.st-layer-search input::placeholder{color:var(--text-faint)}.st-constrain-btn{background:none;border:1px solid var(--border-medium);border-radius:4px;color:var(--text-dim);cursor:pointer;height:30px;width:30px;padding:0;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-sizing:border-box;transition:all .1s}.st-constrain-btn:hover{border-color:var(--text-faint);color:var(--text-muted)}.st-constrain-active{border-color:var(--accent);color:var(--accent);background:var(--accent-tint-08)}.st-corner-expand-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:2px;display:flex;align-items:center;justify-content:center;transition:color .1s}.st-corner-expand-btn:hover{color:var(--text-tertiary)}.st-toggle{position:relative;display:inline-block;width:28px;height:16px;flex-shrink:0;background:var(--border-strong);border:1px solid var(--border-subtle);border-radius:999px;cursor:pointer;padding:0;transition:background .15s,border-color .15s;vertical-align:middle}.st-toggle:after{content:"";position:absolute;top:1px;left:1px;width:12px;height:12px;border-radius:50%;background:var(--surface-panel);box-shadow:var(--shadow-sm);transition:transform .15s cubic-bezier(.16,1,.3,1)}.st-toggle.on{background:var(--accent);border-color:var(--accent)}.st-toggle.on:after{transform:translate(12px)}.st-toggle:hover:not(.on){background:var(--border-strong);filter:brightness(1.1)}.st-row-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))!important}.st-paint-row-controls.st-seg{background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:6px;padding:2px;gap:1px!important}.st-seg .st-icon-btn{flex:1;width:auto!important;height:24px!important;background:transparent;border:none!important;border-radius:4px;color:var(--text-muted)}.st-seg .st-icon-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.st-seg .st-icon-btn-active{background:var(--accent-tint-12)!important;color:var(--accent)!important;border:none!important}.st-export-row{display:grid;grid-template-columns:60px 1fr 64px 24px;gap:6px;align-items:center;margin-bottom:4px}.st-export-row:last-of-type{margin-bottom:8px}.st-export-row .st-export-scale,.st-export-row .st-export-format,.st-export-row .st-export-suffix{height:26px;padding:0 8px;background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-primary);font-family:inherit;font-size:11px;outline:none;transition:border-color .1s;box-sizing:border-box;min-width:0;width:100%}.st-export-row select.st-export-scale,.st-export-row select.st-export-format{-webkit-appearance:none;appearance:none;padding-right:20px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 6px center;cursor:pointer}.st-export-row .st-export-scale:hover,.st-export-row .st-export-format:hover,.st-export-row .st-export-suffix:hover{border-color:var(--border-strong)}.st-export-row .st-export-scale:focus,.st-export-row .st-export-format:focus,.st-export-row .st-export-suffix:focus{border-color:var(--accent)}.st-export-remove{width:24px;height:26px;padding:0;background:transparent;border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s,color .1s,border-color .1s}.st-export-remove:hover{background:var(--surface-hover);color:var(--danger);border-color:var(--border-strong)}.st-export-run{width:100%;height:30px;margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:5px;font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:background .1s}.st-export-run:hover{background:var(--accent-hover)}.st-corner-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}.st-corner-input{display:flex;align-items:center;gap:4px}.st-corner-input label{font-size:9px;color:var(--text-dim);width:16px;flex-shrink:0}.st-corner-input input{flex:1;background:var(--border-subtle);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:11px;padding:4px 6px;outline:none;width:0}.st-corner-input input:focus{border-color:var(--accent)}.st-center{flex:1;min-width:0;position:relative;overflow:hidden}.st-ruler{position:absolute;background:var(--surface-panel);border-color:var(--border-subtle);user-select:none;cursor:ns-resize;z-index:5}.st-ruler-top{top:0;left:22px;right:0;height:22px;border-bottom:1px solid var(--border-subtle);cursor:ns-resize;overflow:hidden}.st-ruler-left{left:0;top:22px;bottom:0;width:22px;border-right:1px solid var(--border-subtle);cursor:ew-resize;overflow:hidden}.st-ruler-corner{position:absolute;left:0;top:0;width:22px;height:22px;background:var(--surface-panel);border-right:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);z-index:6}.st-isolation-bar{position:absolute;top:0;left:0;right:0;height:30px;background:var(--surface-panel);border-bottom:1px solid var(--accent);color:var(--text-secondary);font-size:11px;padding:0 8px;display:flex;align-items:center;gap:4px;z-index:10;box-shadow:var(--shadow-sm);user-select:none}.st-iso-back{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:4px;padding:0}.st-iso-back:hover{background:var(--border-soft);color:var(--text-primary)}.st-iso-crumb{display:flex;align-items:center;gap:5px;background:none;border:none;color:var(--text-tertiary);font-family:inherit;font-size:11px;padding:4px 8px;border-radius:4px;cursor:pointer}.st-iso-crumb:hover{background:var(--border-soft);color:var(--text-primary)}.st-iso-crumb-active{color:var(--text-primary);font-weight:500;cursor:default}.st-iso-crumb-active:hover{background:none}.st-iso-crumb-icon{display:flex;align-items:center;opacity:.7}.st-iso-crumb-active .st-iso-crumb-icon{opacity:1}.st-iso-sep{color:var(--text-dim);font-size:12px;padding:0 1px}.st-center canvas{display:block;cursor:default}.st-center canvas.pen-cursor{cursor:crosshair}.st-center canvas.hand-cursor{cursor:grab}.st-right{width:280px;background:var(--surface-panel);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none}.st-right::-webkit-scrollbar{display:none}.st-props{padding:0}.st-props-empty{padding:32px 14px;color:var(--text-faint);font-size:11px;text-align:center}.st-section{border-bottom:.5px solid var(--border-subtle);margin:0;padding:0}.st-section:last-child{border-bottom:none}details.st-section>summary{list-style:none;cursor:pointer;padding:8px 12px;display:flex;align-items:center;gap:8px;user-select:none;transition:background .1s;min-height:40px;box-sizing:border-box;background:var(--bg-4);border-bottom:none}details.st-section[open]>summary{border-bottom:.5px solid var(--border-subtle)}details.st-section>summary::-webkit-details-marker{display:none}details.st-section>summary:hover{background:var(--border-subtle)}details.st-section>summary:before{content:"";width:10px;height:10px;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'><path d='M3 2l4 3-4 3z' fill='%23666'/></svg>");background-repeat:no-repeat;background-position:center;transition:transform .15s}details.st-section[open]>summary:before{transform:rotate(90deg)}details.st-section>summary:hover:before{filter:brightness(1.6)}details.st-section.st-section-empty>summary:before{visibility:hidden}details.st-section.st-section-empty>summary{cursor:default}details.st-section.st-section-empty>summary:hover{background:var(--bg-4)}details.st-section>summary .st-label{margin-bottom:0;flex:1;font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:none;letter-spacing:0}details.st-section>.st-section-body{padding:10px 12px 14px}div.st-section{padding:10px 12px 14px;border-bottom:1px solid var(--border-subtle)}.st-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:none;letter-spacing:.2px;margin-bottom:8px}.st-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;gap:6px;margin-bottom:6px}.st-row:last-child{margin-bottom:0}.st-row label{font-size:10px;font-weight:600;color:var(--text-dim);flex-shrink:0;text-transform:uppercase;letter-spacing:.2px}.st-row>.st-row-full,.st-row>:only-child{grid-column:1 / -1}.st-row input[type=number]{flex:1;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:11px;font-weight:500;padding:6px 8px;outline:none;width:0;transition:border-color .1s,background .1s;font-variant-numeric:tabular-nums}.st-row input[type=number]:hover{border-color:var(--border-medium)}.st-row input[type=number]:focus{border-color:var(--accent)}.st-field{display:flex;align-items:center;flex:1;min-width:0;height:30px;background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:5px;padding:0 6px 0 8px;transition:background .1s,border-color .1s;box-sizing:border-box}.st-field:hover{background:var(--surface-hover);border-color:var(--border-strong)}.st-field:focus-within{background:var(--surface-base);border-color:var(--accent)}.st-field-prefix{font-size:10px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;padding-right:6px;user-select:none;cursor:ew-resize;font-variant-numeric:tabular-nums}.st-field:focus-within .st-field-prefix{color:var(--text-muted)}.st-field input{flex:1;min-width:0;width:0;background:transparent;border:none;color:var(--text-primary);font-family:inherit;font-size:11px;font-weight:500;padding:0;outline:none;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.st-field input::-webkit-outer-spin-button,.st-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.st-field-suffix{font-size:10px;color:var(--text-dim);flex-shrink:0;padding-left:4px;user-select:none;cursor:ew-resize;font-variant-numeric:tabular-nums}.st-field-spin{display:flex;flex-direction:column;flex-shrink:0;margin-left:4px;opacity:0;transition:opacity .1s}.st-field:hover .st-field-spin,.st-field:focus-within .st-field-spin{opacity:1}.st-field-spin-btn{width:14px;height:11px;padding:0;border:none;background:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:2px;transition:background .08s,color .08s}.st-field-spin-btn:hover{background:var(--border-medium);color:var(--text-primary)}.st-field-spin-btn svg{display:block}.st-row input[type=color]{width:24px;height:24px;border:1px solid var(--text-faint);border-radius:4px;padding:0;background:none;cursor:pointer}.st-props select,.st-row>input[type=text]{height:30px;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:11px;font-weight:500;padding:0 22px 0 8px;outline:none;min-width:0;box-sizing:border-box;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 6px center}.st-row>input[type=text]{padding:0 8px;background-image:none}.st-props select:focus,.st-row>input[type=text]:focus{border-color:var(--accent)}.st-props select option{background:var(--border-subtle);color:var(--text-tertiary)}.st-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.st-section-header .st-label{margin-bottom:0}.st-slider-row{display:flex;align-items:center;gap:6px;height:26px}.st-slider-label{font-size:11px;font-weight:500;color:var(--text-muted);min-width:72px;flex-shrink:0;text-transform:none;letter-spacing:0}.st-slider{flex:1;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-medium);border-radius:2px;outline:none;cursor:pointer;min-width:0;padding:0;margin:0}.st-slider::-webkit-slider-runnable-track{height:3px;background:var(--border-medium);border-radius:2px}.st-slider::-moz-range-track{height:3px;background:var(--border-medium);border-radius:2px}.st-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--border-subtle);border:2px solid var(--text-muted);cursor:pointer;margin-top:-5px;transition:border-color .1s}.st-slider::-webkit-slider-thumb:hover{border-color:var(--accent)}.st-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--border-subtle);border:2px solid var(--text-muted);cursor:pointer}.st-slider::-moz-range-thumb:hover{border-color:var(--accent)}.st-num-input{display:flex;align-items:center;border:1px solid var(--border-soft);border-radius:4px;background:var(--border-subtle);min-width:48px;max-width:56px;height:22px;transition:border-color .1s,background .1s}.st-num-input:hover{background:var(--bg-active);border-color:var(--text-faint)}.st-num-val{font-family:inherit;font-size:11px;color:var(--text-tertiary);border:none;background:transparent;outline:none;width:100%;padding:0 6px;text-align:center;font-variant-numeric:tabular-nums;-moz-appearance:textfield}.st-num-val::-webkit-outer-spin-button,.st-num-val::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.st-icon-btn{width:20px;height:20px;background:transparent;border:none;color:var(--text-muted);border-radius:3px;cursor:pointer;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.st-icon-btn:hover{background:var(--border-medium);color:var(--text-tertiary)}.st-font-input-wrap{display:flex;align-items:center;gap:6px;height:30px;box-sizing:border-box;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:4px;padding:0 8px;transition:border-color .1s}.st-font-input-wrap:focus-within{border-color:var(--accent)}.st-font-input{flex:1;background:none;border:none;color:var(--text-tertiary);font-family:inherit;font-size:11px;font-weight:500;padding:0;outline:none;min-width:0}.st-font-list::-webkit-scrollbar{width:5px}.st-font-list::-webkit-scrollbar-track{background:transparent}.st-font-list::-webkit-scrollbar-thumb{background:var(--text-faint);border-radius:3px}.st-font-list::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.st-font-option{padding:5px 8px;cursor:pointer;font-size:12px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:space-between;transition:background .08s}.st-font-option:hover{background:var(--bg-active)}.st-font-cat{font-size:9px;color:var(--text-faint);font-family:Space Grotesk,sans-serif;text-transform:uppercase;letter-spacing:.3px}.st-select{flex:1;height:30px;box-sizing:border-box;background:var(--bg-4);border:1px solid var(--border-soft);border-radius:4px;color:var(--text-tertiary);font-family:inherit;font-size:11px;font-weight:500;padding:0 4px;outline:none;transition:border-color .1s}.st-select:hover{border-color:var(--border-medium)}.st-select:focus{border-color:var(--accent)}.st-icon-btn-active{color:var(--accent)!important;border-color:var(--accent)!important;background:var(--accent-tint-08)}.st-paint-card{position:relative;display:flex;flex-direction:column;margin-bottom:14px;padding:6px 0 2px;background:transparent;border-top:1px solid var(--bg-active)}.st-paint-card:first-of-type{border-top:none;padding-top:2px}.st-paint-card:hover{background:transparent}.st-paint-card .st-paint-row{display:grid;grid-template-columns:64px minmax(0,1fr) auto;align-items:center;gap:10px;padding:3px 0;margin:0;background:transparent;border:none}.st-paint-card:hover .st-paint-row{background:transparent}.st-paint-row-label{font-size:11px;font-weight:500;color:var(--text-muted);letter-spacing:.1px;user-select:none}.st-paint-row-controls{display:flex;align-items:center;gap:6px;min-width:0}.st-paint-row-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.st-paint-card .st-blend-mini{width:auto;flex:1 1 0;min-width:0;height:30px;text-align:left;font-size:11px;padding:0 22px 0 8px;box-sizing:border-box;color:var(--text-tertiary);background:var(--surface-base);border:1px solid var(--border-subtle);border-radius:4px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 6px center;background-size:10px}.st-paint-row-controls>.st-field{flex:1 1 0}.st-paint-card .st-blend-mini:hover{border-color:var(--border-medium);color:var(--text-primary)}.st-paint-card .st-blend-mini:focus{border-color:var(--accent)}.st-paint-row{position:relative;display:flex;align-items:center;gap:6px;margin-bottom:10px;padding:4px 6px;background:var(--bg-4);border-radius:4px;transition:background .1s}.st-paint-row:hover{background:var(--bg-4)}.st-paint-action-optional{opacity:0;transition:opacity .1s}.st-paint-card:hover .st-paint-action-optional,.st-paint-row:hover .st-paint-action-optional,.st-paint-action-optional[data-active=true]{opacity:1}.st-swatch{width:20px;height:20px;border:1px solid var(--text-faint);border-radius:3px;cursor:pointer;padding:0;flex-shrink:0;background-image:linear-gradient(45deg,var(--text-dim) 25%,transparent 25%),linear-gradient(-45deg,var(--text-dim) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--text-dim) 75%),linear-gradient(-45deg,transparent 75%,var(--text-dim) 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0}.st-paint-hex{flex:1;min-width:0;font-size:11px;color:var(--text-tertiary);font-family:monospace;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.st-paint-alpha{width:40px;flex-shrink:0;background:var(--bg-2);border:1px solid var(--border-medium);border-radius:3px;color:var(--text-tertiary);font-family:inherit;font-size:11px;padding:3px 4px;outline:none;-moz-appearance:textfield}.st-paint-alpha::-webkit-outer-spin-button,.st-paint-alpha::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.st-paint-alpha:focus{border-color:var(--accent)}.st-blend-mini{width:28px;height:22px;flex-shrink:0;background:var(--bg-2);border:1px solid var(--border-medium);border-radius:3px;color:var(--text-muted);font-size:0;padding:0 2px;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2'%3E%3Ccircle cx='9' cy='12' r='6'/%3E%3Ccircle cx='15' cy='12' r='6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:14px}.st-blend-mini:hover{border-color:var(--text-faint)}.st-blend-mini:focus{outline:none;border-color:var(--accent)}.st-blend-mini option{font-size:11px;background:var(--border-subtle);color:var(--text-tertiary)}.st-picker-anchor{position:absolute;top:26px;right:0;z-index:1000}.st-grad-handle{position:absolute;background:var(--text-primary);border:2px solid var(--accent);box-shadow:0 0 0 1px #0000004d,0 2px 6px #0006;cursor:grab;z-index:100}.st-grad-handle:active{cursor:grabbing}.st-effect-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:6px;margin-top:6px;margin-bottom:8px;width:100%}.st-effect-field{display:flex;align-items:center;gap:6px;background:var(--bg-4);border-radius:4px;padding:4px 8px;min-width:0;overflow:hidden}.st-effect-field label{font-size:10px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.st-effect-field input{flex:1 1 0;width:0;min-width:0;background:transparent;color:var(--text-tertiary);border:none;outline:none;font-family:inherit;font-size:11px;padding:2px 0;text-align:left;-moz-appearance:textfield}.st-effect-field input::-webkit-outer-spin-button,.st-effect-field input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.shutter-split{--sidebar-offset: 0px;--scopes-offset: 0px;--rail-offset: 44px;--tools-offset: 48px;display:flex;flex-direction:column;width:100%;height:100%;font-family:Space Grotesk,sans-serif;position:relative}.shutter-split.shutter-sidebar-open{--sidebar-offset: 280px}.shutter-split.shutter-scopes-open{--scopes-offset: 340px}.shutter-top{min-height:0;overflow:hidden;position:relative;transition:flex .2s cubic-bezier(.16,1,.3,1),margin-right .2s cubic-bezier(.16,1,.3,1),margin-left .2s cubic-bezier(.16,1,.3,1);margin-right:calc(var(--sidebar-offset) + var(--rail-offset));margin-left:calc(var(--scopes-offset) + var(--tools-offset, 0px));margin-top:42px;display:flex;flex-direction:column;will-change:flex,margin-right}.shutter-top>.cb,.shutter-top>.shutter-viewer-area{animation:shutter-tab-in .18s cubic-bezier(.16,1,.3,1) both}@keyframes shutter-tab-in{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.shutter-viewer-area{flex:1;min-height:0;position:relative;overflow:hidden}.sh-tools-rail{position:absolute;top:54px;left:var(--scopes-offset, 0px);bottom:0;width:48px;background:var(--surface-panel);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;z-index:51;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none;box-sizing:border-box;transition:left .2s cubic-bezier(.16,1,.3,1)}.sh-tools-rail::-webkit-scrollbar{display:none}.sh-tool-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:5px;padding:0;flex-shrink:0;transition:background .1s,color .1s}.sh-tool-btn svg{width:19px;height:19px}.sh-tool-btn:hover{background:var(--surface-panel);color:var(--text-primary)}.sh-tool-btn-active{background:var(--surface-hover);color:var(--accent)}.sh-tool-btn:active{transform:scale(.93)}.sh-tool-btn:disabled{opacity:.35;cursor:default}.sh-tool-btn:disabled:hover{background:none;color:var(--text-muted)}.sh-tools-sep{width:28px;height:1px;background:var(--surface-hover);margin:5px 0;flex-shrink:0}.sh-tool-btn-warn{color:var(--warn)}.sh-tool-btn-warn:hover{background:var(--surface-panel);color:var(--warn)}.sh-rail-disabled .sh-tool-btn,.sh-rail-disabled .sh-rail-btn{opacity:.25;pointer-events:none}.shutter-viewer-loading{position:absolute;inset:0;z-index:60;background:var(--surface-base);display:flex;align-items:center;justify-content:center;animation:sh-loading-in .1s ease-out;transition:opacity .3s ease-out}.shutter-viewer-loading-out{opacity:0;pointer-events:none}@keyframes sh-loading-in{0%{opacity:0}to{opacity:1}}.shutter-viewer-loading-spinner{width:28px;height:28px;border:2.5px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:sh-spin .7s linear infinite}.sh-lowres-badge{position:absolute;top:56px;left:50%;transform:translate(-50%);z-index:55;display:flex;align-items:center;gap:6px;background:var(--surface-panel);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--border-strong);border-radius:6px;padding:6px 12px;font-family:Space Grotesk,sans-serif;font-size:11px;color:var(--warn);white-space:nowrap;animation:sh-lowres-in .2s ease}@keyframes sh-lowres-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sh-lowres-missing{color:var(--accent);border-color:#ff3b304d}.sh-lowres-degraded{color:var(--warn);border-color:#ff95004d}.sh-lowres-relink{font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:4px;padding:3px 10px;cursor:pointer;margin-left:4px;transition:background .1s}.sh-lowres-relink:hover{background:var(--accent-hover)}.shutter-exif-overlay{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:12px;padding:5px 10px;background:#00000073;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:6px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:500;color:#ffffffd9;pointer-events:none;user-select:none;-webkit-user-select:none;z-index:10;white-space:nowrap}.shutter-exif-dim{color:#ffffff80;font-weight:400}.shutter-filmstrip-divider{flex-shrink:0;height:0;border-top:1px solid var(--border-strong);cursor:row-resize;position:relative;z-index:5;transition:border-top-color .15s}.shutter-filmstrip-divider:before{content:"";position:absolute;inset:-4px 0;z-index:1}.shutter-filmstrip-divider:hover{border-top-color:var(--accent)}.shutter-filmstrip-divider:active{border-top-color:var(--accent);border-top-width:2px}.shutter-filmstrip-show{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:4px 0;border:none;border-top:1px solid var(--border-strong);background:var(--surface-panel);color:var(--text-muted);font-family:Space Grotesk,sans-serif;font-size:10px;cursor:pointer;flex-shrink:0;transition:background .1s,color .1s}.shutter-filmstrip-show:hover{background:var(--surface-hover);color:var(--text-secondary)}.shutter-divider{flex-shrink:0;height:0;border-top:1px solid var(--border-strong);cursor:row-resize;position:relative;z-index:30;margin-right:var(--sidebar-offset);margin-left:var(--scopes-offset);transition:margin-right .2s cubic-bezier(.16,1,.3,1),margin-left .2s cubic-bezier(.16,1,.3,1),border-top-color .15s}.shutter-divider:before{content:"";position:absolute;inset:-4px 0;z-index:1}.shutter-divider:hover{border-top-color:var(--accent)}.shutter-divider:active{border-top-color:var(--accent);border-top-width:2px}.sh-bottom-tabs{position:absolute;top:8px;left:12px;z-index:25;display:flex;align-items:center;gap:0;background:var(--surface-panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--surface-hover);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-sm)}.sh-bottom-tab{padding:5px 16px;border:none;background:none;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:background .1s,color .1s;border-right:1px solid var(--surface-hover)}.sh-bottom-tab:last-child{border-right:none}.sh-bottom-tab:hover{background:var(--surface-panel);color:var(--text-secondary)}.sh-bottom-tab-active{background:var(--surface-hover);color:var(--text-primary)}.shutter-bottom{min-height:0;position:relative;background-color:var(--surface-base);background-image:radial-gradient(circle,var(--border-strong) .5px,transparent .5px),linear-gradient(to right,var(--border-subtle) 1px,transparent 1px),linear-gradient(to bottom,var(--border-subtle) 1px,transparent 1px);background-size:20px 20px,100px 100px,100px 100px;transition:flex .2s cubic-bezier(.16,1,.3,1),margin-right .2s cubic-bezier(.16,1,.3,1),margin-left .2s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;margin-right:calc(var(--sidebar-offset) + var(--rail-offset));margin-left:calc(var(--scopes-offset) + var(--tools-offset, 0px));will-change:flex,margin-right,margin-left}.shutter-bottom .react-flow{flex:1;min-height:0}.sh-pages{position:absolute;top:54px;left:calc(var(--scopes-offset, 0px) + var(--tools-offset, 0px));right:calc(var(--sidebar-offset, 0px) + var(--rail-offset, 0px));height:42px;display:flex;align-items:stretch;gap:0;background:var(--surface-base);border-bottom:1px solid var(--border-subtle);padding:0 6px 0 0;overflow-x:auto;overflow-y:hidden;z-index:52;scrollbar-width:none;-ms-overflow-style:none;font-family:Space Grotesk,sans-serif;box-sizing:border-box;transition:left .2s cubic-bezier(.16,1,.3,1),right .2s cubic-bezier(.16,1,.3,1)}.sh-pages::-webkit-scrollbar{display:none}.sh-page-tab{display:flex;align-items:center;padding:0 18px;min-width:110px;max-width:260px;font-size:12px;font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:transparent;border-right:1px solid var(--border-subtle);user-select:none;flex-shrink:0;white-space:nowrap;transition:background .12s,color .12s;font-family:inherit}.sh-page-tab:hover{background:var(--surface-hover);color:var(--text-secondary)}.sh-page-tab-active{background:var(--surface-panel);color:var(--text-primary)}.sh-page-tab-name{text-overflow:ellipsis;overflow:hidden}.sh-toolbar{position:relative;width:100%;height:54px;display:flex;align-items:center;gap:0;padding:0 10px 0 12px;background:var(--surface-panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);z-index:60;font-family:Space Grotesk,sans-serif;flex-shrink:0;box-sizing:border-box}.sh-tb-group{display:flex;align-items:center;gap:2px;background:none;border:none;border-radius:0;overflow:visible;flex-shrink:0}.sh-tb-btn{width:40px;height:38px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;flex-shrink:0;border-radius:6px;color:var(--text-muted);transition:background .1s,color .1s}.sh-tb-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.sh-tb-btn:hover .sh-tb-icon{color:var(--text-primary)}.sh-tb-btn-on{background:var(--surface-hover);color:var(--accent)}.sh-tb-btn-on .sh-tb-icon{color:var(--accent)}.sh-tb-btn-warn .sh-tb-icon,.sh-tb-btn-warn:hover .sh-tb-icon{color:var(--warn)}.sh-tb-btn:disabled,.sh-tb-btn-disabled{opacity:.35;cursor:default}.sh-tb-btn:disabled:hover,.sh-tb-btn-disabled:hover{background:none;color:var(--text-muted)}.sh-tb-btn:active{transform:scale(.93)}.sh-tb-btn-label{width:auto;min-width:0;padding:0 14px;font-size:12px;font-weight:600;letter-spacing:.1px;color:var(--text-primary)}.sh-tb-btn-label:hover{color:var(--text-primary)}.sh-tb-icon{width:17px;height:17px;color:inherit;transition:color .1s}.sh-tb-div{width:1px;height:16px;background:var(--border-strong);flex-shrink:0;margin:0 6px}.sh-tb-zoom{font-size:12px;font-weight:600;color:var(--text-muted);min-width:40px;text-align:center;cursor:pointer;white-space:nowrap;padding:0 2px;transition:color .1s;font-variant-numeric:tabular-nums}.sh-tb-zoom:hover{color:var(--text-primary)}.sh-tb-ai-label{font-size:10px;font-weight:600;color:var(--text-muted);white-space:nowrap;user-select:none;padding:0 2px;letter-spacing:.2px}.sh-tb-spin{animation:sh-spin 1s linear infinite}@keyframes sh-spin{to{transform:rotate(360deg)}}.sh-ai-progress{display:flex;align-items:center;gap:8px;padding:0 4px}.sh-ai-progress-bar{width:60px;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden;position:relative}.sh-ai-progress-bar:after{content:"";position:absolute;top:0;left:0;height:100%;width:40%;background:var(--accent);border-radius:2px;animation:sh-ai-slide 1.2s cubic-bezier(.4,0,.2,1) infinite}@keyframes sh-ai-slide{0%{left:-40%}to{left:100%}}.sh-ai-progress-text{font-size:10px;font-weight:500;color:var(--accent);white-space:nowrap;animation:sh-ai-pulse 1.5s ease-in-out infinite}@keyframes sh-ai-pulse{0%,to{opacity:1}50%{opacity:.5}}.sh-tb-project-name{padding:0 8px;font-size:12px;color:var(--text-secondary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;flex-shrink:0}.sh-tb-spacer{flex:1;min-width:4px}.sh-tb-status{font-size:11px;font-weight:500;color:var(--text-muted);white-space:nowrap;flex-shrink:0;letter-spacing:.2px;font-variant-numeric:tabular-nums;transition:color .2s;padding:0 8px;align-self:center}.sh-tb-save-flash{color:var(--success)}.sh-save-badge{display:inline-flex;align-items:center;gap:4px;animation:sh-save-in .3s cubic-bezier(.16,1,.3,1)}@keyframes sh-save-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sh-missing-overlay{position:absolute;inset:0;z-index:200;background:var(--shadow-backdrop);display:flex;align-items:center;justify-content:center;animation:sh-missing-in .2s ease}@keyframes sh-missing-in{0%{opacity:0}to{opacity:1}}.sh-missing-popup{background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:12px;padding:24px;max-width:420px;width:90%;box-shadow:var(--shadow-lg);animation:sh-popup-in .25s cubic-bezier(.16,1,.3,1)}@keyframes sh-popup-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.sh-missing-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.sh-missing-title{font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:600;color:var(--text-primary)}.sh-missing-desc{font-family:Space Grotesk,sans-serif;font-size:12px;color:var(--text-muted);line-height:1.5;margin:0 0 16px}.sh-missing-files{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.sh-missing-file{font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-secondary);background:var(--surface-hover);padding:3px 8px;border-radius:4px}.sh-missing-more{font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-muted);padding:3px 0}.sh-missing-actions{display:flex;gap:8px;justify-content:flex-end}.sh-missing-btn{font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;padding:8px 16px;border-radius:6px;border:1px solid var(--border-strong);background:var(--surface-hover);color:var(--text-secondary);cursor:pointer;transition:all .1s}.sh-missing-btn:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--text-muted)}.sh-missing-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.sh-missing-btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.shutter-screen-toggles{position:absolute;bottom:10px;right:10px;z-index:51;display:flex;align-items:center;gap:0;background:var(--surface-panel);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--surface-hover);border-radius:6px;overflow:hidden;box-shadow:var(--shadow-sm)}.shutter-screen-sep{width:1px;height:16px;background:var(--surface-hover);flex-shrink:0}.shutter-screen-toggle{width:32px;height:30px;border:none;background:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .1s;padding:0}.shutter-screen-toggle:hover,.shutter-screen-toggle-active{background:var(--surface-hover)}.shutter-screen-toggle-active .shutter-screen-toggle-icon{color:var(--accent)}.shutter-screen-toggle-icon{width:16px;height:16px;color:var(--text-muted);transition:color .1s}.shutter-screen-toggle:hover .shutter-screen-toggle-icon{color:var(--text-primary)}.sh-mode-switch{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;padding:0 8px}.sh-mode-switch-label{font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:500;color:var(--text-muted);transition:color .15s}.sh-mode-switch-label.sh-mode-switch-active{color:var(--text-primary);font-weight:600}.sh-mode-switch-track{width:28px;height:14px;background:var(--border-strong);border-radius:7px;position:relative;transition:background .2s}.sh-mode-switch-track.sh-mode-switch-on{background:var(--accent)}.sh-mode-switch-thumb{position:absolute;top:2px;left:2px;width:10px;height:10px;background:var(--text-primary);border-radius:50%;transition:left .2s,background .2s}.sh-mode-switch-on .sh-mode-switch-thumb{left:16px;background:var(--surface-base)}.shutter-left-sidebar{position:absolute;top:54px;left:0;bottom:0;width:340px;background:var(--surface-base);border-right:1px solid var(--border-subtle);z-index:50;display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif;overflow:hidden;box-sizing:border-box}.shutter-scopes-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px 2px;flex-shrink:0;border-bottom:1px solid var(--border-subtle)}.shutter-scopes-title{font-size:9px;font-weight:700;color:var(--text-muted);letter-spacing:1px}.shutter-scopes-body{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;-ms-overflow-style:none;scrollbar-width:none}.shutter-scopes-body::-webkit-scrollbar{display:none}.shutter-scope-panel{flex:1;min-height:160px;border-bottom:1px solid var(--border-subtle)}.shutter-scope-vec{min-height:200px}.shutter-right-sidebar{position:absolute;top:54px;right:0;bottom:0;width:280px;background:var(--surface-panel);border-left:1px solid var(--border-subtle);z-index:50;display:flex;flex-direction:column;font-family:Space Grotesk,sans-serif;overflow:hidden;box-sizing:border-box}.sh-right-rail{position:absolute;top:54px;right:var(--sidebar-offset, 0px);bottom:0;width:44px;background:var(--surface-panel);border-left:1px solid var(--border-subtle);z-index:51;transition:right .2s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:2px;box-sizing:border-box}.sh-rail-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:5px;padding:0;flex-shrink:0;transition:background .1s,color .1s}.sh-rail-btn svg{width:19px;height:19px}.sh-rail-btn:hover{background:var(--border-subtle);color:var(--text-secondary)}.sh-rail-btn-active{background:var(--border-subtle);color:var(--accent)}.sh-rail-btn:active{transform:scale(.93)}.shutter-right-tabs{display:flex;align-items:stretch;gap:0;padding:0 12px;flex-shrink:0;background:var(--surface-panel);border:none;border-bottom:.5px solid var(--border-subtle);border-radius:0;overflow:visible}.shutter-right-tab{display:flex;align-items:center;gap:6px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;padding:10px 12px;margin-bottom:-.5px;cursor:pointer;text-transform:none;letter-spacing:0;transition:color .1s,border-color .1s}.shutter-right-tab:hover{color:var(--text-secondary)}.shutter-right-tab-active{color:var(--text-primary);border-bottom-color:var(--accent)}.shutter-right-tab .shutter-right-tab-icon{display:none}.shutter-right-close{margin-left:auto;background:none;border:none;width:24px;height:24px;font-size:15px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:color .1s,background .1s;flex-shrink:0}.shutter-right-close:hover{color:var(--text-secondary);background:var(--surface-hover)}.shutter-right-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:11px}.shutter-settings-body{flex:1 1 0;overflow-y:auto;overflow-x:hidden;min-height:0;display:flex;flex-direction:column;-ms-overflow-style:none;scrollbar-width:none}.shutter-settings-body::-webkit-scrollbar{display:none}.shutter-modules{display:flex;flex-direction:column}.shutter-module{border-bottom:.5px solid var(--border-subtle)}.shutter-module:last-child{border-bottom:none}.shutter-module .ssp{height:auto}.shutter-module .ssp-body{overflow:visible}.shutter-module .ssp-close-btn{display:none}.shutter-module-extra{border-top:.5px solid var(--border-subtle)}.ssp-export-lossless{flex:1;font-size:11px;font-weight:600;color:var(--success);padding-left:2px}.ssp-export-actions{display:flex;gap:4px}.ssp-export-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:7px 8px;border:1px solid var(--border-subtle);border-radius:4px;background:var(--surface-panel);font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .12s;letter-spacing:.2px}.ssp-export-btn:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-strong)}.ssp-export-btn:active{transform:scale(.97)}.ssp-export-btn:disabled{opacity:.4;cursor:default}.ssp-export-btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.ssp-export-btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:#fff}.ssp-export-sel-btns{display:flex;gap:2px;margin-left:auto}.ssp-export-sel-btn{padding:2px 8px;border:1px solid var(--border-subtle);border-radius:3px;background:var(--surface-panel);font-family:Space Grotesk,sans-serif;font-size:9px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .1s}.ssp-export-sel-btn:hover{background:var(--surface-hover);color:var(--text-secondary);border-color:var(--border-strong)}.ssp-export-hint{font-size:9px;color:var(--text-muted);margin-top:2px}.sh-import-progress{position:absolute;top:48px;left:50%;transform:translate(-50%);z-index:25;background:var(--surface-panel);backdrop-filter:blur(12px);border-radius:20px;padding:6px 14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);animation:sh-prog-in .2s cubic-bezier(.16,1,.3,1)}@keyframes sh-prog-in{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sh-import-progress-bar{width:80px;height:3px;background:var(--text-muted);border-radius:2px;overflow:hidden}.sh-import-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .15s cubic-bezier(.16,1,.3,1)}.sh-import-progress-text{font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-primary);white-space:nowrap;font-variant-numeric:tabular-nums}.sh-import-progress-time{font-family:Space Grotesk,sans-serif;font-size:10px;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.shutter-bottom .react-flow__node.selected{box-shadow:none}.shutter-bottom .react-flow__edge-path{stroke:var(--border-strong);stroke-width:1;transition:stroke .12s}.shutter-bottom .react-flow__edge-path:hover{stroke:var(--accent);stroke-width:1.5;cursor:pointer}.shutter-bottom .react-flow__edge.selected .react-flow__edge-path{stroke:var(--accent);stroke-width:1.5}.shutter-bottom .react-flow__connection-line{stroke:var(--accent);stroke-width:1;stroke-dasharray:4 3;opacity:.7}.shutter-bottom .react-flow__pane{background:transparent!important}.shutter-bottom .react-flow__selection{background:#0061fe0d!important;border:1px solid rgba(0,97,254,.3)!important;border-radius:4px}.shutter-bottom .react-flow__controls,.shutter-bottom .react-flow__attribution{display:none}.shutter-bottom .react-flow__minimap{background:var(--surface-panel)!important;border:1px solid var(--border-subtle)!important;border-radius:4px!important}.shutter-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;z-index:5}.shutter-empty p{font-size:13px;color:var(--text-muted);margin:0}@keyframes spin{to{transform:rotate(360deg)}}.cpk-popover{position:absolute;z-index:1000;padding:12px;width:310px;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary)}.cpk-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.cpk-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.cpk-close{background:none;border:none;color:var(--text-dim);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.cpk-close:hover{color:var(--text-primary)}.cpk-canvas-row{display:flex;gap:8px;margin-bottom:10px}.cpk-square-wrap{position:relative;width:256px;height:256px;border-radius:6px;overflow:hidden;cursor:crosshair}.cpk-square{width:256px;height:256px;display:block}.cpk-marker{position:absolute;width:14px;height:14px;border:2px solid #fff;border-radius:50%;pointer-events:none;box-shadow:0 0 3px #00000080}.cpk-strip-wrap{position:relative;width:20px;height:256px;border-radius:4px;overflow:hidden;cursor:pointer}.cpk-strip{width:20px;height:256px;display:block}.cpk-strip-marker{position:absolute;left:-2px;width:24px;height:6px;border:2px solid #fff;border-radius:3px;pointer-events:none;box-shadow:0 0 3px #00000080}.cpk-preview{height:28px;border-radius:6px;margin-bottom:10px;border:1px solid var(--border-subtle)}.cpk-fields{display:flex;flex-direction:column;gap:6px}.cpk-field-row{display:flex;align-items:center;gap:6px}.cpk-field-row label{font-size:11px;color:var(--text-muted);width:28px;flex-shrink:0;font-weight:500}.cpk-field-row input{flex:1;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:5px;padding:4px 6px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:12px;outline:none}.cpk-field-row input:focus{border-color:var(--accent)}.cpk-field-row input[type=number]{width:48px;flex:none}.cpk-field-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}.cpk-field-group{display:flex;align-items:center;gap:4px}.cpk-field-group .cpk-field-row{flex:1}.cpk-field-group .cpk-small label{width:14px}.cpk-field-group .cpk-small input{width:42px}.cpk-copy-btn{background:none;border:none;color:var(--text-dim);font-size:13px;padding:3px 6px;cursor:pointer;flex-shrink:0;transition:all .15s}.cpk-copy-btn:hover{color:var(--text-tertiary)}.cpk-copy-btn.copied{color:var(--accent)}.cpk-cmyk-row{display:flex;gap:10px;font-size:11px;color:var(--text-muted);padding:4px 0 0}.cck-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary);max-width:600px;margin:0 auto}.cck-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.cck-inputs{display:flex;align-items:flex-end;gap:8px;margin-bottom:14px}.cck-color-input{flex:1}.cck-color-input label{display:block;font-size:11px;color:var(--text-muted);margin-bottom:4px}.cck-input-row{display:flex;align-items:center;gap:6px}.cck-swatch{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-medium);flex-shrink:0}.cck-input-row input{flex:1;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:5px;padding:5px 8px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:12px;outline:none}.cck-input-row input:focus{border-color:var(--accent)}.cck-swap{background:none;border:none;color:var(--text-dim);font-size:16px;padding:5px 8px;cursor:pointer;margin-bottom:1px;transition:all .15s}.cck-swap:hover{color:var(--text-tertiary)}.cck-preview{border-radius:8px;padding:20px;margin-bottom:14px;display:flex;flex-direction:column;gap:6px;border:1px solid var(--border-subtle)}.cck-preview-large{font-size:48px;font-weight:700;line-height:1}.cck-preview-medium{font-size:18px;font-weight:500}.cck-preview-small{font-size:12px}.cck-ratio{text-align:center;margin-bottom:14px}.cck-ratio-number{font-size:42px;font-weight:700;color:var(--text-primary)}.cck-ratio-label{font-size:20px;color:var(--text-muted)}.cck-badges{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.cck-badge-row{display:flex;align-items:center;gap:8px}.cck-badge-label{font-size:12px;color:var(--text-muted);width:80px;flex-shrink:0}.cck-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.cck-badge.pass{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.cck-badge.fail{background:#0061fe26;color:var(--accent);border:1px solid rgba(0,97,254,.3)}.cck-palette-row{border-top:1px solid var(--border-subtle);padding-top:10px}.cck-palette-label{font-size:11px;color:var(--text-muted);display:block;margin-bottom:6px}.cck-palette-swatches{display:flex;gap:4px;flex-wrap:wrap}.cck-pal-swatch{width:26px;height:26px;border-radius:5px;border:1px solid var(--border-medium);cursor:pointer;transition:transform .1s}.cck-pal-swatch:hover{transform:scale(1.15);border-color:var(--accent)}.iex-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary);max-width:600px;margin:0 auto}.iex-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.iex-dropzone{border:2px dashed var(--border-medium);border-radius:10px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s}.iex-dropzone:hover,.iex-dropzone.active{border-color:var(--accent);background:#0061fe0a}.iex-drop-icon{font-size:28px;margin-bottom:8px;color:var(--text-dim)}.iex-drop-text{font-size:13px;color:var(--text-muted)}.iex-image-wrap{position:relative;margin-bottom:12px;border-radius:8px;overflow:hidden;border:1px solid var(--border-subtle)}.iex-image{width:100%;max-height:200px;object-fit:cover;display:block}.iex-remove{position:absolute;top:6px;right:6px;background:#0009;border:none;color:var(--text-tertiary);font-size:16px;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.iex-remove:hover{color:var(--text-primary);background:#000c}.iex-controls{display:flex;align-items:center;gap:8px;margin-bottom:12px}.iex-controls label{font-size:12px;color:var(--text-muted);flex-shrink:0}.iex-controls input[type=range]{flex:1;accent-color:var(--accent);height:4px}.iex-k-val{font-size:13px;color:var(--accent);font-weight:600;width:20px;text-align:center}.iex-extract-btn{background:none;border:none;color:var(--text-dim);font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;cursor:pointer;padding:5px 14px;transition:color .15s}.iex-extract-btn:hover{color:var(--text-tertiary)}.iex-extract-btn:disabled{opacity:.5;cursor:default}.iex-results{border-top:1px solid var(--border-subtle);padding-top:12px}.iex-swatches{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.iex-swatch-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}.iex-swatch-item:hover .iex-swatch{transform:scale(1.1)}.iex-swatch{width:40px;height:40px;border-radius:6px;border:1px solid var(--border-medium);transition:transform .1s}.iex-swatch-label{font-size:10px;color:var(--text-muted)}.iex-apply-btn{width:100%;background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:6px;padding:7px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.iex-apply-btn:hover{background:#0061fe1a}.grd-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary)}.grd-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.grd-preview{width:100%;height:120px;border-radius:10px;border:1px solid var(--border-subtle);margin-bottom:12px}.grd-type-row{display:flex;gap:2px;margin-bottom:12px;border:1px solid var(--border-subtle);border-radius:6px;overflow:hidden;padding:3px}.grd-type-btn{flex:1;background:none;border:none;border-radius:4px;color:var(--text-dim);font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:500;padding:6px;cursor:pointer;transition:background-color .15s,color .15s}.grd-type-btn:hover{color:var(--text-tertiary)}.grd-type-btn.active{background:var(--border-medium);color:var(--text-tertiary)}.grd-angle-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.grd-angle-row label{font-size:12px;color:var(--text-muted);flex-shrink:0}.grd-angle-row input[type=range]{flex:1;accent-color:var(--accent)}.grd-angle-val{font-size:12px;color:var(--accent);font-weight:600;width:36px;text-align:right}.grd-track-section{margin-bottom:12px}.grd-track{position:relative;height:20px;border-radius:6px;cursor:pointer;border:1px solid var(--border-medium)}.grd-stop{position:absolute;top:-4px;width:14px;height:28px;border:2px solid #fff;border-radius:4px;cursor:grab;transform:translate(-7px);box-shadow:0 1px 4px #0006;transition:box-shadow .1s}.grd-stop:hover{box-shadow:0 0 0 2px #0061fe66}.grd-stop.selected{box-shadow:0 0 0 2px var(--accent)}.grd-stop:active{cursor:grabbing}.grd-stop-edit{display:flex;align-items:center;gap:6px;margin-bottom:12px}.grd-stop-edit label{font-size:11px;color:var(--text-muted);flex-shrink:0}.grd-stop-edit input[type=color]{width:28px;height:28px;border:none;border-radius:5px;cursor:pointer;background:none;padding:0}.grd-stop-edit input[type=color]::-webkit-color-swatch-wrapper{padding:0}.grd-stop-edit input[type=color]::-webkit-color-swatch{border:1px solid var(--border-medium);border-radius:4px}.grd-stop-hex{width:72px;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:5px;padding:4px 6px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:12px;outline:none}.grd-stop-hex:focus{border-color:var(--accent)}.grd-stop-pos{width:48px;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:5px;padding:4px 6px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:12px;outline:none}.grd-stop-pos:focus{border-color:var(--accent)}.grd-stop-pos::-webkit-inner-spin-button{-webkit-appearance:none}.grd-output{position:relative;margin-bottom:10px}.grd-output textarea{width:100%;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:6px;padding:8px 10px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:11px;resize:none;outline:none}.grd-output textarea:focus{border-color:var(--accent)}.grd-copy-btn{position:absolute;top:6px;right:6px;background:none;border:none;border-radius:4px;color:var(--text-dim);font-family:Space Grotesk,sans-serif;font-size:11px;padding:3px 8px;cursor:pointer;transition:color .15s}.grd-copy-btn:hover{color:var(--text-tertiary)}.grd-copy-btn.copied{color:var(--accent)}.grd-export-btn{width:100%;background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:6px;padding:7px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .15s}.grd-export-btn:hover{background:var(--accent-tint-08)}.hfn-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary);max-width:500px;margin:0 auto}.hfn-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.hfn-base-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}.hfn-base-row label{font-size:12px;color:var(--text-muted);flex-shrink:0}.hfn-base-input{display:flex;align-items:center;gap:6px;flex:1}.hfn-base-input input[type=color]{width:28px;height:28px;border:none;border-radius:5px;cursor:pointer;background:none;padding:0}.hfn-base-input input[type=color]::-webkit-color-swatch-wrapper{padding:0}.hfn-base-input input[type=color]::-webkit-color-swatch{border:1px solid var(--border-medium);border-radius:4px}.hfn-hex-input{flex:1;background:var(--bg-5);border:1px solid var(--border-medium);border-radius:5px;padding:5px 8px;color:var(--text-tertiary);font-family:Space Grotesk,sans-serif;font-size:12px;outline:none}.hfn-hex-input:focus{border-color:var(--accent)}.hfn-types{display:flex;flex-wrap:wrap;gap:2px;margin-bottom:14px;border:1px solid var(--border-subtle);border-radius:6px;overflow:hidden;padding:3px}.hfn-type-btn{background:none;border:none;border-radius:4px;color:var(--text-dim);font-family:Space Grotesk,sans-serif;font-size:11px;padding:4px 8px;cursor:pointer;transition:background-color .15s,color .15s}.hfn-type-btn:hover{color:var(--text-tertiary)}.hfn-type-btn.active{background:var(--border-medium);color:var(--text-tertiary)}.hfn-wheel-wrap{display:flex;justify-content:center;margin-bottom:14px}.hfn-wheel{width:200px;height:200px}.hfn-results{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.hfn-swatch-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}.hfn-swatch-item:hover .hfn-swatch{transform:scale(1.1)}.hfn-swatch{width:38px;height:38px;border-radius:6px;border:1px solid var(--border-medium);transition:transform .1s}.hfn-swatch-label{font-size:10px;color:var(--text-muted)}.hfn-apply-btn{width:100%;background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:6px;padding:7px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .15s}.hfn-apply-btn:hover{background:#0061fe1a}.bls-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary)}.bls-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.bls-empty{font-size:13px;color:var(--text-dim);padding:20px 0;text-align:center}.bls-section{margin-bottom:10px}.bls-row-label{font-size:11px;color:var(--text-muted);margin-bottom:4px;font-weight:500}.bls-strip{display:flex;border-radius:6px;overflow:hidden;border:1px solid var(--border-subtle)}.bls-cell{flex:1;height:28px;min-width:0}.bls-comparison{display:flex;align-items:center;gap:6px}.bls-comparison .bls-strip{flex:1}.bls-vs{font-size:10px;color:var(--text-dim);flex-shrink:0}.shb-panel{padding:8px 0;font-family:Space Grotesk,sans-serif;color:var(--text-tertiary);max-width:600px;margin:0 auto}.shb-header{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}.shb-palette-pills{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:14px}.shb-pill{font-family:Space Grotesk,sans-serif;font-size:10px;font-weight:600;padding:4px 10px;border-radius:20px;border:2px solid transparent;cursor:pointer;transition:opacity .15s,border-color .15s}.shb-pill:hover{opacity:.85}.shb-pill.active{border-color:var(--accent)}.shb-section{margin-bottom:14px}.shb-section-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;font-weight:500}.shb-scale{display:flex;border-radius:8px;overflow:hidden;border:1px solid var(--border-subtle)}.shb-swatch{flex:1;height:56px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;cursor:pointer;transition:transform .1s;position:relative;min-width:0}.shb-swatch:hover{transform:scaleY(1.08);z-index:1}.shb-swatch.copied:after{content:"Copied";position:absolute;top:4px;font-size:9px;color:inherit;font-weight:600}.shb-swatch-label{font-size:8px;font-weight:500;opacity:0;transition:opacity .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shb-swatch:hover .shb-swatch-label{opacity:1}.shb-replace-btn{width:100%;background:transparent;border:1px solid var(--accent);color:var(--accent);border-radius:6px;padding:7px;font-family:Space Grotesk,sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .15s}.shb-replace-btn:hover{background:#0061fe1a}.bg-root{padding:16px 20px 40px}.bg-search-wrap{position:sticky;top:0;z-index:5;background:var(--bg-2);padding-bottom:8px}.bg-search{width:100%;height:36px;background:var(--bg-active);border:1px solid var(--border-subtle);border-radius:6px;padding:0 12px 0 36px;font:500 12px/36px Space Grotesk,sans-serif;color:var(--text-tertiary);outline:none;box-sizing:border-box}.bg-search::placeholder{color:var(--text-dim)}.bg-search:focus{border-color:var(--accent)}.bg-search-icon{position:absolute;left:12px;top:10px;color:var(--text-dim);font-size:14px;pointer-events:none}.bg-tabs{display:flex;align-items:center;gap:2px;padding:3px;border:1px solid var(--border-subtle);border-radius:8px;overflow-x:auto;margin-bottom:12px;flex-shrink:0}.bg-tabs::-webkit-scrollbar{display:none}.bg-tab{padding:6px 14px;font:500 12px Space Grotesk,sans-serif;color:var(--text-dim);background:none;border:none;border-radius:6px;cursor:pointer;transition:background .12s,color .12s;white-space:nowrap}.bg-tab:hover{color:var(--text-tertiary);background:var(--bg-hover)}.bg-tab.active{background:var(--border-medium);color:var(--text-tertiary)}.bg-count{font:400 11px Space Grotesk,sans-serif;color:var(--text-dim);margin-bottom:8px}.bg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:1px;background:var(--bg-5);border-radius:8px;overflow:hidden}.bg-swatch{background:var(--bg-2);cursor:pointer;position:relative;transition:filter .12s}.bg-swatch:hover{filter:brightness(1.15)}.bg-swatch-fill{height:56px;width:100%}.bg-swatch-info{padding:6px 8px}.bg-swatch-name{font:500 11px Space Grotesk,sans-serif;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bg-swatch-hex{font:400 10px Space Grotesk,sans-serif;color:var(--text-dim);margin-top:2px}.bg-add-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:5px;background:#00000080;border:none;color:#fff;font-size:14px;cursor:pointer;opacity:0;transition:opacity .12s;padding:0;display:flex;align-items:center;justify-content:center}.bg-swatch:hover .bg-add-btn{opacity:1}.bg-add-btn:hover{background:#000000bf}.bg-copied{position:absolute;top:16px;left:50%;transform:translate(-50%);background:#000000b3;color:var(--accent);font:600 10px Space Grotesk,sans-serif;padding:3px 8px;border-radius:4px;pointer-events:none}.bg-empty{text-align:center;padding:40px 16px;color:var(--text-dim);font:400 12px Space Grotesk,sans-serif;grid-column:1 / -1}.color-mixer-panel{max-width:500px;margin:0 auto;font-family:Space Grotesk,sans-serif}.mixer-section{margin-bottom:16px}.mixer-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.mixer-wells{display:flex;gap:10px}.mixer-well-wrap{flex:1;position:relative}.mixer-well{width:100%;height:60px;border-radius:8px;border:2px solid var(--border-subtle);cursor:pointer;transition:border-color .15s}.mixer-well:hover{border-color:var(--text-faint)}.mixer-well--selected{border-color:var(--accent)}.mixer-picker{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:50;background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden}.mixer-picker-canvas{position:relative;width:100%;height:140px;cursor:crosshair}.mixer-picker-white{position:absolute;inset:0;background:linear-gradient(to right,#fff,transparent)}.mixer-picker-black{position:absolute;inset:0;background:linear-gradient(to top,#000,transparent)}.mixer-picker-cursor{position:absolute;width:12px;height:12px;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000004d,inset 0 0 0 1px #0000004d;transform:translate(-50%,-50%);pointer-events:none}.mixer-picker-hue{position:relative;height:12px;margin:8px 10px;border-radius:6px;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);cursor:crosshair}.mixer-picker-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0006;pointer-events:none}.mixer-picker-hex{padding:6px 10px 10px;font-size:11px;font-weight:500;color:var(--text-dim)}.mixer-modes{display:flex;flex-wrap:wrap;border:1px solid var(--border-subtle);border-radius:6px;padding:3px;gap:2px;overflow:hidden}.mixer-mode-btn{padding:5px 10px;font-size:11px;font-family:Space Grotesk,sans-serif;font-weight:500;color:var(--text-dim);background:none;border:none;border-radius:4px;cursor:pointer;transition:background .12s,color .12s}.mixer-mode-btn:hover{color:var(--text-tertiary);background:var(--bg-hover)}.mixer-mode-btn--active{background:var(--border-medium);color:var(--text-tertiary)}.mixer-slider{width:100%;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-medium);border-radius:2px;outline:none;cursor:pointer}.mixer-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--text-tertiary);border:none;cursor:pointer}.mixer-slider::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--text-tertiary);border:none;cursor:pointer}.mixer-result-swatch{width:100%;height:80px;border-radius:8px;margin-bottom:10px}.mixer-result-row{display:flex;align-items:center;justify-content:space-between}.mixer-result-hex{font-size:13px;font-family:Space Grotesk,sans-serif;font-weight:600;color:var(--text-tertiary);letter-spacing:.5px}.mixer-apply-btn{background:none;border:1px solid var(--border-subtle);border-radius:6px;padding:8px 20px;font-size:12px;font-family:Space Grotesk,sans-serif;font-weight:600;color:var(--text-tertiary);cursor:pointer;transition:background .12s,color .12s}.mixer-apply-btn:hover{background:var(--bg-hover)}.pn{background:var(--bg-2);border:1px solid var(--bg-active);border-radius:12px;min-width:160px;max-width:200px;font-family:Space Grotesk,sans-serif;cursor:grab;overflow:visible;transition:box-shadow .15s,border-color .15s}.pn:hover{border-color:var(--border-strong);box-shadow:var(--shadow-sm)}.react-flow__node.selected .pn{border-color:var(--accent);box-shadow:var(--shadow-md)}.pn.pn-bypassed{opacity:.35;border-style:dashed}.pn-header{display:flex;align-items:center;gap:6px;height:32px;padding:0 10px;background:var(--bg-active);border-radius:12px 12px 0 0;box-sizing:border-box;transition:background .12s}.pn-header:last-child{border-radius:12px}.pn:hover .pn-header{background:var(--bg-hover)}.pn-header-icon{width:18px;height:18px;color:var(--text-dim);flex-shrink:0}.pn-header-icon svg{width:18px;height:18px}.pn-label{font-size:12px;font-weight:600;color:var(--text-tertiary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pn-bypass-badge{font-size:8px;font-weight:500;color:var(--text-dim);background:var(--bg-active);padding:1px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.pn-swatch{width:100%;height:24px;border-radius:0}.pn-swatch-multi{width:100%;height:24px;border-radius:0;display:flex;overflow:hidden}.pn-swatch-multi>span{flex:1;height:100%}.pn-swatch-multi>span:last-child{border-radius:0}.pn-swatch-multi>span:first-child{border-radius:0}.pn-swatch-picker{position:relative}.pn-picker{position:absolute;top:0;left:calc(100% + 12px);z-index:100;width:200px;background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden;font-family:Space Grotesk,sans-serif}.pn-picker-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px}.pn-picker-title{font-size:11px;font-weight:600;color:var(--text-tertiary)}.pn-picker-close{background:none;border:none;color:var(--text-dim);font-size:14px;cursor:pointer;padding:0;line-height:1}.pn-picker-close:hover{color:var(--text-tertiary)}.pn-picker-canvas{position:relative;width:100%;height:140px;cursor:crosshair;overflow:hidden}.pn-picker-white{position:absolute;inset:0;background:linear-gradient(to right,#fff,transparent)}.pn-picker-black{position:absolute;inset:0;background:linear-gradient(to top,#000,transparent)}.pn-picker-cursor{position:absolute;width:12px;height:12px;border:2px solid #fff;border-radius:50%;box-shadow:0 0 0 1px #0000004d,inset 0 0 0 1px #0000004d;transform:translate(-50%,-50%);pointer-events:none}.pn-picker-hue{position:relative;height:12px;margin:8px 10px;border-radius:6px;background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);cursor:crosshair}.pn-picker-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0006;pointer-events:none}.pn-picker-hex-row{display:flex;align-items:center;padding:6px 10px 10px;gap:2px}.pn-picker-hash{font-size:11px;color:var(--text-dim);font-weight:500}.pn-picker-hex-input{flex:1;background:var(--bg-active);border:1px solid var(--border-medium);border-radius:4px;padding:3px 6px;font:500 11px Space Grotesk,sans-serif;color:var(--text-tertiary);outline:none;text-transform:uppercase}.pn-picker-hex-input:focus{border-color:var(--accent)}.pn-controls{padding:6px 10px 8px;display:flex;flex-direction:column;gap:4px}.pn-select{width:100%;padding:3px 6px;background:var(--bg-active);border:1px solid var(--border-medium);border-radius:4px;color:var(--text-tertiary);font:500 10px Space Grotesk,sans-serif;outline:none;cursor:pointer}.pn-slider{width:100%;height:3px;-webkit-appearance:none;appearance:none;background:var(--border-medium);border-radius:2px;outline:none}.pn-slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:var(--text-tertiary);cursor:pointer}.pn-ctrl-label{display:flex;align-items:center;gap:6px;font:600 9px Space Grotesk,sans-serif;color:var(--text-dim)}.pn-ctrl-label .pn-slider{flex:1}.pn-output-info{padding:6px 10px 8px}.pn-output-row{display:flex;align-items:center;justify-content:space-between;padding:2px 0}.pn-output-label{font-size:9px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.3px}.pn-output-value{font-size:11px;font-weight:500;color:var(--text-tertiary);font-variant-numeric:tabular-nums}.pn-meta{padding:2px 10px 6px;font-size:11px;font-weight:500;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pn-handle{width:10px!important;height:10px!important;border:1.5px solid var(--text-faint)!important;border-radius:50%!important;background:var(--bg-2)!important;z-index:10!important;cursor:crosshair!important;pointer-events:all!important;transition:border-color .12s,background .12s,box-shadow .12s!important}.pn-handle:hover{border-color:var(--text-tertiary)!important;background:var(--text-tertiary)!important;box-shadow:0 0 0 3px var(--surface-hover)!important}.pn-handle-filled{background:var(--text-muted)!important;border-color:var(--text-muted)!important}.pn-handle-filled:hover{background:var(--text-tertiary)!important;border-color:var(--text-tertiary)!important}.pnp{position:absolute;top:8px;left:8px;width:220px;max-height:calc(100% - 16px);background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:10px;box-shadow:var(--shadow-md);z-index:60;font-family:Space Grotesk,sans-serif;display:flex;flex-direction:column;overflow:hidden}.pnp-header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--border-subtle);flex-shrink:0}.pnp-title{font-size:13px;font-weight:600;color:var(--text-tertiary)}.pnp-close{width:20px;height:20px;border-radius:4px;background:none;border:none;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:14px;transition:background-color .1s,color .1s}.pnp-close:hover{background:var(--bg-active);color:var(--text-tertiary)}.pnp-body{flex:1;min-height:0;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:var(--text-faint) transparent}.pnp-body::-webkit-scrollbar{width:4px}.pnp-body::-webkit-scrollbar-track{background:transparent}.pnp-body::-webkit-scrollbar-thumb{background:var(--text-faint);border-radius:2px}.pnp-category{border-bottom:1px solid var(--border-subtle)}.pnp-category:last-child{border-bottom:none}.pnp-cat-label{padding:7px 8px 3px;font-family:Space Grotesk,sans-serif;font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.4px}.pnp-node-list{padding:0 4px 4px;display:flex;flex-direction:column;gap:2px}.pnp-node-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:none;border:none;border-radius:8px;cursor:pointer;transition:background .08s;text-align:left;font-family:Space Grotesk,sans-serif}.pnp-node-btn:hover{background:var(--bg-hover)}.pnp-node-info{display:flex;flex-direction:column;min-width:0}.pnp-node-name{font-size:12px;font-weight:500;color:var(--text-tertiary)}.pnp-node-desc{font-size:11px;color:var(--text-dim)}.png-container{width:100%;height:100%;display:flex;flex-direction:column;background:var(--bg-1);position:relative}.png-toolbar{height:40px;display:flex;align-items:center;gap:2px;padding:4px;background:#1a1a1ae0;border-bottom:1px solid var(--border-subtle);border-radius:10px;flex-shrink:0;z-index:10;pointer-events:auto;font-family:Space Grotesk,sans-serif}.png-pill{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border-subtle);border-radius:100px;background:none;font-size:12px;font-weight:500;color:var(--text-tertiary);cursor:pointer;transition:all .12s}.png-pill:hover{border-color:var(--border-soft);background:var(--bg-5)}.png-pill-active{background:var(--bg-hover)}.png-sep{width:1px;height:18px;background:var(--bg-hover);margin:0 4px;flex-shrink:0}.png-btn{height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:500;transition:all .12s;padding:0 10px;white-space:nowrap}.png-btn:hover{color:var(--text-tertiary);background:var(--bg-hover)}.png-btn:disabled{opacity:.3;cursor:default}.png-btn:disabled:hover{background:none;color:var(--text-muted)}.png-spacer{flex:1}.png-flow{flex:1;min-height:0;position:relative}.png-flow .react-flow__controls,.png-flow .react-flow__attribution{display:none}.png-flow .react-flow__pane{background:radial-gradient(circle,var(--bg-active) 1px,transparent 1px);background-size:20px 20px}.png-flow .react-flow__edge-path{stroke:var(--accent)!important;stroke-width:2!important;filter:drop-shadow(0 0 4px rgba(0,97,254,.3))}.png-flow .react-flow__edge.selected .react-flow__edge-path{stroke:var(--accent)!important;stroke-width:3!important;filter:drop-shadow(0 0 6px rgba(0,97,254,.5))}.png-flow .react-flow__edge.animated .react-flow__edge-path{stroke-dasharray:5;animation:png-dash .5s linear infinite}@keyframes png-dash{to{stroke-dashoffset:-10}}.png-flow .react-flow__connection-path{stroke:var(--accent)!important;stroke-width:2!important}.png-flow .react-flow__minimap{background:var(--bg-2);border:1px solid var(--border-subtle);border-radius:6px}.cp-popover{width:252px;padding:12px;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-md);user-select:none}.cp-sb{position:relative;width:100%;height:150px;border-radius:4px;cursor:crosshair;overflow:hidden}.cp-sb-dot{position:absolute;width:14px;height:14px;border:2px solid #fff;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #00000080;pointer-events:none}.cp-hue{position:relative;width:100%;height:10px;margin-top:12px;border-radius:5px;cursor:pointer;background:linear-gradient(to right,red,#ff0 17%,#0f0 33%,#0ff,#00f 67%,#f0f 83%,red)}.cp-hue-handle{position:absolute;top:50%;width:14px;height:14px;background:#fff;border:2px solid rgba(0,0,0,.25);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 1px 3px #0006}.cp-alpha{position:relative;width:100%;height:10px;margin-top:10px;border-radius:5px;cursor:pointer;background-image:linear-gradient(45deg,#444 25%,transparent 25%),linear-gradient(-45deg,#444 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#444 75%),linear-gradient(-45deg,transparent 75%,#444 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0;overflow:hidden}.cp-alpha-fill{position:absolute;inset:0;border-radius:5px}.cp-alpha-handle{position:absolute;top:50%;width:14px;height:14px;background:#fff;border:2px solid rgba(0,0,0,.25);border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 1px 3px #0006}.cp-inputs{display:flex;gap:4px;margin-top:8px;align-items:center}.cp-input-group{flex:1;display:flex;flex-direction:row;align-items:center;gap:6px;min-width:0}.cp-input-group.cp-small{flex:.5}.cp-eyedropper{width:30px;height:30px;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:4px;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0;transition:background .1s,color .1s,border-color .1s;box-sizing:border-box}.cp-eyedropper:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--border-strong)}.cp-eyedropper:active{transform:scale(.94)}.cp-input-group input{flex:1;min-width:0;width:0;height:30px;box-sizing:border-box;background:var(--surface-panel);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:4px;padding:0 8px;font-size:11px;text-align:center;font-family:inherit;font-variant-numeric:tabular-nums;outline:none;transition:border-color .1s,background .1s;-moz-appearance:textfield;appearance:textfield;-webkit-appearance:none}.cp-input-group input:hover{border-color:var(--border-strong)}.cp-input-group input:focus{background:var(--surface-hover);border-color:var(--accent)}.cp-input-group input::-webkit-outer-spin-button,.cp-input-group input::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0;display:none}.cp-input-group label{order:-1;font-size:10px;font-weight:600;color:var(--text-muted);margin:0;letter-spacing:.3px;text-transform:uppercase;flex-shrink:0;user-select:none}.cp-input-group:focus-within label{color:var(--text-secondary)}.cp-tabs{display:flex;gap:0;margin-bottom:12px;border-bottom:1px solid var(--border-subtle)}.cp-tab{flex:1;background:none;border:none;color:var(--text-muted);font-size:12px;font-family:inherit;padding:8px 0;cursor:pointer;border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.cp-tab:hover{color:var(--text-secondary)}.cp-tab-active{color:var(--text-primary);font-weight:600;border-bottom-color:var(--accent)}.cp-libraries-view{min-height:80px}.cp-library{margin-top:10px;border-top:1px solid var(--border-subtle);padding-top:10px}.cp-library-select{width:100%;height:28px;box-sizing:border-box;background:var(--surface-panel);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:4px;padding:0 24px 0 8px;font-size:11px;font-family:inherit;cursor:pointer;margin-bottom:8px;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .1s}.cp-library-select:hover{border-color:var(--border-strong);color:var(--text-primary)}.cp-library-select:focus{outline:none;border-color:var(--accent)}.cp-library-select option{background:var(--surface-panel);color:var(--text-secondary)}.cp-library-empty{font-size:11px;color:var(--text-muted);text-align:center;padding:8px 0}.cp-swatches-row{display:flex;flex-wrap:wrap;gap:5px}.cp-swatch-wrap{position:relative}.cp-swatch-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--border-subtle);cursor:pointer;padding:0;flex-shrink:0;transition:transform .1s,border-color .1s}.cp-swatch-btn:hover{transform:scale(1.12);border-color:var(--border-strong)}.cp-swatch-remove{display:none;position:absolute;top:-4px;right:-4px;width:12px;height:12px;border-radius:50%;background:var(--accent);color:#fff;border:none;font-size:9px;line-height:1;cursor:pointer;padding:0}.cp-swatch-wrap:hover .cp-swatch-remove{display:block}.pe-wrap{width:252px;padding:12px;background:var(--surface-panel);border:1px solid var(--border-strong);border-radius:8px;box-shadow:var(--shadow-md);user-select:none}.pe-wrap .cp-popover{width:auto;padding:0;background:none;border:none;box-shadow:none;margin-top:10px}.pe-tabs{display:flex;gap:2px;margin-bottom:12px;background:var(--surface-panel);padding:2px;border-radius:6px;border:1px solid var(--border-subtle)}.pe-tabs button{flex:1;height:28px;padding:0;background:transparent;color:var(--text-muted);border:none;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .1s,color .1s}.pe-tabs button:hover{color:var(--text-primary);background:var(--surface-hover)}.pe-tabs button.active{background:var(--accent);color:#fff}.pe-tabs button.active:hover{background:var(--accent)}.pe-type-select{display:block;width:100%;height:30px;margin-bottom:12px;padding:0 24px 0 10px;background:var(--surface-panel);border:1px solid var(--border-subtle);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:11px;font-weight:500;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 8px center;transition:border-color .1s}.pe-type-select:hover{border-color:var(--border-strong)}.pe-type-select:focus{border-color:var(--accent)}.pe-bar{position:relative;width:100%;height:20px;border-radius:4px;cursor:crosshair;background-image:linear-gradient(45deg,#444 25%,transparent 25%),linear-gradient(-45deg,#444 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#444 75%),linear-gradient(-45deg,transparent 75%,#444 75%);background-size:8px 8px;background-position:0 0,0 4px,4px -4px,-4px 0;margin-bottom:10px}.pe-stop{position:absolute;top:-3px;width:12px;height:26px;border:2px solid #fff;border-radius:3px;transform:translate(-50%);cursor:grab;box-shadow:0 0 0 1px #00000080}.pe-stop.active{border-color:var(--accent);box-shadow:0 0 0 1px #00000080,0 0 6px #0061fe80}.pe-angle-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.pe-angle-row label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;min-width:40px}.pe-angle-row input{flex:1;height:28px;box-sizing:border-box;background:var(--surface-panel);color:var(--text-secondary);border:1px solid var(--border-subtle);border-radius:4px;padding:0 8px;font-size:11px;font-family:inherit;outline:none;transition:border-color .1s,background .1s}.pe-angle-row input:hover{border-color:var(--border-strong)}.pe-angle-row input:focus{border-color:var(--accent);background:var(--surface-hover)}.pe-angle-row span{font-size:11px;color:var(--text-muted)}.dash{height:100vh;display:flex;flex-direction:row;background:var(--bg-2);overflow:hidden}.dash-main{flex:1;overflow:hidden;display:flex;flex-direction:column}.dash-mobile-menu{display:none}@media(max-width:768px){.dash-mobile-menu{display:flex;flex-direction:column;gap:4px;padding:6px;background:none;border:none;position:fixed;top:16px;left:16px;z-index:50}.dash-mobile-menu span{display:block;width:18px;height:1.5px;background:var(--text-dim);border-radius:1px;transition:background .2s}.dash-mobile-menu:hover span{background:var(--text-secondary)}}
