:root{color-scheme:dark;--bg:#15151a;--panel:#1f1f22;--panel-2:#26262a;--border:#2e2e33;--text:#d8d8dc;--text-dim:#8c8c93;--accent:#4a5a7a;--accent-2:#6a7a9a}*{box-sizing:border-box}#root,body,html{margin:0;height:100%;background:var(--bg);font-family:-apple-system,system-ui,Segoe UI,sans-serif;-webkit-user-select:none;user-select:none}#root,body,button,html{color:var(--text);font-size:12px}button{background:var(--panel-2);border:1px solid var(--border);padding:4px 10px;border-radius:4px;cursor:pointer}button:hover:not(:disabled){background:#34343a}button.active{background:var(--accent);border-color:var(--accent-2)}button:disabled{opacity:.4;cursor:default}input[type=range]{width:100%;accent-color:var(--accent-2)}input[type=color]{width:32px;height:22px;background:transparent;border:1px solid var(--border);border-radius:3px;padding:0;cursor:pointer}.editor-modal:has(.brush-edit-sections),.modal:has(.brush-edit-sections){min-width:480px;max-width:560px;width:min(560px,calc(100vw - 32px))}.editor-modal__body:has(.brush-edit-sections),.modal-body:has(.brush-edit-sections){max-height:70vh;overflow-y:auto;padding-right:4px}.brush-edit-sections{display:flex;flex-direction:column;gap:14px}.brush-edit-section{display:flex;flex-direction:column;gap:6px}.brush-edit-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);padding-bottom:4px;border-bottom:1px solid var(--border)}.brush-edit-section-body{display:flex;flex-direction:column;gap:4px}.brush-edit-curve-row{display:grid;grid-template-columns:96px 1fr;align-items:center;gap:8px}.brush-edit-curve-label{font-size:11px;color:var(--text-dim)}.brush-edit-curve{display:flex;gap:4px}.brush-edit-curve button{flex:1 1;padding:4px 8px;font-size:11px;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);border-radius:3px;cursor:pointer}.brush-edit-curve button:hover:not(.active){color:var(--text);background:rgba(255,255,255,.04)}.brush-edit-curve button.active{background:rgba(120,145,200,.16);border-color:var(--accent-2);color:var(--text)}.app{display:flex;flex-direction:column;height:100%}.app[data-editor-intro=true],.app[data-from-landing=true]{overflow:hidden}.arrival-flash,.editor-route-flash{position:fixed;inset:0;background:#050508;z-index:1000}.arrival-flash{pointer-events:none;animation:arrival-flash 2.15s cubic-bezier(.16,1,.3,1) .04s forwards}@keyframes arrival-flash{0%,34%{opacity:1}to{opacity:0}}.app[data-from-landing=true] .toolbar{animation:arrival-toolbar .7s cubic-bezier(.16,1,.3,1) .45s both}.app[data-from-landing=true] .workspace{position:relative}.app[data-from-landing=true] .editor-right-stack,.app[data-from-landing=true] .panel.brushes,.app[data-from-landing=true] .right-stack{position:absolute;top:0;bottom:0;z-index:10}.app[data-from-landing=true] .panel.brushes{left:0;animation:arrival-panel-left .75s cubic-bezier(.16,1,.3,1) .55s both}.app[data-from-landing=true] .editor-right-stack,.app[data-from-landing=true] .right-stack{right:0;animation:arrival-panel-right .75s cubic-bezier(.16,1,.3,1) .55s both}.app[data-from-landing=true] .brush-drawer{animation:arrival-fade .6s ease .7s both}.app[data-from-landing=true] .pen-pressure-indicator,.app[data-from-landing=true] .viewport-display-dock{opacity:0;pointer-events:none;transition:none}@keyframes arrival-fade{0%{opacity:0}to{opacity:1}}@keyframes arrival-toolbar{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes arrival-panel-left{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes arrival-panel-right{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.app[data-editor-intro=true] .toolbar{animation:editor-toolbar-intro .52s cubic-bezier(.16,1,.3,1) both}.app[data-editor-intro=true] .panel.brushes{animation:editor-panel-left-intro .58s cubic-bezier(.16,1,.3,1) .08s both}.app[data-editor-intro=true] .editor-right-stack,.app[data-editor-intro=true] .right-stack{animation:editor-panel-right-intro .58s cubic-bezier(.16,1,.3,1) .08s both}.app[data-editor-intro=true] .viewport-wrap{animation:editor-viewport-intro .62s ease both}.app[data-editor-intro=true] .brush-drawer{animation:arrival-fade .42s ease .18s both}@keyframes editor-toolbar-intro{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes editor-panel-left-intro{0%{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:translateX(0)}}@keyframes editor-panel-right-intro{0%{opacity:0;transform:translateX(24px)}to{opacity:1;transform:translateX(0)}}@keyframes editor-viewport-intro{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){.arrival-flash,.editor-route-flash{display:none}.app[data-editor-intro=true] .brush-drawer,.app[data-editor-intro=true] .editor-right-stack,.app[data-editor-intro=true] .panel.brushes,.app[data-editor-intro=true] .right-stack,.app[data-editor-intro=true] .toolbar,.app[data-editor-intro=true] .viewport-wrap{animation:none}.app[data-from-landing=true] .viewport-display-dock{opacity:1;pointer-events:auto;animation:none}}.menu-bar-row{display:flex;height:28px;padding:0 6px;background:var(--panel);border-bottom:1px solid var(--border)}.menu-bar-row,.menu-bar-row .menu-bar{align-items:stretch}.menu-bar-row .menu{display:flex;align-items:stretch}.menu-bar-row .menu-trigger{padding:0 12px;border-radius:0;height:100%}.toolbar{display:flex;align-items:center;gap:12px;height:38px;padding:0 12px;background:var(--panel);border-bottom:1px solid var(--border)}.toolbar .title{font-weight:600;opacity:.85;letter-spacing:.3px}.toolbar .title[data-editable=true]{cursor:text;transition:opacity .12s ease}.toolbar .title[data-editable=true]:hover{opacity:1}.toolbar .title[data-editing=true]{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);border-radius:4px;padding:2px 6px;margin:-3px -7px;font:inherit;font-weight:600;letter-spacing:.3px;color:inherit;outline:none;min-width:120px}.toolbar .spacer{flex:1 1}.panel-title-with-meta{display:inline-flex;align-items:baseline;gap:8px}.panel-title-with-meta .panel-meta{color:var(--text-dim);letter-spacing:.2px}.panel-title-with-meta .panel-meta,.pen-pressure-indicator{font-size:11px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.pen-pressure-indicator{position:absolute;bottom:16px;right:16px;padding:4px 10px;border:1px solid var(--border);border-radius:4px;background:var(--panel);color:var(--text);letter-spacing:.3px;pointer-events:none;opacity:0;transition:opacity .45s ease .1s;z-index:5}.pen-pressure-indicator.pen-pressure-indicator--active{opacity:1;transition:opacity .15s ease}.seg{display:flex;gap:0}.seg button{border-radius:0}.seg button:first-child{border-top-left-radius:4px;border-bottom-left-radius:4px}.seg button:last-child{border-top-right-radius:4px;border-bottom-right-radius:4px}.seg button+button{border-left:none}.seg-tight{margin-bottom:12px}.workspace{display:flex;flex:1 1;min-height:0;position:relative}.panel{width:230px;background:var(--panel);border-right:1px solid var(--border);padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.panel.brushes{width:288px;padding:0;overflow:hidden;position:relative;z-index:2}.brushes-scroll{flex:1 1 auto;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.brushes-dock{flex:0 0 auto;padding:12px;border-top:1px solid var(--border);background:rgba(0,0,0,.18)}.panel.brushes .brushes-dock,.panel.brushes .brushes-scroll{transition:opacity .24s ease,filter .24s ease}.panel.brushes.brush-locked .brushes-dock,.panel.brushes.brush-locked .brushes-scroll{opacity:.5;filter:blur(2px);pointer-events:none}.title-dim{opacity:.45;font-weight:400;font-style:italic}.right-stack{display:flex;flex-direction:column;border-left:1px solid var(--border);min-height:0;width:288px}.right-stack .panel{width:100%;border-right:none;border-left:none}.right-stack .panel.layers{flex:0 0 auto;max-height:40%;border-bottom:1px solid var(--border)}.right-stack .panel.sky{flex:1 1 auto;min-height:0}.panel.layers{border-right:none;border-left:1px solid var(--border)}.panel-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;opacity:.85;margin-bottom:4px}.panel-header .add-buttons{display:flex;gap:4px}.brushes .row{display:flex;align-items:center;justify-content:space-between;gap:8px}.brushes .row>span:first-child{color:var(--text-dim)}.brushes .check-row input{margin:0;accent-color:var(--accent-2)}.section-label{font-size:10px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-dim);opacity:.65;margin-top:4px}.brush-row{display:flex;gap:6px;align-items:stretch}.brush-vis-wrap{flex:1 1;min-width:0}.mode-tabs{display:flex;flex-direction:column;gap:1px;width:28px}.mode-tab{flex:1 1;min-height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:rgba(14,14,18,.65);border:1px solid rgba(255,255,255,.06);border-radius:6px;color:var(--text-dim);cursor:pointer;transition:background 80ms ease,border-color 80ms ease,color 80ms ease;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),inset 0 -1px 0 rgba(0,0,0,.25)}.mode-tab:hover{color:var(--text);border-color:rgba(255,255,255,.12)}.mode-tab.active{background:rgba(120,145,200,.16);border-color:var(--accent-2);color:var(--text)}.panel.sky .row{display:flex;align-items:center;justify-content:space-between;gap:8px}.panel.sky .row>span:first-child{color:var(--text-dim)}.panel.sky .color-row{justify-content:flex-start}.panel.sky .color-row>span{color:var(--text-dim)}.panel.sky .check-row input{margin:0;accent-color:var(--accent-2)}.panel.sky select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:3px;padding:2px 4px;font-size:11px;flex:1 1}.hint-block{color:var(--text-dim);font-size:11px;line-height:1.5;padding:4px 0}.viewport-wrap{flex:1 1;min-width:0;background:#0e0e12;position:relative}.viewport-wrap canvas{display:block;touch-action:none}.viewport-display-dock{position:absolute;z-index:5;top:12px;right:12px;width:240px;max-width:calc(100% - 24px);display:flex;flex-direction:column;gap:6px;padding:8px 11px 11px;background:rgba(20,22,28,.72);backdrop-filter:blur(10px) saturate(1.1);-webkit-backdrop-filter:blur(10px) saturate(1.1);border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 28px rgba(0,0,0,.42);transition:padding .22s cubic-bezier(.4,0,.2,1),gap .22s cubic-bezier(.4,0,.2,1),box-shadow .22s cubic-bezier(.4,0,.2,1),opacity .48s cubic-bezier(.16,1,.3,1)}.viewport-display-dock.collapsed{padding:6px 11px;gap:0;box-shadow:0 4px 14px rgba(0,0,0,.36)}.viewport-display-dock .dock-header{display:flex;align-items:center;justify-content:space-between;width:100%;font-size:10px;font-weight:600;letter-spacing:.9px;text-transform:uppercase;color:var(--text-dim);padding:3px 2px;background:transparent;border:0;border-radius:3px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .14s ease}.viewport-display-dock .dock-header:active,.viewport-display-dock .dock-header:focus,.viewport-display-dock .dock-header:focus-visible,.viewport-display-dock .dock-header:hover{background:transparent;border:0;color:var(--text)}.viewport-display-dock .dock-header:focus-visible{outline:1px solid var(--accent-2);outline-offset:2px}.viewport-display-dock .dock-chevron{flex:0 0 auto;opacity:.65;transition:transform .24s cubic-bezier(.4,0,.2,1),opacity .14s ease}.viewport-display-dock .dock-header:hover .dock-chevron{opacity:1}.viewport-display-dock.collapsed .dock-chevron{transform:rotate(-90deg)}.viewport-display-dock .dock-body{display:grid;grid-template-rows:1fr;transition:grid-template-rows .24s cubic-bezier(.4,0,.2,1),opacity .18s ease;opacity:1}.viewport-display-dock.collapsed .dock-body{grid-template-rows:0fr;opacity:0;pointer-events:none}.viewport-display-dock .dock-body-inner{min-height:0;overflow:hidden}.viewport-display-dock .dock-body-inner,.viewport-display-dock .dock-section{display:flex;flex-direction:column;gap:6px}.viewport-display-dock .dock-divider{height:1px;margin:2px -3px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.08),transparent)}.viewport-display-dock .dock-help{margin:2px 2px 0;font-size:10.5px;line-height:1.45;color:var(--text-dim);opacity:.78}.viewport-display-dock .row,.viewport-display-dock .view-dock-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.viewport-display-dock .row>span:first-child,.viewport-display-dock .view-dock-row>span:first-child{color:var(--text-dim);flex:0 0 auto;font-size:11.5px}.viewport-display-dock .seg{flex:0 0 auto;display:inline-flex}.viewport-display-dock .seg button{position:relative;min-width:30px;min-height:22px;padding:2px 7px;font-size:10.5px;background:rgba(40,42,50,.72);border-color:var(--border);transition:background .11s ease,border-color .11s ease,color .11s ease}.viewport-display-dock .seg button+button{border-left:1px solid var(--border);margin-left:-1px}.viewport-display-dock .seg button:hover{z-index:1;background:rgba(60,64,76,.85)}.viewport-display-dock .seg button.active{z-index:2;background:var(--accent);border-color:var(--accent-2);color:var(--text)}.viewport-display-dock .check-row input{margin:0;accent-color:var(--accent-2)}.viewport-display-dock .scrub{border-radius:6px;min-height:26px}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modal-fade .14s ease-out}.modal{background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:16px 18px;min-width:320px;max-width:460px;box-shadow:0 10px 40px rgba(0,0,0,.6);animation:modal-pop .18s ease-out}.modal-title{margin:0 0 10px;font-size:13px;font-weight:600;letter-spacing:.2px}.modal-body{color:var(--text-dim);font-size:12px;line-height:1.55;margin-bottom:14px}.modal-body p{margin:0 0 8px}.modal-body p:last-child{margin-bottom:0}.modal-body strong{color:var(--text);font-weight:600}.modal-actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}.modal-actions button.primary{background:var(--accent);border-color:var(--accent-2)}.modal-actions button.primary:hover:not(:disabled){background:#5a6a8a}.modal-actions button.danger{background:#6a3838;border-color:#8a4848}.modal-actions button.danger:hover:not(:disabled){background:#7a4444}.upgrade-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;border:1px solid #b58a3a;background:linear-gradient(180deg,#d4a04c,#b58a3a);color:#15151a;border-radius:4px;cursor:pointer}.upgrade-btn:hover:not(:disabled){background:linear-gradient(180deg,#e0ad58,#c1953f)}.pro-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:#d4a04c;border:1px solid #b58a3a;border-radius:999px;background:rgba(180,138,58,.08)}.account-btn,.redeem-itch-btn{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;border:1px solid var(--border);background:var(--panel);color:var(--text);border-radius:4px;cursor:pointer}.redeem-itch-btn{background:rgba(255,255,255,.035)}.account-btn:hover,.redeem-itch-btn:hover:not(:disabled){background:var(--panel-hi,#2a2f3a)}.account-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 4px 2px 10px;border:1px solid var(--border);border-radius:999px;background:rgba(255,255,255,.04)}.account-email{font-size:12px;color:var(--text-dim);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.itch-redeem-form,.login-form,.name-form{display:flex;flex-direction:column;gap:8px}.itch-redeem-form input,.login-form input,.name-form input{padding:8px 10px;border:1px solid var(--border);border-radius:4px;background:rgba(0,0,0,.25);color:var(--text);font-size:13px;font-family:inherit}.itch-redeem-form input:focus,.login-form input:focus,.name-form input:focus{outline:none;border-color:var(--accent-2)}.name-form-label{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim)}.login-error{margin:0;color:#ff8c8c;font-size:12px}.itch-redeem-help{color:var(--text-dim);font-size:12px}.itch-redeem-success{color:var(--text)}.resolution-list{display:flex;flex-direction:column;gap:6px;margin:10px 0}.resolution-option{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:8px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;cursor:pointer}.resolution-option.active{background:rgba(120,145,200,.16);border-color:var(--accent-2)}.resolution-option input{margin:0;accent-color:var(--accent-2)}.resolution-main{display:flex;flex-direction:column;gap:2px;min-width:0}.resolution-name{color:var(--text);font-weight:600}.resolution-size{color:var(--text-dim);font-size:11px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.resolution-note{color:var(--text-dim);font-size:11px;white-space:nowrap}.project-list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto;margin:10px 0}.project-option{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;width:100%;padding:8px 10px;text-align:left;background:var(--panel-2);border:1px solid var(--border)}.project-option.active{background:rgba(120,145,200,.16);border-color:var(--accent-2)}.project-option-main{display:flex;flex-direction:column;gap:2px;min-width:0}.project-option-name{color:var(--text);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-option-date,.project-option-meta{color:var(--text-dim);font-size:11px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.brush-tip-grid{display:flex;flex-direction:column;gap:6px;max-height:50vh;overflow-y:auto;padding-right:2px}.brush-tip-option{display:grid;grid-template-columns:44px 1fr;grid-template-rows:auto auto;gap:2px 10px;align-items:center;text-align:left;padding:8px 10px}.brush-tip-option.active{background:rgba(120,145,200,.16);border-color:var(--accent-2)}.brush-tip-preview{grid-row:1/span 2;width:36px;height:36px;border-radius:4px;background-color:#050507;background-size:cover;background-position:50%;border:1px solid rgba(255,255,255,.08)}.brush-tip-name{font-weight:600;color:var(--text)}.brush-tip-desc{color:var(--text-dim);font-size:11px}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}@keyframes modal-pop{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.editor-modal:has(.projects-modal-body),.modal:has(.projects-modal-body){max-width:720px;width:min(720px,calc(100vw - 32px))}.projects-modal-body{display:flex;flex-direction:column;gap:10px;min-height:80px}.projects-error{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid #6a3838;background:rgba(180,70,70,.12);color:#ff8c8c;border-radius:4px;font-size:12px}.projects-error button{background:transparent;border:none;color:#ff8c8c;font-size:16px;line-height:1;padding:0 4px;cursor:pointer}.projects-error-inline{color:#ff8c8c}.projects-empty{display:flex;flex-direction:column;align-items:center;align-self:center;gap:4px;padding:28px 24px;border:1px dashed var(--border);border-radius:6px;text-align:center;color:var(--text-dim);max-width:380px}.projects-empty>svg{opacity:.6;margin-bottom:4px}.projects-empty-title{color:var(--text);font-weight:600;font-size:13px;margin:0}.projects-empty p:last-child{margin:0;font-size:12px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;max-height:60vh;overflow-y:auto;padding:2px}.project-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--border);border-radius:5px;background:var(--panel-2);overflow:hidden;transition:border-color .12s ease,background .12s ease}.project-card[data-active=true]{border-color:var(--accent-2);background:rgba(120,145,200,.1)}.project-card-body{display:flex;flex-direction:column;gap:0;padding:0;text-align:left;background:transparent;border:none;border-radius:0;cursor:pointer}.project-card-body:hover:not(:disabled){background:rgba(255,255,255,.03)}.project-card-body:disabled{cursor:default;opacity:.6}.project-card-thumb{position:relative;display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:2/1;background:#050507;color:var(--text-dim);border-bottom:1px solid var(--border);overflow:hidden}.project-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.project-card-badge{position:absolute;top:6px;left:6px;padding:2px 7px;font-size:10px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--text);background:rgba(20,24,36,.85);border:1px solid var(--accent-2);border-radius:999px}.project-card-meta{display:flex;flex-direction:column;gap:2px;padding:8px 10px 10px;min-width:0}.project-card-name{color:var(--text);font-weight:600;font-size:12px}.project-card-name,.project-card-sub{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card-sub{color:var(--text-dim);font-size:11px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.project-card-delete{position:absolute;top:6px;right:6px;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:1px solid var(--border);background:rgba(20,24,36,.85);color:var(--text-dim);border-radius:4px;cursor:pointer;opacity:0;transition:opacity .12s ease,color .12s ease,border-color .12s ease}.project-card-delete:focus-visible,.project-card:focus-within .project-card-delete,.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover:not(:disabled){color:#ff8c8c;border-color:#8a4848}.project-card-delete:disabled{cursor:default;opacity:.4}.add-layer-split{position:relative;display:flex;gap:0}.add-layer-split button{border-radius:0;min-height:22px;padding-block:3px;font-size:11px}.add-layer-split button:first-child{border-top-left-radius:4px;border-bottom-left-radius:4px}.add-layer-split button.caret{border-top-right-radius:4px;border-bottom-right-radius:4px;border-left:none;padding:3px 4px}.layer-header-controls{display:grid;grid-template-columns:minmax(84px,30%) minmax(0,1fr);gap:6px;align-items:center;width:100%}.layer-header-controls select{min-width:0;width:100%}.layer-header-controls .scrub{box-sizing:border-box;height:24px;width:100%;border-radius:3px;padding-inline:8px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px}.toggle-row{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:4px;text-align:left;cursor:pointer;font-size:12px;transition:background 80ms ease,border-color 80ms ease,color 80ms ease}.toggle-row:hover{background:#34343a}.toggle-row.on{background:rgba(120,145,200,.16);border-color:var(--accent-2)}.toggle-row .toggle-label{flex:1 1}.toggle-row>svg{flex-shrink:0;color:var(--text-dim)}.toggle-row.on>svg{color:var(--accent-2)}.kbd{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;font-size:10px;color:var(--text-dim);opacity:.7;letter-spacing:.3px;flex-shrink:0}.add-layer-popover{position:fixed;background:var(--panel);border:1px solid var(--border);border-radius:4px;box-shadow:0 8px 24px rgba(0,0,0,.5);min-width:180px;padding:4px;z-index:200;display:flex;flex-direction:column;gap:1px;max-height:calc(100vh - 80px);overflow-y:auto}.add-layer-popover .popover-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:1px solid transparent;border-radius:3px;padding:6px 10px;font-size:12px;color:var(--text)}.add-layer-popover .popover-item:hover:not(:disabled){background:var(--panel-2)}.add-layer-popover .popover-item.danger{color:#d97777}.add-layer-popover .popover-item:disabled{opacity:.35;cursor:default}.add-layer-popover .popover-separator{height:1px;margin:4px 6px;background:var(--border)}.add-layer-popover .popover-item svg{flex-shrink:0;color:var(--text-dim)}.add-layer-popover .popover-item:hover svg{color:var(--text)}.add-layer-popover .popover-item.indented{padding-left:18px}.add-layer-popover .popover-item .icon-placeholder{display:inline-block;width:14px;height:14px;flex-shrink:0}.add-layer-popover .popover-section{display:flex;flex-direction:column;gap:1px}.add-layer-popover .popover-section-label{display:flex;align-items:center;gap:6px;padding:7px 14px 5px;margin:4px -4px 2px;background:rgba(255,255,255,.035);border-top:1px solid rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.05);font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-dim)}.add-layer-popover .popover-section:first-child .popover-section-label{margin-top:0}.lp{position:fixed;inset:0;overflow:hidden;display:flex;align-items:center;justify-content:space-between;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(70,110,160,.12),transparent 70%),radial-gradient(circle at 80% 60%,rgba(95,207,214,.08),transparent 45%),radial-gradient(circle at 25% 70%,rgba(180,100,70,.06),transparent 50%),#050508;--lp-accent:#5fcfd6;--lp-accent-bright:#82ddde;--lp-accent-dim:rgba(95,207,214,0.18)}@keyframes lp-globe-enter{0%{opacity:0}to{opacity:1}}.lp-globe{z-index:1;animation:lp-globe-enter .9s ease both}.lp-flash,.lp-globe{position:absolute;inset:0}.lp-flash{background:#050508;pointer-events:none;opacity:0;z-index:50;transition:opacity .24s ease}.lp[data-phase=transitioning] .lp-flash{opacity:1;transition:opacity 1.5s ease}.lp[data-phase=inside] .lp-flash{opacity:0;transition:opacity .28s ease}@keyframes lp-nav-enter{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lp-nav{position:absolute;top:0;left:0;right:0;height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 36px;z-index:5;pointer-events:none;animation:lp-nav-enter .7s ease .25s both}.lp-nav>*{pointer-events:all}.lp-nav-logo{font-size:13px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;color:rgba(255,255,255,.92)}.lp-nav-actions{display:flex;align-items:center;gap:10px;pointer-events:all}.lp-nav-cta{padding:8px 18px;background:transparent;border:1px solid var(--lp-accent);border-radius:8px;color:var(--lp-accent);font-size:12px;font-weight:600;letter-spacing:.4px;cursor:pointer;transition:background .18s ease,color .18s ease}.lp-nav-cta:hover:not(:disabled){background:var(--lp-accent-dim);border-color:var(--lp-accent-bright);color:var(--lp-accent-bright)}.lp-nav-install{border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.78)}.lp-nav-install:hover:not(:disabled){border-color:rgba(255,255,255,.45);color:white;background:rgba(255,255,255,.08)}.offline-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:#15151a;color:var(--text)}.offline-panel{width:min(420px,100%);padding:24px;border:1px solid var(--border);border-radius:8px;background:var(--panel)}.offline-panel h1{margin:0 0 10px;font-size:20px}.offline-panel p{margin:0 0 18px;color:var(--text-dim);line-height:1.5}.offline-panel a{display:inline-flex;color:var(--text);text-decoration:none;border:1px solid var(--accent-2);border-radius:4px;padding:7px 12px;background:var(--accent)}@keyframes lp-hero-enter{0%{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:translateX(0)}}.lp-hero-anchor{margin-left:64px;max-width:460px;pointer-events:none;position:relative;z-index:4;animation:lp-hero-enter .8s cubic-bezier(.16,1,.3,1) .3s both}.lp-hero-anchor>*{pointer-events:all}.lp-hero-title{margin:0 0 24px;font-size:60px;line-height:1.04;font-weight:700;letter-spacing:-1.6px;color:rgba(255,255,255,.96);text-shadow:0 2px 32px rgba(0,0,0,.55)}.lp-hero-accent{color:var(--lp-accent)}.lp-hero-sub{margin:0 0 32px;font-size:15px;line-height:1.6;color:rgba(255,255,255,.78)}.lp-hero-sub,.lp-product-terms{text-shadow:0 1px 16px rgba(0,0,0,.55)}.lp-product-terms{display:flex;flex-wrap:wrap;gap:7px 12px;margin:-12px 0 28px;max-width:420px;color:rgba(255,255,255,.72);font-size:12px;font-weight:600;line-height:1.45}.lp-product-terms span{display:inline-flex;align-items:center;min-width:0}.lp-product-terms span:first-child{color:var(--lp-accent-bright)}.lp-hero-buttons{display:flex;gap:12px}.lp-hero-cta{padding:13px 22px;font-size:12px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;border-radius:8px;cursor:pointer;transition:background .18s ease,border-color .18s ease,color .18s ease}.lp-hero-cta-primary{background:var(--lp-accent);color:#06262a;border:1px solid var(--lp-accent)}.lp-hero-cta-primary:hover:not(:disabled){background:var(--lp-accent-bright);border-color:var(--lp-accent-bright);color:#06262a}.lp-hero-cta-secondary{background:transparent;color:var(--lp-accent);border:1px solid var(--lp-accent)}.lp-hero-cta-secondary:hover:not(:disabled){background:var(--lp-accent-dim);border-color:var(--lp-accent-bright);color:var(--lp-accent-bright)}.lp-pane-anchor{margin-right:52px;pointer-events:none;position:relative;z-index:3}@keyframes lp-nav-exit{to{transform:translateY(-110%);opacity:0}}@keyframes lp-hero-exit{to{transform:translateX(-160%);opacity:0}}@keyframes lp-pane-exit{to{transform:translateX(160%);opacity:0}}.lp[data-phase=inside] .lp-nav,.lp[data-phase=transitioning] .lp-nav{animation:lp-nav-exit .7s cubic-bezier(.6,0,.4,1) forwards;pointer-events:none}.lp[data-phase=inside] .lp-hero-anchor,.lp[data-phase=transitioning] .lp-hero-anchor{animation:lp-hero-exit .7s cubic-bezier(.6,0,.4,1) forwards;pointer-events:none}.lp[data-phase=inside] .lp-pane-anchor,.lp[data-phase=transitioning] .lp-pane-anchor{animation:lp-pane-exit .7s cubic-bezier(.6,0,.4,1) forwards;pointer-events:none}@keyframes lp-pane-enter{0%{opacity:0;transform:translateX(22px)}to{opacity:1;transform:translateX(0)}}.lp-pane{pointer-events:all;width:340px;padding:36px 32px;display:flex;flex-direction:column;gap:26px;background:rgba(15,17,24,.22);backdrop-filter:blur(64px) saturate(1.7);-webkit-backdrop-filter:blur(64px) saturate(1.7);border:1px solid rgba(255,255,255,.14);border-radius:20px;box-shadow:0 12px 56px rgba(0,0,0,.6);animation:lp-pane-enter .6s cubic-bezier(.16,1,.3,1) .4s both}.lp-logo{font-size:24px;font-weight:700;letter-spacing:-.3px;color:rgba(255,255,255,.96)}.lp-tagline{margin:0;font-size:14px;line-height:1.6;color:rgba(255,255,255,.72)}.lp-eyebrow{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:-6px}.lp-closer{margin:0;font-size:13px;line-height:1.55;color:rgba(255,255,255,.6)}.lp-sliders{gap:22px}.lp-slider,.lp-sliders{display:flex;flex-direction:column}.lp-slider{gap:10px}.lp-slider-row{display:flex;align-items:baseline;justify-content:space-between}.lp-slider-label{font-size:12px;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.82)}.lp-slider-value{font-size:12px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;color:var(--lp-accent)}.lp-slider-track{position:relative;width:100%;height:18px;display:flex;align-items:center;cursor:pointer;outline:none;touch-action:none}.lp-slider-track:before{content:"";position:absolute;left:0;right:0;height:3px;border-radius:2px;background:linear-gradient(to right,var(--lp-accent) 0,var(--lp-accent) var(--lp-fill,0),rgba(255,255,255,.18) var(--lp-fill,0),rgba(255,255,255,.18) 100%)}.lp-slider-thumb{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--lp-accent);transform:translateX(-50%);pointer-events:none;box-shadow:0 1px 6px rgba(0,0,0,.5),0 0 0 4px rgba(95,207,214,.18)}.lp-slider-track:focus-visible{outline:1px solid var(--lp-accent);outline-offset:4px;border-radius:2px}.lp-cta{width:100%;padding:14px 0;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.24);border-radius:12px;color:rgba(255,255,255,.95);font-size:15px;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:background .18s ease,border-color .18s ease}.lp-cta:hover:not(:disabled){background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.36)}@media (max-width:980px){.lp{display:block;align-items:flex-end;justify-content:center;padding:84px 22px 30px}.lp-nav{padding:0 18px}.lp-nav-logo{font-size:11px;letter-spacing:1.2px}.lp-nav-actions{gap:6px}.lp-nav-cta{padding:7px 12px;border-radius:6px}.lp-hero-anchor{width:calc(100vw - 44px);max-width:calc(100vw - 44px);margin:0}.lp-hero-title{margin-bottom:18px;font-size:44px;letter-spacing:0}.lp-hero-sub{font-size:14px}.lp-hero-sub,.lp-product-terms{margin-bottom:24px}.lp-pane-anchor{display:none}}@media (max-width:520px){.lp-nav-actions{display:none}.lp-hero-sub,.lp-product-terms{max-width:320px}}[data-tutorial-piece]{z-index:1100;--tutorial-gold:#d4a04c;--tutorial-gold-soft:rgba(212,160,76,0.55);--tutorial-gold-glow:rgba(212,160,76,0.35)}.tutorial-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);z-index:1100;animation:tutorial-fade-in .8s ease both;transition:opacity 1.4s ease}.tutorial-backdrop[data-fading=true]{opacity:0;pointer-events:none}.tutorial-highlight-bridge{inset:0;pointer-events:none;animation:tutorial-bridge-out .72s ease .08s forwards}.tutorial-dim,.tutorial-highlight-bridge{position:fixed;background:rgba(0,0,0,.55);z-index:1100}.tutorial-dim{animation:tutorial-fade-in .5s ease both;transition:opacity .52s ease,top .85s cubic-bezier(.22,1,.36,1),left .85s cubic-bezier(.22,1,.36,1),right .85s cubic-bezier(.22,1,.36,1),bottom .85s cubic-bezier(.22,1,.36,1),width .85s cubic-bezier(.22,1,.36,1),height .85s cubic-bezier(.22,1,.36,1)}.tutorial-cutout-border{position:fixed;border:1.5px solid var(--tutorial-gold);border-radius:7px;pointer-events:none;z-index:1101;transform-origin:center;animation:tutorial-cutout-pulse 3.4s ease-in-out infinite;transition:opacity .52s ease,top .85s cubic-bezier(.22,1,.36,1),left .85s cubic-bezier(.22,1,.36,1),width .85s cubic-bezier(.22,1,.36,1),height .85s cubic-bezier(.22,1,.36,1)}@keyframes tutorial-cutout-pulse{0%,to{transform:scale(1);box-shadow:0 0 0 1px rgba(212,160,76,.18),0 0 18px rgba(212,160,76,.22)}50%{transform:scale(1.012);box-shadow:0 0 0 2px rgba(212,160,76,.4),0 0 36px rgba(212,160,76,.55)}}.tutorial-card{position:fixed;background:transparent;isolation:isolate;border:1px solid var(--tutorial-gold);border-radius:10px;padding:18px 20px 16px;box-shadow:0 14px 38px rgba(0,0,0,.55),0 0 0 1px rgba(212,160,76,.14),0 0 30px rgba(212,160,76,.22),inset 0 1px 0 rgba(255,255,255,.12);display:flex;flex-direction:column;gap:14px;z-index:1102;animation:tutorial-card-in .7s cubic-bezier(.16,1,.3,1) both;transition:opacity .52s ease,top .85s cubic-bezier(.22,1,.36,1),left .85s cubic-bezier(.22,1,.36,1),width .85s cubic-bezier(.22,1,.36,1)}.tutorial-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:rgba(20,20,24,.78);backdrop-filter:blur(48px) saturate(1.8);-webkit-backdrop-filter:blur(48px) saturate(1.8);z-index:-1;pointer-events:none}@keyframes tutorial-card-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.tutorial-card-text{color:rgba(255,255,255,.96);font-size:14px;font-weight:300;line-height:1.55;letter-spacing:.1px}.tutorial-card-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.tutorial-step-count{color:rgba(255,255,255,.55);font-size:11px;letter-spacing:.6px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.tutorial-next{font-size:12px;font-weight:500;padding:6px 14px;background:rgba(212,160,76,.16);border:1px solid rgba(212,160,76,.55);color:rgba(255,240,220,.96);border-radius:6px;letter-spacing:.3px;transition:opacity .52s ease,background .18s ease,border-color .18s ease}.tutorial-next:hover{background:rgba(212,160,76,.28);border-color:var(--tutorial-gold)}.tutorial-dismiss,.tutorial-next.gesture-next{background:rgba(20,20,24,.45);backdrop-filter:blur(14px) saturate(1.3);-webkit-backdrop-filter:blur(14px) saturate(1.3);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.88);font-size:12px;font-weight:500;padding:7px 16px;border-radius:999px;letter-spacing:.4px;box-shadow:0 4px 14px rgba(0,0,0,.35)}.tutorial-dismiss:hover,.tutorial-next.gesture-next:hover{background:rgba(20,20,24,.65);border-color:rgba(255,255,255,.4);color:rgba(255,255,255,.98)}.tutorial-next.gesture-next{margin-top:8px}.tutorial-dismiss{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:1103;font-size:14px;font-weight:500;padding:11px 26px;letter-spacing:.6px;transition:opacity .52s ease,background .18s ease,border-color .18s ease,color .18s ease}@keyframes tutorial-fade-in{0%{opacity:0}to{opacity:1}}@keyframes tutorial-bridge-out{0%{opacity:1}to{opacity:0}}.tutorial-center{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;text-align:center;padding:0 32px;z-index:1102;transition:opacity .52s ease}.tutorial-center,.tutorial-center *{pointer-events:none}.tutorial-center button{pointer-events:auto}.tutorial-mask-line{overflow:hidden;padding:.12em 0;display:block;line-height:1}.tutorial-marquee{position:fixed;left:0;right:0;display:flex;justify-content:center;z-index:1102;pointer-events:none;transition:opacity .52s ease,top 1.4s cubic-bezier(.22,1,.36,1),transform 1.4s cubic-bezier(.22,1,.36,1)}.tutorial-marquee.is-center{top:50%;transform:translateY(-50%)}.tutorial-marquee.is-upper{top:22%;transform:translateY(0)}.tutorial-welcome-text{display:block;margin:0;font-size:96px;font-weight:200;letter-spacing:8px;color:rgba(255,255,255,.96);line-height:1;-webkit-user-select:none;user-select:none;animation:tutorial-welcome-rise 1.6s cubic-bezier(.16,1,.3,1) both}@keyframes tutorial-welcome-rise{0%{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}.gesture-block{gap:14px}.tutorial-eyebrow{font-size:11px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--tutorial-gold);line-height:1;transform:translateY(110%);animation:tutorial-text-rise 1.4s cubic-bezier(.16,1,.3,1) .2s both}.tutorial-instruction{font-size:32px;font-weight:300;letter-spacing:.6px;color:rgba(255,255,255,.96);max-width:720px;line-height:1.25;transform:translateY(110%);animation:tutorial-text-rise 1.5s cubic-bezier(.16,1,.3,1) .5s both}@keyframes tutorial-text-rise{0%{transform:translateY(110%);opacity:0}to{transform:translateY(0);opacity:1}}.tutorial-arc-wrap{position:relative;width:720px;height:220px;margin-top:6px;filter:drop-shadow(0 0 12px rgba(212,160,76,.5))}.tutorial-arc{display:block;width:100%;height:100%}.tutorial-arc-path{stroke:var(--tutorial-gold);fill:none;stroke-dasharray:100;stroke-dashoffset:100;animation:tutorial-arc-loop 4.2s ease-in-out 1.2s infinite}@keyframes tutorial-arc-loop{0%{stroke-dashoffset:100;opacity:0}10%{opacity:1}55%{stroke-dashoffset:0;opacity:1}82%{stroke-dashoffset:0;opacity:0}to{stroke-dashoffset:0;opacity:0}}.tutorial-arc-dot{position:absolute;top:0;left:0;width:14px;height:14px;border-radius:50%;background:var(--tutorial-gold);box-shadow:0 0 0 2px rgba(212,160,76,.25),0 0 16px rgba(212,160,76,.85);offset-path:path("M 60 180 Q 360 30 660 180");offset-distance:0;offset-rotate:0deg;opacity:0;animation:tutorial-arc-dot 4.2s ease-in-out 1.2s infinite}@keyframes tutorial-arc-dot{0%{offset-distance:0;opacity:0}8%{opacity:1}55%{offset-distance:100%;opacity:1}82%{offset-distance:100%;opacity:0}to{offset-distance:100%;opacity:0}}.tutorial-backdrop[data-exiting=true],.tutorial-card[data-exiting=true],.tutorial-center[data-exiting=true],.tutorial-cutout-border[data-exiting=true],.tutorial-dim[data-exiting=true],.tutorial-dismiss[data-exiting=true],.tutorial-marquee[data-exiting=true]{animation:tutorial-exit-fade .52s ease forwards;pointer-events:none}@keyframes tutorial-exit-fade{0%{opacity:1}to{opacity:0}}.tutorial-next.gesture-next{margin-top:6px;background:transparent;border:1px solid rgba(255,255,255,.18);color:var(--text-dim);letter-spacing:.4px;padding:6px 14px;border-radius:999px}.tutorial-next.gesture-next:hover{color:var(--text);border-color:rgba(255,255,255,.32);background:rgba(255,255,255,.04)}@media (prefers-reduced-motion:reduce){.tutorial-backdrop,.tutorial-card,.tutorial-cutout-border,.tutorial-dim,.tutorial-eyebrow,.tutorial-instruction,.tutorial-welcome-text{animation:none;transform:none;opacity:1}.tutorial-arc-path{animation:none;opacity:.85;stroke-dashoffset:0}.tutorial-arc-dot{animation:none;opacity:.9;offset-distance:100%}}