.edit-callout{position:absolute;z-index:1000;display:flex;align-items:stretch;background:#1e1e1ef2;border-radius:10px;box-shadow:0 2px 12px #0000004d;animation:edit-callout-in .15s ease-out;pointer-events:auto;user-select:none;-webkit-user-select:none}.edit-callout-item{padding:8px 14px;color:#fff;font-size:14px;white-space:nowrap;cursor:pointer;display:flex;align-items:center}.edit-callout-item:first-child{border-radius:10px 0 0 10px}.edit-callout-item:last-child{border-radius:0 10px 10px 0}.edit-callout-item:only-child{border-radius:10px}.edit-callout-item:active{background:#ffffff26}.edit-callout-item--active{color:#6cf}.edit-callout-item--user-selected{color:#ffa940}.edit-callout-sep{width:1px;background:#ffffff40;align-self:stretch;margin:6px 0}.edit-callout-arrow{position:absolute;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent}.edit-callout-arrow--bottom{bottom:-7px;border-top:7px solid rgba(30,30,30,.95)}.edit-callout-arrow--top{top:-7px;border-bottom:7px solid rgba(30,30,30,.95)}@keyframes edit-callout-in{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.canvas-editor-wrapper{position:relative;width:fit-content;margin:12px;overflow:hidden;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.canvas-paper{position:relative;transform-origin:top center;box-shadow:0 2px 8px #00000026;transition:transform .1s ease}.canvas-page{position:relative;box-shadow:0 2px 8px #00000026}.canvas-main{display:block;cursor:text;background:#fff}.cursor-blink{position:absolute;background:#1890ff;animation:cursor-blink 1.06s step-end infinite;pointer-events:none;z-index:5}@keyframes cursor-blink{0%,50%{opacity:1}50.01%,to{opacity:0}}.cursor-blink.cursor-touch{background:#06f;box-shadow:0 0 2px #0066ff80}.ime-input{position:absolute;width:1px;height:24px;padding:0;border:none;outline:none;background:transparent;color:transparent;caret-color:transparent;resize:none;overflow:hidden;z-index:10;font-size:16px;font-family:Bpmf Zihi Kai Std,sans-serif}.selection-handle{position:absolute;width:56px;height:56px;transform:translate(-50%,-50%);touch-action:none;z-index:1000;cursor:grab}.selection-handle:before{content:"";position:absolute;left:50%;bottom:50%;width:2px;height:20px;background:#4285f4;transform:translate(-50%)}.selection-handle:after{content:"";position:absolute;left:50%;top:50%;width:10px;height:10px;background:#4285f4;border-radius:50%;transform:translate(-50%,-50%)}.selection-handle.handle-start:before{bottom:auto;top:50%}.selection-handle.vertical:before{inset:50% 50% auto auto;width:20px;height:2px;transform:translateY(-50%)}.selection-handle.vertical.handle-end:before{right:auto;left:50%}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.gallery-logo{width:28px;height:28px;cursor:pointer;transition:opacity .15s;margin-right:auto}.gallery-logo:hover{opacity:.7}.gallery{flex:1;overflow-y:auto;background:#e0e0e0;position:relative}.gallery--dragging:after{content:"放開以匯入 .bopo 檔案";position:absolute;inset:16px;border:3px dashed var(--color-primary);border-radius:var(--radius-lg);background:#1890ff14;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--color-primary);pointer-events:none;z-index:100}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,209px);gap:12px;padding:14px}@media(max-width:520px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;padding:10px}.gallery-card-thumb img{inset:10px;width:calc(100% - 20px);height:calc(100% - 20px)}.gallery .toolbar .ui-btn--icon{width:36px;height:36px}.gallery .toolbar .ui-btn--icon svg{width:24px;height:24px}.gallery .toolbar{flex-wrap:nowrap;overflow-x:auto;gap:6px}.gallery .toolbar .ui-btn--sm{padding:8px 12px;white-space:nowrap}.gallery .toolbar .ui-btn--sm svg{width:20px;height:20px}.gallery-select-count{font-weight:500;white-space:nowrap}.gallery-logo{width:32px;height:32px}}.gallery-card{cursor:pointer;position:relative}.gallery-card--add .gallery-card-thumb--add{border:2px dashed var(--color-border);background:transparent;color:var(--color-text-tertiary);transition:border-color .15s,color .15s;display:flex;align-items:center;justify-content:center}.gallery-card--add:hover .gallery-card-thumb--add{border-color:var(--color-primary);color:var(--color-primary)}.gallery-card-name--add{color:var(--color-text-tertiary);cursor:pointer;text-align:center}.gallery-card--add:hover .gallery-card-name--add{color:var(--color-primary)}.gallery-card:hover .gallery-card-thumb{transform:translateY(-2px)}.gallery-card:hover .gallery-card-thumb{box-shadow:0 4px 16px #0000001f}.gallery-card-thumb{aspect-ratio:1;background:#e8e8e8;border-radius:var(--radius-md);border:1px solid var(--color-border);overflow:hidden;position:relative}.gallery-card-thumb img{position:absolute;inset:8px;width:calc(100% - 16px);height:calc(100% - 16px);object-fit:contain}.gallery-card-thumb-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-disabled);font-size:11px}.gallery-card-menu-btn{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;border:none;background:#ffffffe6;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;color:var(--color-text-secondary);font-size:14px}.gallery-card:hover .gallery-card-menu-btn{opacity:1}.gallery-card-menu-btn:hover{background:#fffffff2;color:var(--color-text)}.gallery-card-footer{padding:4px 2px 0}.gallery-card-name{font-size:13px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text;padding:2px 4px;border-radius:var(--radius-sm);border:1px solid transparent}.gallery-card-name:hover{border-color:var(--color-border)}.gallery-card-name-input{width:100%;font-size:13px;color:var(--color-text);padding:2px 4px;border-radius:var(--radius-sm);border:1px solid var(--color-primary);outline:none;background:var(--color-bg)}.gallery-card-date{font-size:11px;color:var(--color-text-tertiary);padding:2px 4px}.gallery-select-count{font-size:var(--font-size-base);color:var(--color-text-secondary);padding:3px 8px 5px;border-radius:var(--radius-sm);min-width:80px;text-align:center}.gallery .toolbar .ui-btn--sm{font-size:var(--font-size-base);padding:3px 8px 5px}.gallery .toolbar .gallery-btn-delete.ui-btn{color:var(--color-danger)}.gallery .toolbar .gallery-btn-delete.ui-btn:disabled{color:var(--color-text-disabled)}.gallery .toolbar .gallery-btn-delete.ui-btn:hover:not(:disabled){background:var(--color-danger-bg)}.gallery-select-spacer{margin-right:auto}.gallery-card--selected .gallery-card-thumb{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary)}.gallery-card-checkbox{position:absolute;top:4px;left:4px;width:18px;height:18px;border-radius:50%;border:2px solid rgba(0,0,0,.3);background:#ffffffe6;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.gallery-card-checkbox--checked{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;color:var(--color-text-tertiary);gap:16px}.gallery-empty-icon{font-size:48px;opacity:.3}.gallery-empty-actions{display:flex;gap:12px}.gallery-empty-drop{margin-top:16px;padding:24px 48px;border:2px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-tertiary);font-size:14px}.gallery--dragging .gallery-empty-drop{border-color:var(--color-primary);background:#1890ff14;color:var(--color-primary)}.landing{flex:1;display:flex;align-items:flex-start;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);overflow-y:auto;padding:2rem 0}.landing-content{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem}.landing-logo{width:80px;height:80px;margin-bottom:1.5rem}.landing-title{font-size:2rem;font-weight:600;color:var(--color-text);margin:0 0 .75rem}.landing-desc{font-size:1rem;color:var(--color-text-secondary);margin:0 0 1.5rem;max-width:480px;line-height:1.6}.landing-screenshot{max-width:100%;width:600px;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;margin-bottom:2rem}.landing-btn{padding:.75rem 2rem;font-size:1.1rem;font-weight:500;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s,border-color .15s}.landing-btn:hover{background:var(--color-primary-hover)}.landing-btn--start{margin-bottom:2rem}.landing-buttons{display:flex;gap:.75rem;margin-bottom:2rem}.landing-btn--secondary{background:#fff;color:var(--color-text);border:1px solid var(--color-border)}.landing-btn--secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark)}.landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;max-width:800px;width:100%;margin-top:1rem}.landing-feature{background:#fff;border-radius:var(--radius-md);padding:1.25rem;text-align:center;box-shadow:0 2px 8px #0000000f}.landing-feature-icon{font-size:2rem;margin-bottom:.5rem}.landing-feature-title{font-size:1rem;font-weight:600;color:var(--color-text);margin-bottom:.25rem}.landing-feature-desc{font-size:.85rem;color:var(--color-text-secondary);line-height:1.4}.landing-footer{margin-top:2rem;font-size:.85rem;color:var(--color-text-tertiary);display:flex;flex-direction:column;align-items:center;gap:.5rem}.landing-footer-links{display:flex;align-items:center;gap:.5rem}.landing-footer-links button{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:inherit;padding:0}.landing-footer-links button:hover{color:var(--color-primary);text-decoration:underline}.landing-footer-copyright{font-size:.75rem}@media(max-width:520px){.landing{padding:1rem 0}.landing-content{padding:1rem}.landing-logo{width:60px;height:60px;margin-bottom:1rem}.landing-title{font-size:1.5rem}.landing-desc{font-size:.9rem}.landing-buttons{flex-direction:column;width:100%;max-width:280px}.landing-btn{padding:.6rem 1.5rem;font-size:1rem;width:100%}.landing-screenshot{width:100%;border-radius:var(--radius-md)}.landing-features{grid-template-columns:1fr;gap:1rem}.landing-feature{padding:1rem}.landing-feature-icon{font-size:1.5rem}.landing-feature-title{font-size:.9rem}.landing-feature-desc{font-size:.8rem}}.auto-correct-hint{position:fixed;top:50%;left:50%;transform:translate(-50%);background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;z-index:1000;display:flex;flex-direction:column;gap:12px;max-width:360px;animation:hint-slide-up .2s ease-out}@keyframes hint-slide-up{0%{opacity:0;transform:translate(-50%) scale(.95)}to{opacity:1;transform:translate(-50%) scale(1)}}.auto-correct-hint-message{font-size:14px;color:var(--color-text);line-height:1.5}.auto-correct-hint-actions{display:flex;align-items:center;gap:12px}.auto-correct-hint-checkbox{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-secondary);cursor:pointer;margin-right:auto}.auto-correct-hint-checkbox input{margin:0;cursor:pointer}@media(max-width:480px){.auto-correct-hint{width:85%;max-width:none}}:root{--color-primary: #1890ff;--color-primary-dark: #1677ff;--color-primary-hover: #4096ff;--color-primary-bg: #e6f0ff;--color-primary-bg-alt: #e6f7ff;--color-danger: #e53e3e;--color-danger-bg: #fff5f5;--color-success: #52c41a;--color-text: #333;--color-text-secondary: #666;--color-text-tertiary: #999;--color-text-disabled: #bbb;--color-border: #d9d9d9;--color-border-dark: #ccc;--color-border-light: #eee;--color-bg: #fff;--color-bg-hover: #f5f5f5;--color-bg-alt: #f0f0f0;--shadow-dropdown: 0 2px 8px rgba(0, 0, 0, .12);--shadow-modal: 0 4px 24px rgba(0, 0, 0, .2);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 14px;--font-size-lg: 16px}.global-tooltip{padding:4px 8px;background:#1e1e1eeb;color:#fff;font-size:var(--font-size-base);font-weight:400;line-height:1.4;white-space:nowrap;border-radius:var(--radius-sm);pointer-events:none}.ui-btn{padding:4px 12px;border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text);display:inline-flex;align-items:center;justify-content:center}.ui-btn:hover:not(:disabled){background:var(--color-bg-hover);border-color:#999}.ui-btn:disabled{color:var(--color-text-disabled);cursor:default}.ui-btn--toggle.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.ui-btn--icon{width:32px;height:32px;padding:0}.ui-btn--ghost{background:transparent;border-color:transparent}.ui-btn--ghost:hover:not(:disabled){background:var(--color-bg-hover);border-color:transparent}.ui-btn--ghost.active{background:var(--color-primary-bg);border-color:transparent}.ui-btn--primary{padding:8px 20px;background:var(--color-primary-dark);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);gap:4px}.ui-btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.ui-btn--cancel{padding:8px 20px;background:var(--color-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base)}.ui-btn--cancel:hover:not(:disabled){color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.ui-btn--danger{padding:8px 16px;background:var(--color-bg);color:var(--color-danger);border:1px solid var(--color-danger)}.ui-btn--danger:hover:not(:disabled){background:var(--color-danger-bg)}.ui-btn--danger:disabled{color:var(--color-border-dark);border-color:#ddd}.ui-btn--ghost{border:none;background:transparent;padding:4px 8px}.ui-btn--ghost:hover:not(:disabled){background:var(--color-bg-alt);border:none}.ui-btn--sm{padding:4px 8px;font-size:var(--font-size-sm)}.ui-popover-overlay{position:fixed;inset:0;z-index:999}.ui-popover{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown);z-index:1000;min-width:64px;padding:4px 0;overflow:hidden}.ui-popover--absolute{position:absolute}.ui-popover--fixed{position:fixed}.ui-popover-title{padding:6px 12px;font-size:12px;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border-light)}.ui-popover-item{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--font-size-base);cursor:pointer;white-space:nowrap}.ui-popover-item svg{flex-shrink:0}.ui-popover-item:hover{background:var(--color-bg-hover)}.ui-popover-item.active{color:var(--color-primary);font-weight:600}.ui-popover-item.selected{background:var(--color-primary-bg-alt);color:var(--color-primary)}.ui-popover-item.selected-orange{background:#fff7e6;color:#fa8c16}.ui-popover-item.disabled{color:var(--color-text-disabled);cursor:default;pointer-events:none}.ui-popover-zoom-row{display:flex;align-items:center;justify-content:space-between;padding:4px 6px;gap:2px}.ui-popover-zoom-btn{width:28px;height:28px;border:none;background:transparent;border-radius:var(--radius-sm);font-size:16px;cursor:pointer;color:var(--color-text);display:flex;align-items:center;justify-content:center}.ui-popover-zoom-btn:hover{background:var(--color-bg-hover)}.ui-popover-zoom-label{font-size:13px;min-width:36px;text-align:center}.ui-popover-divider{border:none;border-top:1px solid var(--color-border-light);margin:4px 0}.ui-modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:2000}.ui-modal{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);width:calc(100vw - 32px);max-width:480px;max-height:90dvh;display:flex;flex-direction:column;overflow:hidden}.ui-modal--wide{max-width:720px}.ui-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--color-border-light)}.ui-modal-header h2{margin:0;font-size:var(--font-size-lg);font-weight:600;display:flex;align-items:center;gap:6px}.ui-modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--color-text-tertiary);padding:0 4px}.ui-modal-close:hover{color:var(--color-text)}.ui-modal-tabs{display:flex;border-bottom:1px solid var(--color-border-light);padding:0 20px}.ui-modal-tab{padding:8px 16px;border:none;background:none;font-size:var(--font-size-base);color:var(--color-text-secondary);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.ui-modal-tab:hover{color:var(--color-text)}.ui-modal-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:500}.ui-modal-body{padding:20px;overflow-y:auto}.ui-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.ui-btn-group{display:flex}.ui-btn-group .ui-btn{border-radius:0}.ui-btn-group .ui-btn+.ui-btn{border-left:none}.ui-btn-group .ui-btn:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.ui-btn-group .ui-btn:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.ui-btn-group .ui-btn:hover:not(:disabled){border-color:#999}.ui-btn-group .ui-btn:hover:not(:disabled)+.ui-btn{border-left-color:#999}.ui-btn-group .ui-btn--toggle.active{border:1px solid var(--color-primary);margin-left:-1px;position:relative;z-index:1}.ui-btn-group .ui-btn--toggle.active:first-child{margin-left:0}.ui-separator--vertical{width:0;height:20px;align-self:center;border-left:1px solid var(--color-border-dark)}.ui-separator--horizontal{border:none;border-top:1px solid #e0e0e0;margin:16px 0}.ui-select{position:relative;display:inline-flex}.ui-select-trigger{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text);height:32px;white-space:nowrap}.ui-select-trigger:hover{border-color:#999}.ui-select-trigger .ui-select-label{flex:1;overflow:hidden;text-overflow:ellipsis;min-width:0}.ui-select-trigger .ui-select-arrow{flex-shrink:0}.ui-icon-dropdown{display:inline-flex;align-items:center;justify-content:center;gap:1px;width:32px;height:32px;padding:0;border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;color:var(--color-text)}.ui-icon-dropdown:hover:not(:disabled){background:var(--color-bg-hover);border-color:#999}.ui-icon-dropdown:disabled{opacity:.4;cursor:default;pointer-events:none}.ui-icon-dropdown-arrow{font-size:8px;color:var(--color-text-tertiary);line-height:1}.ui-select-trigger .ui-select-arrow{font-size:14px;color:var(--color-text-tertiary);line-height:1;font-family:system-ui,sans-serif}.ui-combo{position:relative;height:32px}.ui-combo--disabled{opacity:.4;pointer-events:none}.ui-combo-input{width:100%;height:100%;border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);background:var(--color-bg);text-align:center;font-size:14px;color:var(--color-text);padding:0 20px 0 4px;cursor:text}.ui-combo-input:hover{border-color:#999}.ui-combo-input:focus{outline:none;border-color:var(--color-primary)}.ui-combo-arrow{position:absolute;right:0;top:0;width:20px;height:100%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--color-text-tertiary);cursor:pointer;border:none;background:none;padding:0}.font-select-search{position:sticky;top:0;padding:6px 8px;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);z-index:1}.font-select-search input{width:100%;padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;outline:none;box-sizing:border-box}.font-select-search input:focus{border-color:var(--color-primary)}.font-select-body{max-height:400px;overflow-y:auto}.font-select-action{padding:6px 12px;font-size:13px;color:var(--color-primary);cursor:pointer;display:flex;align-items:center;gap:4px}.font-select-action:hover{background:var(--color-bg-hover)}.font-select-action.disabled{color:var(--color-text-disabled);cursor:default;pointer-events:none}.font-select-manual{padding:6px 8px;display:flex;gap:4px}.font-select-manual input{flex:1;min-width:0;padding:4px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:13px;outline:none}.font-select-manual input:focus{border-color:var(--color-primary)}.font-select-manual input.error{border-color:var(--color-danger)}.font-select-manual button{padding:4px 10px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:13px;cursor:pointer;white-space:nowrap}.font-select-manual button:hover{background:var(--color-primary-hover)}.font-select-error{padding:2px 12px 6px;font-size:12px;color:var(--color-danger)}.font-select-force{margin-left:8px;color:var(--color-primary);cursor:pointer;text-decoration:underline}.ui-color-picker{position:relative;display:inline-block}.ui-color-picker-trigger{display:flex;flex-direction:column;align-items:center;justify-content:center;width:32px;height:32px;padding:4px;border:1px solid var(--color-border-dark);border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;gap:2px}.ui-color-picker-trigger:hover:not(:disabled){background:var(--color-bg-hover);border-color:#999}.ui-color-picker-trigger:disabled{opacity:.4;cursor:default}.ui-color-picker-icon{font-size:14px;font-weight:600;line-height:1;color:var(--color-text)}.ui-color-picker-bar{width:16px;height:3px;border-radius:1px}.ui-color-picker-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-dropdown);z-index:1000;padding:8px}.ui-color-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:4px}.ui-color-picker-swatch{width:20px;height:20px;border:2px solid transparent;border-radius:50%;cursor:pointer;padding:0}.ui-color-picker-swatch:hover{transform:scale(1.1)}.ui-color-picker-swatch.active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-bg)}.ui-color-picker-swatch.light{border-color:var(--color-border)}.ui-color-picker-reset{display:block;width:100%;padding:6px 8px;border:none;background:none;font-size:13px;color:var(--color-text-secondary);cursor:pointer;text-align:left}.ui-color-picker-reset:hover{background:var(--color-bg-hover);color:var(--color-text)}.ui-switch{position:relative;width:44px;height:24px;padding:0;border:none;border-radius:12px;background:var(--color-border);cursor:pointer;transition:background .2s}.ui-switch:hover:not(:disabled){background:var(--color-border-dark)}.ui-switch.checked{background:var(--color-primary)}.ui-switch.checked:hover:not(:disabled){background:var(--color-primary-hover)}.ui-switch:disabled{opacity:.5;cursor:not-allowed}.ui-switch-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:left .2s}.ui-switch.checked .ui-switch-thumb{left:22px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-bg-alt)}.app{display:flex;flex-direction:column;height:100%}.toolbar{background:var(--color-bg);border-bottom:1px solid #ddd;padding:8px 16px;display:flex;align-items:center;gap:2px;flex-wrap:wrap;overflow-x:clip}.toolbar--two-rows{flex-direction:column;align-items:flex-start;padding:8px 16px;gap:4px}.toolbar-row{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.toolbar h1{font-size:var(--font-size-base);font-weight:500;color:var(--color-text)}.toolbar-logo{width:28px;height:28px;margin-right:4px;cursor:pointer;transition:opacity .15s}.toolbar-logo:hover{opacity:.7}.toolbar .ui-btn-group .ui-btn--toggle{padding:4px 8px}.toolbar-name{font-size:var(--font-size-base);cursor:text;padding:2px 6px;border-radius:var(--radius-sm);border:1px solid transparent;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar-name:hover{border-color:var(--color-border)}.toolbar-name-input{font-size:var(--font-size-base);font-weight:500;color:var(--color-text);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--color-primary);outline:none;background:var(--color-bg);max-width:200px}.save-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-tertiary);margin-left:4px;vertical-align:middle}.save-indicator--saving{color:var(--color-text-secondary)}.save-indicator--saving svg{animation:save-spin .8s linear infinite}.save-indicator--saved{color:var(--color-success)}@keyframes save-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fontsize-control{display:flex;align-items:center}.toolbar-spacer{flex:1}.toolbar .ui-btn{border-color:transparent}.toolbar .ui-btn:hover:not(:disabled){border-color:transparent}.toolbar .ui-btn--toggle.active{border-color:transparent;background:var(--color-primary-bg);color:var(--color-primary)}.toolbar .ui-select-trigger{border-color:transparent}.toolbar .ui-select-trigger:hover{border-color:transparent;background:var(--color-bg-hover)}.toolbar .ui-icon-dropdown,.toolbar .ui-icon-dropdown:hover,.toolbar .ui-color-picker-trigger{border-color:transparent}.toolbar .ui-color-picker-trigger:hover:not(:disabled){border-color:transparent}.toolbar .ui-combo-input,.toolbar .ui-combo-input:hover{border-color:transparent;background:var(--color-bg-hover)}.toolbar .ui-combo-input:focus{border-color:var(--color-primary)}.toolbar .ui-btn-group .ui-btn+.ui-btn{border-left-color:transparent}.toolbar .ui-btn-group .ui-btn:hover:not(:disabled)+.ui-btn{border-left-color:transparent}.toolbar .ui-btn-group .ui-btn--toggle.active{border-color:transparent}.toolbar .ui-btn-group .ui-btn--toggle.active+.ui-btn:not(.active){border-left-color:transparent}.editor-container{flex:1;overflow:auto;padding:0;display:flex;justify-content:safe center;background:#e0e0e0;position:relative}.page-indicator{position:fixed;bottom:12px;right:12px;background:#0009;color:#fff;padding:4px 10px;border-radius:12px;font-size:12px;pointer-events:none;z-index:100}.g2pw-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.g2pw-panel{background:#000000d9;border-radius:16px;padding:32px 48px;display:flex;flex-direction:column;align-items:center;gap:16px}.g2pw-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:g2pw-spin .8s linear infinite}.g2pw-status{color:#fff;font-size:16px;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.4)}.g2pw-hint{color:#fffc;font-size:14px;text-shadow:0 1px 3px rgba(0,0,0,.4)}.g2pw-cancel{padding:6px 24px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-sm);font-size:14px;cursor:pointer}.g2pw-cancel:hover{background:#ffffff26}.g2pw-result-icon{width:48px;height:48px;border:3px solid var(--color-success);border-radius:50%;color:var(--color-success);font-size:28px;display:flex;align-items:center;justify-content:center;line-height:1}@keyframes g2pw-spin{to{transform:rotate(360deg)}}.status-bar{display:flex;align-items:center;gap:16px;height:24px;padding:0 12px;background:#e8e8e8;color:var(--color-text-secondary);font-size:12px;flex-shrink:0;overflow:visible}.status-item{white-space:nowrap}.status-corrected{color:var(--color-success)}.status-uncorrected{color:var(--color-text-tertiary)}.status-tip-icon{width:14px;height:14px;fill:var(--color-text-tertiary);vertical-align:-2px;margin-right:2px;flex-shrink:0}.status-tip{color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.status-zoom{display:flex;align-items:center;gap:4px;flex-shrink:0}.status-zoom-action{width:20px!important;height:20px!important;font-size:13px!important;color:var(--color-text-secondary)!important;border-radius:3px!important;padding:0!important}.status-zoom-action:hover{color:var(--color-text)!important}.status-zoom-slider{width:80px;height:4px;appearance:none;background:#ddd;border-radius:2px;outline:none;cursor:pointer}.status-zoom-slider::-webkit-slider-thumb{appearance:none;width:12px;height:12px;background:#888;border-radius:50%;cursor:pointer}.status-zoom-slider::-webkit-slider-thumb:hover{background:var(--color-text-secondary)}@media(max-width:600px){.status-zoom-action,.hide-mobile{display:none}}.status-zoom-menu-wrap{position:relative}.status-zoom-popover{top:100%;right:0;margin-top:4px;padding:8px}.status-zoom-popover-main{display:flex;align-items:stretch;gap:8px}.status-zoom-slider-vertical{writing-mode:vertical-lr;direction:rtl;width:4px;appearance:none;background:#ddd;border-radius:2px;outline:none;cursor:pointer;margin:7px 0}.status-zoom-slider-vertical::-webkit-slider-thumb{appearance:none;width:12px;height:12px;background:#888;border-radius:50%;cursor:pointer}.status-zoom-slider-vertical::-webkit-slider-thumb:hover{background:var(--color-text-secondary)}.status-zoom-presets{display:flex;flex-direction:column}.status-zoom-btn{background:var(--color-bg);border:1px solid transparent;color:var(--color-text);font-size:14px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);height:32px;min-width:48px;text-align:center}.status-zoom-btn:hover{background:var(--color-bg-hover)}.status-stats-wrap{position:relative}.status-stats-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:3px;white-space:nowrap}.status-stats-btn:hover{background:#e0e0e0;color:var(--color-text)}.status-stats-popover{bottom:100%;left:0;margin-bottom:4px;min-width:120px;padding:8px 12px}.status-stats-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.status-stats-label{color:var(--color-text-secondary)}.status-stats-value{color:var(--color-text);font-weight:500;margin-left:16px}.status-page-nav{display:flex;align-items:center;justify-content:center;gap:4px;padding-top:4px}.status-page-nav-btn{width:28px;height:28px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg);color:var(--color-text);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.status-page-nav-btn:hover:not(:disabled){background:var(--color-bg-hover)}.status-page-nav-btn:disabled{opacity:.4;cursor:not-allowed}.status-page-nav-input{width:48px;height:28px;border:1px solid var(--color-border);border-radius:4px;text-align:center;font-size:13px;background:var(--color-bg);color:var(--color-text)}.status-page-nav-input:focus{outline:none;border-color:var(--color-primary)}.modal-setting-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0}.modal-setting-label{font-size:14px;color:var(--color-text)}.modal-columns{display:flex;gap:24px}.modal-col{flex:1;min-width:0}.modal-col+.modal-col{border-left:1px solid var(--color-border-light);padding-left:24px}@media(max-width:600px){.modal-columns{flex-direction:column}.modal-col+.modal-col{border-left:none;padding-left:0;border-top:1px solid var(--color-border-light);padding-top:16px}}.modal-section-indent{padding-left:16px}.modal-row-group{display:flex;flex-direction:column;gap:8px}.modal-row{display:flex;align-items:center;gap:12px}.modal-row-label{min-width:36px;font-size:14px;color:var(--color-text-secondary)}.modal-margin-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;width:200px;margin-top:12px}.settings-control-wide{width:200px;display:flex;justify-content:flex-end}.settings-margin-control{width:200px;display:flex;flex-direction:column;align-items:stretch}.settings-margin-buttons{display:flex;width:200px}.settings-margin-buttons .ui-btn{flex:1;height:32px}.settings-control-wide .ui-btn,.settings-control-wide .ui-select-trigger{height:32px}.modal-margin-field{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.modal-margin-grid>:nth-child(odd){justify-self:start}.modal-margin-grid>:nth-child(2n){justify-self:end}.modal-margin-input{width:48px;height:32px;padding:2px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);text-align:center;outline:none}.modal-margin-input:focus{border-color:var(--color-primary)}.modal-margin-unit{font-size:12px;color:var(--color-text-tertiary)}.modal-storage-row{display:flex;align-items:center;gap:12px}.modal-storage-size{font-size:13px;color:var(--color-text-secondary)}.modal-hint{margin:8px 0 0;font-size:12px;color:var(--color-text-tertiary)}.modal-checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.modal-app-name{margin:0;font-size:18px;font-weight:600}.modal-version{margin:4px 0 0;font-size:14px;color:var(--color-text-tertiary)}.modal-copyright{margin:4px 0 0;font-size:12px;color:var(--color-text-tertiary)}.modal-copyright a{color:var(--color-text-tertiary)}.modal-copyright a:hover{color:#2563eb}.modal-intro{margin:12px 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.modal-section-title{margin:0 0 8px;font-size:13px;font-weight:600;color:var(--color-text-secondary)}.modal-credits{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}.modal-credits li{display:flex;flex-direction:column;gap:2px}.modal-credits a{font-size:13px;font-weight:500;color:#2563eb;text-decoration:none}.modal-credits a:hover{text-decoration:underline}.modal-credit-detail{font-size:12px;color:var(--color-text-secondary)}.modal-credit-license{font-size:11px;color:var(--color-text-tertiary)}.modal-legal-content{font-size:12px;color:#555;line-height:1.6;padding:8px 0 4px}.modal-legal-content p{margin:6px 0}.modal-legal-content ul{margin:4px 0;padding-left:20px}.modal-legal-content li{margin:2px 0}.app.addon-mode .toolbar{padding:4px 8px;gap:4px}.app.addon-mode .toolbar .ui-select-trigger{width:180px!important}.app.addon-mode .editor-container{background:#fff}.app.addon-mode .status-bar{display:none}.canvas-editor-wrapper.seamless-mode{overflow:visible;margin:0}.canvas-editor-wrapper.seamless-mode .canvas-page,.canvas-editor-wrapper.seamless-mode .canvas-paper{box-shadow:none}.canvas-editor-wrapper.seamless-mode .canvas-main{border:none}.addon-insert-bar{position:fixed;bottom:12px;left:50%;transform:translate(-50%);z-index:100}.addon-insert-btn{padding:10px 24px;font-size:15px;font-weight:500;border:none;border-radius:20px;cursor:pointer;background:var(--color-primary);color:#fff;box-shadow:0 2px 8px #0003;transition:background .15s,transform .1s}.addon-insert-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:scale(1.02)}.addon-insert-btn:disabled{opacity:.7;cursor:not-allowed}.addon-insert-btn.pending{background:#888}.addon-insert-btn.success{background:var(--color-success)}.addon-insert-btn.error{background:var(--color-danger)}.mobile-toolbar{background:var(--color-bg);border-bottom:1px solid #ddd;flex-shrink:0}.mobile-toolbar-row1{display:flex;align-items:center;justify-content:space-between;padding:6px 8px}.mobile-toolbar-left{display:flex;align-items:center;gap:2px}.mobile-toolbar-logo{width:32px;height:32px;cursor:pointer}.mobile-toolbar-center{flex:1;display:flex;justify-content:flex-start;align-items:center;gap:4px;min-width:0}.mobile-toolbar-name{font-size:20px;font-weight:500;color:var(--color-text);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:4px 8px;border-radius:var(--radius-sm)}.mobile-toolbar-name:active{background:var(--color-bg-hover)}.mobile-toolbar-name-input{font-size:20px;font-weight:500;color:var(--color-text);padding:4px 8px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);outline:none;background:var(--color-bg);max-width:200px;text-align:center}.mobile-toolbar-right{display:flex;align-items:center;gap:2px}.mobile-toolbar-row2{display:flex;align-items:center;gap:2px;padding:2px 6px 5px}.mobile-toolbar-style-item{position:relative;display:flex;align-items:center}.mobile-toolbar-style-btn{display:flex;align-items:center;gap:1px;padding:2px 6px;height:36px;background:var(--color-bg);border:1px solid transparent;border-radius:var(--radius-sm);font-size:var(--font-size-lg);color:var(--color-text);cursor:pointer}.mobile-toolbar-style-btn:hover{background:var(--color-bg-hover)}.mobile-toolbar-style-btn:disabled{opacity:.4;cursor:default}.mobile-toolbar-size-btn{min-width:36px;justify-content:center}.mobile-toolbar-font-label{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-toolbar-arrow{font-size:14px;color:var(--color-text-tertiary)}.mobile-toolbar-sep{width:1px;height:18px;background:var(--color-border);margin:0 1px}.mobile-toolbar .ui-btn{border-color:transparent}.mobile-toolbar .ui-btn:hover:not(:disabled){border-color:transparent}.mobile-toolbar .ui-btn--toggle.active{border-color:transparent;background:var(--color-primary-bg);color:var(--color-primary)}.mobile-toolbar .ui-btn--icon{width:36px;height:36px;font-size:20px}.mobile-toolbar .ui-btn--icon svg{width:24px;height:24px}.mobile-toolbar .ui-color-picker-trigger{width:36px;height:36px;padding:0;border-color:transparent}.mobile-toolbar .ui-color-picker-icon{font-size:18px}.mobile-toolbar .ui-color-picker-bar{width:20px;height:4px}.mobile-toolbar .ui-icon-dropdown{width:36px;height:36px}.mobile-toolbar .ui-color-picker-trigger:hover:not(:disabled){border-color:transparent}.mobile-toolbar .ui-icon-dropdown,.mobile-toolbar .ui-icon-dropdown:hover{border-color:transparent}.mobile-menu-overlay{position:fixed;inset:0;background:#0000004d;z-index:1000}.mobile-menu{position:fixed;right:12px;top:calc(56px + env(safe-area-inset-top,0px));bottom:max(12px,env(safe-area-inset-bottom,0px));width:280px;background:#fff;border-radius:14px;box-shadow:0 8px 32px #00000026;z-index:1001;display:flex;flex-direction:column;overflow:hidden;animation:mobile-menu-slide-in .25s ease-out}@keyframes mobile-menu-slide-in{0%{transform:translate(calc(100% + 12px));opacity:.5}to{transform:translate(0);opacity:1}}.mobile-menu-header{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 12px 14px 16px;border-bottom:1px solid var(--color-border-light);flex-shrink:0;gap:8px}.mobile-menu-header-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.mobile-menu-name{display:inline-flex;align-items:center;gap:6px;font-size:20px;font-weight:500;color:var(--color-text);cursor:pointer}.mobile-menu-name svg{flex-shrink:0;color:var(--color-text-tertiary)}.mobile-menu-name-input{font-size:20px;font-weight:500;border:none;outline:none;background:transparent;color:var(--color-text);padding:0;margin:0;width:100%}.mobile-menu-meta{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.mobile-menu-content{flex:1;overflow-x:hidden;overflow-y:auto}.mobile-menu-group{background:transparent}.mobile-menu-group:first-child{padding-top:8px}.mobile-menu-group:last-child{padding-bottom:8px}.mobile-menu-divider{height:8px;background:#0000000d;flex-shrink:0}.mobile-menu-item{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;align-items:center;gap:2px 8px;padding:14px 16px;background:none;border:none;font-size:var(--font-size-lg);color:var(--color-text);cursor:pointer;text-align:left;width:100%}.mobile-menu-item:disabled{opacity:.5;cursor:not-allowed}.mobile-menu-item:active:not(:disabled){background:#00000014}.mobile-menu-group .mobile-menu-item+.mobile-menu-item{border-top:1px solid var(--color-border-light)}.mobile-menu-item-text{grid-column:2;grid-row:1}.mobile-menu-item-hint{grid-column:1 / 3;grid-row:2;font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-weight:400}.mobile-menu-item>svg:first-child{grid-column:1;grid-row:1}.mobile-menu-item>svg:last-of-type,.mobile-menu-item>.ui-switch,.mobile-menu-item>.mobile-menu-zoom{grid-column:3;grid-row:1}.mobile-menu-item>svg:first-child:last-of-type{grid-column:3}.mobile-menu-item>.mobile-menu-item-text:first-child{grid-column:1 / 3}.mobile-menu-item>svg{fill:var(--color-text-secondary)}.mobile-menu-zoom{display:flex;align-items:center;gap:4px}.mobile-menu-zoom button{width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:#0000000f;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text)}.mobile-menu-zoom button:active{background:#0000001f}.mobile-menu-zoom button.active{background:var(--color-primary);color:#fff}.mobile-menu-zoom button.active svg{fill:#fff}.mobile-menu-zoom-value{min-width:44px;text-align:center;font-size:var(--font-size-base);color:var(--color-text-secondary)}.mobile-submenu-overlay{position:absolute;inset:0;background:#0000001a;border-radius:14px}.mobile-submenu{position:absolute;right:0;width:100%;background:var(--color-bg);border-radius:12px;box-shadow:0 4px 20px #0003;overflow:hidden}.mobile-submenu--down{animation:mobile-submenu-slide-down .15s ease-out}.mobile-submenu--up{animation:mobile-submenu-slide-up .15s ease-out}@keyframes mobile-submenu-slide-down{0%{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes mobile-submenu-slide-up{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}.mobile-submenu-header{display:flex;align-items:center;gap:4px;width:100%;padding:14px 16px;border:none;background:none;font-size:20px;font-weight:600;color:var(--color-text);cursor:pointer;border-bottom:1px solid var(--color-border-light)}.mobile-submenu-header:active{background:#0000000d}.mobile-submenu-header svg{fill:currentColor}.mobile-submenu .mobile-menu-item{padding:12px 14px;font-size:19px}.mobile-submenu .mobile-menu-item+.mobile-menu-item{border-top:1px solid var(--color-border-light)}.mobile-submenu-section{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;gap:12px}.mobile-submenu-section+.mobile-submenu-section{border-top:1px solid var(--color-border-light)}.mobile-submenu-section+.mobile-menu-item{border-top:1px solid var(--color-border-light)}.mobile-submenu-label{font-size:17px;color:var(--color-text);flex-shrink:0}.mobile-submenu-options{display:flex;gap:6px}.mobile-submenu-option{padding:6px 12px;border:none;border-radius:var(--radius-sm);background:#0000000f;font-size:15px;color:var(--color-text);cursor:pointer}.mobile-submenu-option:active{background:#0000001f}.mobile-submenu-option.active{background:var(--color-primary);color:#fff}.mobile-submenu-option--icon{padding:6px;display:flex;align-items:center;justify-content:center}.settings-group{padding:12px 0}.settings-group:first-child{padding-top:0}.settings-divider{height:8px;background:#0000000a;margin:0 -20px}.settings-item{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:2px 16px;padding:10px 0}.settings-item+.settings-item{border-top:1px solid var(--color-border-light)}.settings-item-label{grid-column:1;grid-row:1;align-self:start;line-height:32px;font-size:var(--font-size-base);color:var(--color-text)}.settings-item-hint{grid-column:1;grid-row:2;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.settings-item>:not(.settings-item-label):not(.settings-item-hint){grid-column:2;grid-row:1;align-self:center}@media(max-width:520px){:root{--font-size-xs: 12px;--font-size-sm: 14px;--font-size-base: 18px;--font-size-lg: 20px}}
