.canvas-editor-wrapper{position:relative;display:flex;justify-content:center;align-items:flex-start}.canvas-paper{transform-origin:top center;box-shadow:0 2px 8px #00000026;transition:transform .1s ease}.canvas-main{display:block;cursor:text;background:#fff}.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:Bopomofo,sans-serif}.context-menu-overlay{position:fixed;inset:0;z-index:100}.context-menu{position:fixed;background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:101;min-width:120px;padding:4px 0}.context-menu-title{padding:8px 12px;font-size:12px;color:#666;border-bottom:1px solid #eee}.context-menu-item{padding:8px 12px;cursor:pointer;font-size:14px}.context-menu-item:hover{background:#f5f5f5}.context-menu-item.selected{background:#e6f7ff;color:#1890ff}.context-menu-separator{border-top:1px solid #eee;margin:4px 0}.context-menu-item.disabled{color:#bbb;cursor:default;pointer-events:none}.context-menu-divider{height:1px;background:#eee;margin:4px 0}.hover-reading-menu{position:fixed;background:#fff;border:1px solid #d9d9d9;border-radius:4px;padding:4px 0;box-shadow:0 2px 8px #00000026;z-index:1000;min-width:80px}.hover-reading-title{padding:4px 12px;font-size:12px;color:#999}.hover-reading-item{padding:4px 12px;cursor:pointer;font-size:13px}.hover-reading-item:hover{background:#f5f5f5}.hover-reading-item.selected{color:#1890ff;font-weight:700}*{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:#f0f0f0}.app{display:flex;flex-direction:column;height:100%}.toolbar{background:#fff;border-bottom:1px solid #ddd;padding:8px 16px;display:flex;align-items:center;gap:16px}.toolbar h1{font-size:16px;font-weight:500;color:#333}.toolbar-history{display:flex;gap:2px}.toolbar-history button{width:28px;height:28px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:16px;color:#333;display:flex;align-items:center;justify-content:center;padding:0}.toolbar-history button:hover:not(:disabled){background:#f5f5f5;border-color:#999}.toolbar-history button:disabled{color:#bbb;cursor:default}.fontsize-control{display:flex;align-items:center;margin-left:auto}.fontsize-combo{position:relative;width:56px;height:28px}.fontsize-input{position:absolute;inset:0;width:100%;height:100%;border:1px solid #ccc;border-radius:4px;background:#fff;text-align:center;font-size:13px;color:#333;padding:0 16px 0 4px;cursor:default}.fontsize-input:focus{outline:none;border-color:#1890ff;cursor:text}.fontsize-select{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.fontsize-combo:after{content:"▾";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:10px;color:#999;pointer-events:none}.zoom-control{display:flex;align-items:center;gap:2px}.zoom-control button{width:28px;height:28px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:16px;color:#333;display:flex;align-items:center;justify-content:center;padding:0}.zoom-control button:hover{background:#f5f5f5;border-color:#999}.zoom-combo{position:relative;width:72px;height:28px}.zoom-input{position:absolute;inset:0;width:100%;height:100%;border:1px solid #ccc;border-radius:4px;background:#fff;text-align:center;font-size:13px;color:#333;padding:0 16px 0 4px;cursor:default}.zoom-input:focus{outline:none;border-color:#1890ff;cursor:text}.zoom-select{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.zoom-combo:after{content:"▾";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:10px;color:#999;pointer-events:none}.toolbar-actions{display:flex;gap:8px;flex:1}.toolbar-spacer{flex:1}.toolbar-actions select{padding:4px 8px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:13px;color:#333}.toolbar-actions button{padding:4px 12px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:13px;color:#333}.toolbar-actions button:hover{background:#f5f5f5;border-color:#999}.toolbar-actions button.active{background:#e6f0ff;border-color:#1890ff;color:#1890ff}.margin-edit-btn{padding:4px 8px!important;font-size:12px!important}.toolbar-separator{width:1px;background:#ccc;align-self:stretch;margin:2px 0}.editor-container{flex:1;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:40px;background:#e0e0e0;position:relative}.g2pw-overlay{position:fixed;inset:0;background:#00000059;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;gap:20px}.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-cancel{padding:6px 24px;background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:4px;font-size:14px;cursor:pointer}.g2pw-cancel:hover{background:#ffffff26}@keyframes g2pw-spin{to{transform:rotate(360deg)}}.status-bar{display:flex;align-items:center;gap:16px;height:24px;padding:0 12px;background:#e8e8e8;color:#666;font-size:12px;flex-shrink:0}.status-item{white-space:nowrap}.modal-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:2000}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 24px #0003;min-width:320px;max-width:480px}.modal:has(.modal-body-wide){max-width:720px}.modal-columns{display:flex;gap:24px}.modal-col{flex:1;min-width:0}.modal-col+.modal-col{border-left:1px solid #eee;padding-left:24px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid #eee}.modal-header h2{margin:0;font-size:16px;font-weight:600}.modal-close{background:none;border:none;font-size:18px;cursor:pointer;color:#999;padding:0 4px}.modal-close:hover{color:#333}.modal-body{padding:20px}.modal-danger-btn{padding:8px 16px;background:#fff;color:#e53e3e;border:1px solid #e53e3e;border-radius:4px;cursor:pointer;font-size:13px}.modal-danger-btn:hover:not(:disabled){background:#fff5f5}.modal-danger-btn:disabled{color:#ccc;border-color:#ddd;cursor:default}.modal-storage-row{display:flex;align-items:center;gap:12px}.modal-storage-size{font-size:13px;color:#666}.modal-hint{margin:8px 0 0;font-size:12px;color:#999}.modal-divider{border:none;border-top:1px solid #e0e0e0;margin:16px 0}.modal-app-name{margin:0;font-size:18px;font-weight:600}.modal-version{margin:4px 0 0;font-size:14px;color:#999}.modal-copyright{margin:4px 0 0;font-size:12px;color:#999}.modal-copyright a{color:#999}.modal-copyright a:hover{color:#2563eb}.modal-section-title{margin:0 0 8px;font-size:13px;font-weight:600;color:#666}.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:#666}.modal-credit-license{font-size:11px;color:#999}.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}
