:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;min-width:320px;min-height:100vh;background-color:#f5f5f5}button{border-radius:6px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:all .25s ease}button:hover{border-color:#667eea}button:focus,button:focus-visible{outline:2px solid #667eea;outline-offset:2px}input[type=color],input[type=range]{cursor:pointer}.share-wrapper{position:relative}.share-btn{border-radius:6px 0 0 6px}.share-popup{position:absolute;top:calc(100% + 10px);right:0;background:#1e1e2e;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:12px;min-width:300px;max-width:400px;box-shadow:0 8px 24px #0006;animation:popupFadeIn .2s ease-out;z-index:1000}.share-popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85rem;font-weight:600;color:#ffffffe6}.share-popup-close{background:none;border:none;color:#ffffff80;cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:4px}.share-popup-close:hover{color:#ffffffe6;background:#ffffff1a}.share-popup-link{background:#0000004d;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:8px 10px;font-size:.75rem;color:#ffffffb3;word-break:break-all;margin-bottom:10px;-webkit-user-select:all;user-select:all}.share-popup-actions{display:flex;gap:8px}.share-popup-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:6px;background:#ffffff0f;color:#ffffffd9;font-size:.8rem;cursor:pointer;transition:background .15s,border-color .15s}.share-popup-btn:hover{background:#ffffff1f;border-color:#ffffff40}.share-popup-auth{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08);font-size:.75rem;color:#ffffff80}.share-popup-auth-logout{background:none;border:none;color:#fff6;cursor:pointer;font-size:.75rem;padding:4px 8px;border-radius:4px;transition:color .15s,background .15s}.share-popup-auth-logout:hover{color:#ef5350;background:#ef53501a}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.snackbar-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999}.snackbar-message{background-color:#323232;color:#fff;padding:12px 24px;border-radius:4px;font-size:.9rem;font-weight:500;box-shadow:0 3px 6px #00000029,0 3px 6px #0000003b;animation:slideIn .3s ease-in-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.shortcuts-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.shortcuts-modal{background-color:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease-in-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shortcuts-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.shortcuts-modal-header h2{margin:0;font-size:1.5rem;color:#333}.shortcuts-close-btn{background:none;border:none;cursor:pointer;color:#999;display:flex;align-items:center;justify-content:center;transition:color .2s ease;padding:.25rem}.shortcuts-close-btn:hover{color:#333}.shortcuts-modal-content{flex:1;overflow-y:auto;padding:1.5rem}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.shortcut-item{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;background-color:#f9f9f9;border-radius:6px;border-left:3px solid #667eea}.shortcut-key{background-color:#333;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:600;white-space:nowrap;font-family:Monaco,Courier New,monospace;flex-shrink:0}.shortcut-description{font-size:.9rem;color:#555;line-height:1.4}.shortcuts-modal-footer{padding:1rem 1.5rem;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end}.shortcuts-close-button{padding:.6rem 1.5rem;background-color:#667eea;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.shortcuts-close-button:hover{background-color:#5568d3;transform:translateY(-2px);box-shadow:0 2px 8px #667eea4d}.shortcuts-close-button:active{transform:translateY(0)}.shortcuts-modal-content::-webkit-scrollbar{width:6px}.shortcuts-modal-content::-webkit-scrollbar-track{background:#f1f1f1}.shortcuts-modal-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.shortcuts-modal-content::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 600px){.shortcuts-modal{width:95%;max-height:90vh}.shortcuts-grid{grid-template-columns:1fr}.shortcuts-modal-header,.shortcuts-modal-content{padding:1rem}.shortcuts-modal-footer{padding:.75rem 1rem}}.minimap-container{position:fixed;bottom:20px;right:20px;background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000026;z-index:100;overflow:hidden;animation:slideIn .3s ease-in-out}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.minimap-header{padding:8px 12px;background-color:#f5f5f5;border-bottom:1px solid #e0e0e0;font-size:.85rem;font-weight:600;color:#333;-webkit-user-select:none;user-select:none;display:flex;justify-content:space-between;align-items:center;gap:8px}.minimap-controls{display:flex;gap:4px}.minimap-btn{background:none;border:none;padding:4px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.minimap-btn:hover{background-color:#e0e0e0;color:#333}.minimap-btn:active{background-color:#d0d0d0}.minimap-canvas{display:block;background-color:#fafafa}@media (max-width: 768px){.minimap-container{bottom:10px;right:10px}.minimap-header{padding:6px 10px;font-size:.8rem}}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}.annotate-container{display:flex;flex-direction:column;height:100vh;background-color:#fff;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.status-bar{padding:.5rem 1.5rem;border-top:1px solid #e0e0e0;background-color:#f9f9f9;text-align:left;font-size:.8rem}.status-bar p{margin:0;color:#666;font-weight:500;display:flex;gap:1rem;align-items:center}.status-shortcut-link{background:none;border:none;color:#667eea;font-size:.8rem;font-weight:500;cursor:pointer;margin-left:auto;padding:0;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.status-shortcut-link:hover{color:#5568d3}.annotate-main{display:flex;flex-direction:column;flex:1;overflow:hidden}.annotate-toolbar{display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 2rem;background-color:#fff;border-bottom:1px solid #e0e0e0;align-items:center;box-shadow:0 2px 4px #0000000f}.annotate-toolbar>.tool-group:last-child{margin-left:auto}.annotate-toolbar>.tool-group+.tool-group:before{content:"";display:block;width:1px;height:24px;background:#d0d0d0;margin-right:.5rem}.shape-toolbar{display:flex;flex-wrap:nowrap;gap:1.5rem;padding:.75rem 2rem;background-color:#f8f8f8;border-bottom:1px solid #e0e0e0;align-items:center;box-shadow:0 1px 2px #00000008;overflow-x:auto;overflow-y:hidden}.toolbar-placeholder{font-size:.9rem;color:#999;font-style:italic;margin:0 auto}.annotate-content{display:flex;flex:1;overflow:hidden;gap:1px;background-color:#e0e0e0}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;padding:0;background-color:#fff;overflow:hidden;position:relative}.drawing-canvas{border:none;border-radius:0;background-color:#fff;cursor:default;box-shadow:none;display:block}.empty-state{position:absolute;display:flex;align-items:center;justify-content:center;color:#999;font-size:1.1rem;text-align:center;pointer-events:none}.empty-state p{margin:0;color:#999;font-weight:500}.layers-panel{width:280px;background-color:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;transition:width .2s ease}.layers-panel h3{margin:0;padding:1rem;border-bottom:1px solid #e0e0e0;font-size:1rem;color:#333;background-color:#fafafa}.layers-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e0e0e0;background-color:#fafafa;gap:.5rem}.layers-panel-header h3{margin:0;padding:0;border-bottom:none;font-size:1rem;color:#333;background-color:transparent;flex:1;min-width:0}.layers-list{flex:1;overflow-y:auto;padding:.5rem}.no-layers{padding:1rem;text-align:center;color:#999;font-size:.9rem;margin-top:2rem}.layer-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;margin-bottom:.5rem;background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease}.layer-item:hover{background-color:#f0f0f0;border-color:#ddd}.layer-item.selected{background-color:#e8eeff;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.layer-item.layer-placeholder{background-color:#f5f5f5;border:1px dashed #ccc;cursor:default;opacity:.7}.layer-item.layer-placeholder:hover{background-color:#f5f5f5;border-color:#ccc}.layer-content{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.layer-info{display:flex;flex-direction:column;flex:1;min-width:0;gap:.25rem}.layer-text-preview{font-size:.8rem;color:#999;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.layer-text-edit{display:flex;align-items:center;flex:1;min-width:0;padding:.25rem}.layer-text-input{width:100%;padding:.4rem .5rem;border:1px solid #667eea;border-radius:4px;font-size:.9rem;font-family:inherit;box-sizing:border-box}.layer-text-input:focus{outline:none;box-shadow:0 0 0 2px #667eea33}.layer-visibility{background:none;border:none;padding:.25rem;cursor:pointer;color:#999;display:flex;align-items:center;justify-content:center;transition:color .2s ease;flex-shrink:0}.layer-visibility:hover{color:#667eea}.layer-color-swatch{width:16px;height:16px;border-radius:3px;border:1px solid #ccc;flex-shrink:0;box-shadow:inset 0 0 1px #0003}.layer-name{font-size:.85rem;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.layer-actions{display:flex;gap:.25rem;margin-left:.5rem}.layer-btn{background:none;border:none;padding:.25rem;cursor:pointer;color:#999;display:flex;align-items:center;justify-content:center;transition:color .2s ease;border-radius:4px}.layer-btn:hover{color:#667eea;background-color:#667eea1a}.layer-btn-delete{color:#f44336}.layer-btn-delete:hover{color:#fff;background-color:#f44336}.layer-btn:disabled{opacity:.5;cursor:not-allowed}.tool-group{display:flex;align-items:center;gap:.5rem}.tool-group label{font-weight:500;font-size:.9rem;color:#333;margin-right:.3rem}.tool-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid #ddd;border-radius:6px;background-color:#fff;cursor:pointer;transition:all .2s ease;color:#666;padding:0}.tool-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2}.tool-btn:hover:not(:disabled){border-color:#667eea;color:#667eea;transform:translateY(-2px);box-shadow:0 2px 8px #667eea33}.tool-btn.active{background-color:#667eea;border-color:#667eea;color:#fff;box-shadow:0 2px 8px #667eea4d}.tool-btn.active:hover{background-color:#5568d3;border-color:#5568d3;color:#fff;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.tool-btn:disabled{opacity:.5;cursor:not-allowed}.color-picker{width:40px;height:40px;border:none;border-radius:6px;cursor:pointer;box-shadow:0 1px 3px #0000001a}.size-slider{width:100px;height:6px;cursor:pointer;accent-color:#667eea}.size-display{font-weight:500;color:#333;min-width:45px;text-align:right;font-size:.9rem}.line-style-select{padding:.5rem .8rem;border:1px solid #ddd;border-radius:6px;background-color:#fff;cursor:pointer;font-size:.9rem;color:#333;min-width:120px;transition:all .2s ease}.line-style-select:hover{border-color:#667eea;box-shadow:0 1px 3px #667eea1a}.line-style-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.zoom-display{font-weight:500;color:#333;min-width:60px;text-align:center;font-size:.9rem}.action-btn{display:flex;align-items:center;gap:.4rem;padding:.6rem 1rem;border:1px solid #ddd;border-radius:6px;background-color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;color:#333;transition:all .2s ease;white-space:nowrap}.action-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}.action-btn:hover:not(:disabled){border-color:#667eea;color:#667eea;background-color:#f0f4ff;transform:translateY(-2px);box-shadow:0 2px 8px #667eea33}.action-btn:disabled{opacity:.4;cursor:not-allowed}.export-dropdown-wrapper{display:flex;align-items:center;position:relative}.export-dropdown-toggle{display:flex;align-items:center;justify-content:center;background:none;border:1px solid #ddd;border-left:none;border-radius:0 6px 6px 0;padding:.5rem .35rem;cursor:pointer;color:#555;transition:all .2s ease}.export-dropdown-toggle:hover{background-color:#f0f4ff;border-color:#667eea;color:#667eea}.export-dropdown-menu{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;min-width:160px;padding:4px}.export-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;font-size:.85rem;color:#333;border-radius:6px;transition:background .15s ease}.export-dropdown-item:hover{background-color:#f0f4ff;color:#667eea}.app-menu-wrapper{position:relative}.app-menu-btn{border-radius:6px}.app-menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #0000001f;z-index:100;min-width:200px;padding:4px}.app-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:none;cursor:pointer;font-size:.85rem;color:#333;border-radius:6px;transition:background .15s ease;text-decoration:none}.app-menu-item:hover{background-color:#f0f4ff;color:#667eea}.app-menu-about{cursor:default;color:#888;font-size:.8rem;border-top:1px solid #eee;margin-top:2px;padding-top:10px}.app-menu-about:hover{background:none;color:#888}.clear-btn{background-color:#f44336;border-color:#f44336;color:#fff}.clear-btn:hover:not(:disabled){background-color:#da190b;border-color:#da190b;box-shadow:0 2px 8px #f443364d}.format-btn{background:none;border:none;padding:4px 6px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.format-btn:hover{color:#667eea;background-color:#667eea1a}.format-btn.active{background-color:#667eea;color:#fff}.option-btn{background:none;border:none;padding:2px 6px;cursor:pointer;color:#666;font-size:.7rem;display:flex;align-items:center;gap:4px;border-radius:4px;transition:all .2s ease}.option-btn:hover{color:#667eea;background-color:#667eea1a}.option-btn.muted{opacity:.5}.option-btn-group{display:flex;align-items:center;gap:4px}.layers-panel.collapsed{width:36px;min-width:36px}.layers-panel.collapsed .layers-panel-header h3,.layers-panel.collapsed .layers-list,.layers-panel.collapsed .layers-panel-header .layer-btn{display:none}.layers-panel.collapsed .layers-panel-header{padding:.5rem;justify-content:center}.layers-toggle-btn{background:none;border:none;padding:4px;cursor:pointer;color:#666;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.layers-toggle-btn:hover{color:#667eea;background-color:#667eea1a}.stamp-picker{display:flex;gap:1rem;align-items:flex-start}.stamp-category{display:flex;align-items:center;gap:.4rem}.stamp-category-label{font-size:.7rem;color:#999;font-weight:500;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.stamp-category-items{display:flex;gap:2px}.stamp-btn{width:34px;height:34px;padding:3px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease}.stamp-btn:hover{background-color:#667eea1a;border-color:#ddd}.stamp-btn.active{background-color:#667eea;border-color:#667eea}.text-input-modal{position:absolute;background-color:#fff;border:2px solid #667eea;border-radius:8px;padding:1rem;box-shadow:0 4px 16px #0003;z-index:1000;min-width:300px}.text-input-field{width:100%;padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit;margin-bottom:.75rem;box-sizing:border-box}.text-input-field:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.text-input-buttons{display:flex;gap:.5rem;justify-content:flex-end}.text-btn-submit,.text-btn-cancel{padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.text-btn-submit{background-color:#667eea;color:#fff}.text-btn-submit:hover{background-color:#5568d3;transform:translateY(-2px);box-shadow:0 2px 8px #667eea4d}.text-btn-cancel{background-color:#f0f0f0;color:#333}.text-btn-cancel:hover{background-color:#e0e0e0;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.layers-list::-webkit-scrollbar{width:6px}.layers-list::-webkit-scrollbar-track{background:#f1f1f1}.layers-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.layers-list::-webkit-scrollbar-thumb:hover{background:#999}@media (max-width: 1024px){.layers-panel{width:240px}.annotate-toolbar{gap:1rem;padding:.75rem 1rem}}@media (max-width: 768px){.annotate-header{padding:1rem}.annotate-header h1{font-size:1.5rem}.annotate-toolbar{gap:.75rem;padding:.5rem 1rem}.canvas-container{padding:1rem}.layers-panel{width:200px}.tool-btn{width:36px;height:36px}.action-btn{padding:.5rem .8rem;font-size:.85rem}.tool-group{gap:.3rem}}@media (max-width: 600px){.annotate-content{flex-direction:column}.layers-panel{width:100%;height:200px;border-left:none;border-top:1px solid #e0e0e0}.annotate-toolbar{gap:.5rem;padding:.5rem;font-size:.85rem}.action-btn .btn-text{display:none}.action-btn{padding:.5rem;width:40px;height:40px;justify-content:center}.action-btn svg{width:20px;height:20px}.btn-text,.download-format-select{display:none}}.update-prompt{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:12px;background:#323232;color:#fff;padding:12px 20px;border-radius:8px;font-size:.9rem;font-weight:500;box-shadow:0 4px 12px #0000004d;animation:slideUp .3s ease-out}.update-prompt-btn{background:#667eea;color:#fff;border:none;padding:6px 16px;border-radius:4px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.update-prompt-btn:hover{background:#5a6fd6}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}
