*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}h1{font-size:2rem;margin-bottom:.25rem}.subtitle{color:#555;margin-bottom:1.5rem}.drop-zone{width:100%;max-width:720px;border:3px dashed #b0b8c8;border-radius:16px;padding:3rem 1rem;text-align:center;cursor:pointer;transition:background .2s,border-color .2s;background:#fff;margin-bottom:1.5rem}.drop-zone.dragover{background:#e8f0fe;border-color:#4a7dff}.drop-zone p{font-size:1.1rem;color:#666}.drop-zone .browse{display:inline-block;margin-top:.75rem;padding:.5rem 1.5rem;background:#4a7dff;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer}.drop-zone .browse:hover{background:#3a6ae8}.spinner{margin:1rem 0;font-size:1.1rem;color:#4a7dff}.spinner:after{content:"";display:inline-block;width:18px;height:18px;border:3px solid #4a7dff;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-left:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.canvas-wrapper{width:100%;max-width:720px;margin-bottom:1.5rem}canvas{width:100%;border-radius:12px;box-shadow:0 2px 12px #0000001f}.object-list{width:100%;max-width:720px}.object-list h2{font-size:1.25rem;margin-bottom:.75rem}.obj-entry{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#fff;border-radius:10px;margin-bottom:.5rem;box-shadow:0 1px 4px #0000000f}.color-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}.obj-cutout,.nb-cutout{object-fit:contain;background:#f0f0f0;border-radius:6px;flex-shrink:0;cursor:pointer;transition:transform .15s}.obj-cutout:hover,.nb-cutout:hover{transform:scale(1.15)}.obj-cutout{width:40px;height:40px}.nb-cutout{width:36px;height:36px}.cutout-lightbox{display:none;position:fixed;inset:0;background:#0009;z-index:1100;justify-content:center;align-items:center;cursor:pointer}.cutout-lightbox.active{display:flex}.cutout-lightbox img{max-width:90vw;max-height:80vh;object-fit:contain;background:#fff;border-radius:12px;padding:1rem;box-shadow:0 8px 32px #0000004d;animation:modalIn .2s ease}.obj-label{font-weight:600;font-size:1.05rem}.obj-label-zh{color:#888;font-size:.95rem}.obj-labels{flex:1;display:flex;align-items:baseline;gap:.5rem}.obj-conf{color:#666;font-size:.95rem}.btn-add{background:#4a7dff;color:#fff;border:none;border-radius:6px;width:28px;height:28px;font-size:1.1rem;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .2s}.btn-add:hover{background:#3a6ae8}.btn-add.added{background:#aaa;cursor:default}.notebook{width:100%;max-width:720px;margin-top:1.5rem}.notebook-header{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;margin-bottom:.75rem}.notebook-header h2{font-size:1.25rem}.notebook-badge{background:#4a7dff;color:#fff;font-size:.8rem;font-weight:700;padding:.1rem .5rem;border-radius:10px;min-width:22px;text-align:center}.notebook-toggle{margin-left:auto;font-size:.9rem;color:#888}.notebook-entries{overflow:hidden;transition:max-height .3s ease}.nb-entry{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:#fff;border-radius:10px;margin-bottom:.5rem;box-shadow:0 1px 4px #0000000f}.nb-word{font-weight:600;font-size:1.05rem;cursor:pointer;color:#4a7dff;transition:color .2s}.nb-word:hover{color:#2a5acc;text-decoration:underline}.nb-zh{color:#888;font-size:.95rem;flex:1}.btn-dict,.btn-remove{border:none;border-radius:6px;padding:.3rem .7rem;font-size:.85rem;cursor:pointer;transition:background .2s}.btn-dict{background:#e8f0fe;color:#4a7dff}.btn-dict:hover{background:#d0e0fc}.btn-remove{background:#fde8e8;color:#e53e3e}.btn-remove:hover{background:#fcd0d0}.notebook-empty{color:#999;font-size:.95rem;padding:.5rem 0}.modal-overlay{display:none;position:fixed;inset:0;background:#00000073;z-index:1000;justify-content:center;align-items:center;padding:1rem}.modal-overlay.active{display:flex}.modal{background:#fff;border-radius:16px;width:100%;max-width:520px;max-height:80vh;overflow-y:auto;padding:1.5rem;position:relative;box-shadow:0 8px 32px #0003;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;line-height:1}.modal-close:hover{color:#333}.dict-word{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.dict-phonetic{color:#888;font-size:1.05rem;margin-bottom:1rem}.dict-pos{font-weight:600;font-size:1rem;color:#4a7dff;margin-top:.75rem;margin-bottom:.35rem;font-style:italic}.dict-def{margin-bottom:.3rem;line-height:1.5}.dict-example{color:#666;font-style:italic;margin-left:1rem;margin-bottom:.5rem;font-size:.95rem}.dict-loading,.dict-error{text-align:center;padding:2rem 0;color:#888;font-size:1.05rem}.dict-error{color:#e53e3e}
