.toast{display:flex;align-items:flex-start;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-radius:var(--radius-lg);border:1px solid;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;min-width:240px;max-width:420px;pointer-events:auto;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function),transform var(--default-transition-duration) var(--default-transition-timing-function)}.toast--success{background:var(--color-success-banner-bg);border-color:var(--color-success-banner-border);color:var(--color-success-banner-text)}.toast--error{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.toast--warning{background:var(--color-star-bg);border-color:var(--color-star-border);color:var(--color-star)}.toast:hover{opacity:.9}.toast__body{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs);flex:1;min-width:0}.toast__message{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1.4}.toast__description{font-size:var(--font-size-xs);opacity:.8;line-height:1.4;word-break:break-word}.toast__close{flex:0 0 auto;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:none;background:transparent;color:inherit;font-size:var(--font-size-md);line-height:1;cursor:pointer;border-radius:var(--radius-sm);opacity:.7;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function)}.toast__close:hover,.toast__close:focus-visible{opacity:1}.toast__close:focus-visible{outline:2px solid currentColor;outline-offset:2px}.toast:focus-visible{outline:2px solid currentColor;outline-offset:2px}.toast-container{position:fixed;top:var(--spacing-sp-lg);left:50%;transform:translate(-50%);z-index:var(--z-toast);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sp-sm);pointer-events:none}.auth-button{position:absolute;z-index:var(--z-canvas-overlay);top:calc(var(--chrome-height) + 12px);right:200px;display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:8px;border:1px solid var(--color-border-faint);color:var(--color-fg-muted);font-size:13px;cursor:pointer;transition:background .15s,color .15s}.auth-button:hover{background:var(--color-surface-glass);color:var(--color-fg)}.auth-button-wrapper{position:absolute;z-index:var(--z-canvas-overlay);top:calc(var(--chrome-height) + 12px);right:200px}.auth-user-btn{position:relative;top:auto;right:auto}.auth-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.auth-avatar-placeholder{width:24px;height:24px;border-radius:50%;background:var(--color-control-bg-hover);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--color-fg-muted)}.auth-user-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:8px;padding:4px 0;box-shadow:var(--shadow-dropdown);animation:popover-fade-in .12s ease-out}.auth-dropdown-item{display:block;width:100%;padding:8px 14px;background:none;border:none;color:var(--color-fg-muted);font-size:13px;text-align:left;cursor:pointer;transition:background .1s,color .1s}.auth-dropdown-item:hover{background:var(--color-control-bg);color:var(--color-fg)}.auth-dropdown-signout:hover{color:var(--color-danger)}.auth-dropdown-divider{height:1px;background:var(--color-border-faint);margin:4px 0}.auth-button-placeholder{position:absolute;z-index:var(--z-canvas-overlay);top:calc(var(--chrome-height) + 12px);right:200px;width:160px;height:38px;visibility:hidden}@media(max-width:640px){.auth-user-name{display:none}.auth-button-placeholder{width:60px}}.app-hamburger-menu{position:relative}.app-hamburger-trigger{display:flex;align-items:center;justify-content:center;width:40px;min-height:var(--global-header-height);background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-fg-muted);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.app-hamburger-trigger:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.app-hamburger-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-2xs) 0;box-shadow:var(--shadow-menu)}.app-hamburger-item{display:flex;align-items:center;width:100%;padding:var(--spacing-sp-xs) var(--spacing-sp-md);background:none;border:none;color:var(--color-fg);font:inherit;font-size:var(--font-size-sm);cursor:pointer;text-align:left;text-decoration:none;box-sizing:border-box;transition:background var(--default-transition-duration) var(--default-transition-timing-function)}.app-hamburger-item:hover{background:var(--color-control-bg-hover)}.app-hamburger-divider{height:1px;background:var(--color-border);margin:var(--spacing-sp-2xs) 0}.app-hamburger-auth{padding:var(--spacing-sp-2xs) 0;position:relative}.app-hamburger-auth .auth-button{position:static;top:auto;right:auto;background:none;border:none;-webkit-backdrop-filter:none;backdrop-filter:none;border-radius:var(--radius-sm);color:var(--color-fg-muted);font:inherit;font-size:var(--font-size-sm);padding:var(--spacing-sp-xs) var(--spacing-sp-md);width:100%;box-sizing:border-box;justify-content:flex-start;z-index:auto;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.app-hamburger-auth .auth-button:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.app-hamburger-auth .auth-button-wrapper{position:relative;top:auto;right:auto}.global-header{height:calc(var(--global-header-height) + env(safe-area-inset-top,0px));min-height:calc(var(--global-header-height) + env(safe-area-inset-top,0px));display:flex;align-items:center;padding:env(safe-area-inset-top,0px) max(var(--spacing-sp-md),env(safe-area-inset-right,0px)) 0 max(var(--spacing-sp-md),env(safe-area-inset-left,0px));gap:var(--spacing-sp-md);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:var(--z-header);position:relative}.global-header-left{display:flex;align-items:center;gap:var(--spacing-sp-sm);flex-shrink:0}.global-header-logo-btn{display:flex;align-items:center;gap:var(--spacing-sp-sm);background:none;border:none;padding:0;cursor:pointer;color:var(--color-fg);font:inherit;transition:color var(--default-transition-duration) var(--default-transition-timing-function)}.global-header-logo-btn:hover{color:var(--color-fg-muted)}.global-header-logo{display:inline-flex;width:22px;height:22px;flex-shrink:0}.global-header-logo>svg{width:100%;height:100%}.global-header-app-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.02em}.global-header-nav{flex:1 1 auto;display:flex;justify-content:center;min-width:0}.global-header-nav-list{display:flex;align-items:center;gap:var(--spacing-sp-2xs);list-style:none;margin:0;padding:0}.global-header-nav-item{display:flex}.global-header-nav-link{display:inline-flex;align-items:center;padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);border-radius:var(--radius-sm);text-decoration:none;color:var(--color-fg-muted);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.global-header-nav-link:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.global-header-nav-link.is-active{color:var(--color-fg);background:var(--color-control-bg)}.global-header-right{display:flex;align-items:center;gap:var(--spacing-sp-xs);flex-shrink:0}.global-header-search{display:flex;align-items:center;gap:var(--spacing-sp-2xs);padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);border:1px solid var(--color-border);border-radius:var(--radius-full);background:var(--color-control-bg);color:var(--color-fg-muted);transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.global-header-search:focus-within{border-color:var(--color-border-focus);color:var(--color-fg)}.global-header-search-icon{flex-shrink:0}.global-header-search-input{border:none;outline:none;background:transparent;color:var(--color-fg);font:inherit;font-size:var(--font-size-xs);width:14em;min-width:0;padding:0}.global-header-search-input::placeholder{color:var(--color-fg-faint)}.global-header-search-input::-webkit-search-cancel-button,.global-header-search-input::-webkit-search-decoration{display:none}.global-header-create-btn{display:flex;align-items:center;gap:var(--spacing-sp-2xs);padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);border-radius:var(--radius-sm);border:1px solid transparent;background:var(--color-accent);color:var(--color-fg-on-accent);font:inherit;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function)}.global-header-create-btn:hover{opacity:.85}.global-header-create-btn svg{flex-shrink:0}.global-header .auth-button{position:static;top:auto;right:auto}.global-header .auth-button-wrapper{position:relative;top:auto;right:auto}.global-header-hamburger{display:flex;align-items:stretch;margin-left:var(--spacing-sp-xs);border-left:1px solid var(--color-border)}.global-header-hamburger .app-hamburger-menu{display:flex;align-items:stretch}.global-header-hamburger .app-hamburger-trigger{width:var(--global-header-height);height:100%;border-radius:0;border:none;background:transparent}.global-header-hamburger .app-hamburger-trigger:hover{background:var(--color-control-bg)}@media(max-width:960px){.global-header-search-input{width:8em}}@media(max-width:720px){.global-header{padding:env(safe-area-inset-top,0px) max(var(--spacing-sp-sm),env(safe-area-inset-right,0px)) 0 max(var(--spacing-sp-sm),env(safe-area-inset-left,0px));gap:var(--spacing-sp-sm)}.global-header-app-name{display:none}.global-header-nav,.global-header-search,.global-header-create-btn,.global-header-right>.auth-button,.global-header-right>.auth-button-wrapper{display:none}}.tooltip{position:fixed;z-index:var(--z-tooltip);padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-fg);pointer-events:none;max-width:280px;white-space:normal;word-break:break-word;opacity:0;transition:opacity .12s ease,transform .12s ease}.tooltip--visible{opacity:1}.tooltip--top{transform:translateY(2px)}.tooltip--top.tooltip--visible{transform:translateY(0)}.tooltip--bottom{transform:translateY(-2px)}.tooltip--bottom.tooltip--visible{transform:translateY(0)}.tooltip--left{transform:translate(2px)}.tooltip--left.tooltip--visible{transform:translate(0)}.tooltip--right{transform:translate(-2px)}.tooltip--right.tooltip--visible{transform:translate(0)}.composition-share-btn{display:inline-flex;align-items:center;gap:var(--spacing-sp-xs);padding:0 var(--spacing-sp-md);height:100%;background:transparent;border:none;color:var(--color-fg);font:inherit;font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.composition-share-btn:hover:not(:disabled){background:var(--color-control-bg)}.composition-share-btn--copied{color:var(--color-success)}.composition-share-btn-icon{display:inline-flex;font-size:var(--font-size-base);line-height:1}@media(max-width:640px){.composition-share-btn-label{display:none}}.editor-header{height:calc(var(--global-header-height) + env(safe-area-inset-top,0px));min-height:calc(var(--global-header-height) + env(safe-area-inset-top,0px));display:flex;align-items:stretch;padding-top:env(safe-area-inset-top,0px);padding-left:env(safe-area-inset-left,0px);padding-right:env(safe-area-inset-right,0px);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border);z-index:var(--z-toolbar);position:relative}.editor-header-logo-btn{display:flex;align-items:center;gap:var(--spacing-sp-sm);padding:0 var(--spacing-sp-md);background:none;border:none;border-right:1px solid var(--color-border);color:var(--color-fg);font:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:color var(--default-transition-duration) var(--default-transition-timing-function)}.editor-header-logo-btn:hover{color:var(--color-fg-muted)}.editor-header-logo-img{display:inline-flex;width:20px;height:20px;flex-shrink:0}.editor-header-logo-img>svg{width:100%;height:100%}.editor-header-logo-name{font-size:var(--font-size-sm);font-weight:600;letter-spacing:.02em}.editor-header-tabs{flex:1;min-width:0;display:flex;align-items:stretch;overflow:hidden}.editor-header-tabs .tab-bar{flex:1;height:100%;min-height:0;background:transparent;border-bottom:none}.editor-header-share,.editor-header-menu{display:flex;align-items:stretch;flex-shrink:0;border-left:1px solid var(--color-border)}.editor-header-menu .app-hamburger-menu{display:flex;align-items:stretch}.editor-header-menu .app-hamburger-trigger{width:var(--global-header-height);height:100%;border-radius:0;border:none;background:transparent}.editor-header-menu .app-hamburger-trigger:hover{background:var(--color-control-bg)}@media(max-width:640px){.editor-header-logo-name{display:none}}.tab-bar{height:var(--tab-bar-height);min-height:var(--tab-bar-height);display:flex;align-items:stretch;background:var(--color-bg);border-bottom:1px solid var(--color-border);z-index:var(--z-toolbar);position:relative;overflow-x:auto;overflow-y:hidden;scrollbar-width:none}.tab-bar::-webkit-scrollbar{display:none}.tab-bar-tab{display:flex;align-items:center;gap:var(--spacing-sp-2xs);padding:0 var(--spacing-sp-md);font-size:var(--font-size-xs);color:var(--color-fg-subtle);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;position:relative;transition:color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.tab-bar-tab:hover{background:var(--color-control-bg);color:var(--color-fg-muted)}.tab-bar-tab.active{color:var(--color-fg);border-bottom-color:var(--color-fg-muted)}.tab-bar-tab-name{pointer-events:none}.tab-bar-tab-input{background:var(--color-control-bg);border:1px solid var(--color-border-focus);border-radius:var(--radius-sm);color:var(--color-fg);font-size:var(--font-size-xs);padding:1px var(--spacing-sp-2xs);outline:none;width:100px}.tab-bar-close{display:flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--color-fg-subtle);font-size:var(--font-size-2xs);cursor:pointer;opacity:0;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.tab-bar-tab:hover .tab-bar-close,.tab-bar-tab.active .tab-bar-close{opacity:1}.tab-bar-close:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.tab-bar-add,.tab-bar-preview{display:flex;align-items:center;justify-content:center;width:var(--tab-bar-height);min-width:var(--tab-bar-height);font-size:var(--font-size-base);color:var(--color-fg-subtle);background:transparent;border:none;cursor:pointer;transition:color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.tab-bar-add:hover,.tab-bar-preview:hover{background:var(--color-control-bg);color:var(--color-fg)}.tab-bar-add:focus-visible,.tab-bar-preview:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.drop-anywhere-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;pointer-events:none;background:color-mix(in oklch,var(--palette-bg) 65%,transparent);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drop-anywhere-overlay-inner{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sp-xl) var(--spacing-sp-2xl);border:2px dashed var(--color-accent);border-radius:var(--radius-xl);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.drop-anywhere-overlay-label{color:var(--color-fg);font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);font-family:var(--font-sans);letter-spacing:.01em}.composer-anim-controls{display:flex;min-width:0;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-xs) var(--spacing-sp-md);border-radius:var(--radius-full);background:var(--color-surface-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border-subtle);color:var(--color-fg);font-size:var(--font-size-xs);line-height:1;box-shadow:var(--shadow-strip-hover);-webkit-user-select:none;user-select:none}.composer-anim-controls__play-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px;padding:0;background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);color:var(--color-fg);cursor:pointer;transition:background .12s,border-color .12s}.composer-anim-controls__play-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border)}.composer-anim-controls__play-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.composer-anim-controls__play-btn[aria-pressed=true]{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info)}.composer-anim-controls__play-btn[aria-pressed=true]:hover{background:var(--color-info-bg-hover)}.composer-anim-controls__icon{width:10px;height:10px;display:block}.composer-anim-controls__slider{flex:1;min-width:80px;accent-color:var(--color-accent);cursor:pointer;margin:0}.composer-anim-controls__slider:focus-visible{outline:2px solid var(--color-focus-ring);border-radius:var(--radius-xs)}.composer-anim-controls__frame-count{font-size:var(--font-size-2xs);font-variant-numeric:tabular-nums;color:var(--color-fg-muted);white-space:nowrap;flex-shrink:0}.composer-anim-controls__fps-badge{font-size:var(--font-size-2xs);font-variant-numeric:tabular-nums;font-weight:600;color:var(--color-fg-subtle);background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);padding:1px var(--spacing-sp-xs);white-space:nowrap;flex-shrink:0}.composer-anim-controls__fps-select{font-family:inherit;font-size:var(--font-size-2xs);font-variant-numeric:tabular-nums;font-weight:600;color:var(--color-fg-subtle);background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-full);padding:1px var(--spacing-sp-md) 1px var(--spacing-sp-xs);white-space:nowrap;flex-shrink:1;min-width:52px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='8' height='6' viewBox='0 0 8 6' fill='none' stroke='%23666' stroke-width='1.5'%3e%3cpath d='M1 1.5l3 3 3-3'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right var(--spacing-sp-2xs) center;background-size:8px 6px;transition:background-color .12s,border-color .12s}.composer-anim-controls__fps-select:hover{background-color:var(--color-control-bg-hover);border-color:var(--color-border)}.composer-anim-controls__fps-select:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.composer-anim-controls__capture-badge{display:inline-flex;align-items:center;gap:2px;font-size:var(--font-size-2xs);font-variant-numeric:tabular-nums;font-weight:600;color:var(--color-accent);background:color-mix(in oklch,var(--color-accent) 12%,transparent);border:1px solid color-mix(in oklch,var(--color-accent) 35%,transparent);border-radius:var(--radius-full);padding:1px var(--spacing-sp-xs);white-space:nowrap;flex-shrink:0}.login-required-overlay{position:relative;display:inline-block;cursor:pointer;outline:none}.login-required-overlay:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px;border-radius:var(--radius-md)}.login-required-overlay-inner{opacity:.4;pointer-events:none;-webkit-user-select:none;user-select:none;filter:grayscale(30%);transition:opacity var(--default-transition-duration) var(--default-transition-timing-function)}.login-required-overlay:hover .login-required-overlay-inner{opacity:.3}.login-required-overlay[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-modal);color:var(--color-fg);font-size:var(--font-size-xs);white-space:nowrap;pointer-events:none;z-index:var(--z-overlay-root);opacity:0;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function)}.login-required-overlay[data-tooltip]:hover:after,.login-required-overlay[data-tooltip]:focus-visible:after{opacity:1}.url-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.url-modal{background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);padding:24px;max-width:520px;width:90%;box-shadow:var(--shadow-modal)}.url-modal-title{font-size:16px;font-weight:600;color:var(--color-fg);margin-bottom:8px}.url-modal-description{font-size:12px;color:var(--color-fg-subtle);margin:0 0 12px}.url-modal-textarea{width:100%;padding:8px 10px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:12px;font-family:monospace;resize:none;outline:none}.url-modal-textarea:focus{border-color:var(--color-border-focus)}.url-modal-actions{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}.url-modal-copy-btn{background:var(--color-control-bg-hover)}.url-modal-close-btn{background:var(--color-control-bg)}.confirm-dialog{background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);padding:24px;max-width:480px;width:90%;box-shadow:var(--shadow-modal)}.confirm-dialog-title{font-size:16px;font-weight:600;color:var(--color-fg);margin-bottom:8px}.confirm-dialog-message{font-size:13px;color:var(--color-fg-subtle);margin:0 0 16px;line-height:1.5}.confirm-dialog-content{margin-bottom:16px}.confirm-dialog-actions{display:flex;gap:8px;justify-content:flex-end}.confirm-dialog-cancel{background:var(--color-control-bg)}.confirm-dialog-primary{background:var(--color-control-bg-hover)}.confirm-dialog-danger{background:var(--color-danger);color:var(--color-fg-on-accent)}.confirm-dialog-danger:hover{background:var(--color-danger-hover)}.confirm-dialog-preview{border-radius:8px;overflow:hidden;background:var(--color-preview-bg);max-height:300px;display:flex;align-items:center;justify-content:center}.confirm-dialog-preview-img{width:100%;max-height:300px;object-fit:contain}.preset-size-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-modal);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:preset-size-fade-in .15s ease-out}@keyframes preset-size-fade-in{0%{opacity:0}to{opacity:1}}.preset-size-modal{width:90vw;height:90vh;display:flex;flex-direction:column;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal-lg);overflow:hidden;animation:preset-size-slide-in .2s ease-out}@keyframes preset-size-slide-in{0%{opacity:0;transform:scale(.97) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.preset-size-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.preset-size-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg)}.preset-size-close-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;background:var(--color-control-bg);border-radius:var(--radius-md);flex-shrink:0}.preset-size-close-btn:hover{background:var(--color-control-bg-hover)}.preset-size-filter-row{display:flex;align-items:center;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-sm) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.preset-size-filter-label{font-size:var(--font-size-xs);color:var(--color-fg-muted);white-space:nowrap;flex-shrink:0}.preset-size-filter-input{flex:1;min-width:0;padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);font-size:var(--font-size-xs);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg);outline:none}.preset-size-filter-input::placeholder{color:var(--color-fg-faint)}.preset-size-filter-input:focus{border-color:var(--color-border-hover);box-shadow:0 0 0 2px var(--color-focus-ring)}.preset-size-filter-input::-webkit-search-cancel-button,.preset-size-filter-input::-webkit-search-decoration{display:none}.preset-size-tabs{display:flex;gap:var(--spacing-sp-2xs);padding:var(--spacing-sp-sm) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0;flex-wrap:wrap}.preset-size-tab-btn{padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);font-size:var(--font-size-xs);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg-muted);border:1px solid transparent;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.preset-size-tab-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.preset-size-tab-btn.active{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.preset-size-grid-container{flex:1;overflow-y:auto;padding:var(--spacing-sp-lg)}.preset-size-category-heading{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg-muted);margin-bottom:var(--spacing-sp-sm);text-transform:uppercase;letter-spacing:.05em}.preset-size-category-heading:not(:first-child){margin-top:var(--spacing-sp-xl)}.preset-size-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sp-md)}.preset-size-empty{padding:48px 0;text-align:center;color:var(--color-fg-faint);font-size:var(--font-size-base)}.preset-size-card{padding:var(--spacing-sp-md);background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function);display:flex;flex-direction:column;gap:var(--spacing-sp-sm);outline:none}.preset-size-card:hover{border-color:var(--color-border-hover);background:var(--color-control-bg-hover)}.preset-size-card:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.preset-size-aspect-preview{display:flex;align-items:center;justify-content:center;height:60px}.preset-size-aspect-box{border:1.5px solid var(--color-fg-faint);border-radius:2px;background:linear-gradient(135deg,#2d47724d,#356e7133)}.preset-size-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-2xs)}.preset-size-card-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preset-size-card-star{background:none;border:none;color:var(--color-fg-faint);font-size:14px;cursor:default;padding:0 2px;line-height:1;flex-shrink:0}.preset-size-card-platform{font-size:var(--font-size-2xs);color:var(--color-fg-subtle)}.preset-size-card-dims{font-size:var(--font-size-xs);color:var(--color-fg-faint);font-variant-numeric:tabular-nums}.preset-size-tab-my-presets{border-color:transparent}.preset-size-tab-my-presets.unauthenticated{opacity:.55}.preset-size-my-presets{position:relative;min-height:120px}.preset-size-panel-error{margin-bottom:var(--spacing-sp-md);padding:var(--spacing-sp-sm) var(--spacing-sp-md);background:var(--color-danger-subtle, oklch(35% .12 25 / 20%));color:var(--color-danger, oklch(65% .18 25));border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.preset-size-loading{padding:var(--spacing-sp-xl) 0;text-align:center;color:var(--color-fg-faint);font-size:var(--font-size-sm)}.preset-size-save-card{border-style:dashed;border-color:var(--color-border-hover);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sp-xs);text-align:center}.preset-size-save-card:hover{border-color:var(--color-fg-muted);background:var(--color-control-bg-hover)}.preset-size-save-icon-wrap{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--color-control-bg-hover);margin-bottom:var(--spacing-sp-2xs)}.preset-size-save-plus{font-size:22px;line-height:1;color:var(--color-fg-muted)}.preset-size-save-card .preset-size-card-header{justify-content:center}.preset-size-kebab-wrap{position:relative;flex-shrink:0}.preset-size-kebab-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;background:transparent;border-radius:var(--radius-sm);color:var(--color-fg-faint);padding:0;cursor:pointer}.preset-size-kebab-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.preset-size-kebab-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);z-index:var(--z-local-1);min-width:120px;padding:var(--spacing-sp-2xs);display:flex;flex-direction:column;gap:2px}.preset-size-kebab-menu--flipped{top:auto;bottom:calc(100% + 4px);right:0}.preset-size-kebab-item{width:100%;text-align:left;padding:var(--spacing-sp-xs) var(--spacing-sp-sm);font-size:var(--font-size-xs);border-radius:var(--radius-sm);background:transparent;color:var(--color-fg-muted);cursor:pointer}.preset-size-kebab-item:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.preset-size-kebab-danger{color:var(--color-danger, oklch(65% .18 25))}.preset-size-kebab-danger:hover{background:var(--color-danger-subtle, oklch(35% .12 25 / 20%));color:var(--color-danger, oklch(65% .18 25))}.preset-size-name-input{width:100%;padding:var(--spacing-sp-sm) var(--spacing-sp-md);font-size:var(--font-size-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg);outline:none;box-sizing:border-box}.preset-size-name-input:focus{border-color:var(--color-border-hover);box-shadow:0 0 0 2px var(--color-focus-ring)}.preset-size-dialog-error{margin-top:var(--spacing-sp-sm);font-size:var(--font-size-xs);color:var(--color-danger, oklch(65% .18 25))}@media(max-width:640px){.preset-size-modal{position:absolute;top:env(safe-area-inset-top,0px);right:env(safe-area-inset-right,0px);bottom:env(safe-area-inset-bottom,0px);left:env(safe-area-inset-left,0px);width:auto;height:auto;border-radius:0}.preset-size-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.viewer-canvas-size-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:var(--color-overlay-backdrop);display:flex;align-items:flex-start;justify-content:center;padding:calc(var(--chrome-height, 0px) + var(--spacing-sp-lg, 24px)) var(--spacing-sp-md, 16px) var(--spacing-sp-md, 16px)}.viewer-canvas-size-dialog{width:360px;max-width:calc(100vw - 2 * var(--spacing-sp-md, 16px));background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-menu);padding:var(--spacing-sp-md, 16px);display:flex;flex-direction:column;gap:var(--spacing-sp-sm);color:var(--color-fg)}.viewer-canvas-size-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-2xs)}.viewer-canvas-size-title{font-size:13px;font-weight:600;margin:0;color:var(--color-fg)}.viewer-canvas-size-subtitle{font-size:10px;color:var(--color-fg-muted);margin:0;line-height:1.4}.viewer-canvas-size-close-btn{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-fg-muted);cursor:pointer;font-size:16px;line-height:1;padding:0}.viewer-canvas-size-close-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.viewer-canvas-size-dims{display:flex;align-items:flex-start;gap:var(--spacing-sp-2xs)}.viewer-canvas-size-field{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs);flex:1 1 0;min-width:0}.viewer-canvas-size-label{font-size:11px;color:var(--color-fg-muted);margin:0;font-weight:500;letter-spacing:.02em}.viewer-canvas-size-input{width:100%;box-sizing:border-box;height:28px;padding:0 var(--spacing-sp-2xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg);font:inherit;font-size:12px;font-variant-numeric:tabular-nums}.viewer-canvas-size-input:focus{outline:none;border-color:var(--color-border-focus, var(--color-accent))}.viewer-canvas-size-input--error{border-color:var(--color-danger)}.viewer-canvas-size-error{font-size:10px;color:var(--color-danger);margin:0;min-height:1.1em;line-height:1.1}.viewer-canvas-size-swap{display:flex;align-items:flex-end;padding-bottom:calc(10px + var(--spacing-sp-3xs))}.viewer-canvas-size-swap-btn{height:28px;padding:0 var(--spacing-sp-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg);cursor:pointer;font-size:11px;font-weight:500;white-space:nowrap}.viewer-canvas-size-swap-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover, var(--color-border))}.viewer-canvas-size-viewmode{display:inline-flex;align-self:stretch;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;background:var(--color-control-bg)}.viewer-canvas-size-viewmode-btn{flex:1 1 0;font-size:11px;padding:6px 12px;background:transparent;border:none;color:var(--color-fg-muted);cursor:pointer;font-weight:500;letter-spacing:.02em}.viewer-canvas-size-viewmode-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.viewer-canvas-size-viewmode-btn.is-active{background:var(--color-control-bg-hover);color:var(--color-fg);box-shadow:inset 0 -2px 0 var(--color-border-focus, var(--color-accent))}.viewer-canvas-size-apply-row{display:flex;gap:var(--spacing-sp-2xs)}.viewer-canvas-size-apply-btn{flex:1 1 auto;height:28px;padding:0 var(--spacing-sp-sm);border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-accent);color:var(--color-fg-on-accent);cursor:pointer;font-size:11px;font-weight:600;transition:opacity .15s;white-space:nowrap}.viewer-canvas-size-apply-btn:hover:not(:disabled){opacity:.85}.viewer-canvas-size-apply-btn:disabled{opacity:.35;cursor:default}.viewer-canvas-size-cancel-btn{flex:1 1 auto;height:28px;padding:0 var(--spacing-sp-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-fg-muted);cursor:pointer;font-size:11px;font-weight:500;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}.viewer-canvas-size-cancel-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover, var(--color-border));color:var(--color-fg)}.viewer-canvas-size-keep-view{display:inline-flex;align-items:center;gap:var(--spacing-sp-2xs);font-size:11px;color:var(--color-fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.viewer-canvas-size-keep-view input[type=checkbox]{margin:0;cursor:pointer}.viewer-canvas-size-presets-section{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs)}.viewer-canvas-size-presets-label{font-size:11px;color:var(--color-fg-muted);font-weight:500;margin:0;letter-spacing:.02em}.viewer-canvas-size-presets{display:flex;flex-wrap:wrap;gap:var(--spacing-sp-3xs)}.viewer-canvas-size-preset-btn{font-size:10px;padding:3px var(--spacing-sp-2xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg-muted);cursor:pointer;font-variant-numeric:tabular-nums;white-space:nowrap}.viewer-canvas-size-preset-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover, var(--color-border))}.viewer-canvas-size-preset-btn.is-current{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-focus, var(--color-accent))}.viewer-canvas-size-readout{font-size:11px;color:var(--color-fg-muted);margin:0;font-variant-numeric:tabular-nums;text-align:right}.selection-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-selection);-webkit-user-select:none;user-select:none;touch-action:none}.selection-overlay-passthrough{z-index:var(--z-canvas-overlay);pointer-events:none}.selection-dim{position:absolute;background:var(--color-overlay-backdrop)}.selection-overlay-passthrough .selection-dim{pointer-events:none}.selection-dim-top{top:0;left:0;right:0}.selection-dim-bottom{left:0;right:0}.selection-dim-left{left:0}.selection-box{position:absolute;border:2px dashed var(--color-canvas-dashed);cursor:move;box-sizing:border-box;touch-action:none}.selection-overlay-passthrough .selection-box{pointer-events:auto}.selection-handle{position:absolute;width:10px;height:10px;background:var(--color-canvas-handle);border:1px solid var(--color-canvas-handle-border);border-radius:2px;transform:translate(-50%,-50%);z-index:var(--z-local-1);touch-action:none;transition:width .1s,height .1s,box-shadow .1s}.selection-overlay-passthrough .selection-handle{pointer-events:auto}.selection-handle:hover{width:12px;height:12px;box-shadow:0 0 6px var(--color-canvas-handle-glow)}.selection-center-indicator{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--color-canvas-handle);border:1px solid var(--color-canvas-handle-border);transform:translate(-50%,-50%);pointer-events:none;z-index:var(--z-local-1)}.selection-toolbar{position:absolute;z-index:var(--z-local-2);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);display:flex;flex-direction:column;gap:var(--spacing-sp-xs);-webkit-user-select:none;user-select:none}.selection-overlay-passthrough .selection-toolbar{pointer-events:auto}.selection-toolbar-drag{cursor:grab;padding:2px 0;text-align:center;color:var(--color-fg-faint);font-size:10px;letter-spacing:.2em;touch-action:none}.selection-toolbar-drag:active{cursor:grabbing}.selection-toolbar-row{display:flex;gap:4px;align-items:center}.selection-mode-btn{font-size:11px;padding:4px 10px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-fg-muted);cursor:pointer}.selection-mode-btn:hover{background:var(--color-control-bg-hover)}.selection-mode-btn.active{background:var(--color-control-bg-hover);border-color:var(--color-border-focus);color:var(--color-fg)}.selection-presets-btn{margin-left:auto;border-style:dashed}.selection-detail-btn{border-style:solid}.selection-viewmode-toggle{display:inline-flex;align-self:stretch;border:1px solid var(--color-border);border-radius:6px;overflow:hidden;background:var(--color-control-bg)}.selection-viewmode-btn{flex:1 1 0;font-size:11px;padding:4px 12px;background:transparent;border:none;color:var(--color-fg-muted);cursor:pointer;font-weight:500;letter-spacing:.02em}.selection-viewmode-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.selection-viewmode-btn.is-active{background:var(--color-control-bg-hover);color:var(--color-fg);box-shadow:inset 0 -2px 0 var(--color-border-focus)}.selection-detail{display:flex;flex-wrap:wrap;gap:4px;align-items:center;font-size:11px;color:var(--color-fg-muted)}.selection-detail-heading{width:100%;font-size:10px;font-weight:500;color:var(--color-fg-muted);letter-spacing:.02em}.selection-detail-input{width:60px;padding:3px 6px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-fg);font-size:11px;text-align:right;font-variant-numeric:tabular-nums}.selection-detail-separator{color:var(--color-fg-faint);font-weight:600}.selection-ratio-lock-label{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--color-fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.selection-ratio-lock-label input[type=checkbox]{margin:0;cursor:pointer}.selection-keep-view-toggle{display:inline-flex;align-items:center;gap:var(--spacing-sp-2xs);margin-top:var(--spacing-sp-xs);font-size:11px;color:var(--color-fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.selection-keep-view-toggle input[type=checkbox]{margin:0;cursor:pointer}.selection-preset-clamp-hint{margin:0;margin-top:var(--spacing-sp-xs);font-size:10px;color:var(--color-fg-faint);line-height:1.3}.selection-actions{display:flex;gap:6px;border-top:1px solid var(--color-border-subtle);padding-top:6px}.selection-actions button:disabled{opacity:.5;cursor:not-allowed}.selection-btn-generate{background:var(--color-control-bg-hover)}.selection-btn-generate:hover{background:var(--color-border-hover)}.selection-btn-json{background:var(--color-control-bg)}.selection-btn-json:hover{background:var(--color-control-bg-hover)}.selection-btn-exit{background:var(--color-control-bg)}.selection-btn-exit:hover{background:var(--color-control-bg-hover)}.selection-toolbar-icons{display:flex;gap:var(--spacing-sp-2xs);align-items:center}.selection-icon-btn-wrapper{position:relative}.selection-icon-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg-muted);cursor:pointer;touch-action:auto;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.selection-icon-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.selection-icon-btn[aria-expanded=true]{background:var(--color-control-bg-hover);border-color:var(--color-border-focus);color:var(--color-fg)}.selection-popover{position:absolute;top:calc(100% + var(--spacing-sp-xs));background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-2xs) 0;box-shadow:var(--shadow-menu);z-index:var(--z-local-3);min-width:160px}.selection-popover-area{left:0;min-width:220px;padding:var(--spacing-sp-sm)}.selection-popover-misc{right:0}.selection-popover-modes{display:flex;gap:var(--spacing-sp-2xs);flex-wrap:wrap;margin-bottom:var(--spacing-sp-xs)}.selection-popover-item{display:flex;align-items:center;width:100%;padding:var(--spacing-sp-xs) var(--spacing-sp-md);background:none;border:none;color:var(--color-fg);font:inherit;font-size:var(--font-size-sm);cursor:pointer;text-align:left;white-space:nowrap;box-sizing:border-box}.selection-popover-item:hover:not([disabled]){background:var(--color-control-bg-hover)}.selection-popover-item[disabled]{opacity:.5;cursor:not-allowed}.selection-popover-divider{height:1px;background:var(--color-border);margin:var(--spacing-sp-2xs) 0}.selection-canvas-locked-badge{display:inline-flex;align-items:center;gap:var(--spacing-sp-2xs);padding:0 var(--spacing-sp-sm);height:44px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg-muted);font-size:11px;font-variant-numeric:tabular-nums;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none}.selection-canvas-locked-badge svg{flex-shrink:0;opacity:.7}.selection-icon-btn-dismiss{color:var(--color-danger)}.selection-icon-btn-dismiss:hover{color:var(--color-danger-hover);background:var(--color-danger-bg-hover);border-color:var(--color-danger-hover)}.regenerate-restore-btn{position:absolute;top:var(--spacing-sp-sm);right:var(--spacing-sp-sm);z-index:var(--z-canvas-chrome);display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg-muted);cursor:pointer;touch-action:auto;pointer-events:auto;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.regenerate-restore-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}@media(max-width:640px){.selection-toolbar{padding:var(--spacing-sp-xs)}}.image-overlay-transform{position:absolute;top:0;right:0;bottom:0;left:0;z-index:var(--z-side-panel);pointer-events:none;-webkit-user-select:none;user-select:none;touch-action:none}.image-overlay-bounds{position:absolute;border:2px dashed var(--color-canvas-dashed);cursor:move;box-sizing:border-box;pointer-events:all;touch-action:none}.image-overlay-handle{position:absolute;width:10px;height:10px;background:var(--color-canvas-handle);border:1px solid var(--color-canvas-handle-border);border-radius:2px;transform:translate(-50%,-50%);z-index:var(--z-local-1);pointer-events:all;touch-action:none;transition:width .1s,height .1s,box-shadow .1s}.image-overlay-handle:hover{width:12px;height:12px;box-shadow:0 0 6px var(--color-canvas-handle-glow)}.image-overlay-toolbar{position:absolute;z-index:var(--z-local-2);transform:translate(-50%);display:flex;gap:2px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:6px;border:1px solid var(--color-border);padding:3px;pointer-events:all}.image-overlay-mode-btn{font-size:11px;padding:3px 10px;background:var(--color-control-bg);border:1px solid transparent;border-radius:4px;color:var(--color-fg-muted);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.image-overlay-mode-btn:hover{background:var(--color-control-bg-hover)}.image-overlay-mode-btn.active{background:var(--color-control-bg-hover);border-color:var(--color-border-focus);color:var(--color-fg)}.compose-fab{position:fixed;top:calc(var(--chrome-height-safe) + var(--spacing-sp-sm));right:max(var(--spacing-sp-sm),env(safe-area-inset-right,0px));z-index:var(--z-fab);min-height:56px;padding:var(--spacing-sp-md) var(--spacing-sp-2xl);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-accent);border-radius:var(--radius-lg);color:var(--color-fg);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.compose-fab:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-focus)}.compose-fab:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.video-export-dialog{background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);padding:24px;max-width:520px;width:90%;box-shadow:var(--shadow-modal);color:var(--color-fg);display:flex;flex-direction:column;gap:14px}.video-export-dialog__title{font-size:16px;font-weight:600;color:var(--color-fg)}.video-export-dialog__description{font-size:12px;color:var(--color-fg-subtle);margin:-8px 0 0}.video-export-dialog__field{display:flex;flex-direction:column;gap:6px}.video-export-dialog__field-label{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--color-fg-subtle);font-weight:500}.video-export-dialog__field-value{font-size:12px;color:var(--color-fg);font-variant-numeric:tabular-nums}.video-export-dialog__select,.video-export-dialog__input{background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:13px;padding:6px 10px;outline:none;font-family:inherit}.video-export-dialog__select:focus,.video-export-dialog__input:focus{border-color:var(--color-border-focus)}.video-export-dialog__slider{width:100%;accent-color:var(--color-accent)}.video-export-dialog__preset-row{display:flex;gap:6px;flex-wrap:wrap}.video-export-dialog__preset-btn{background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:12px;padding:4px 10px;cursor:pointer;font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.video-export-dialog__preset-btn:hover:not(:disabled){border-color:var(--color-border-hover)}.video-export-dialog__preset-btn[aria-pressed=true]{background:var(--color-control-bg-hover);border-color:var(--color-border-focus);color:var(--color-fg);font-weight:600}.video-export-dialog__preset-btn:disabled{opacity:.5;cursor:not-allowed}.video-export-dialog__progress{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.video-export-dialog__progress-label{font-size:12px;color:var(--color-fg);font-variant-numeric:tabular-nums;display:flex;justify-content:space-between}.video-export-dialog__progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.video-export-dialog__progress-bar-fill{height:100%;background:var(--color-accent);transition:width 80ms linear}.video-export-dialog__spinner-row{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--color-fg);padding:10px 12px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.video-export-dialog__spinner{width:14px;height:14px;border-radius:50%;border:2px solid var(--color-border);border-top-color:var(--color-accent);animation:video-export-spin .8s linear infinite}@keyframes video-export-spin{to{transform:rotate(360deg)}}.video-export-dialog__success,.video-export-dialog__error{font-size:12px;padding:8px 12px;border-radius:var(--radius-md)}.video-export-dialog__success{background:var(--color-success-soft, var(--color-control-bg));color:var(--color-success, var(--color-fg));border:1px solid var(--color-border)}.video-export-dialog__error{background:var(--color-danger-soft, var(--color-control-bg));color:var(--color-danger, var(--color-fg));border:1px solid var(--color-danger, var(--color-border))}.video-export-dialog__actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}.video-export-dialog__btn{background:var(--color-control-bg)}.video-export-dialog__btn--primary{background:var(--color-control-bg-hover);font-weight:600}.video-export-dialog__btn:disabled{opacity:.5;cursor:not-allowed}.composition-thumb{position:relative;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;background:var(--color-preview-bg);width:100%;height:100%;isolation:isolate}.composition-thumb-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.composition-thumb-anim-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;transition:opacity .12s ease-out;pointer-events:none;z-index:var(--z-local-1)}.composition-thumb-live-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.composition-thumb-live-canvas{display:block;width:100%;height:100%;object-fit:cover}.composition-thumb-placeholder-text{font-size:var(--font-size-xs);color:var(--color-fg-faint);text-transform:uppercase;letter-spacing:.05em;text-align:center;padding:var(--spacing-sp-sm)}.composition-thumb--skeleton{background:var(--color-preview-bg)}.composition-thumb-skeleton-pulse{width:100%;height:100%;background:var(--color-control-bg);animation:composition-thumb-skeleton-pulse 1.5s ease-in-out infinite}@keyframes composition-thumb-skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}@media(prefers-reduced-motion:reduce){.composition-thumb-skeleton-pulse{animation:none;opacity:.6}.composition-thumb-anim-video{opacity:0!important}}.composition-thumb-wip-badge{position:absolute;top:var(--spacing-sp-xs);right:var(--spacing-sp-xs);background:#030303b8;color:#dedede;font-size:var(--font-size-2xs);font-weight:700;letter-spacing:.06em;line-height:1;padding:var(--spacing-vsp-2xs) var(--spacing-hsp-xs);border-radius:var(--radius-sm);pointer-events:none;z-index:var(--z-local-1)}.composition-thumb-enlarge{position:relative;display:inline-flex;align-items:center;justify-content:center}.composition-thumb-enlarge-placeholder{position:relative;display:flex;align-items:center;justify-content:center;min-width:200px;min-height:100px;background:var(--color-preview-bg)}.composition-thumb-wip-badge--enlarge{top:var(--spacing-sp-sm);right:var(--spacing-sp-sm);font-size:var(--font-size-xs);padding:var(--spacing-sp-3xs) var(--spacing-sp-sm)}.gallery-modal{background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;max-width:680px;width:92%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-modal)}.gallery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.gallery-header-actions{display:flex;gap:8px}.gallery-close-btn{background:var(--color-control-bg)}.gallery-loading{display:flex;align-items:center;gap:12px;padding:32px 0;justify-content:center;color:var(--color-fg-subtle);font-size:13px}.gallery-empty{padding:32px 0;text-align:center;color:var(--color-fg-faint);font-size:13px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.gallery-card{position:relative;background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:8px;overflow:hidden;transition:border-color .15s}.gallery-card:hover{border-color:var(--color-border-hover)}.gallery-card-preview{aspect-ratio:1;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--color-preview-bg)}.gallery-card-img{width:100%;height:100%;object-fit:cover}.gallery-card-placeholder{font-size:11px;color:var(--color-fg-faint);text-transform:uppercase;letter-spacing:.05em;text-align:center;padding:8px}.gallery-card-info{padding:8px}.gallery-card-name{font-size:12px;color:var(--color-fg-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.gallery-card-description{font-size:10px;color:var(--color-fg-faint);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.gallery-card-meta{display:flex;gap:8px;font-size:10px;color:var(--color-fg-faint)}.gallery-card-delete{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:var(--color-overlay-backdrop);border:none;color:var(--color-fg-muted);font-size:14px;line-height:1;cursor:pointer;opacity:0;transition:opacity .15s,color .15s;display:flex;align-items:center;justify-content:center}.gallery-card:hover .gallery-card-delete{opacity:1}.gallery-card-delete:hover{color:var(--color-danger)}.gallery-load-more{display:block;width:100%;margin-top:16px}.gallery-upload-status{padding:8px 12px;margin-bottom:12px;font-size:12px;color:var(--color-fg-muted);background:var(--color-control-bg);border-radius:var(--radius-md)}.gallery-card-actions{display:flex;align-items:center;justify-content:space-between;padding:4px 8px 8px}.gallery-card-action-btn{font-size:11px;padding:3px 10px}.asset-notes{padding:0 8px 4px}.asset-notes-input{width:100%;padding:4px 6px;background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:11px;outline:none;transition:border-color .15s}.asset-notes-input::placeholder{color:var(--color-fg-faint)}.asset-notes-input:focus{border-color:var(--color-border-focus)}.gallery-card-action-btn-danger{color:var(--color-danger)}.gallery-card-action-btn-danger:hover{color:var(--color-danger-hover)}.load-pattern-dialog{max-width:760px}.load-pattern-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--color-border-subtle);padding-bottom:0}.load-pattern-tab{padding:6px 14px;font-size:13px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-fg-subtle);cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.load-pattern-tab:hover{color:var(--color-fg-muted)}.load-pattern-tab--active{color:var(--color-fg);border-bottom-color:var(--color-accent)}.load-pattern-search{padding:5px 10px;font-size:12px;background:var(--color-control-bg);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-fg-muted);outline:none;width:160px;transition:border-color .15s}.load-pattern-search:focus{border-color:var(--color-border-focus)}.gallery-card-preview--pattern{display:flex;align-items:center;justify-content:center;background:var(--color-control-bg);cursor:pointer}.save-pattern-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}@media(max-width:640px){.gallery-modal{width:100%;height:100dvh;max-width:100%;max-height:100dvh;border-radius:0;border:none;box-shadow:none;padding:var(--spacing-sp-lg)}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:var(--spacing-sp-sm)}}.discard-dialog{background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);padding:24px;max-width:400px;width:90%;box-shadow:var(--shadow-modal)}.discard-dialog-actions{display:flex;gap:8px;margin-top:16px}.discard-dialog-discard{background:var(--color-danger);color:var(--color-fg-on-accent)}.discard-dialog-discard:hover{background:var(--color-danger-hover)}.discard-dialog-keep{background:var(--color-success);color:var(--color-fg-on-accent)}.discard-dialog-keep:hover{background:var(--color-success-active)}.generate-thumb-dialog{background:var(--color-surface-modal);border:1px solid var(--color-border-hover);border-radius:var(--radius-lg);padding:var(--spacing-sp-lg);max-width:560px;width:92%;box-shadow:var(--shadow-modal)}.generate-thumb-dialog-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-fg);margin-bottom:var(--spacing-sp-sm)}.generate-thumb-dialog-description{font-size:var(--font-size-sm);color:var(--color-fg-subtle);margin:0 0 var(--spacing-sp-md);line-height:1.5}.generate-thumb-dialog-preview{border-radius:var(--radius-md);overflow:hidden;background:var(--color-preview-bg);margin-bottom:var(--spacing-sp-md);display:flex;align-items:center;justify-content:center;max-height:360px}.generate-thumb-dialog-preview-img{width:100%;height:100%;object-fit:contain;max-height:360px;display:block}.generate-thumb-dialog-placeholder{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;color:var(--color-fg-muted);font-size:var(--font-size-sm);background:var(--color-control-bg);border-radius:var(--radius-sm)}.generate-thumb-dialog-actions{display:flex;gap:var(--spacing-sp-sm);justify-content:flex-end}.generate-thumb-dialog-save{background:var(--color-control-bg-hover)}.generate-thumb-dialog-cancel{background:var(--color-control-bg)}.perf-badge{position:absolute;top:var(--spacing-sp-2xs);left:var(--spacing-sp-2xs);display:inline-flex;align-items:center;gap:var(--spacing-sp-3xs);padding:2px var(--spacing-sp-2xs);border-radius:var(--radius-sm);border:1px solid;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);font-size:var(--font-size-2xs);font-weight:var(--font-weight-medium);line-height:1;pointer-events:none;z-index:var(--z-local-1)}.perf-badge--low{background:var(--color-success-bg);border-color:var(--color-success-banner-border);color:var(--color-success)}.perf-badge--medium{background:var(--color-star-bg);border-color:var(--color-star-border);color:var(--color-star)}.perf-badge--high{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.perf-badge__icon{width:10px;height:10px;flex:0 0 auto}.perf-badge__score{font-variant-numeric:tabular-nums;line-height:1}.perf-badge--inline{position:static}.pattern-type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sp-xs);max-height:320px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border-hover) transparent}.pattern-type-grid-tile{--_tile-label-on-dark: oklch(95% 0 0);--_tile-label-on-light: oklch(10% 0 0);--_tile-shadow-on-dark: oklch(0% 0 0 / 60%);--_tile-shadow-on-light: oklch(100% 0 0 / 60%);position:relative;isolation:isolate;aspect-ratio:3 / 2;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),transform var(--default-transition-duration) var(--default-transition-timing-function)}.pattern-type-grid-tile:hover{border-color:var(--color-border-hover)}.pattern-type-grid-tile:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.pattern-type-grid-tile[aria-selected=true]{border-color:var(--color-fg)}.pattern-type-grid-tile canvas{display:block;width:100%;height:100%}.pattern-type-grid-tile-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-control-bg);color:var(--color-fg-faint);font-size:var(--font-size-2xs);pointer-events:none}.pattern-type-grid-tile-placeholder[data-rendered=true]{display:none}.pattern-type-grid-tile-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;padding:var(--spacing-sp-2xs) var(--spacing-sp-xs);pointer-events:none}.pattern-type-grid-tile-label-text{font-size:var(--font-size-2xs);font-weight:600;line-height:1.2;text-shadow:0 0 4px var(--_shadow-color, oklch(0% 0 0 / 60%)),0 1px 2px var(--_shadow-color, oklch(0% 0 0 / 40%))}.pattern-type-grid-tile--deleted{cursor:default;opacity:.6}.pattern-type-grid-tile-placeholder--deleted{display:flex;font-size:var(--font-size-2xs);color:var(--color-fg-muted);text-align:center;padding:var(--spacing-sp-xs)}.pattern-type-grid-tile-user-badge{position:absolute;top:var(--spacing-sp-2xs);right:var(--spacing-sp-2xs);width:8px;height:8px;border-radius:50%;background:var(--color-fg);opacity:.7}.pattern-type-grid-tile-edit-btn{position:absolute;bottom:var(--spacing-sp-xs);right:var(--spacing-sp-xs);padding:var(--spacing-sp-3xs) var(--spacing-sp-xs);background:var(--color-surface-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg);font-size:var(--font-size-2xs);cursor:pointer;opacity:0;transition:opacity .15s;z-index:var(--z-local-2)}.pattern-type-grid-tile:hover .pattern-type-grid-tile-edit-btn,.pattern-type-grid-tile:focus-within .pattern-type-grid-tile-edit-btn{opacity:1}.pattern-type-grid-tile-edit-btn:hover{background:var(--color-control-bg-hover)}.pce-root{height:100%;overflow:hidden;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg)}.pce-root:focus-within{border-color:var(--color-focus-ring);box-shadow:0 0 0 2px color-mix(in oklch,var(--color-focus-ring) 40%,transparent)}.pce-error-gutter{width:var(--spacing-sp-lg);padding:0 var(--spacing-sp-2xs)}.pce-gutter-error-spacer{display:inline-block;width:var(--spacing-sp-sm);height:var(--spacing-sp-sm);visibility:hidden}.pce-gutter-error-icon{display:inline-flex;align-items:center;justify-content:center;width:var(--spacing-sp-sm);height:var(--spacing-sp-sm);border-radius:50%;background:var(--color-danger);color:var(--color-bg);font-size:var(--font-size-2xs);font-weight:700;line-height:1;cursor:help;-webkit-user-select:none;user-select:none}.pce-gutter-error-tooltip{position:fixed;z-index:var(--z-color-picker);background:var(--color-tooltip-bg);color:var(--color-tooltip-fg);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);max-width:22.5rem;line-height:1.5;white-space:pre-wrap;pointer-events:none;box-shadow:var(--shadow-dropdown)}.uped-dialog{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:96vw;height:96vh;max-width:none;max-height:none;display:flex;flex-direction:column;box-shadow:var(--shadow-modal-lg);overflow:hidden}.uped-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-faint);flex-shrink:0}.uped-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-fg)}.uped-close{padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);font-size:var(--font-size-base);line-height:1}.uped-body{display:flex;flex:1;min-height:0;overflow:hidden}.uped-left{display:flex;flex-direction:column;flex:1;min-width:0;border-right:1px solid var(--color-border-faint);overflow:hidden}.uped-fields{padding:var(--spacing-sp-md) var(--spacing-sp-lg);display:flex;flex-direction:column;gap:var(--spacing-sp-sm);flex-shrink:0;border-bottom:1px solid var(--color-border-faint)}.uped-editor{flex:1;min-height:0;overflow:hidden}.uped-right{width:clamp(360px,32vw,540px);flex-shrink:0;display:flex;flex-direction:column;padding:var(--spacing-sp-md);gap:var(--spacing-sp-md);overflow-y:auto}.uped-field{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs)}.uped-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-fg-subtle)}.uped-label-optional{font-weight:400;color:var(--color-fg-faint)}.uped-input,.uped-textarea{padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-sm);outline:none;width:100%;box-sizing:border-box}.uped-input:focus,.uped-textarea:focus{border-color:var(--color-border-focus)}.uped-input--error{border-color:var(--color-danger-border)!important}.uped-textarea{resize:vertical;font-family:inherit}.uped-field-error{font-size:var(--font-size-xs);color:var(--color-danger)}.uped-preview-section{display:flex;flex-direction:column;gap:var(--spacing-sp-xs)}.uped-preview-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-fg-subtle)}.uped-preview-wrap{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--color-preview-bg)}.uped-preview-canvas{display:block;width:100%;height:auto}@media(max-width:960px){.uped-body{flex-direction:column}.uped-left{border-right:none;border-bottom:1px solid var(--color-border-faint)}.uped-right{width:100%}}.uped-preview-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-overlay-modal);font-size:var(--font-size-xs);color:var(--color-fg-subtle)}.uped-error-panel{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);padding:var(--spacing-sp-sm);display:flex;flex-direction:column;gap:var(--spacing-sp-3xs)}.uped-error-item{font-size:var(--font-size-xs);color:var(--color-danger);line-height:1.5}.uped-error-loc{font-weight:600;margin-right:var(--spacing-sp-3xs)}.uped-save-error{background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md);padding:var(--spacing-sp-sm);font-size:var(--font-size-xs);color:var(--color-danger)}.uped-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-sm) var(--spacing-sp-lg);border-top:1px solid var(--color-border-faint);flex-shrink:0}.uped-footer-right,.uped-footer-left{display:flex;gap:var(--spacing-sp-sm);align-items:center}.uped-btn-delete{background:var(--color-danger-bg);color:var(--color-danger);border-color:var(--color-danger-border)}.uped-btn-delete:hover:not(:disabled){background:var(--color-danger-bg-hover);border-color:var(--color-danger-border-hover)}.uped-btn-save{background:var(--color-control-bg-hover)}.uped-btn-save:disabled,.uped-btn-delete:disabled{opacity:.5;cursor:not-allowed}.pattern-type-dialog{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:90vw;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.pattern-type-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-md) var(--spacing-sp-md) 0}.pattern-type-dialog-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg)}.pattern-type-dialog-close{padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);font-size:var(--font-size-base);line-height:1}.pattern-type-dialog-body{padding:var(--spacing-sp-md);overflow-y:auto;flex:1;min-height:0}.pattern-type-dialog .pattern-type-grid{max-height:none;overflow-y:visible;grid-template-columns:repeat(3,1fr)}@media(min-width:700px){.pattern-type-dialog .pattern-type-grid{grid-template-columns:repeat(4,1fr)}}.pattern-type-dialog-section{margin-bottom:var(--spacing-sp-lg)}.pattern-type-dialog-section:last-child{margin-bottom:0}.pattern-type-dialog-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg-faint);margin-bottom:var(--spacing-sp-sm)}.pattern-type-dialog-status{font-size:var(--font-size-sm);color:var(--color-fg-faint);padding:var(--spacing-sp-sm) 0}.pattern-type-dialog-status--error{color:var(--color-danger)}.pattern-type-dialog-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sp-sm)}.pattern-type-dialog-section-header .pattern-type-dialog-section-title{margin-bottom:0}.pattern-type-dialog-create-btn{font-size:var(--font-size-xs);padding:var(--spacing-sp-3xs) var(--spacing-sp-sm)}:root{--step-rail-width: 48px}.step-rail{position:fixed;top:var(--chrome-height-safe);left:env(safe-area-inset-left,0px);bottom:env(safe-area-inset-bottom,0px);width:var(--step-rail-width);z-index:var(--z-rail);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-xs) 0;background:transparent;pointer-events:none}.step-rail-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-glass);color:var(--color-fg-icon);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-dropdown);cursor:pointer;pointer-events:auto;transition:background-color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.step-rail-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover);color:var(--color-fg)}.step-rail-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.step-rail-btn.is-active{background:var(--color-control-bg-hover);border-color:var(--color-accent);color:var(--color-fg)}.step-rail-btn svg{flex-shrink:0}.step-rail-separator{width:20px;height:1px;background:var(--color-border-subtle);flex-shrink:0}@media(max-width:640px){.step-rail-btn{width:44px;height:44px}}.editor-side-panel{position:fixed;top:calc(var(--chrome-height-safe) + var(--spacing-sp-sm));left:calc(env(safe-area-inset-left,0px) + var(--step-rail-width));width:320px;height:auto;max-height:calc(100vh - var(--chrome-height-safe) - env(safe-area-inset-bottom,0px) - var(--spacing-sp-lg));z-index:var(--z-side-panel);display:flex;flex-direction:column;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--color-border);border-radius:0 var(--radius-md) var(--radius-md) 0;transform:translate(-100%);visibility:hidden;pointer-events:none;transition:transform var(--default-transition-duration) var(--default-transition-timing-function),visibility var(--default-transition-duration) var(--default-transition-timing-function)}.editor-side-panel.is-open{transform:translate(0);visibility:visible;pointer-events:auto}.editor-side-panel-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-side-panel-placeholder);background:transparent;cursor:default}.editor-side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-md) var(--spacing-sp-md) var(--spacing-sp-md) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-faint);flex-shrink:0}.editor-side-panel-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-wide);color:var(--color-fg-muted);text-transform:uppercase}.editor-side-panel-close{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:none;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-fg-muted);cursor:pointer;flex-shrink:0;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.editor-side-panel-close:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover);color:var(--color-fg)}.editor-side-panel-close:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.editor-side-panel-body{flex:1;overflow-y:auto;padding:var(--spacing-sp-lg)}.editor-side-panel-muted-message{padding:var(--spacing-sp-md);color:var(--color-fg-muted);font-size:var(--font-size-sm)}.slider-reset-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sp-2xs);border:none;background:none;border-radius:var(--radius-sm);color:var(--color-fg-muted);cursor:pointer;flex-shrink:0}.slider-reset-btn:hover:not(:disabled){background:var(--color-control-bg-hover)}.slider-reset-btn:disabled{opacity:.35;cursor:default}.canvas-settings-panel{display:flex;flex-direction:column;gap:var(--spacing-sp-sm)}.canvas-settings-section{display:flex;flex-direction:column;gap:var(--spacing-sp-xs)}.canvas-settings-section-label{margin:0;padding:0 0 var(--spacing-sp-3xs);font-size:var(--font-size-xs);font-weight:500;color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.04em}.canvas-settings-radiogroup{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs)}.canvas-settings-radio{display:flex;align-items:center;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--color-fg);font-size:var(--font-size-base);text-align:left;cursor:pointer;transition:background-color .12s ease,border-color .12s ease;width:100%}.canvas-settings-radio:hover{background:var(--color-control-bg)}.canvas-settings-radio:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:1px}.canvas-settings-radio.is-active{background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.canvas-settings-radio-dot{width:14px;height:14px;border:2px solid var(--color-fg-muted);border-radius:var(--radius-full);flex:0 0 auto;position:relative}.canvas-settings-radio.is-active .canvas-settings-radio-dot{border-color:var(--color-fg)}.canvas-settings-radio.is-active .canvas-settings-radio-dot:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:var(--radius-full);background:var(--color-fg)}.canvas-settings-radio-label{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs)}.canvas-settings-radio-name{font-size:var(--font-size-base);color:var(--color-fg);line-height:1.1}.canvas-settings-radio-desc{font-size:var(--font-size-xs);color:var(--color-fg-muted);line-height:1.2}.editor-state-banner{position:fixed;top:calc(var(--chrome-height-safe) + var(--spacing-sp-md));left:50%;transform:translate(-50%);z-index:var(--z-banner);display:flex;align-items:center;gap:var(--spacing-sp-md);padding:var(--spacing-sp-sm) var(--spacing-sp-lg);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);white-space:nowrap}@media(max-width:640px){.editor-state-banner{flex-direction:column;align-items:stretch;gap:var(--spacing-sp-sm);white-space:normal;left:calc(env(safe-area-inset-left,0px) + var(--step-rail-width));right:max(var(--spacing-sp-md),env(safe-area-inset-right,0px));transform:none;max-width:none}.editor-state-banner-actions{justify-content:flex-end}}.editor-state-banner-label{font-size:var(--font-size-sm);color:var(--color-fg-muted)}.editor-state-banner-actions{display:flex;gap:var(--spacing-sp-sm)}.editor-state-banner-btn{padding:var(--spacing-sp-xs) var(--spacing-sp-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-control-bg);color:var(--color-fg);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.editor-state-banner-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.editor-state-banner-btn:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.editor-state-banner-btn-primary{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-accent-fg, #fff)}.editor-state-banner-btn-primary:hover{background:var(--color-accent-hover, var(--color-accent));border-color:var(--color-accent-hover, var(--color-accent))}.viewer-canvas-viewport{width:100%;height:100%;overflow:auto;overflow-anchor:none;touch-action:pan-x pan-y;position:relative;display:flex;padding-inline-start:var(--viewer-canvas-padding-inline-start, 0px);padding-inline-end:var(--viewer-canvas-padding-inline-end, 0px);padding-block-start:var(--viewer-canvas-padding-block-start, 0px);padding-block-end:var(--viewer-canvas-padding-block-end, 0px);background:var(--color-bg)}.viewer-canvas-wrapper{position:relative;box-shadow:var(--shadow-canvas);outline:1px solid var(--color-border-subtle);flex:0 0 auto}.viewer-canvas-wrapper canvas{cursor:default;touch-action:none;display:block}.viewer-canvas-viewport--pan,.viewer-canvas-viewport--pan canvas{cursor:grab}.viewer-canvas-viewport--pan-active,.viewer-canvas-viewport--pan-active canvas{cursor:grabbing}.viewer-canvas-viewport--zoom,.viewer-canvas-viewport--zoom canvas{cursor:zoom-in}.viewer-zoom-toolbar{position:absolute;top:var(--spacing-sp-md);left:50%;transform:translate(-50%);z-index:var(--z-canvas-overlay);display:flex;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-dropdown);pointer-events:auto}.viewer-zoom-toolbar__btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--color-fg-icon);cursor:pointer;transition:background-color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.viewer-zoom-toolbar__btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover);color:var(--color-fg)}.viewer-zoom-toolbar__btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.viewer-zoom-toolbar__btn--active{background:var(--color-control-bg-hover);border-color:var(--color-border-focus);color:var(--color-fg)}.viewer-zoom-toolbar__btn--active:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-focus)}.viewer-zoom-toolbar__btn svg{width:16px;height:16px;flex-shrink:0}.viewer-zoom-toolbar__pct{min-width:3.5ch;text-align:center;font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;color:var(--color-fg-muted);-webkit-user-select:none;user-select:none;line-height:1}.viewer-zoom-toolbar__sep{width:1px;height:16px;background:var(--color-border-subtle);flex-shrink:0}@media(max-width:640px){.viewer-zoom-toolbar__btn{width:36px;height:36px}}.next-canvas-size-hint{position:absolute;pointer-events:none;box-sizing:border-box;outline:2px dashed rgba(255,255,255,.85);outline-offset:-1px;box-shadow:0 0 0 1px #00000059,inset 0 0 0 1px #00000059;background:#ffffff0a}.next-canvas-size-hint-label{position:absolute;bottom:0;right:0;transform:translateY(100%);margin-top:4px;padding:2px 5px;background:#000000a6;color:#fffffff2;font-size:10px;font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:.02em;border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;text-shadow:none}.enlarge-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:var(--z-toast);animation:popover-fade-in .15s ease-out}.enlarge-content{position:relative;display:flex;align-items:center;max-width:90vw;max-height:85vh}.enlarge-image{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:4px;box-shadow:var(--shadow-modal)}.enlarge-nav{position:absolute;top:50%;transform:translateY(-50%);background:var(--color-overlay-backdrop);border:1px solid var(--color-border-hover);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--color-fg);font-size:24px;cursor:pointer;transition:background .15s;z-index:var(--z-local-1)}.enlarge-nav:hover{background:var(--color-surface-glass)}.enlarge-nav-prev{left:-56px}.enlarge-nav-next{right:-56px}.enlarge-footer{display:flex;gap:12px;align-items:center;margin-top:12px;color:var(--color-fg-muted);font-size:13px}.enlarge-counter{font-variant-numeric:tabular-nums;color:var(--color-fg-faint)}.enlarge-filename{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:400px}.user-page-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:popover-fade-in .15s ease-out}.user-page{background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:92%;max-width:760px;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.user-page-header{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid var(--color-border-subtle)}.user-page-photo-section{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}.user-page-photo{width:56px;height:56px;border-radius:50%;overflow:hidden;cursor:pointer;background:var(--color-control-bg);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-border);transition:border-color .15s}.user-page-photo:hover{border-color:var(--color-border-focus)}.user-page-photo-img{width:100%;height:100%;object-fit:cover}.user-page-photo-placeholder{font-size:20px;font-weight:600;color:var(--color-fg-muted)}.user-page-photo-remove{background:none;border:none;color:var(--color-fg-faint);font-size:10px;cursor:pointer;padding:0}.user-page-photo-remove:hover{color:var(--color-danger)}.user-page-info{flex:1;min-width:0}.user-page-nickname{display:block;background:none;border:none;color:var(--color-fg);font-size:18px;font-weight:600;cursor:pointer;padding:2px 0;text-align:left;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-page-nickname:hover{color:var(--color-fg)}.user-page-nickname-input{font-size:18px;font-weight:600;padding:2px 6px;width:100%}.user-page-email{font-size:12px;color:var(--color-fg-faint);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-page-close{flex-shrink:0;align-self:flex-start}.user-page-tabs{display:flex;border-bottom:1px solid var(--color-border-subtle);padding:0 24px}.user-page-tab{padding:10px 20px;background:none;border:none;border-bottom:2px solid transparent;color:var(--color-fg-faint);font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.user-page-tab:hover{color:var(--color-fg-muted)}.user-page-tab.active{color:var(--color-fg);border-bottom-color:var(--color-fg-muted)}.user-page-content{flex:1;overflow-y:auto;padding:20px 24px}.user-page-files-actions{margin-bottom:12px}.user-page-dustbox{margin-top:20px;border-top:1px solid var(--color-border-subtle);padding-top:8px}.user-page-dustbox-toggle{display:block;width:100%;background:none;border:none;color:var(--color-fg-faint);font-size:12px;cursor:pointer;padding:6px 0;text-align:left;transition:color .15s}.user-page-dustbox-toggle:hover{color:var(--color-fg-muted)}.user-page-dustbox-content{background:var(--color-control-bg);border-radius:8px;padding:8px;margin-top:4px}.user-page-dustbox-list{display:flex;flex-direction:column;gap:4px}.user-page-dustbox-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);font-size:12px}.user-page-dustbox-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-fg-subtle)}.user-page-dustbox-item-meta{color:var(--color-fg-faint);font-size:10px;flex-shrink:0}.user-page-dustbox-restore{font-size:10px;padding:2px 8px;flex-shrink:0}.user-page-dustbox-perm-delete{font-size:10px;padding:2px 8px;flex-shrink:0;color:var(--color-danger)}.user-page-dustbox-perm-delete:hover{color:var(--color-danger-hover)}@media(max-width:640px){.user-page{position:absolute;top:env(safe-area-inset-top,0px);right:env(safe-area-inset-right,0px);bottom:env(safe-area-inset-bottom,0px);left:env(safe-area-inset-left,0px);width:auto;max-width:none;height:auto;max-height:none;border-radius:0;border:none;box-shadow:none}.user-page-header{padding:var(--spacing-sp-lg);gap:var(--spacing-sp-md)}.user-page-tabs{padding:0 var(--spacing-sp-lg)}.user-page-tab{padding:var(--spacing-sp-sm) var(--spacing-sp-md);font-size:var(--font-size-sm)}.user-page-content{padding:var(--spacing-sp-lg)}}.home-page{height:100%;overflow-y:auto;background:var(--color-bg);padding:var(--spacing-sp-xl)}.home-page-hint{margin:0 0 var(--spacing-sp-md) 0;font-size:var(--font-size-sm);color:var(--color-fg-muted)}.home-page-grid{column-count:6;column-gap:var(--spacing-sp-sm);column-fill:balance}@media(max-width:1280px){.home-page-grid{column-count:5}}@media(max-width:1024px){.home-page-grid{column-count:4}}@media(max-width:720px){.home-page-grid{column-count:3}}@media(max-width:480px){.home-page-grid{column-count:2}}.home-page-tile-wrap{break-inside:avoid;margin-bottom:var(--spacing-sp-sm)}.home-page-tile{position:relative;width:100%;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:transform var(--default-transition-duration) var(--default-transition-timing-function)}.home-page-tile:hover{transform:scale(1.02)}.home-page-tile canvas{display:block;width:100%;height:100%}.home-page-tile-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--color-control-bg);color:var(--color-fg-faint);font-size:var(--font-size-sm);pointer-events:none}.home-page-tile-placeholder[data-rendered=true]{display:none}.home-page-tile-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;background:linear-gradient(to top,var(--color-overlay-backdrop) 0%,transparent 50%);opacity:0;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function);pointer-events:none}.home-page-tile:hover .home-page-tile-overlay{opacity:1}.home-page-tile-label{padding:var(--spacing-sp-sm) var(--spacing-sp-md);color:var(--color-fg);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.template-list-page{width:100%;height:100%;overflow-y:auto;padding:var(--spacing-sp-2xl) var(--spacing-sp-xl)}.template-list-header{margin-bottom:var(--spacing-sp-xl)}.template-list-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg);margin:0 0 var(--spacing-sp-2xs) 0}.template-list-subtitle{font-size:var(--font-size-sm);color:var(--color-fg-muted);margin:0}.template-list-loading,.template-list-empty{text-align:center;padding:var(--spacing-sp-2xl) 0;color:var(--color-fg-muted);font-size:var(--font-size-sm)}.template-list-empty-hint{color:var(--color-fg-subtle);font-size:var(--font-size-xs);margin-top:var(--spacing-sp-sm)}.template-list-tab-bar{display:flex;gap:var(--spacing-sp-2xs);margin-bottom:var(--spacing-sp-lg);border-bottom:1px solid var(--color-border);padding-bottom:0}.template-list-tab{padding:var(--spacing-sp-xs) var(--spacing-sp-md);border:none;border-bottom:2px solid transparent;background:transparent;color:var(--color-fg-subtle);font-size:var(--font-size-sm);font:inherit;cursor:pointer;margin-bottom:-1px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.template-list-tab:hover{color:var(--color-fg-muted)}.template-list-tab.active{color:var(--color-fg);border-bottom-color:var(--color-fg)}.template-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sp-lg)}.template-list-card{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-control-bg);cursor:pointer;overflow:hidden;padding:0;font:inherit;color:inherit;text-align:left;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.template-list-card:hover{border-color:var(--color-border-hover);background:var(--color-control-bg-hover)}.template-list-card-preview{width:100%;aspect-ratio:1200 / 630;background:var(--color-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.template-list-card-img{width:100%;height:100%;object-fit:cover}.template-list-card-placeholder{color:var(--color-fg-faint)}.template-list-card-info{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs);padding:var(--spacing-sp-sm)}.template-list-card-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-list-card-fields{font-size:var(--font-size-2xs);color:var(--color-fg-subtle)}.template-list-load-more{display:flex;justify-content:center;padding:var(--spacing-sp-xl) 0}.template-list-load-more-btn{padding:var(--spacing-sp-sm) var(--spacing-sp-xl);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function)}.template-list-load-more-btn:hover:not(:disabled){background:var(--color-control-bg-hover)}.template-list-load-more-btn:disabled{opacity:.5;cursor:default}.template-card{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-control-bg);cursor:pointer;overflow:hidden;padding:0;font:inherit;color:inherit;text-align:left;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.template-card:hover{border-color:var(--color-border-hover);background:var(--color-control-bg-hover)}.template-card-preview{width:100%;aspect-ratio:1200 / 630;background:var(--color-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}.template-card-img{width:100%;height:100%;object-fit:cover}.template-card-placeholder{color:var(--color-fg-faint)}.template-card-info{display:flex;flex-direction:column;gap:var(--spacing-sp-3xs);padding:var(--spacing-sp-sm)}.template-card-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-card-owner{background:none;border:none;padding:0;font:inherit;font-size:var(--font-size-xs);color:var(--color-fg-subtle);cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--default-transition-duration) var(--default-transition-timing-function)}.template-card-owner:hover{color:var(--color-fg-muted)}.template-card-stats{display:flex;gap:var(--spacing-sp-sm)}.template-card-stat{display:flex;align-items:center;gap:var(--spacing-sp-3xs);font-size:var(--font-size-2xs);color:var(--color-fg-faint)}.template-card-skeleton{cursor:default;pointer-events:none}.template-card-skeleton-preview{background:var(--color-border-subtle);animation:skeleton-pulse 1.5s ease-in-out infinite}.template-card-skeleton-line{border-radius:var(--radius-sm);background:var(--color-border-subtle);animation:skeleton-pulse 1.5s ease-in-out infinite}.template-card-skeleton-name{height:12px;width:70%}.template-card-skeleton-owner{height:10px;width:45%;animation-delay:.1s}.template-card-skeleton-stats{height:10px;width:55%;animation-delay:.2s}.gallery-page{width:100%;height:100%;overflow-y:auto;padding:var(--spacing-sp-2xl) var(--spacing-sp-xl)}.gallery-page-header{margin-bottom:var(--spacing-sp-xl)}.gallery-page-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg);margin:0 0 var(--spacing-sp-2xs) 0}.gallery-page-subtitle{font-size:var(--font-size-sm);color:var(--color-fg-muted);margin:0}.gallery-page-toolbar{display:flex;gap:var(--spacing-sp-xs);margin-bottom:var(--spacing-sp-xl);flex-wrap:wrap}.gallery-sort-btn{padding:var(--spacing-sp-xs) var(--spacing-sp-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);cursor:pointer;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.gallery-sort-btn:hover{border-color:var(--color-border-hover);background:var(--color-control-bg-hover);color:var(--color-fg)}.gallery-sort-btn-active{border-color:var(--color-border-focus);background:var(--color-control-bg-hover);color:var(--color-fg)}.gallery-page-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--spacing-sp-lg)}.gallery-page-empty{text-align:center;padding:var(--spacing-sp-2xl) 0;color:var(--color-fg-muted);font-size:var(--font-size-sm)}.gallery-page-empty-hint{color:var(--color-fg-subtle);font-size:var(--font-size-xs);margin-top:var(--spacing-sp-sm)}.gallery-page-load-more{display:flex;justify-content:center;padding:var(--spacing-sp-xl) 0}.gallery-page-load-more-btn{padding:var(--spacing-sp-sm) var(--spacing-sp-xl);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function)}.gallery-page-load-more-btn:hover:not(:disabled){background:var(--color-control-bg-hover)}.gallery-page-load-more-btn:disabled{opacity:.5;cursor:default}.template-detail-page{width:100%;height:100%;overflow-y:auto;padding:var(--spacing-sp-2xl) var(--spacing-sp-xl);max-width:900px;margin:0 auto}.template-detail-back{margin-bottom:var(--spacing-sp-lg)}.template-detail-back-btn{display:inline-flex;align-items:center;gap:var(--spacing-sp-xs);background:none;border:none;padding:var(--spacing-sp-xs) 0;color:var(--color-fg-muted);font-size:var(--font-size-sm);cursor:pointer;transition:color var(--default-transition-duration) var(--default-transition-timing-function)}.template-detail-back-btn:hover{color:var(--color-fg)}.template-detail-hero{width:100%;aspect-ratio:1200 / 630;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-control-bg);margin-bottom:var(--spacing-sp-xl)}.template-detail-hero-img{width:100%;height:100%;object-fit:cover}.template-detail-hero-placeholder{width:100%;height:100%;background:var(--color-border-subtle);animation:skeleton-pulse 1.5s ease-in-out infinite}.template-detail-body{display:flex;flex-direction:column;gap:var(--spacing-sp-2xl)}.template-detail-info{display:flex;flex-direction:column;gap:var(--spacing-sp-md)}.template-detail-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg);margin:0}.template-detail-description{font-size:var(--font-size-sm);color:var(--color-fg-muted);margin:0;line-height:1.6}.template-detail-meta{display:flex;align-items:center;gap:var(--spacing-sp-lg);flex-wrap:wrap}.template-detail-owner{background:none;border:none;padding:0;font:inherit;font-size:var(--font-size-sm);color:var(--color-fg-subtle);cursor:pointer;transition:color var(--default-transition-duration) var(--default-transition-timing-function)}.template-detail-owner:hover{color:var(--color-fg-muted)}.template-detail-stats{display:flex;gap:var(--spacing-sp-md)}.template-detail-stat{display:flex;align-items:center;gap:var(--spacing-sp-3xs);font-size:var(--font-size-sm);color:var(--color-fg-faint)}.template-detail-use-btn{align-self:flex-start;border-color:var(--color-border-focus);color:var(--color-fg);font-weight:500}.template-detail-samples-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-fg);margin:0 0 var(--spacing-sp-md) 0}.template-detail-samples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-sp-md)}.template-detail-sample{border-radius:var(--radius-md);overflow:hidden;aspect-ratio:1200 / 630;background:var(--color-control-bg)}.template-detail-sample-img{width:100%;height:100%;object-fit:cover}.template-detail-sample-placeholder{width:100%;height:100%;background:var(--color-border-subtle);animation:skeleton-pulse 1.5s ease-in-out infinite}.template-detail-loading,.template-detail-error{text-align:center;padding:var(--spacing-sp-2xl) 0;color:var(--color-fg-muted);font-size:var(--font-size-sm);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sp-lg)}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.composition-card{display:flex;flex-direction:column;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;font:inherit;color:inherit;text-align:left;isolation:isolate;transition:transform var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.composition-card:hover,.composition-card:focus-visible{transform:translateY(calc(-1 * var(--spacing-1px) * 2));border-color:var(--color-border-hover);box-shadow:0 var(--spacing-sp-2xs) var(--spacing-sp-md) #0000002e;outline:none}.composition-card:focus-visible{border-color:var(--color-border-focus)}.composition-card-thumb-wrap{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--color-preview-bg);overflow:hidden}.composition-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm);background:linear-gradient(to bottom,#00000073,#0000 65%);opacity:.85;transition:opacity var(--default-transition-duration) var(--default-transition-timing-function);z-index:var(--z-local-1)}.composition-card:hover .composition-card-overlay,.composition-card:focus-visible .composition-card-overlay{opacity:1}.composition-card-author{pointer-events:auto;display:inline-flex;align-items:center;gap:var(--spacing-sp-xs);background:#0b0b0b99;color:#eee;border:none;border-radius:var(--radius-full);padding:var(--spacing-vsp-2xs) var(--spacing-hsp-sm) var(--spacing-vsp-2xs) var(--spacing-vsp-2xs);font:inherit;font-size:var(--font-size-xs);line-height:1;cursor:pointer;max-width:100%;min-width:0;transition:background var(--default-transition-duration) var(--default-transition-timing-function)}.composition-card-author:hover,.composition-card-author:focus-visible{background:#161616c7;outline:none}.composition-card-author-avatar{width:var(--spacing-sp-lg);height:var(--spacing-sp-lg);border-radius:var(--radius-full);object-fit:cover;display:block;flex-shrink:0;background:var(--color-control-bg)}.composition-card-author-avatar--placeholder{background:#484848}.composition-card-author-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:8em}.composition-card-author-handle{opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:6em}.composition-card-visibility{pointer-events:none;display:inline-flex;align-items:center;font-size:var(--font-size-2xs);font-weight:700;line-height:1;letter-spacing:.04em;text-transform:uppercase;padding:var(--spacing-vsp-2xs) var(--spacing-hsp-sm);border-radius:var(--radius-sm);flex-shrink:0}.composition-card-visibility--public{background:var(--color-success-bg);color:var(--color-success)}.composition-card-visibility--private{background:#0b0b0bb3;color:#eee}.composition-card-meta{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-sm) var(--spacing-sp-md)}.composition-card-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 auto;min-width:0}.composition-card-views{display:inline-flex;align-items:center;gap:var(--spacing-sp-3xs);font-size:var(--font-size-xs);color:var(--color-fg-faint);flex-shrink:0}.composition-card-views-icon{width:var(--spacing-sp-md);height:var(--spacing-sp-md);flex-shrink:0}.composition-card-views-value{font-variant-numeric:tabular-nums;line-height:1}@media(prefers-reduced-motion:reduce){.composition-card,.composition-card-overlay,.composition-card-author{transition:none}.composition-card:hover,.composition-card:focus-visible{transform:none}}.feed-status-message{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-vsp-xs);padding:var(--spacing-sp-2xl) var(--spacing-sp-lg);text-align:center}.feed-status-message-icon{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:var(--radius-full);margin-bottom:var(--spacing-vsp-xs)}.feed-status-message--error .feed-status-message-icon{color:var(--color-danger);background:var(--color-danger-bg)}.feed-status-message--empty .feed-status-message-icon{color:var(--color-fg-subtle);background:var(--color-control-bg)}.feed-status-message-title{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-fg)}.feed-status-message--error .feed-status-message-title{color:var(--color-danger)}.feed-status-message-body{margin:0;font-size:var(--font-size-sm);color:var(--color-fg-muted);max-width:40ch;line-height:1.5}.trending-page{display:flex;flex-direction:column;height:100%;overflow-y:auto}.trending-page-window-bar{position:sticky;top:0;z-index:var(--z-toolbar);display:flex;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm) var(--spacing-sp-xl);background:var(--color-bg);border-bottom:1px solid var(--color-border-subtle)}.trending-page-pill{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--spacing-vsp-xs) var(--spacing-hsp-md);font:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-fg-muted);background:transparent;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.trending-page-pill:hover{color:var(--color-fg);background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.trending-page-pill:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.trending-page-pill--active{background:var(--color-accent);color:var(--color-fg-on-accent);border-color:var(--color-accent);font-weight:var(--font-weight-semibold)}.trending-page-pill--active:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-fg-on-accent)}.trending-page-grid-area{flex:1;padding:var(--spacing-sp-xl)}.trending-page-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sp-lg)}@media(max-width:1100px){.trending-page-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.trending-page-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.trending-page-grid{grid-template-columns:1fr}}.trending-page-status{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sp-2xl);color:var(--color-fg-muted);font-size:var(--font-size-base);text-align:center}.trending-page-load-more{display:flex;justify-content:center;padding:var(--spacing-sp-xl) 0}.trending-page-load-more-btn{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-vsp-sm) var(--spacing-hsp-xl);font:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-fg);background:var(--color-control-bg);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.trending-page-load-more-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.trending-page-load-more-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.trending-page-load-more-btn:disabled{opacity:.5;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.trending-page-pill,.trending-page-load-more-btn{transition:none}}.mine-page{display:flex;flex-direction:column;height:100%;overflow-y:auto}.mine-page--anon,.mine-page--loading{align-items:center;justify-content:center}.mine-page-sign-in{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sp-md);max-width:360px;text-align:center;padding:var(--spacing-sp-xl)}.mine-page-sign-in-text{margin:0;color:var(--color-fg-muted);font-size:var(--font-size-base);line-height:1.5}.mine-page-sign-in-btn{min-width:120px}.mine-page-filter-bar{position:sticky;top:0;z-index:var(--z-toolbar);display:flex;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm) var(--spacing-sp-xl);background:var(--color-bg);border-bottom:1px solid var(--color-border-subtle)}.mine-page-pill{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--spacing-vsp-xs) var(--spacing-hsp-md);font:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-fg-muted);background:transparent;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.mine-page-pill:hover{color:var(--color-fg);background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.mine-page-pill:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.mine-page-pill--active{background:var(--color-accent);color:var(--color-fg-on-accent);border-color:var(--color-accent);font-weight:var(--font-weight-semibold)}.mine-page-pill--active:hover{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-fg-on-accent)}.mine-page-grid-area{flex:1;padding:var(--spacing-sp-xl)}.mine-page-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sp-lg)}@media(max-width:1100px){.mine-page-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:760px){.mine-page-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:480px){.mine-page-grid{grid-template-columns:1fr}}.mine-page-status{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sp-2xl);color:var(--color-fg-muted);font-size:var(--font-size-base);text-align:center}.mine-page-status--error{color:var(--color-error)}.mine-page-empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sp-lg);padding:var(--spacing-sp-2xl);text-align:center}.mine-page-empty-text{margin:0;color:var(--color-fg-muted);font-size:var(--font-size-base);line-height:1.5}.mine-page-empty-cta{text-decoration:none}.mine-page-load-more{display:flex;justify-content:center;padding:var(--spacing-sp-xl) 0}.mine-page-load-more-btn{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-vsp-sm) var(--spacing-hsp-xl);font:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-fg);background:var(--color-control-bg);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.mine-page-load-more-btn:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.mine-page-load-more-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.mine-page-load-more-btn:disabled{opacity:.5;cursor:not-allowed}@media(prefers-reduced-motion:reduce){.mine-page-pill,.mine-page-load-more-btn{transition:none}}.tags-page,.tag-detail-page{display:flex;flex-direction:column;gap:var(--spacing-vsp-xl);padding:var(--spacing-sp-2xl);max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.tags-page-header,.tag-detail-page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sp-md)}.tags-page-title,.tag-detail-page-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-fg);letter-spacing:var(--tracking-tight);margin:0}.tag-detail-page-subtitle{font-size:var(--font-size-base);color:var(--color-fg-muted);margin:0}.tags-sort-toggle{display:flex;gap:var(--spacing-hsp-xs);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-3xs)}.tags-sort-toggle-btn{padding:var(--spacing-sp-2xs) var(--spacing-hsp-md);border:none;background:transparent;color:var(--color-fg-muted);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.tags-sort-toggle-btn:hover{color:var(--color-fg);background:var(--color-control-bg-hover)}.tags-sort-toggle-btn[aria-pressed=true]{background:var(--color-accent);color:var(--color-fg)}.tags-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-sp-sm);list-style:none;padding:0;margin:0}.tags-cloud>li{display:contents}.tag-chip{display:inline-flex;align-items:center;gap:var(--spacing-hsp-xs);padding:var(--spacing-sp-2xs) var(--spacing-hsp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-fg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:none;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.tag-chip:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover);color:var(--color-fg)}.tag-chip:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.tag-chip-name{color:var(--color-accent)}.tag-chip-count{font-size:var(--font-size-xs);color:var(--color-fg-subtle);background:var(--color-border);border-radius:var(--radius-full);padding:0 var(--spacing-hsp-xs);min-width:var(--spacing-sp-lg);text-align:center;line-height:var(--font-size-lg)}.tag-detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sp-md)}@media(max-width:1024px){.tag-detail-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:640px){.tag-detail-grid{grid-template-columns:repeat(2,1fr)}.tags-page,.tag-detail-page{padding:var(--spacing-sp-lg)}}.tags-page-loading,.tag-detail-page-loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sp-2xl);color:var(--color-fg-muted);font-size:var(--font-size-base);gap:var(--spacing-hsp-sm)}.tags-page-empty,.tag-detail-page-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-sp-2xl);color:var(--color-fg-muted);font-size:var(--font-size-base);text-align:center;gap:var(--spacing-vsp-sm)}.tags-page-error,.tag-detail-page-error{display:flex;align-items:center;justify-content:center;padding:var(--spacing-sp-2xl);color:var(--color-danger);font-size:var(--font-size-base);text-align:center}.shortcut-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.shortcut-panel{background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sp-xl);max-width:400px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-modal)}.shortcut-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sp-lg)}.shortcut-panel-title{font-size:var(--font-size-lg);font-weight:600;margin:0}.shortcut-panel-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--color-fg-muted);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.shortcut-panel-close:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.shortcut-panel-search{margin-bottom:var(--spacing-sp-md)}.shortcut-panel-search-input{width:100%;box-sizing:border-box;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg);font-size:var(--font-size-sm);font-family:inherit;padding:var(--spacing-sp-xs) var(--spacing-sp-sm);outline:none;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function)}.shortcut-panel-search-input::placeholder{color:var(--color-fg-faint)}.shortcut-panel-search-input:focus{border-color:var(--color-accent, var(--color-border-focus, var(--color-fg-muted)))}.shortcut-panel-body{overflow-y:auto;flex:1;min-height:0}.shortcut-panel-empty{font-size:var(--font-size-sm);color:var(--color-fg-faint);margin:0;padding:var(--spacing-sp-sm) 0}.shortcut-panel-section{margin-bottom:var(--spacing-sp-md)}.shortcut-panel-section:last-child{margin-bottom:0}.shortcut-panel-section-title{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-faint);margin:0 0 var(--spacing-sp-sm)}.shortcut-panel-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-2xs) 0}.shortcut-panel-action{font-size:var(--font-size-sm);color:var(--color-fg)}.shortcut-panel-key{font-size:var(--font-size-xs);font-family:inherit;padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg-muted);min-width:28px;text-align:center}.account-setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-onboarding)}.account-setup-card{background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sp-2xl);max-width:480px;width:90%;box-shadow:var(--shadow-modal)}.account-setup-header{margin-bottom:var(--spacing-sp-xl)}.account-setup-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-fg);margin:0 0 var(--spacing-sp-sm)}.account-setup-subtitle{font-size:var(--font-size-sm);color:var(--color-fg-subtle);margin:0;line-height:1.5}.account-setup-form{display:flex;flex-direction:column;gap:var(--spacing-sp-lg)}.account-setup-field{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.account-setup-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle)}.account-setup-required{color:var(--color-danger)}.account-setup-optional{color:var(--color-fg-faint);font-weight:400;text-transform:none;letter-spacing:0;font-size:var(--font-size-xs)}.account-setup-input-wrapper{position:relative}.account-setup-input{width:100%;padding:var(--spacing-sp-sm) var(--spacing-sp-md);padding-right:36px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);outline:none;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function);box-sizing:border-box}.account-setup-input:focus{border-color:var(--color-border-focus)}.account-setup-input--error{border-color:var(--color-danger)}.account-setup-input--valid{border-color:var(--color-success)}.account-setup-status-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:18px;height:18px}.account-setup-spinner{width:14px;height:14px;border:2px solid var(--color-border);border-top-color:var(--color-fg-subtle);border-radius:50%;animation:account-setup-spin .6s linear infinite}@keyframes account-setup-spin{to{transform:rotate(360deg)}}.account-setup-icon{width:16px;height:16px}.account-setup-icon--success{color:var(--color-success)}.account-setup-icon--error{color:var(--color-danger)}.account-setup-hint{font-size:var(--font-size-xs);color:var(--color-fg-faint);margin:0;line-height:1.4}.account-setup-validation-msg{min-height:16px;font-size:var(--font-size-xs)}.account-setup-error{color:var(--color-danger)}.account-setup-success{color:var(--color-success)}.account-setup-textarea{width:100%;padding:var(--spacing-sp-sm) var(--spacing-sp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);outline:none;resize:vertical;font-family:inherit;line-height:1.5;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function);box-sizing:border-box}.account-setup-textarea:focus{border-color:var(--color-border-focus)}.account-setup-submit-error{font-size:var(--font-size-sm);color:var(--color-danger);margin:0}.account-setup-submit{width:100%;padding:var(--spacing-sp-sm) var(--spacing-sp-lg);background:var(--color-control-bg-hover);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),opacity var(--default-transition-duration) var(--default-transition-timing-function)}.account-setup-submit:not(:disabled):hover{background:var(--color-border-focus)}.account-setup-submit:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.account-setup-submit:disabled{opacity:.4;cursor:not-allowed}.tpd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal)}.tpd-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);z-index:var(--z-local-1)}.tpd-panel{position:absolute;inset:var(--spacing-sp-lg);z-index:var(--z-local-2);display:flex;flex-direction:column;background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal-lg);overflow:hidden;outline:none}.tpd-title-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.tpd-close-btn{position:absolute;top:var(--spacing-sp-md);right:var(--spacing-sp-md);z-index:var(--z-local-1);width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);color:var(--color-fg-muted);font-size:var(--font-size-base);cursor:pointer;transition:background .1s,color .1s}.tpd-close-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.tpd-close-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.tpd-body{flex:1 1 auto;display:flex;flex-direction:column;padding:var(--spacing-sp-lg);min-height:0;overflow:hidden}.tab-preview-grid{flex:1 1 auto;display:grid;gap:var(--spacing-sp-md);min-height:0}.tab-preview-grid--two{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.tab-preview-grid--quad{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.tab-preview-grid--many{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-auto-rows:minmax(180px,1fr);overflow-y:auto;align-content:start;max-height:100%}.tab-preview-tile{display:flex;flex-direction:column;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;outline:none;transition:border-color .1s,box-shadow .1s,background .1s;min-height:0;overflow:hidden;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;font:inherit;text-align:left;width:100%}.tab-preview-tile:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-canvas)}.tab-preview-tile:focus-visible{border-color:var(--color-border-focus);box-shadow:0 0 0 2px var(--color-focus-ring)}.tab-preview-tile--active{border-color:var(--color-border-focus);box-shadow:0 0 0 1px var(--color-border-focus)}.tab-preview-tile__thumb{flex:1 1 auto;display:flex;align-items:center;justify-content:center;background:var(--color-surface-glass);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);overflow:hidden;min-height:0}.tab-preview-tile__thumb img{width:100%;height:100%;object-fit:contain}.tab-preview-tile__thumb-placeholder{font-size:var(--font-size-sm);color:var(--color-fg-muted);padding:var(--spacing-sp-sm);text-align:center;word-break:break-word}.tab-preview-tile__caption{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-xs);flex:0 0 auto}.tab-preview-tile__name{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-sm);color:var(--color-fg)}.tab-preview-tile__badge{flex:0 0 auto;font-size:var(--font-size-2xs);color:var(--color-fg-on-accent);background:var(--color-border-focus);padding:var(--spacing-vsp-2xs) var(--spacing-hsp-sm);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em}.tpd-tiles{display:flex;flex-wrap:wrap;gap:var(--spacing-sp-md);align-items:stretch;justify-content:center;width:100%}.tpd-tile{display:flex;flex-direction:column;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);cursor:pointer;font:inherit;text-align:left}.tpd-tile:hover{background:var(--color-control-bg-hover)}.tpd-tile:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.tpd-tile-thumb{display:block;width:100%;height:auto;background:var(--color-surface-muted, var(--color-surface));border-radius:var(--radius-sm)}.tpd-tile-label{font-size:var(--font-size-sm);color:var(--color-fg-muted)}.color-schemes-import-prompt{max-width:520px}.color-schemes-import-actions{justify-content:space-between;gap:8px;flex-wrap:wrap}.color-picker-oklch{position:fixed;z-index:var(--z-color-picker);width:320px;padding:var(--spacing-sp-md);background:var(--color-surface-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown);display:flex;flex-direction:column;gap:var(--spacing-sp-sm)}.color-picker-oklch[data-mode-shell=expanded]{width:520px;padding:var(--spacing-sp-lg);gap:var(--spacing-sp-md)}.color-picker-oklch-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-sm)}.color-picker-oklch-drag-handle{cursor:grab;color:var(--color-fg-subtle);font-size:var(--font-size-sm);line-height:1;padding:var(--spacing-sp-3xs);border-radius:var(--radius-xs);-webkit-user-select:none;user-select:none;touch-action:none;flex-shrink:0}.color-picker-oklch-drag-handle:hover{color:var(--color-fg)}.color-picker-oklch-drag-handle:active{cursor:grabbing}.color-picker-oklch-label{font-size:var(--font-size-xs);color:var(--color-fg-subtle);text-transform:uppercase;letter-spacing:.06em}.color-picker-oklch-mode-toggle{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-full);padding:2px;background:var(--color-control-bg)}.color-picker-oklch-mode-btn{font-size:var(--font-size-xs);font-weight:600;padding:var(--spacing-sp-3xs) var(--spacing-sp-sm);border:0;background:transparent;color:var(--color-fg-subtle);border-radius:var(--radius-full);cursor:pointer;min-width:44px}.color-picker-oklch-mode-btn[aria-pressed=true]{background:var(--color-control-bg-hover);color:var(--color-fg)}.color-picker-oklch-mode-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.color-picker-oklch-expand-btn{border:1px solid var(--color-border);background:var(--color-control-bg);color:var(--color-fg-subtle);border-radius:var(--radius-sm);padding:var(--spacing-sp-3xs) var(--spacing-sp-xs);font-size:var(--font-size-xs);cursor:pointer}.color-picker-oklch-expand-btn:hover{border-color:var(--color-border-hover);color:var(--color-fg)}.color-picker-oklch-expand-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.color-picker-oklch-top-row{display:flex;align-items:center;gap:var(--spacing-sp-sm)}.color-picker-oklch-preview{position:relative;width:40px;height:40px;border-radius:var(--radius-sm);border:1px solid var(--color-border-hover);overflow:hidden;flex-shrink:0}.color-picker-oklch[data-mode-shell=expanded] .color-picker-oklch-preview{width:50px;height:50px}.color-picker-oklch-preview-checkerboard{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-conic-gradient(gray,gray 25%,silver 0%,silver 50%);background-size:10px 10px}.color-picker-oklch-preview-color{position:absolute;top:0;right:0;bottom:0;left:0}.color-picker-oklch-hex-input{font-family:monospace;font-size:var(--font-size-base);flex:1;min-width:0;padding:var(--spacing-sp-2xs) var(--spacing-sp-xs);background:var(--color-control-bg);border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-fg);outline:none}.color-picker-oklch-hex-input:focus{border-color:var(--color-border-focus)}.color-picker-oklch-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--spacing-sp-3xs)}.color-picker-oklch[data-mode-shell=expanded] .color-picker-oklch-grid{grid-template-columns:repeat(12,1fr)}.color-picker-oklch-grid-cell{position:relative;aspect-ratio:1;border:1px solid var(--color-border);border-radius:var(--radius-xs);cursor:pointer;padding:0;outline:none}.color-picker-oklch-grid-cell:hover{border-color:var(--color-border-hover)}.color-picker-oklch-grid-cell:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.color-picker-oklch-grid-cell[aria-selected=true]{border-color:var(--color-border-focus);box-shadow:0 0 0 1px var(--color-border-focus)}.color-picker-oklch-grid-cell[data-oog=true]:after{content:"";position:absolute;top:1px;right:1px;bottom:1px;left:1px;border:1px dashed oklch(98% 0 0 / .4);border-radius:var(--radius-xs);pointer-events:none}.color-picker-oklch-sliders{display:flex;flex-direction:column;gap:var(--spacing-sp-xs)}.color-picker-oklch-slider-row{display:flex;align-items:center;gap:var(--spacing-sp-sm)}.color-picker-oklch-slider-label{font-size:var(--font-size-xs);color:var(--color-fg-subtle);width:1.5rem;flex-shrink:0;text-align:center;font-weight:600}.color-picker-oklch-slider{flex:1;position:relative;height:18px;background:var(--color-control-bg);border-radius:var(--radius-full);cursor:pointer;outline:none}.color-picker-oklch-slider:focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring)}.color-picker-oklch-slider-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-full);pointer-events:none}.color-picker-oklch-slider-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:var(--radius-full);background:var(--color-fg);border:2px solid var(--color-bg);box-shadow:var(--shadow-dropdown);pointer-events:none}.color-picker-oklch-slider-value{font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;color:var(--color-fg);width:3rem;flex-shrink:0;text-align:right}.color-picker-oklch-readout{font-size:var(--font-size-xs);color:var(--color-fg-subtle);font-family:monospace;padding:var(--spacing-sp-2xs) var(--spacing-sp-xs);border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);background:var(--color-control-bg)}.composer-hsla-picker{position:fixed;z-index:var(--z-color-picker);width:320px;padding:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown)}.composer-hsla-top-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.composer-hsla-preview{position:relative;width:48px;height:48px;border-radius:6px;border:1px solid var(--color-border-hover);overflow:hidden;flex-shrink:0}.composer-hsla-preview-checkerboard{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-conic-gradient(gray,gray 25%,silver 0%,silver 50%);background-size:12px 12px}.composer-hsla-preview-color{position:absolute;top:0;right:0;bottom:0;left:0}.composer-hsla-hex-input{font-family:monospace;font-size:1rem;width:8rem;padding:4px 6px;background:var(--color-control-bg);border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);color:var(--color-fg);outline:none}.composer-hsla-hex-input:focus{border-color:var(--color-border-focus)}.composer-hsla-slider-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}.composer-hsla-slider-label{font-size:.875rem;color:var(--color-fg-subtle);width:1rem;flex-shrink:0;text-align:center}.composer-hsla-slider-row input[type=range]{flex:1;height:1.5rem;accent-color:var(--color-focus-ring)}.composer-hsla-slider-value{font-size:.875rem;color:var(--color-fg);width:2.5rem;flex-shrink:0;text-align:right}.composer-hsla-swatch-btn{position:relative;display:block;border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);cursor:pointer;overflow:hidden;padding:0;background:none}.composer-hsla-swatch-btn:hover{border-color:var(--color-border-focus)}.composer-hsla-swatch-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.composer-hsla-swatch-checkerboard{position:absolute;top:0;right:0;bottom:0;left:0;background-image:repeating-conic-gradient(gray,gray 25%,silver 0%,silver 50%);background-size:10px 10px}.composer-hsla-swatch-color{position:absolute;top:0;right:0;bottom:0;left:0}.composer-hsla-palette{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border)}.composer-hsla-palette-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.composer-hsla-palette-label{font-size:.75rem;color:var(--color-fg-subtle);text-transform:uppercase;letter-spacing:.05em}.composer-hsla-palette-add{width:20px;height:20px;display:flex;align-items:center;justify-content:center;padding:0;font-size:1rem;line-height:1;color:var(--color-fg-subtle);background:var(--color-control-bg);border:1px solid var(--color-border-hover);border-radius:var(--radius-sm);cursor:pointer}.composer-hsla-palette-add:hover{color:var(--color-fg);border-color:var(--color-border-focus)}.composer-hsla-palette-swatches{display:flex;flex-wrap:wrap;gap:4px}.composer-hsla-palette-swatch-wrap{position:relative}.composer-hsla-palette-swatch{width:20px;height:20px;border:1px solid var(--color-border-hover);border-radius:50%;cursor:pointer;padding:0}.composer-hsla-palette-swatch:hover{border-color:var(--color-fg-muted);transform:scale(1.1)}.composer-hsla-palette-remove{display:none;position:absolute;top:-4px;right:-4px;width:14px;height:14px;padding:0;font-size:.625rem;line-height:1;color:var(--color-fg);background:var(--color-control-bg-hover);border:1px solid var(--color-border-hover);border-radius:50%;cursor:pointer;align-items:center;justify-content:center}.composer-hsla-palette-swatch-wrap:hover .composer-hsla-palette-remove{display:flex}.composer-hsla-palette-remove:hover{background:var(--color-danger-active);border-color:var(--color-danger-active-border)}.scheme-switcher-popover{position:fixed;bottom:calc(var(--popover-bottom, 0px) + var(--spacing-vsp-xs));left:var(--popover-left, 0px);z-index:var(--z-popover-portaled);min-width:240px;max-width:min(360px,calc(100vw - var(--spacing-hsp-lg) * 2));background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-menu);overflow:hidden}.scheme-switcher-popover__list{list-style:none;margin:0;padding:var(--spacing-vsp-2xs) 0;max-height:280px;overflow-y:auto;scrollbar-width:thin}.scheme-switcher-popover__item{display:flex;align-items:center;gap:var(--spacing-hsp-sm);padding:var(--spacing-vsp-2xs) var(--spacing-hsp-md);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-fg);outline:none;transition:background var(--default-transition-duration) var(--default-transition-timing-function)}.scheme-switcher-popover__item.is-highlight,.scheme-switcher-popover__item:hover,.scheme-switcher-popover__item:focus-visible{background:var(--color-control-bg-hover)}.scheme-switcher-popover__item.is-active{font-weight:var(--font-weight-semibold)}.scheme-switcher-popover__swatches{display:inline-flex;flex:0 0 auto;gap:2px}.scheme-switcher-popover__dot{display:inline-block;width:10px;height:14px;border-radius:var(--radius-xs);border:1px solid var(--color-border-faint)}.scheme-switcher-popover__name{flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scheme-switcher-popover__badge{display:inline-flex;align-items:center;flex:0 0 auto;padding:var(--spacing-vsp-2xs) var(--spacing-hsp-sm);border-radius:var(--radius-full);border:1px solid var(--color-border-faint);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-2xs);font-weight:var(--font-weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;line-height:var(--leading-none)}.scheme-switcher-popover__badge--mine{background:color-mix(in oklch,var(--color-accent) 18%,transparent);border-color:color-mix(in oklch,var(--color-accent) 40%,transparent);color:var(--color-fg)}.scheme-switcher-popover__check{flex:0 0 auto;font-size:var(--font-size-sm);color:var(--color-accent)}.color-bar-action-buttons{display:inline-flex;align-items:center;gap:var(--spacing-hsp-2xs);flex:0 0 auto}.color-bar-action-buttons__btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:30px;height:30px;padding:0;margin:0;background:var(--color-control-bg);border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);color:var(--color-fg-icon);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),opacity var(--default-transition-duration) var(--default-transition-timing-function)}.color-bar-action-buttons__btn:hover:not(:disabled){background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border)}.color-bar-action-buttons__btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.color-bar-action-buttons__btn.is-active,.color-bar-action-buttons__btn[aria-pressed=true]{background:color-mix(in oklch,var(--color-accent) 28%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 60%,var(--color-border));color:var(--color-accent-fg, var(--color-fg))}.color-bar-action-buttons__btn:disabled{cursor:not-allowed;opacity:.35}.color-bar-action-buttons__icon{width:15px;height:15px;display:block}.epfi-dialog{position:fixed;bottom:calc(var(--epfi-bottom, 80px) + var(--spacing-vsp-xs));right:calc(var(--epfi-right, 60px));z-index:var(--z-popover-portaled);width:340px;max-width:calc(100vw - var(--spacing-sp-lg) * 2);display:flex;flex-direction:column;gap:var(--spacing-vsp-sm);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal-lg);padding:var(--spacing-sp-lg);animation:epfi-appear .15s ease-out}@keyframes epfi-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.epfi-dialog__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-hsp-sm)}.epfi-dialog__title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg);margin:0}.epfi-dialog__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);color:var(--color-fg-muted);cursor:pointer;flex-shrink:0;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.epfi-dialog__close:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.epfi-dialog__dropzone{display:flex;align-items:center;justify-content:center;min-height:100px;border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-md);color:var(--color-fg-muted);font-size:var(--font-size-xs);text-align:center;cursor:pointer;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function);position:relative;overflow:hidden;background:var(--color-control-bg)}.epfi-dialog__dropzone:hover,.epfi-dialog__dropzone.is-over{border-color:var(--color-accent);background:var(--color-control-bg-hover);color:var(--color-fg)}.epfi-dialog__dropzone-hint{pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-vsp-2xs)}.epfi-dialog__file-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.epfi-dialog__preview{display:flex;flex-direction:column;gap:var(--spacing-vsp-sm)}.epfi-dialog__img{width:100%;height:120px;object-fit:cover;border-radius:var(--radius-md);display:block}.epfi-dialog__slider-row{display:flex;align-items:center;gap:var(--spacing-hsp-sm)}.epfi-dialog__slider-label{font-size:var(--font-size-xs);color:var(--color-fg-muted);white-space:nowrap;flex-shrink:0}.epfi-dialog__slider{flex:1 1 auto;accent-color:var(--color-accent);cursor:pointer;height:4px}.epfi-dialog__slider-value{font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;color:var(--color-fg);width:2ch;text-align:right;flex-shrink:0}.epfi-dialog__palette{display:flex;gap:var(--spacing-hsp-2xs);flex-wrap:wrap}.epfi-dialog__swatch{width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid var(--color-border-faint);flex-shrink:0}.epfi-dialog__error{font-size:var(--font-size-xs);color:var(--color-error, #ef4444);padding:var(--spacing-vsp-2xs) 0}.epfi-dialog__footer{display:flex;justify-content:flex-end;gap:var(--spacing-hsp-xs)}.epfi-dialog__btn{display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 var(--spacing-hsp-md);font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--color-border-faint);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),opacity var(--default-transition-duration) var(--default-transition-timing-function)}.epfi-dialog__btn--cancel{background:var(--color-control-bg);color:var(--color-fg-muted)}.epfi-dialog__btn--cancel:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.epfi-dialog__btn--apply{background:var(--color-accent);color:var(--color-accent-fg, #fff);border-color:transparent}.epfi-dialog__btn--apply:hover:not(:disabled){opacity:.85}.epfi-dialog__btn--apply:disabled{opacity:.4;cursor:not-allowed}.bottom-palette-strip{display:flex;align-items:center;gap:var(--spacing-hsp-md);width:100%;min-height:80px;flex:0 0 auto;position:relative;z-index:var(--z-rail);padding:var(--spacing-vsp-sm) var(--spacing-hsp-lg) max(var(--spacing-vsp-sm),env(safe-area-inset-bottom,0px));background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--color-border-faint);color:var(--color-fg);font-size:var(--font-size-sm);box-sizing:border-box}.bottom-palette-strip__actions{position:relative;display:flex;align-items:center;gap:var(--spacing-hsp-2xs);flex:0 0 auto}.bottom-palette-strip__picker-trigger{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;margin:0;background:var(--color-control-bg);border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);color:var(--color-fg-icon);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__picker-trigger:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border)}.bottom-palette-strip__picker-trigger:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.bottom-palette-strip__picker-trigger[aria-expanded=true]{background:var(--color-control-bg-hover);border-color:var(--color-border);color:var(--color-fg)}.bottom-palette-strip__picker-icon{width:16px;height:16px;display:block}.bottom-palette-strip__lock{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-sm);border:1px solid var(--color-border-faint);background:var(--color-control-bg);color:var(--color-fg-icon);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__lock:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border)}.bottom-palette-strip__lock:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.bottom-palette-strip__lock.is-locked,.bottom-palette-strip__lock[aria-pressed=true]{background:color-mix(in oklch,var(--color-accent) 28%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 60%,var(--color-border));color:var(--color-accent-fg, var(--color-fg))}.bottom-palette-strip__lock-icon{width:16px;height:16px;display:block}.bottom-palette-strip__pick-controls{display:inline-flex;align-items:center;gap:var(--spacing-hsp-2xs);flex:0 0 auto}.bottom-palette-strip__target-toggle{display:inline-flex;align-items:stretch;border:1px solid var(--color-border-faint);border-radius:var(--radius-md);background:var(--color-control-bg);overflow:hidden;min-height:40px}.bottom-palette-strip__target-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--color-fg-muted);font:inherit;font-weight:var(--font-weight-semibold);font-size:var(--font-size-2xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;min-width:40px;padding:var(--spacing-vsp-2xs) var(--spacing-hsp-sm);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__target-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.bottom-palette-strip__target-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px;position:relative;z-index:var(--z-focus-ring)}.bottom-palette-strip__target-btn.is-active{background:color-mix(in oklch,var(--color-accent) 28%,var(--color-control-bg));color:var(--color-accent-fg, var(--color-fg))}.bottom-palette-strip__target-btn+.bottom-palette-strip__target-btn{border-left:1px solid var(--color-border-faint)}.bottom-palette-strip__swap{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border-faint);background:var(--color-control-bg);color:var(--color-fg-icon);font-size:18px;line-height:1;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__swap:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border)}.bottom-palette-strip__swap:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.bottom-palette-strip__swatches{display:flex;align-items:stretch;gap:var(--spacing-hsp-xs);flex:1 1 auto;min-width:0;overflow-x:auto;scrollbar-width:thin}.bottom-palette-strip__swatch{position:relative;display:flex;align-items:flex-end;justify-content:center;flex:1 1 0;min-width:56px;height:56px;aspect-ratio:1 / 1;padding:var(--spacing-vsp-2xs) var(--spacing-hsp-2xs);border-radius:var(--radius-sm);border:1px solid var(--color-border-faint);box-sizing:border-box}.bottom-palette-strip__swatch--button{-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit;color:inherit;cursor:pointer;min-height:40px;transition:transform var(--default-transition-duration) var(--default-transition-timing-function),box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__swatch--button:hover{transform:translateY(-1px);box-shadow:var(--shadow-strip-hover)}.bottom-palette-strip__swatch--button:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.bottom-palette-strip__swatch--button.is-fg{box-shadow:inset 0 0 0 2px var(--color-accent)}.bottom-palette-strip__swatch--button.is-bg{box-shadow:inset 0 0 0 2px var(--color-fg)}.bottom-palette-strip__swatch--button.is-fg.is-bg{box-shadow:inset 0 0 0 2px var(--color-accent),inset 0 0 0 4px var(--color-fg)}.bottom-palette-strip__swatch--button.is-editing{box-shadow:inset 0 0 0 2px var(--color-info)}.bottom-palette-strip__swatch--button.is-editing.is-fg{box-shadow:inset 0 0 0 2px var(--color-info),inset 0 0 0 4px var(--color-accent)}.bottom-palette-strip__swatch--button.is-editing.is-bg{box-shadow:inset 0 0 0 2px var(--color-info),inset 0 0 0 4px var(--color-fg)}.bottom-palette-strip__swatch--button.is-editing.is-fg.is-bg{box-shadow:inset 0 0 0 2px var(--color-info),inset 0 0 0 4px var(--color-accent),inset 0 0 0 6px var(--color-fg)}.bottom-palette-strip__swatch--button.is-deleting{box-shadow:inset 0 0 0 2px var(--color-danger)}.bottom-palette-strip__swatch--button.is-deleting.is-checked{box-shadow:inset 0 0 0 3px var(--color-danger)}.bottom-palette-strip__swatch--button.is-deleting.is-fg{box-shadow:inset 0 0 0 2px var(--color-danger),inset 0 0 0 4px var(--color-accent)}.bottom-palette-strip__swatch--button.is-deleting.is-bg{box-shadow:inset 0 0 0 2px var(--color-danger),inset 0 0 0 4px var(--color-fg)}.bottom-palette-strip__swatch--button.is-deleting.is-fg.is-bg{box-shadow:inset 0 0 0 2px var(--color-danger),inset 0 0 0 4px var(--color-accent),inset 0 0 0 6px var(--color-fg)}.bottom-palette-strip__swatch-checkbox{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:var(--radius-xs);border:2px solid rgba(255,255,255,.75);background:#00000040;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__swatch-checkbox.is-checked{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.bottom-palette-strip__checkbox-icon{width:11px;height:11px;display:block}.bottom-palette-strip__indicators{position:absolute;top:var(--spacing-vsp-2xs);right:var(--spacing-hsp-2xs);display:inline-flex;gap:2px;pointer-events:none}.bottom-palette-strip__indicator{display:inline-flex;align-items:center;justify-content:center;min-width:18px;padding:1px 4px;border-radius:var(--radius-xs);font-size:var(--font-size-2xs);font-weight:var(--font-weight-bold);letter-spacing:var(--tracking-wide);line-height:var(--leading-none)}.bottom-palette-strip__indicator--fg{background:var(--color-accent);color:var(--color-accent-fg, var(--color-bg))}.bottom-palette-strip__indicator--bg{background:var(--color-fg);color:var(--color-bg)}.bottom-palette-strip__swatch-index{position:absolute;top:var(--spacing-vsp-2xs);left:var(--spacing-hsp-2xs);font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);font-family:var(--font-mono);opacity:.7;line-height:var(--leading-none)}.bottom-palette-strip__swatch-roles{display:flex;flex-wrap:wrap;justify-content:center;gap:2px;max-width:100%}.bottom-palette-strip__role{display:inline-flex;align-items:center;padding:1px var(--spacing-hsp-xs);border-radius:var(--radius-xs);font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--tracking-wide);text-transform:lowercase;line-height:var(--leading-none);white-space:nowrap}.bottom-palette-strip__swatches.is-moving{cursor:move}.bottom-palette-strip__swatch--button.is-movable{cursor:move;box-shadow:inset 0 0 0 2px color-mix(in oklch,var(--color-warning) 55%,transparent)}.bottom-palette-strip__swatch--button.is-drag-source{opacity:.5;transform:translateY(-2px)}.bottom-palette-strip__swatch--button.is-drop-target:hover{box-shadow:inset 0 0 0 3px var(--color-warning)}.bottom-palette-strip__swatch--button.is-randomizing{box-shadow:inset 0 0 0 2px color-mix(in oklch,var(--color-warning) 80%,transparent)}.bottom-palette-strip__swatch--button.is-randomize-locked{box-shadow:inset 0 0 0 2px var(--color-warning)}.bottom-palette-strip__swatch-lock-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;border-radius:inherit;pointer-events:none;background:color-mix(in oklch,currentColor 12%,transparent);color:var(--color-fg);opacity:.85}.bottom-palette-strip__swatch-lock-overlay.is-locked{background:color-mix(in oklch,var(--color-warning) 25%,transparent);color:var(--color-warning);opacity:1}.bottom-palette-strip__swatch-lock-overlay .bottom-palette-strip__lock-icon{width:20px;height:20px}.bottom-palette-strip__edit-launcher{z-index:var(--z-palette-bar)}.bottom-palette-strip__gear{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:40px;height:40px;border-radius:var(--radius-md);border:1px solid var(--color-border-faint);background:var(--color-control-bg);color:var(--color-fg-icon);cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.bottom-palette-strip__gear:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border)}.bottom-palette-strip__gear:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.bottom-palette-strip__gear[aria-pressed=true]{background:color-mix(in oklch,var(--color-accent) 22%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 55%,var(--color-border));color:var(--color-fg)}.bottom-palette-strip__gear-icon{width:20px;height:20px;display:block}.bottom-palette-strip[data-visible=false]{opacity:0;visibility:hidden;pointer-events:none}@media(max-width:640px){.bottom-palette-strip{padding:var(--spacing-vsp-xs) var(--spacing-hsp-sm);gap:var(--spacing-hsp-sm)}.bottom-palette-strip__actions{gap:var(--spacing-hsp-3xs)}.bottom-palette-strip__swatch{min-width:48px;height:48px}.bottom-palette-strip__swatch--button{min-height:40px}}.mode-action-panel{display:flex;flex-direction:column;gap:var(--spacing-sp-md);padding:var(--spacing-sp-md) var(--spacing-sp-lg);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-menu);width:280px;max-width:100%;color:var(--color-fg)}.mode-action-panel__body{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs);font-size:var(--font-size-xs);color:var(--color-fg);line-height:1.4}.mode-action-panel__hint{font-weight:var(--font-weight-semibold);color:var(--color-fg);margin:0}.mode-action-panel__detail{color:var(--color-fg-muted);margin:0}.mode-action-panel__actions{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:var(--spacing-hsp-sm);padding-top:var(--spacing-sp-sm);border-top:1px solid var(--color-border-faint)}.mode-action-panel__btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;height:30px;padding:0 var(--spacing-hsp-md);margin:0;background:var(--color-control-bg);border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);color:var(--color-fg);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.mode-action-panel__btn:hover:not(:disabled){background:var(--color-control-bg-hover);border-color:var(--color-border)}.mode-action-panel__btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.mode-action-panel__btn:disabled,.mode-action-panel__btn.is-disabled{cursor:not-allowed;opacity:.45}.mode-action-panel__btn--primary{background:color-mix(in oklch,var(--color-accent) 20%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 55%,var(--color-border));color:var(--color-accent-fg, var(--color-fg))}.mode-action-panel__btn--primary:hover:not(:disabled){background:color-mix(in oklch,var(--color-accent) 38%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 75%,var(--color-border))}.mode-action-panel__btn--danger{background:var(--color-danger-bg);border-color:var(--color-danger-border);color:var(--color-danger)}.mode-action-panel__btn--danger:hover:not(:disabled){background:var(--color-danger-bg-hover);border-color:var(--color-danger-border-hover, var(--color-danger-border));color:var(--color-danger-hover)}.rp-card{--rp-thumb-size-dual: 14px;--rp-thumb-size-hue: 16px;--rp-track-h-dual: 4px;--rp-track-h-hue: 8px;--rp-row-h: 20px;--rp-thumb-margin-dual: -5px;--rp-thumb-margin-hue: -4px;--rp-fill-h-dual: 4px;--rp-fill-h-hue: 8px;--rp-fill-h-dual-hover: 8px;--rp-fill-h-hue-hover: 12px;display:flex;flex-direction:column;gap:var(--spacing-sp-md);padding:var(--spacing-sp-md) var(--spacing-sp-lg);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-menu);width:360px;max-width:100%;color:var(--color-fg);transition:width var(--default-transition-duration)}.rp-card[data-enabled=false]{width:fit-content}.rp-card[data-enlarged=true]{--rp-thumb-size-dual: 22px;--rp-thumb-size-hue: 26px;--rp-track-h-dual: 8px;--rp-track-h-hue: 12px;--rp-row-h: 32px;--rp-thumb-margin-dual: -7px;--rp-thumb-margin-hue: -7px;--rp-fill-h-dual: 8px;--rp-fill-h-hue: 12px;--rp-fill-h-dual-hover: 14px;--rp-fill-h-hue-hover: 18px;width:720px}.rp-toggle-row{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sp-sm)}.rp-enlarge-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-fg-subtle);cursor:pointer;transition:color var(--default-transition-duration),background var(--default-transition-duration),border-color var(--default-transition-duration);flex-shrink:0}.rp-enlarge-btn:hover{color:var(--color-fg);background:var(--color-control-bg);border-color:var(--color-border)}.rp-enlarge-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.rp-body{display:flex;flex-direction:row;align-items:flex-start;gap:var(--spacing-sp-md)}.rp-left{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-sp-md)}.rp-right{flex:0 0 auto;width:110px;transition:width var(--default-transition-duration)}.rp-card[data-enlarged=true] .rp-right{width:220px}.rp-hue-slider-section{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.rp-hue-ring-wrapper{position:relative;width:100%;aspect-ratio:1}.rp-actions{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:var(--spacing-hsp-sm);padding-top:var(--spacing-sp-sm);border-top:1px solid var(--color-border-faint)}.rp-action-btn{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;height:30px;padding:0 var(--spacing-hsp-md);margin:0;background:var(--color-control-bg);border:1px solid var(--color-border-faint);border-radius:var(--radius-sm);color:var(--color-fg);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);white-space:nowrap;cursor:pointer;transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.rp-action-btn:hover:not(:disabled){background:var(--color-control-bg-hover);border-color:var(--color-border)}.rp-action-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.rp-action-btn--apply{background:color-mix(in oklch,var(--color-accent) 20%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 55%,var(--color-border));color:var(--color-accent-fg, var(--color-fg))}.rp-action-btn--apply:hover:not(:disabled){background:color-mix(in oklch,var(--color-accent) 38%,var(--color-control-bg));border-color:color-mix(in oklch,var(--color-accent) 75%,var(--color-border))}.etp-body{display:flex;flex-direction:column;gap:var(--spacing-sp-md)}.etp-slider-row{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.etp-slider-header{display:flex;align-items:center;justify-content:space-between}.etp-slider-header-right{display:flex;align-items:center;gap:var(--spacing-sp-2xs)}.etp-slider-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle)}.etp-slider-value{font-size:var(--font-size-xs);color:var(--color-fg-faint);font-variant-numeric:tabular-nums;min-width:3ch;text-align:right}.etp-slider-track{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:var(--rp-row-h, 20px);background:transparent;padding:0;margin:0;outline:none;cursor:pointer}.etp-slider-track::-webkit-slider-runnable-track{height:var(--rp-track-h-dual, 4px);background:var(--color-control-bg);border-radius:2px}.etp-slider-track::-moz-range-track{height:var(--rp-track-h-dual, 4px);background:var(--color-control-bg);border-radius:2px}.etp-slider-track::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--rp-thumb-size-dual, 14px);height:var(--rp-thumb-size-dual, 14px);border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg);box-shadow:0 1px 2px #00000059;margin-top:var(--rp-thumb-margin-dual, -5px);transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.etp-slider-track::-moz-range-thumb{width:var(--rp-thumb-size-dual, 14px);height:var(--rp-thumb-size-dual, 14px);border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg);box-shadow:0 1px 2px #00000059;transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.etp-slider-track:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.etp-slider-track:focus-visible::-moz-range-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.etp-checkbox-row{display:flex;align-items:center;gap:var(--spacing-sp-sm)}.etp-checkbox-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle);cursor:pointer;-webkit-user-select:none;user-select:none}.etp-checkbox{accent-color:var(--color-accent);width:14px;height:14px;cursor:pointer;flex-shrink:0}.hue-arc-control{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hue-arc-control-svg{display:block;width:100%;height:100%;overflow:visible}.hue-arc-thumb{pointer-events:all;cursor:grab;outline:none}.hue-arc-thumb:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.hue-arc-thumb:active{cursor:grabbing}.hue-chart{display:block;width:100%;height:100%;max-width:100%;max-height:100%}.hue-chart-dots circle{transition:opacity var(--default-transition-duration) var(--default-transition-timing-function)}.hrs-root{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs);width:100%}.hrs-track-wrapper{position:relative;height:var(--rp-row-h, 20px)}.hrs-track{position:absolute;top:50%;left:0;right:0;height:var(--rp-track-h-hue, 8px);transform:translateY(-50%);border-radius:4px;background:linear-gradient(90deg,red,#ff0,#0f0,#0ff,#00f,#f0f,red);pointer-events:none}.hrs-fill{position:absolute;top:50%;height:var(--rp-fill-h-hue, 8px);transform:translateY(-50%);background:#fff6;pointer-events:none;transition:height var(--default-transition-duration, .12s) var(--default-transition-timing-function, ease)}.hrs-fill--full-circle{pointer-events:none;cursor:default}.hrs-fill--draggable{pointer-events:auto;touch-action:none;cursor:grab}.hrs-fill--draggable:hover{height:var(--rp-fill-h-hue-hover, 12px)}.hrs-fill--draggable:active{cursor:grabbing;height:var(--rp-fill-h-hue-hover, 12px)}.hrs-input{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;margin:0;padding:0;outline:none}.hrs-input::-webkit-slider-runnable-track{height:var(--rp-track-h-hue, 8px);background:transparent}.hrs-input::-moz-range-track{height:var(--rp-track-h-hue, 8px);background:transparent}.hrs-input::-webkit-slider-thumb{pointer-events:all;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--rp-thumb-size-hue, 16px);height:var(--rp-thumb-size-hue, 16px);border-radius:50%;background:var(--color-bg);cursor:pointer;border:2px solid var(--color-accent);box-shadow:0 1px 2px #00000059;margin-top:var(--rp-thumb-margin-hue, -4px);transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.hrs-input::-moz-range-thumb{pointer-events:all;width:var(--rp-thumb-size-hue, 16px);height:var(--rp-thumb-size-hue, 16px);border-radius:50%;background:var(--color-bg);cursor:pointer;border:2px solid var(--color-accent);box-shadow:0 1px 2px #00000059;transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.hrs-input:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.hrs-input:focus-visible::-moz-range-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.hrs-input--lo{z-index:var(--z-local-1)}.hrs-input--hi{z-index:var(--z-local-2)}.hrs-live{font-size:var(--font-size-xs);color:var(--color-fg-faint);font-variant-numeric:tabular-nums;text-align:right}.ndp-panel{padding-top:var(--spacing-sp-md);width:100%}.ndp-toggle-row{display:flex;align-items:center;gap:var(--spacing-sp-sm)}.ndp-checkbox{accent-color:var(--color-accent);width:14px;height:14px;cursor:pointer;flex-shrink:0}.ndp-toggle-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg-subtle);cursor:pointer;-webkit-user-select:none;user-select:none}.ndp-sliders{display:flex;flex-direction:column;gap:var(--spacing-sp-md);margin-top:var(--spacing-sp-md)}.ndp-slider-row{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.ndp-slider-header{display:flex;align-items:center;justify-content:space-between}.ndp-slider-label{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle)}.ndp-slider-values{font-size:var(--font-size-xs);color:var(--color-fg-faint);font-variant-numeric:tabular-nums}.ndp-dual-range{position:relative;height:var(--rp-row-h, 20px)}.ndp-dual-range-track{position:absolute;top:50%;left:0;right:0;height:var(--rp-track-h-dual, 4px);transform:translateY(-50%);background:var(--color-control-bg);border-radius:2px;pointer-events:none}.ndp-dual-range-fill{position:absolute;top:50%;transform:translateY(-50%);height:var(--rp-fill-h-dual, 4px);background:var(--color-accent);border-radius:2px;opacity:.7;pointer-events:auto;touch-action:none;cursor:grab;transition:height var(--default-transition-duration)}.ndp-dual-range-fill:hover,.ndp-dual-range-fill--dragging{height:var(--rp-fill-h-dual-hover, 8px)}.ndp-dual-range-fill--dragging{cursor:grabbing}.ndp-dual-range-input{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;margin:0;padding:0;outline:none}.ndp-dual-range-input::-webkit-slider-runnable-track{height:var(--rp-track-h-dual, 4px);background:transparent}.ndp-dual-range-input::-moz-range-track{height:var(--rp-track-h-dual, 4px);background:transparent}.ndp-dual-range-input::-webkit-slider-thumb{pointer-events:all;-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--rp-thumb-size-dual, 14px);height:var(--rp-thumb-size-dual, 14px);border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg);box-shadow:0 1px 2px #00000059;margin-top:var(--rp-thumb-margin-dual, -5px);transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.ndp-dual-range-input::-moz-range-thumb{pointer-events:all;width:var(--rp-thumb-size-dual, 14px);height:var(--rp-thumb-size-dual, 14px);border-radius:50%;background:var(--color-accent);cursor:pointer;border:2px solid var(--color-bg);box-shadow:0 1px 2px #00000059;transition:box-shadow var(--default-transition-duration) var(--default-transition-timing-function)}.ndp-dual-range-input:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.ndp-dual-range-input:focus-visible::-moz-range-thumb{box-shadow:0 0 0 2px var(--color-focus-ring)}.ndp-dual-range-input--lo{z-index:var(--z-local-1)}.ndp-dual-range-input--hi{z-index:var(--z-local-2)}.ndp-hue-section{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.ndp-hue-header{display:flex;align-items:center;justify-content:space-between}.ndp-hue-ring-wrapper{position:relative;width:100%;aspect-ratio:1}.palette-mode-panel-host{position:fixed;z-index:var(--z-palette-bar);bottom:calc(env(safe-area-inset-bottom,0px) + var(--bottom-bar-height) + var(--spacing-sp-sm));right:calc(env(safe-area-inset-right,0px) + var(--spacing-sp-md));pointer-events:none}.palette-mode-panel-host>*{pointer-events:auto}.slot-editor{display:flex;flex-direction:column;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-2xs) 0}.slot-editor__notice{display:flex;align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-info-bg, var(--color-surface-glass));border:1px solid var(--color-info-border, var(--color-border));border-radius:var(--radius-sm);color:var(--color-info-text, var(--color-fg));font-size:var(--font-size-xs);line-height:1.3}.slot-editor__notice-icon{font-size:var(--font-size-sm);line-height:1;color:var(--color-info, var(--color-fg-muted))}.slot-editor__notice-text{flex:1 1 auto;min-width:0}.slot-editor__save-btn{flex:0 0 auto;height:24px;padding:0 var(--spacing-sp-sm);border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:var(--color-accent);color:var(--color-fg-on-accent);cursor:pointer;font-size:var(--font-size-2xs);font-weight:600;letter-spacing:.02em;transition:background .15s,border-color .15s}.slot-editor__save-btn:hover:not(:disabled){background:color-mix(in oklch,var(--color-accent) 88%,white);border-color:color-mix(in oklch,var(--color-accent) 88%,white)}.slot-editor__save-btn:disabled{opacity:.5;cursor:default}.slot-editor__save-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.slot-editor__error{padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-danger-bg, transparent);border:1px solid var(--color-danger-border);border-radius:var(--radius-sm);color:var(--color-danger);font-size:var(--font-size-xs);line-height:1.4}.slot-editor__save-status{font-size:var(--font-size-2xs);color:var(--color-fg-muted);letter-spacing:.02em}.slot-editor__save-status--error{color:var(--color-danger)}.slot-editor__save-status--saved{color:var(--color-success, var(--color-fg-muted))}.slot-editor__rows{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.slot-editor__row{display:grid;grid-template-columns:auto auto 1fr auto auto;align-items:center;gap:var(--spacing-sp-2xs);padding:var(--spacing-sp-2xs) var(--spacing-sp-2xs);border-radius:var(--radius-sm);border:1px solid transparent;transition:background .12s,border-color .12s}.slot-editor__row:hover{background:color-mix(in oklch,var(--color-surface-glass) 60%,transparent);border-color:var(--color-border-subtle, var(--color-border))}.slot-editor__index{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 var(--spacing-sp-3xs);border-radius:var(--radius-sm);background:var(--color-border-faint, var(--color-border));color:var(--color-fg-muted);font-size:var(--font-size-2xs);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:.02em}.slot-editor__swatch-cell{display:inline-flex;width:28px;height:28px}.slot-editor__hex{width:100%;min-width:0;box-sizing:border-box;height:28px;padding:0 var(--spacing-sp-2xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-glass);color:var(--color-fg);font:inherit;font-size:var(--font-size-sm);font-variant-numeric:tabular-nums;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.slot-editor__hex:focus{outline:none;border-color:var(--color-accent)}.slot-editor__hex:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px;border-color:var(--color-accent)}.slot-editor__hex--invalid{border-color:var(--color-danger)}.slot-editor__role{height:28px;padding:0 var(--spacing-sp-2xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface-glass);color:var(--color-fg);font:inherit;font-size:var(--font-size-xs);cursor:pointer}.slot-editor__role:focus{outline:none;border-color:var(--color-accent)}.slot-editor__role:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px;border-color:var(--color-accent)}.slot-editor__delete{width:24px;height:24px;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-fg-muted);cursor:pointer;font-size:var(--font-size-base);line-height:1;transition:background .12s,border-color .12s,color .12s}.slot-editor__delete:hover:not(:disabled){background:var(--color-danger-bg, transparent);border-color:var(--color-danger);color:var(--color-danger)}.slot-editor__delete:disabled{opacity:.35;cursor:default}.slot-editor__delete:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.slot-editor__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-sm);padding-top:var(--spacing-sp-2xs)}.slot-editor__add{flex:0 1 auto;height:28px;padding:0 var(--spacing-sp-sm);border:1px dashed var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-fg);cursor:pointer;font-size:var(--font-size-xs);font-weight:500;transition:background .15s,border-color .15s,color .15s}.slot-editor__add:hover:not(:disabled){background:color-mix(in oklch,var(--color-accent) 12%,transparent);border-color:var(--color-accent);color:var(--color-accent)}.slot-editor__add:disabled{opacity:.4;cursor:default}.slot-editor__add:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.slot-editor__count{font-size:var(--font-size-2xs);color:var(--color-fg-muted);font-variant-numeric:tabular-nums;letter-spacing:.02em}.slot-editor__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.prompt-dialog{max-width:420px}.prompt-dialog-input{width:100%;box-sizing:border-box;margin-bottom:12px;padding:8px 10px;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font:inherit;font-size:14px}.prompt-dialog-input:focus{outline:none;border-color:var(--color-border-focus)}.prompt-dialog-input:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px;border-color:var(--color-border-focus)}.prompt-dialog-input[aria-invalid=true]{border-color:var(--color-danger)}.prompt-dialog-error{margin:-4px 0 12px;font-size:12px;color:var(--color-danger)}.scheme-picker{display:flex;flex-direction:column;gap:var(--spacing-sp-md);width:100%}.scheme-picker-filter{display:flex;gap:var(--spacing-sp-2xs);flex-wrap:wrap}.scheme-picker-pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--color-border-faint);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);padding:var(--spacing-sp-2xs) var(--spacing-sp-md);border-radius:var(--radius-full);cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.scheme-picker-pill:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.scheme-picker-pill-active{background:var(--theme-accent);color:var(--color-fg-on-accent);border-color:var(--theme-accent)}.scheme-picker-pill-active:hover{background:color-mix(in oklch,var(--theme-accent) 90%,white);color:var(--color-fg-on-accent);border-color:color-mix(in oklch,var(--theme-accent) 90%,white)}.scheme-picker-pill:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.scheme-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--spacing-sp-sm)}.scheme-picker-card{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:flex;flex-direction:column;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm);background:var(--color-control-bg);border:1px solid var(--color-border-faint);border-radius:var(--radius-md);cursor:pointer;text-align:left;color:var(--color-fg);font-family:inherit;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}.scheme-picker-card:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover)}.scheme-picker-card-active{border-color:var(--theme-accent);box-shadow:0 0 0 1px var(--theme-accent)}.scheme-picker-card-active:hover{border-color:color-mix(in oklch,var(--theme-accent) 90%,white);box-shadow:0 0 0 1px color-mix(in oklch,var(--theme-accent) 90%,white)}.scheme-picker-card:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.scheme-picker-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-2xs);min-height:var(--spacing-sp-lg)}.scheme-picker-card-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto;min-width:0}.scheme-picker-card-actions{display:inline-flex;gap:var(--spacing-sp-3xs);flex:0 0 auto}.scheme-picker-action{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-block;font-family:inherit;font-size:var(--font-size-2xs);color:var(--color-fg-subtle);background:transparent;padding:var(--spacing-sp-3xs) var(--spacing-sp-2xs);border-radius:var(--radius-sm);border:1px solid var(--color-border-faint);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s ease,color .12s ease,border-color .12s ease}.scheme-picker-action:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.scheme-picker-action-danger:hover{background:var(--color-danger);color:var(--color-fg-on-accent);border-color:var(--color-danger)}.scheme-picker-action:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.scheme-picker-swatch-row{display:grid;width:100%;height:var(--spacing-sp-md);border-radius:var(--radius-xs);overflow:hidden;border:1px solid var(--color-border-faint)}.scheme-picker-swatch{display:block;width:100%;height:100%}.scheme-picker-thumbnail{display:block;width:100%;height:var(--spacing-sp-2xl);object-fit:cover;border-radius:var(--radius-xs);border:1px solid var(--color-border-faint)}.scheme-picker-empty{padding:var(--spacing-sp-lg);text-align:center;color:var(--color-fg-subtle);font-size:var(--font-size-sm);background:var(--color-control-bg);border:1px dashed var(--color-border-faint);border-radius:var(--radius-md)}.scheme-picker-error{font-size:var(--font-size-xs);color:var(--color-fg-on-accent);background:var(--color-danger);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);border-radius:var(--radius-sm)}.palette-generator-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}.palette-generator-dialog{background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:95vw;max-width:1200px;height:90vh;display:flex;flex-direction:column;overflow:hidden}.palette-generator-dialog-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.palette-generator-dialog-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-fg)}.palette-generator-dialog-close{padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);font-size:var(--font-size-base);line-height:1}.palette-generator-dialog-controls{display:flex;gap:var(--spacing-sp-md);align-items:stretch;padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.palette-generator-dialog-textarea{flex:1;min-height:64px;padding:var(--spacing-sp-sm) var(--spacing-sp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);font-family:inherit;line-height:1.5;resize:vertical;outline:none;transition:border-color var(--default-transition-duration) var(--default-transition-timing-function);box-sizing:border-box}.palette-generator-dialog-textarea:focus{border-color:var(--color-border-focus)}.palette-generator-dialog-control-actions{display:flex;flex-direction:column;gap:var(--spacing-sp-sm);flex-shrink:0;min-width:160px}.palette-generator-dialog-action{padding:var(--spacing-sp-sm) var(--spacing-sp-md);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-md);cursor:pointer}.palette-generator-dialog-action:disabled{opacity:.4;cursor:not-allowed}.palette-generator-dialog-action--ai{background:var(--color-control-bg-hover);border:1px solid var(--color-border-hover);color:var(--color-fg)}.palette-generator-dialog-action--ai:not(:disabled):hover{background:var(--color-border-focus)}.palette-generator-dialog-action--random{background:var(--color-control-bg);border:1px solid var(--color-border);color:var(--color-fg)}.palette-generator-dialog-action--random:not(:disabled):hover{background:var(--color-control-bg-hover)}.palette-generator-dialog-body{display:flex;gap:var(--spacing-sp-lg);padding:var(--spacing-sp-lg);flex:1;min-height:0;overflow:hidden}.palette-generator-dialog-grid-region{flex:1;min-width:0;overflow-y:auto;display:flex;flex-direction:column}.palette-generator-dialog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-sp-md);align-content:start}.palette-generator-dialog-card{display:flex;flex-direction:column;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function),transform var(--default-transition-duration) var(--default-transition-timing-function)}.palette-generator-dialog-card:hover{background:var(--color-control-bg-hover);border-color:var(--color-border-hover);transform:translateY(-1px)}.palette-generator-dialog-card:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.palette-generator-dialog-card-swatches{display:flex;gap:2px;border-radius:var(--radius-sm);overflow:hidden;height:56px}.palette-generator-dialog-card-swatch{flex:1;display:block}.palette-generator-dialog-card-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.palette-generator-dialog-empty{font-size:var(--font-size-sm);color:var(--color-fg-faint);padding:var(--spacing-sp-2xl);text-align:center}.palette-generator-dialog-error{font-size:var(--font-size-sm);color:var(--color-danger);padding:var(--spacing-sp-md);background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:var(--radius-md)}.palette-generator-dialog-hue-chart{width:240px;flex-shrink:0;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-md);display:flex;flex-direction:column;align-items:center;overflow-y:auto}.palette-generator-dialog-commentary{padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-top:1px solid var(--color-border-subtle);flex-shrink:0;max-height:25%;overflow-y:auto}.palette-generator-dialog-commentary-text{margin:0;font-size:var(--font-size-sm);color:var(--color-fg-subtle);line-height:1.5}.palette-generator-dialog-commentary-text--placeholder{color:var(--color-fg-faint);font-style:italic}@media(max-width:720px){.palette-generator-dialog-body{flex-direction:column;overflow-y:auto}.palette-generator-dialog-hue-chart{width:100%;height:160px}.palette-generator-dialog-controls{flex-direction:column}.palette-generator-dialog-control-actions{flex-direction:row;min-width:0}.palette-generator-dialog-action{flex:1}}:root{--color-scheme-panel-width: 360px}.color-scheme-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);pointer-events:auto;display:flex;justify-content:flex-end;background:transparent}.color-scheme-panel{position:relative;display:flex;flex-direction:column;width:min(calc(var(--color-scheme-panel-width) * var(--display-scale, 1)),calc(100vw - var(--spacing-sp-lg)));height:100%;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-left:1px solid var(--color-border);box-shadow:var(--shadow-modal, 0 8px 32px hsl(0deg 0% 0% / .25));overflow:hidden;animation:color-scheme-panel-slide-in var(--default-transition-duration) var(--default-transition-timing-function)}@keyframes color-scheme-panel-slide-in{0%{transform:translate(100%)}to{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.color-scheme-panel{animation:none}}.color-scheme-panel-header{display:flex;align-items:center;gap:var(--spacing-sp-sm);padding:var(--spacing-sp-sm) var(--spacing-sp-md);border-bottom:1px solid var(--color-border);flex-shrink:0}.color-scheme-panel-tabs{display:flex;gap:var(--spacing-sp-2xs);flex:1;min-width:0}.color-scheme-panel-tab{position:relative;padding:var(--spacing-sp-xs) var(--spacing-sp-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-fg-muted);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function)}.color-scheme-panel-tab:hover{color:var(--color-fg);background:var(--color-control-bg-hover)}.color-scheme-panel-tab:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.color-scheme-panel-tab--active{color:var(--color-fg)}.color-scheme-panel-tab--active:after{content:"";position:absolute;left:var(--spacing-sp-sm);right:var(--spacing-sp-sm);bottom:calc(var(--spacing-sp-xs) * -1);height:2px;background:var(--color-accent);border-radius:var(--radius-full)}.color-scheme-panel-generate{flex-shrink:0;display:inline-flex;align-items:center;padding:var(--spacing-sp-xs) var(--spacing-sp-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-fg);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--default-transition-duration) var(--default-transition-timing-function),background var(--default-transition-duration) var(--default-transition-timing-function),border-color var(--default-transition-duration) var(--default-transition-timing-function)}.color-scheme-panel-generate:hover{background:var(--color-control-bg-hover);border-color:var(--color-accent)}.color-scheme-panel-generate:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.color-scheme-panel-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:var(--spacing-sp-2xl);height:var(--spacing-sp-2xl);border:none;background:transparent;color:var(--color-fg-muted);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--default-transition-duration) var(--default-transition-timing-function),color var(--default-transition-duration) var(--default-transition-timing-function)}.color-scheme-panel-close:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.color-scheme-panel-close:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.color-scheme-panel-body{flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-sp-lg)}.color-scheme-panel-tab-body{display:flex;flex-direction:column;gap:var(--spacing-sp-md)}.color-scheme-panel-tab-placeholder{padding:var(--spacing-sp-lg);border:1px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);line-height:1.5}@media(max-width:600px){.color-scheme-panel{width:100vw;border-left:none}.color-scheme-panel-close{width:44px;height:44px}}.mve-root{display:flex;flex-direction:column;gap:var(--spacing-sp-md);height:100%;overflow-y:auto;padding:var(--spacing-sp-sm);box-sizing:border-box}.mve-preview-row{display:flex;gap:var(--spacing-sp-md);align-items:flex-start;flex:0 0 auto}.mve-thumb-group{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs);flex:1 1 0;min-width:0}.mve-thumb-label{font-size:var(--font-size-xs);color:var(--color-fg-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em}.mve-thumb{width:100%;aspect-ratio:1;background:var(--color-surface-glass);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);overflow:hidden;display:flex;align-items:center;justify-content:center}.mve-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.mve-thumb-placeholder{width:100%;height:100%;opacity:.2;background:var(--color-fg-muted)}.mve-form{display:flex;flex-direction:column;gap:var(--spacing-sp-sm);flex:1 1 auto}.mve-name-group{display:flex;flex-direction:column;gap:var(--spacing-sp-2xs)}.mve-name-label{display:block;font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle)}.mve-name-input{width:100%;padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);font:inherit;outline:none;box-sizing:border-box}.mve-name-input:focus{border-color:var(--color-border-focus)}.mve-name-input--error{border-color:var(--color-danger)}.mve-name-error{font-size:var(--font-size-xs);color:var(--color-danger)}.mve-save-error{font-size:var(--font-size-xs);color:var(--color-danger);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);border-radius:var(--radius-sm);background:color-mix(in oklch,var(--color-danger) 10%,transparent);text-align:right}.mve-sliders{display:flex;flex-direction:column;gap:var(--spacing-sp-xs)}.mve-toggle-row{display:flex;align-items:center;gap:var(--spacing-sp-sm)}.mve-toggle-checkbox{accent-color:var(--color-accent);width:14px;height:14px;cursor:pointer;flex-shrink:0}.mve-toggle-label{font-size:var(--font-size-sm);color:var(--color-fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.mve-actions{display:flex;gap:var(--spacing-sp-sm);justify-content:flex-end;flex:0 0 auto;padding-top:var(--spacing-sp-sm);border-top:1px solid var(--color-border-subtle)}.mve-btn-cancel{padding:var(--spacing-sp-xs) var(--spacing-sp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg-muted);font-size:var(--font-size-sm);font:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:background .1s,color .1s,border-color .1s}.mve-btn-cancel:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.mve-btn-cancel:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.mve-btn-save{padding:var(--spacing-sp-xs) var(--spacing-sp-md);background:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-md);color:var(--color-fg-on-accent);font-size:var(--font-size-sm);font:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:opacity .1s}.mve-btn-save:not(:disabled):hover{opacity:.85}.mve-btn-save:disabled{opacity:.4;cursor:not-allowed}.mve-btn-save:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal)}.vtd-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--color-overlay-backdrop);z-index:var(--z-local-1)}.vtd-panel{position:absolute;inset:var(--spacing-sp-lg);z-index:var(--z-local-2);display:flex;flex-direction:column;background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal-lg);overflow:hidden;outline:none}.vtd-header{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sp-md);padding:var(--spacing-sp-md) var(--spacing-sp-lg);border-bottom:1px solid var(--color-border-subtle);min-height:0}.vtd-header-left{display:flex;align-items:center;gap:var(--spacing-sp-md);flex:1 1 auto;min-width:0}.vtd-header-right{flex:0 0 auto;display:flex;align-items:center}.vtd-title{flex:0 0 auto;margin:0;font-size:var(--font-size-lg);font-weight:600;color:var(--color-fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vtd-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vtd-pattern-only-label{display:flex;align-items:center;gap:var(--spacing-sp-xs);font-size:var(--font-size-sm);color:var(--color-fg-muted);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.vtd-pattern-only-input{cursor:pointer;accent-color:var(--color-accent);width:14px;height:14px}.vtd-pattern-only-label:hover{color:var(--color-fg)}.vtd-create-variation-btn{padding:var(--spacing-vsp-xs) var(--spacing-hsp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:var(--font-size-sm);font:inherit;cursor:pointer;white-space:nowrap;transition:background .1s,color .1s,border-color .1s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.vtd-create-variation-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.vtd-create-variation-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-back-btn{padding:var(--spacing-vsp-xs) var(--spacing-hsp-md);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:var(--font-size-sm);font:inherit;cursor:pointer;white-space:nowrap;transition:background .1s,color .1s,border-color .1s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.vtd-back-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.vtd-back-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-close-btn{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);color:var(--color-fg-muted);font-size:var(--font-size-base);cursor:pointer;transition:background .1s,color .1s;flex-shrink:0}.vtd-close-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.vtd-close-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-body{flex:1 1 auto;display:flex;flex-direction:column;padding:var(--spacing-sp-lg);min-height:0;overflow-y:auto}.vtd-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--spacing-sp-md);align-content:start}.vtd-editor-placeholder{flex:1 1 auto;display:flex;align-items:center;justify-content:center;color:var(--color-fg-muted);font-size:var(--font-size-sm)}.vtd-tile{display:flex;flex-direction:column;gap:var(--spacing-sp-xs);min-height:0}.vtd-tile-main-btn{display:flex;flex-direction:column;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;outline:none;transition:border-color .1s,box-shadow .1s,background .1s;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;font:inherit;text-align:left;width:100%;flex:1 1 auto;min-height:0;overflow:hidden}.vtd-tile-main-btn:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-canvas)}.vtd-tile-main-btn:focus-visible{border-color:var(--color-border-focus);box-shadow:0 0 0 2px var(--color-focus-ring)}.vtd-tile-thumb{display:flex;align-items:center;justify-content:center;background:var(--color-surface-glass);border:1px solid var(--color-border-subtle);border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:var(--vtd-thumb-ar, 1);width:100%}.vtd-tile-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.vtd-tile-thumb-placeholder{width:100%;height:100%;opacity:.4;background:currentColor}.vtd-tile-name{flex:0 0 auto;display:block;font-size:var(--font-size-sm);color:var(--color-fg-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 var(--spacing-sp-2xs)}.vtd-tile-actions{display:flex;gap:var(--spacing-sp-xs);flex:0 0 auto}.vtd-tile-action-btn{flex:1 1 0;padding:var(--spacing-vsp-xs) var(--spacing-hsp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:var(--font-size-xs);cursor:pointer;transition:background .1s,color .1s,border-color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit}.vtd-tile-action-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.vtd-tile-action-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-user-section{flex:0 0 auto;margin-top:var(--spacing-sp-lg)}.vtd-section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-fg-muted);text-transform:uppercase;letter-spacing:.06em;margin:0 0 var(--spacing-sp-sm) 0;padding:var(--spacing-sp-xs) 0;border-top:1px solid var(--color-border-subtle)}.vtd-tile--user,.vtd-tile--user .vtd-tile-thumb{position:relative}.vtd-tile-star{position:absolute;top:var(--spacing-sp-2xs);right:var(--spacing-sp-2xs);font-size:12px;color:var(--color-accent);line-height:1;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.5)}.vtd-tile-overflow-btn{flex:0 0 auto;width:28px;padding:0;background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-fg-muted);font-size:var(--font-size-base);cursor:pointer;transition:background .1s,color .1s,border-color .1s;display:flex;align-items:center;justify-content:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;font:inherit}.vtd-tile-overflow-btn:hover{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-hover)}.vtd-tile-overflow-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.vtd-tile-menu-wrap{position:relative}.vtd-tile-menu{position:absolute;bottom:calc(100% + var(--spacing-sp-2xs));right:0;min-width:120px;background:var(--color-surface-modal);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-modal-lg);z-index:var(--z-local-3);overflow:hidden;display:flex;flex-direction:column}.vtd-tile-menu-item{padding:var(--spacing-vsp-xs) var(--spacing-hsp-md);background:none;border:none;border-radius:0;color:var(--color-fg);font-size:var(--font-size-sm);font:inherit;text-align:left;cursor:pointer;transition:background .1s;-webkit-appearance:none;-moz-appearance:none;appearance:none;white-space:nowrap}.vtd-tile-menu-item:hover{background:var(--color-control-bg-hover)}.vtd-tile-menu-item:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:-2px}.vtd-tile-menu-item--danger{color:var(--color-danger)}.vtd-tile-menu-item--danger:hover{background:color-mix(in srgb,var(--color-danger) 10%,transparent)}.app-shell{width:100%;height:100vh;height:100dvh;display:grid;grid-template-rows:var(--chrome-height) 1fr var(--bottom-bar-height)}.app-shell.is-editor{--chrome-height: var(--global-header-height);--chrome-height-safe: calc(var(--chrome-height) + env(safe-area-inset-top, 0px))}.app-shell-content{position:relative;overflow:hidden;min-height:0}.tab-content-wrapper,.app-shell-page-loading{width:100%;height:100%}.app-shell-composition-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sp-md);height:100%;color:var(--color-fg-muted);font-size:var(--font-size-base)}.app-shell-composition-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sp-lg);height:100%;text-align:center;padding:var(--spacing-sp-2xl)}.app-shell-composition-not-found-message{color:var(--color-fg-muted);font-size:var(--font-size-base);max-width:360px}/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}.collapse{visibility:collapse}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.isolate{isolation:isolate}.container{width:100%}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.align-bottom{vertical-align:bottom}.align-top{vertical-align:top}.capitalize{text-transform:capitalize}.lowercase{text-transform:lowercase}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.accent-fg{accent-color:var(--color-fg)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.sepia{--tw-sepia:sepia(100%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.\[fps-change-restarts-anim\:post\]{fps-change-restarts-anim:post}.\[fps-change-restarts-anim\:pre\]{fps-change-restarts-anim:pre}:root{color-scheme:dark;--palette-bg:oklch(14% 0 0);--palette-fg:oklch(90% 0 0);--palette-cursor:oklch(90% 0 0);--palette-selection:oklch(100% 0 0/.2);--palette-0:oklch(20% 0 0);--palette-1:oklch(55% .2 25);--palette-2:oklch(60% .15 145);--palette-3:oklch(75% .15 85);--palette-4:oklch(55% .15 260);--palette-5:oklch(60% .2 320);--palette-6:oklch(65% .12 200);--palette-7:oklch(80% 0 0);--palette-8:oklch(45% 0 0);--palette-9:oklch(65% .2 25);--palette-10:oklch(70% .15 145);--palette-11:oklch(85% .15 85);--palette-12:oklch(65% .15 260);--palette-13:oklch(70% .2 320);--palette-14:oklch(75% .12 200);--palette-15:oklch(95% 0 0);--palette-shadow-base:var(--palette-0);--palette-canvas-handle-base:var(--palette-15);--palette-canvas-dashed-base:var(--palette-canvas-handle-base);--z-canvas-chrome:1;--z-focus-ring:1;--z-tooltip:10000;--z-canvas-overlay:10;--z-side-panel-placeholder:13;--z-rail:14;--z-side-panel:15;--z-banner:20;--z-crop-overlay:20;--z-menu-bar:30;--z-menu-dropdown:31;--z-ctx-menu-backdrop:40;--z-ctx-menu:50;--z-popover-low:60;--z-selection:100;--z-fab:150;--z-overlay-root:200;--z-palette-bar:250;--z-toolbar:299;--z-header:300;--z-modal:500;--z-toast:600;--z-preview:700;--z-onboarding:1000;--z-popover-portaled:2000;--z-drawer:2500;--z-color-picker:9999;--z-local-1:1;--z-local-2:2;--z-local-3:3;--theme-bg:var(--palette-bg);--theme-fg:var(--palette-fg);--theme-fg-muted:var(--palette-7);--theme-fg-subtle:var(--palette-6);--theme-fg-faint:var(--palette-4);--theme-fg-icon:var(--palette-6);--theme-accent:var(--palette-5);--theme-move-accent:oklch(72% .18 60);--theme-surface-glass:var(--palette-bg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-surface-glass:color-mix(in oklch, var(--palette-bg) 75%, transparent)}}:root{--theme-control-bg:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-control-bg:color-mix(in oklch, var(--palette-fg) 8%, transparent)}}:root{--theme-control-bg-hover:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-control-bg-hover:color-mix(in oklch, var(--palette-fg) 15%, transparent)}}:root{--theme-border:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-border:color-mix(in oklch, var(--palette-fg) 12%, transparent)}}:root{--theme-border-hover:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-border-hover:color-mix(in oklch, var(--palette-fg) 15%, transparent)}}:root{--theme-border-focus:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-border-focus:color-mix(in oklch, var(--palette-fg) 30%, transparent)}}:root{--theme-border-subtle:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-border-subtle:color-mix(in oklch, var(--palette-fg) 8%, transparent)}}:root{--theme-border-faint:var(--palette-fg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-border-faint:color-mix(in oklch, var(--palette-fg) 10%, transparent)}}:root{--theme-focus-ring:var(--palette-14);--theme-fg-on-accent:var(--palette-9);--theme-danger:var(--palette-10);--theme-danger-hover:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-hover:color-mix(in oklch, var(--palette-10) 85%, white)}}:root{--theme-danger-bg:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-bg:color-mix(in oklch, var(--palette-10) 10%, transparent)}}:root{--theme-danger-border:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-border:color-mix(in oklch, var(--palette-10) 30%, transparent)}}:root{--theme-danger-bg-hover:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-bg-hover:color-mix(in oklch, var(--palette-10) 20%, transparent)}}:root{--theme-danger-active:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-active:color-mix(in oklch, var(--palette-10) 70%, var(--palette-bg))}}:root{--theme-danger-active-border:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-active-border:color-mix(in oklch, var(--palette-10) 85%, var(--palette-bg))}}:root{--theme-danger-border-hover:var(--palette-10)}@supports (color:color-mix(in lab,red,red)){:root{--theme-danger-border-hover:color-mix(in oklch, var(--palette-10) 40%, transparent)}}:root{--theme-success:var(--palette-11);--theme-success-hover:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-hover:color-mix(in oklch, var(--palette-11) 85%, white)}}:root{--theme-success-bg:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-bg:color-mix(in oklch, var(--palette-11) 20%, transparent)}}:root{--theme-success-active:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-active:color-mix(in oklch, var(--palette-11) 70%, var(--palette-bg))}}:root{--theme-star:var(--palette-13);--theme-star-hover:var(--palette-13)}@supports (color:color-mix(in lab,red,red)){:root{--theme-star-hover:color-mix(in oklch, var(--palette-13) 85%, white)}}:root{--theme-star-bg:var(--palette-13)}@supports (color:color-mix(in lab,red,red)){:root{--theme-star-bg:color-mix(in oklch, var(--palette-13) 12%, transparent)}}:root{--theme-star-border:var(--palette-13)}@supports (color:color-mix(in lab,red,red)){:root{--theme-star-border:color-mix(in oklch, var(--palette-13) 35%, transparent)}}:root{--theme-info:var(--palette-12);--theme-info-muted:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-muted:color-mix(in oklch, var(--palette-12) 50%, var(--palette-bg))}}:root{--theme-info-bg:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-bg:color-mix(in oklch, var(--palette-12) 15%, transparent)}}:root{--theme-info-border:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-border:color-mix(in oklch, var(--palette-12) 40%, transparent)}}:root{--theme-info-bg-hover:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-bg-hover:color-mix(in oklch, var(--palette-12) 25%, transparent)}}:root{--theme-info-text:var(--palette-7);--theme-info-text-hover:var(--palette-9);--theme-info-banner-bg:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-banner-bg:color-mix(in oklch, var(--palette-12) 10%, transparent)}}:root{--theme-info-banner-border:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-banner-border:color-mix(in oklch, var(--palette-12) 30%, transparent)}}:root{--theme-info-banner-btn-bg:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-banner-btn-bg:color-mix(in oklch, var(--palette-12) 20%, transparent)}}:root{--theme-info-banner-btn-hover-bg:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-banner-btn-hover-bg:color-mix(in oklch, var(--palette-12) 30%, transparent)}}:root{--theme-info-banner-btn-hover-border:var(--palette-12)}@supports (color:color-mix(in lab,red,red)){:root{--theme-info-banner-btn-hover-border:color-mix(in oklch, var(--palette-12) 50%, transparent)}}:root{--theme-success-banner-bg:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-bg:color-mix(in oklch, var(--palette-11) 12%, transparent)}}:root{--theme-success-banner-border:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-border:color-mix(in oklch, var(--palette-11) 40%, transparent)}}:root{--theme-success-banner-text:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-text:color-mix(in oklch, var(--palette-11) 80%, transparent)}}:root{--theme-success-banner-btn-bg:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-btn-bg:color-mix(in oklch, var(--palette-11) 25%, transparent)}}:root{--theme-success-banner-btn-border:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-btn-border:color-mix(in oklch, var(--palette-11) 50%, transparent)}}:root{--theme-success-banner-btn-hover-bg:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-btn-hover-bg:color-mix(in oklch, var(--palette-11) 35%, transparent)}}:root{--theme-success-banner-btn-hover-border:var(--palette-11)}@supports (color:color-mix(in lab,red,red)){:root{--theme-success-banner-btn-hover-border:color-mix(in oklch, var(--palette-11) 65%, transparent)}}:root{--theme-surface:var(--palette-2)}@supports (color:color-mix(in lab,red,red)){:root{--theme-surface:color-mix(in oklch, var(--palette-2) 80%, var(--palette-bg))}}:root{--theme-surface-modal:var(--palette-2);--theme-surface-sidebar:var(--palette-1);--theme-overlay-backdrop:var(--palette-bg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-overlay-backdrop:color-mix(in oklch, var(--palette-bg) 60%, transparent)}}:root{--theme-overlay-modal:var(--palette-bg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-overlay-modal:color-mix(in oklch, var(--palette-bg) 70%, transparent)}}:root{--theme-preview-bg:var(--palette-bg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-preview-bg:color-mix(in oklch, var(--palette-bg) 30%, transparent)}}:root{--theme-tooltip-bg:var(--palette-3);--theme-tooltip-fg:var(--palette-9);--theme-canvas-handle:var(--palette-canvas-handle-base);--theme-canvas-handle-border:var(--palette-bg)}@supports (color:color-mix(in lab,red,red)){:root{--theme-canvas-handle-border:color-mix(in oklch, var(--palette-bg) 50%, transparent)}}:root{--theme-canvas-handle-glow:var(--palette-canvas-dashed-base)}@supports (color:color-mix(in lab,red,red)){:root{--theme-canvas-handle-glow:color-mix(in oklch, var(--palette-canvas-dashed-base) 50%, transparent)}}:root{--theme-canvas-dashed:var(--palette-canvas-dashed-base)}@supports (color:color-mix(in lab,red,red)){:root{--theme-canvas-dashed:color-mix(in oklch, var(--palette-canvas-dashed-base) 70%, transparent)}}:root{--theme-syntax-keyword:var(--palette-4);--theme-syntax-string:var(--palette-3);--theme-syntax-number:var(--palette-2);--theme-syntax-function:var(--palette-11);--theme-syntax-definition:var(--palette-14);--theme-syntax-property:var(--palette-6);--theme-syntax-type:var(--palette-5)}:root,:host{--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--color-bg:var(--theme-bg);--color-fg:var(--theme-fg);--color-fg-muted:var(--theme-fg-muted);--color-fg-subtle:var(--theme-fg-subtle);--color-fg-faint:var(--theme-fg-faint);--color-fg-icon:var(--theme-fg-icon);--color-accent:var(--theme-accent);--color-move-accent:var(--theme-move-accent);--color-surface:var(--theme-surface);--color-surface-glass:var(--theme-surface-glass);--color-control-bg:var(--theme-control-bg);--color-control-bg-hover:var(--theme-control-bg-hover);--color-border:var(--theme-border);--color-border-hover:var(--theme-border-hover);--color-border-focus:var(--theme-border-focus);--color-border-subtle:var(--theme-border-subtle);--color-border-faint:var(--theme-border-faint);--color-focus-ring:var(--theme-focus-ring);--color-danger:var(--theme-danger);--color-danger-hover:var(--theme-danger-hover);--color-danger-bg:var(--theme-danger-bg);--color-danger-border:var(--theme-danger-border);--color-danger-bg-hover:var(--theme-danger-bg-hover);--color-danger-active:var(--theme-danger-active);--color-danger-active-border:var(--theme-danger-active-border);--color-success:var(--theme-success);--color-success-hover:var(--theme-success-hover);--color-success-bg:var(--theme-success-bg);--color-success-active:var(--theme-success-active);--color-star:var(--theme-star);--color-star-hover:var(--theme-star-hover);--color-star-bg:var(--theme-star-bg);--color-star-border:var(--theme-star-border);--color-fg-on-accent:var(--theme-fg-on-accent);--color-info:var(--theme-info);--color-info-muted:var(--theme-info-muted);--color-info-bg:var(--theme-info-bg);--color-info-border:var(--theme-info-border);--color-info-bg-hover:var(--theme-info-bg-hover);--color-info-text:var(--theme-info-text);--color-info-text-hover:var(--theme-info-text-hover);--color-success-banner-bg:var(--theme-success-banner-bg);--color-success-banner-border:var(--theme-success-banner-border);--color-success-banner-text:var(--theme-success-banner-text);--color-danger-border-hover:var(--theme-danger-border-hover);--color-surface-modal:var(--theme-surface-modal);--color-overlay-backdrop:var(--theme-overlay-backdrop);--color-overlay-modal:var(--theme-overlay-modal);--color-preview-bg:var(--theme-preview-bg);--color-tooltip-bg:var(--theme-tooltip-bg);--color-tooltip-fg:var(--theme-tooltip-fg);--color-canvas-handle:var(--theme-canvas-handle);--color-canvas-handle-border:var(--theme-canvas-handle-border);--color-canvas-handle-glow:var(--theme-canvas-handle-glow);--color-canvas-dashed:var(--theme-canvas-dashed);--shadow-dropdown:0 4px 12px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-dropdown:0 4px 12px color-mix(in oklch, var(--palette-shadow-base) 30%, transparent)}}:root,:host{--shadow-modal:0 16px 48px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-modal:0 16px 48px color-mix(in oklch, var(--palette-shadow-base) 40%, transparent)}}:root,:host{--shadow-modal-lg:0 24px 64px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-modal-lg:0 24px 64px color-mix(in oklch, var(--palette-shadow-base) 60%, transparent)}}:root,:host{--shadow-menu:0 8px 24px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-menu:0 8px 24px color-mix(in oklch, var(--palette-shadow-base) 50%, transparent)}}:root,:host{--shadow-canvas:0 4px 24px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-canvas:0 4px 24px color-mix(in oklch, var(--palette-shadow-base) 40%, transparent)}}:root,:host{--shadow-sidebar-mobile:-8px 0 24px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-sidebar-mobile:-8px 0 24px color-mix(in oklch, var(--palette-shadow-base) 35%, transparent)}}:root,:host{--shadow-strip-hover:0 2px 6px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){:root,:host{--shadow-strip-hover:0 2px 6px color-mix(in oklch, var(--palette-shadow-base) 18%, transparent)}}:root,:host{--color-syntax-keyword:var(--theme-syntax-keyword);--color-syntax-string:var(--theme-syntax-string);--color-syntax-number:var(--theme-syntax-number);--color-syntax-function:var(--theme-syntax-function);--color-syntax-definition:var(--theme-syntax-definition);--color-syntax-property:var(--theme-syntax-property);--color-syntax-type:var(--theme-syntax-type);--spacing-1px:1px;--spacing-sp-3xs:3px;--spacing-sp-2xs:4px;--spacing-sp-xs:6px;--spacing-sp-sm:8px;--spacing-sp-md:12px;--spacing-sp-lg:16px;--spacing-sp-xl:20px;--spacing-sp-2xl:28px;--spacing-hsp-2xs:2px;--spacing-hsp-xs:4px;--spacing-hsp-sm:8px;--spacing-hsp-md:12px;--spacing-hsp-lg:16px;--spacing-hsp-xl:24px;--spacing-vsp-2xs:2px;--spacing-vsp-xs:4px;--spacing-vsp-sm:8px;--spacing-vsp-xl:24px;--radius-xs:2px;--radius-sm:4px;--radius-md:6px;--radius-lg:12px;--radius-xl:20px;--radius-full:9999px;--font-size-2xs:10px;--font-size-xs:11px;--font-size-sm:12px;--font-size-base:13px;--font-size-lg:18px;--font-size-xl:22px;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-none:1;--tracking-tight:-.02em;--tracking-wide:.02em;--font-sans:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, "Cascadia Code", "Fira Code", monospace;--global-header-height:40px;--tab-bar-height:32px;--chrome-height:calc(var(--global-header-height) + var(--tab-bar-height));--bottom-bar-height:80px}:root{--chrome-height-safe:calc(var(--chrome-height) + env(safe-area-inset-top,0px));--display-scale:1;--spacing-sp-3xs:calc(3px * var(--display-scale));--spacing-sp-2xs:calc(4px * var(--display-scale));--spacing-sp-xs:calc(6px * var(--display-scale));--spacing-sp-sm:calc(8px * var(--display-scale));--spacing-sp-md:calc(12px * var(--display-scale));--spacing-sp-lg:calc(16px * var(--display-scale));--spacing-sp-xl:calc(20px * var(--display-scale));--spacing-sp-2xl:calc(28px * var(--display-scale));--font-size-2xs:calc(10px * var(--display-scale));--font-size-xs:calc(11px * var(--display-scale));--font-size-sm:calc(12px * var(--display-scale));--font-size-base:calc(13px * var(--display-scale));--font-size-lg:calc(18px * var(--display-scale));--font-size-xl:calc(22px * var(--display-scale));--font-size-2xl:calc(28px * var(--display-scale));--global-header-height:calc(40px * var(--display-scale));--tab-bar-height:calc(32px * var(--display-scale))}body{background:var(--color-bg);color:var(--color-fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow:hidden}.app{width:100%;height:100%;position:relative}.canvas-layer{justify-content:center;align-items:center;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.canvas-layer canvas{object-fit:contain;width:100%;height:100%}.canvas-layer.canvas-layer-no-fit{overflow:hidden}.canvas-layer.canvas-layer-no-fit canvas{object-fit:unset;width:auto;max-width:none;height:auto;max-height:none}.canvas-layer>.viewer-anim-controls-stack{left:50%;bottom:var(--spacing-sp-sm);z-index:var(--z-canvas-overlay);pointer-events:none;max-width:calc(100% - 2 * var(--spacing-sp-md));position:absolute;transform:translate(-50%)}.canvas-layer>.viewer-anim-controls-stack>*{pointer-events:auto}.floating-link{z-index:var(--z-canvas-overlay);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);color:var(--color-fg-muted);letter-spacing:.02em;border-radius:8px;align-items:center;gap:8px;padding:8px 14px;font-size:14px;font-weight:400;text-decoration:none;transition:background .15s,color .15s;display:flex;position:absolute}.floating-link:hover{background:var(--color-control-bg-hover);color:var(--color-fg)}.site-link{top:calc(var(--chrome-height) + 12px);right:max(16px,env(safe-area-inset-right,0px))}.site-logo{width:26px;height:26px}.doc-link{bottom:max(16px,env(safe-area-inset-bottom,0px));right:max(16px,env(safe-area-inset-right,0px));gap:6px}.doc-link svg{flex-shrink:0}.control-group{margin-bottom:var(--spacing-sp-md)}.control-group label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle);margin-bottom:var(--spacing-sp-2xs);font-weight:500;display:block}.slug-row{gap:var(--spacing-sp-xs);display:flex}.slug-row input{flex:1;min-width:0}.pattern-type-select-row{gap:var(--spacing-sp-xs);display:flex}.pattern-type-select-row select{flex:1;min-width:0}.btn-expand-patterns{padding:var(--spacing-sp-xs);flex-shrink:0;justify-content:center;align-items:center;display:flex}.pattern-panel-save-load-row{gap:var(--spacing-sp-xs);display:flex}.pattern-panel-save-btn,.pattern-panel-load-btn{font-size:var(--font-size-xs);flex:1}input[type=text],select{width:100%;padding:var(--spacing-sp-xs) var(--spacing-sp-sm);background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg);font-size:var(--font-size-base);outline:none}input[type=text]:focus,select:focus{border-color:var(--color-border-focus)}.btn{padding:var(--spacing-sp-xs) var(--spacing-sp-md);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg);font-size:var(--font-size-sm);cursor:pointer;white-space:nowrap}.btn:hover{background:var(--color-control-bg-hover)}.collapsible-section{border-top:1px solid var(--color-border-faint);margin-top:var(--spacing-sp-sm)}.collapsible-section:first-of-type{border-top:none;margin-top:0}.collapsible-section-header{width:100%;padding:var(--spacing-sp-sm) 0;color:var(--color-fg-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;background:0 0;border:none;justify-content:space-between;align-items:center;transition:color .15s;display:flex}.collapsible-section-header:hover{color:var(--color-fg)}.collapsible-section-title{font-weight:500}.collapsible-section-chevron{font-size:var(--font-size-2xs);opacity:.6}.collapsible-section-content{padding-bottom:var(--spacing-sp-sm)}.slider-with-input-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle);margin-bottom:var(--spacing-sp-2xs);font-weight:500;display:block}.range-row{align-items:center;gap:var(--spacing-sp-sm);display:flex}.range-row input[type=range]{accent-color:var(--color-accent);flex:1}.range-value{font-size:var(--font-size-sm);font-variant-numeric:tabular-nums;text-align:right;min-width:28px;color:var(--color-fg-muted)}.range-value-editable{text-align:right;min-width:40px;max-width:60px;color:inherit;font:inherit;background:0 0;border:1px solid #0000;border-radius:3px;outline:none;padding:1px 4px}.range-value-editable:focus{background:var(--color-control-bg);border-color:var(--color-border-hover)}.composer-label-value-editable{width:4ch;min-width:unset;max-width:unset;font-size:inherit;padding:0 2px;display:inline}.param-section{border-top:1px solid var(--color-border-subtle);padding-top:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-md)}.hsl-section{margin-bottom:var(--spacing-sp-md)}.param-section .section-label,.hsl-section .section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-faint);margin-bottom:var(--spacing-sp-sm);font-weight:600;display:block}.param-control{margin-bottom:var(--spacing-sp-sm)}.param-label-row{justify-content:space-between;align-items:center;display:flex}.param-control label{font-size:var(--font-size-2xs)}label.fix-toggle{font-size:var(--font-size-2xs);opacity:.6;cursor:pointer;align-items:center;gap:3px;line-height:1;display:inline-flex}label.fix-toggle:has(input:checked){opacity:1}label.fix-toggle input[type=checkbox]{vertical-align:middle;accent-color:var(--color-accent);margin:0}.param-control .range-value{min-width:36px;font-size:var(--font-size-xs)}.toggle-row{justify-content:space-between;align-items:center;display:flex}.toggle-row input[type=checkbox]{accent-color:var(--color-accent);width:14px;height:14px}.hsl-slider-row{align-items:center;gap:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-xs);display:flex}.hsl-slider-row input[type=range]{accent-color:var(--color-accent);flex:1}.hsl-label{font-size:var(--font-size-xs);color:var(--color-fg-subtle);flex-shrink:0;width:1rem;font-weight:500}.hsl-value{font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;text-align:right;min-width:2.5rem;color:var(--color-fg-muted);flex-shrink:0}.hsl-toggle-row{align-items:center;gap:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-xs);display:flex}.hsl-toggle-row input[type=checkbox]{accent-color:var(--color-accent)}.btn-hsl-reset{padding:var(--spacing-sp-2xs) var(--spacing-sp-md);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg);font-size:var(--font-size-xs);cursor:pointer;margin-top:var(--spacing-sp-2xs)}.btn-hsl-reset:hover{background:var(--color-control-bg-hover)}.view-transform-section{border-top:1px solid var(--color-border-subtle);padding-top:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-md)}.view-transform-section .section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-faint);margin-bottom:var(--spacing-sp-sm);font-weight:600;display:block}.view-transform-slider-row{align-items:center;gap:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-xs);display:flex}.view-transform-checkbox-row{align-items:center;gap:var(--spacing-sp-xs);font-size:var(--font-size-xs);color:var(--color-fg);margin-bottom:var(--spacing-sp-xs);display:flex}.view-transform-checkbox-row>label{align-items:center;gap:var(--spacing-sp-xs);cursor:pointer;display:flex}.view-transform-checkbox-row input[type=checkbox]{accent-color:var(--color-accent)}.view-transform-slider-row input[type=range]{accent-color:var(--color-accent);flex:1}.view-transform-slider-row input[type=range]:disabled{opacity:.4;cursor:not-allowed}.view-transform-label{font-size:var(--font-size-xs);color:var(--color-fg-subtle);white-space:nowrap;flex-shrink:0;min-width:1rem;font-weight:500}.view-transform-value{font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;text-align:right;min-width:2.5rem;color:var(--color-fg-muted);flex-shrink:0}.view-transform-zoom-track{flex:1;position:relative}.view-transform-zoom-track input[type=range]{width:100%;accent-color:var(--color-accent)}.view-transform-zoom-tick{background:var(--color-fg-faint);pointer-events:none;width:1px;height:6px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.btn-view-transform-reset{padding:var(--spacing-sp-2xs) var(--spacing-sp-md);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg);font-size:var(--font-size-xs);cursor:pointer;margin-top:var(--spacing-sp-2xs)}.btn-view-transform-reset:hover{background:var(--color-control-bg-hover)}.button-row{margin-top:var(--spacing-sp-md);gap:var(--spacing-sp-sm);display:flex}.action-buttons{gap:var(--spacing-sp-sm);flex-direction:column;display:flex}.btn-download{flex:1}.selection-btn-edit{background:var(--color-control-bg)}.selection-btn-edit:hover{background:var(--color-control-bg-hover)}.image-overlay-section{border-top:1px solid var(--color-border-subtle);padding-top:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-md)}.image-overlay-section .section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-faint);margin-bottom:var(--spacing-sp-sm);font-weight:600;display:block}.image-import-area{justify-content:center;align-items:center;gap:var(--spacing-sp-2xs);padding:var(--spacing-sp-lg) var(--spacing-sp-md);border:1px dashed var(--color-border-hover);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg-muted);font-size:var(--font-size-sm);cursor:pointer;flex-direction:column;transition:border-color .15s,background .15s;display:flex}.image-import-area:hover,.image-import-area.dragging{border-color:var(--color-border-focus);background:var(--color-control-bg-hover)}.image-import-hint{font-size:var(--font-size-2xs);color:var(--color-fg-faint)}.processing-indicator{align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-md);font-size:var(--font-size-sm);color:var(--color-fg-muted);flex-direction:column;display:flex}@keyframes processing-spin{to{transform:rotate(360deg)}}.processing-spinner{border:2px solid var(--color-border);border-top-color:var(--color-fg-muted);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite processing-spin;display:inline-block}.processing-progress-bar{background:var(--color-control-bg);border-radius:2px;width:100%;height:4px;overflow:hidden}.processing-progress-fill{background:var(--color-fg-muted);border-radius:2px;height:100%;transition:width .3s}.canvas-regen-loader{bottom:var(--spacing-sp-lg);left:var(--spacing-sp-lg);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:80px;height:80px;z-index:var(--z-canvas-overlay);pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute}@keyframes regen-spin{to{transform:rotate(360deg)}}.canvas-regen-loader__spinner{border:4px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:44px;height:44px;animation:.9s linear infinite regen-spin}.deleted-pattern-overlay{pointer-events:none;z-index:var(--z-canvas-overlay);justify-content:center;align-items:center;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.deleted-pattern-message{padding:var(--spacing-sp-md) var(--spacing-sp-lg);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-fg-muted);font-size:var(--font-size-sm);margin:0}.image-overlay-clear-btn{width:100%;margin-bottom:var(--spacing-sp-sm)}.image-overlay-controls{gap:var(--spacing-sp-sm);flex-direction:column;display:flex}.image-overlay-slider-row{gap:var(--spacing-sp-2xs);flex-direction:column;display:flex}.image-overlay-label{font-size:var(--font-size-2xs);color:var(--color-fg-subtle)}.image-overlay-reset-btn{padding:var(--spacing-sp-2xs) var(--spacing-sp-md);border:1px solid var(--color-border-hover);border-radius:var(--radius-md);background:var(--color-control-bg);color:var(--color-fg);font-size:var(--font-size-2xs);cursor:pointer;align-self:flex-start}.image-overlay-reset-btn:hover{background:var(--color-control-bg-hover)}.image-overlay-aspect-row{gap:var(--spacing-sp-2xs);margin-bottom:var(--spacing-sp-sm);flex-direction:column;display:flex}.image-overlay-aspect-btns{gap:var(--spacing-sp-2xs);display:flex}.image-overlay-aspect-btn{font-size:var(--font-size-2xs);padding:var(--spacing-sp-2xs) var(--spacing-sp-sm);flex:1}.image-overlay-aspect-btn.active{background:var(--color-control-bg-hover);border-color:var(--color-border-focus)}.image-overlay-error{margin-top:var(--spacing-sp-xs);padding:var(--spacing-sp-xs) var(--spacing-sp-sm);font-size:var(--font-size-2xs);color:var(--color-danger)}.image-layer-panel{border-top:1px solid var(--color-border-subtle);padding-top:var(--spacing-sp-sm);margin-bottom:var(--spacing-sp-md)}.image-layer-panel .section-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-faint);margin-bottom:var(--spacing-sp-sm);font-weight:600;display:block}.image-layer-add{margin-bottom:var(--spacing-sp-sm);padding:var(--spacing-sp-sm) var(--spacing-sp-md)}.image-layer-list{max-height:240px;margin-bottom:var(--spacing-sp-sm);flex-direction:column;gap:2px;display:flex;overflow-y:auto}.image-layer-item{align-items:center;gap:var(--spacing-sp-xs);padding:var(--spacing-sp-2xs) var(--spacing-sp-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);cursor:pointer;font-size:var(--font-size-2xs);-webkit-user-select:none;user-select:none;transition:background .1s,border-color .1s;display:flex}.image-layer-item:hover{background:var(--color-control-bg-hover)}.image-layer-item.selected{border-color:var(--color-border-focus);background:var(--color-control-bg-hover)}.image-layer-item.dragging{opacity:.4}.image-layer-drag-handle{cursor:grab;color:var(--color-fg-faint);font-size:var(--font-size-xs);padding:0 2px;line-height:1}.image-layer-thumbnail{border-radius:var(--radius-sm);object-fit:contain;background:var(--color-control-bg);flex-shrink:0;width:40px;height:40px}.image-layer-thumbnail-empty{border-radius:var(--radius-sm);background:var(--color-control-bg);flex-shrink:0;width:40px;height:40px;display:inline-block}.image-layer-name{text-overflow:ellipsis;white-space:nowrap;color:var(--color-fg);flex:1;overflow:hidden}.image-layer-spinner{border-width:1.5px;flex-shrink:0;width:12px;height:12px}.image-layer-bg-toggle{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-control-bg);color:var(--color-fg-faint);cursor:pointer;flex-shrink:0;padding:2px 6px;font-size:9px;transition:background .1s,color .1s}.image-layer-bg-toggle.active{background:var(--color-control-bg-hover);color:var(--color-fg);border-color:var(--color-border-focus)}.image-layer-bg-toggle:hover{background:var(--color-control-bg-hover)}.image-layer-duplicate{color:var(--color-fg-faint);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;line-height:1}.image-layer-duplicate:hover{color:var(--color-fg)}.image-layer-delete{color:var(--color-fg-faint);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;line-height:1}.image-layer-delete:hover{color:var(--color-danger)}.image-layer-controls{gap:var(--spacing-sp-sm);flex-direction:column;display:flex}.info-popover-wrapper{display:inline-flex;position:relative}.info-trigger{color:var(--color-fg-faint);cursor:pointer;opacity:.6;background:0 0;border:none;padding:0 4px;font-size:14px;line-height:1;transition:opacity .15s}.info-trigger:hover{opacity:1}.info-popover{background:var(--color-surface-modal);color:var(--color-fg-muted);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sp-sm) var(--spacing-sp-md);font-size:var(--font-size-sm);max-width:250px;z-index:var(--z-selection);line-height:1.4;animation:.15s ease-out popover-fade-in;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.info-popover-arrow{background:var(--color-surface-modal);clip-path:polygon(0 0,100% 0,50% 100%);width:10px;height:5px;position:absolute;bottom:-5px;left:50%;transform:translate(-50%)}@keyframes popover-fade-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.save-pattern-field{margin-bottom:12px}.save-pattern-label{text-transform:uppercase;letter-spacing:.05em;color:var(--color-fg-subtle);margin-bottom:4px;font-size:11px;font-weight:500;display:block}.save-pattern-label-optional{text-transform:none;color:var(--color-fg-muted);font-weight:400}.save-pattern-textarea{resize:vertical;width:100%;min-height:60px;font-family:inherit;font-size:13px}.save-pattern-preview{border-radius:6px;max-height:120px;margin-bottom:12px;overflow:hidden}.save-pattern-preview img{object-fit:cover;width:100%;height:120px}.save-pattern-error{color:var(--color-danger);background:var(--color-danger-bg);border-radius:var(--radius-md);margin-bottom:8px;padding:8px 12px;font-size:12px}.save-pattern-slug-section{margin-bottom:12px}.save-pattern-slug-preview{align-items:center;gap:6px;font-size:11px;display:flex}.save-pattern-slug-label{color:var(--color-fg-subtle)}.save-pattern-slug-value{color:var(--color-fg-muted);background:var(--color-control-bg);border-radius:var(--radius-xs);border:1px solid var(--color-border-subtle);text-overflow:ellipsis;white-space:nowrap;max-width:200px;padding:1px 5px;font-family:monospace;font-size:11px;overflow:hidden}.save-pattern-slug-customize{font:inherit;color:var(--color-accent);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;flex-shrink:0;padding:0;font-size:11px;text-decoration:underline}.save-pattern-slug-customize:hover{opacity:.8}.save-pattern-slug-hint{color:var(--color-fg-subtle);margin-top:4px;font-size:10px;display:block}.image-upload-btn{width:100%;font-size:var(--font-size-2xs);margin-top:var(--spacing-sp-xs)}.media-browser-modal{max-width:600px}.media-browser-filter{margin-bottom:12px}.media-browser-filter input{background:var(--color-control-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-fg);outline:none;padding:6px 10px;font-size:12px}.media-browser-filter input:focus{border-color:var(--color-border-focus)}.image-layer-browse{color:var(--color-fg-faint);font-size:var(--font-size-sm);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;line-height:1}.image-layer-browse:hover{color:var(--color-fg)}[data-theme=light]{color-scheme:light;--palette-shadow-base:oklch(0% 0 0);--theme-move-accent:oklch(58% .2 50);--palette-canvas-handle-base:oklch(100% 0 0);--palette-canvas-dashed-base:var(--palette-fg);--shadow-dropdown:0 4px 12px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-dropdown:0 4px 12px color-mix(in oklch, var(--palette-shadow-base) 12%, transparent)}}[data-theme=light]{--shadow-modal:0 16px 48px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-modal:0 16px 48px color-mix(in oklch, var(--palette-shadow-base) 15%, transparent)}}[data-theme=light]{--shadow-modal-lg:0 24px 64px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-modal-lg:0 24px 64px color-mix(in oklch, var(--palette-shadow-base) 20%, transparent)}}[data-theme=light]{--shadow-menu:0 8px 24px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-menu:0 8px 24px color-mix(in oklch, var(--palette-shadow-base) 15%, transparent)}}[data-theme=light]{--shadow-canvas:0 4px 24px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-canvas:0 4px 24px color-mix(in oklch, var(--palette-shadow-base) 12%, transparent)}}[data-theme=light]{--shadow-strip-hover:0 2px 6px var(--palette-shadow-base)}@supports (color:color-mix(in lab,red,red)){[data-theme=light]{--shadow-strip-hover:0 2px 6px color-mix(in oklch, var(--palette-shadow-base) 8%, transparent)}}@media(prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}@media(max-width:640px){.site-link,.doc-link{display:none}input[type=text],input[type=number],input[type=email],input[type=search],input[type=password],input[type=url],select,textarea{font-size:16px!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
