.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:2rem 3rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-box h1{text-align:center;margin-bottom:.5rem;color:#333}.subtitle{text-align:center;color:#666;margin-bottom:2rem;font-size:.9rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem}.login-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .3s}.login-button:hover:not(:disabled){opacity:.9}.login-button:disabled{opacity:.6;cursor:not-allowed}.bounding-box-list{width:100%}.empty-message{color:#999;text-align:center;padding:2rem 1rem;font-size:.85rem}.annotation-items{display:flex;flex-direction:column;gap:.5rem}.annotation-item{padding:.75rem;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:border-color .15s;background:#fff}.annotation-item:hover{border-color:#999}.annotation-item.editing{border-color:#3b82f6;border-width:2px;padding:calc(.75rem - 1px)}.box-title{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e8e8e8}.annotation-actions{display:flex;gap:.5rem;margin-left:auto}.annotation-index{font-size:.75rem;color:#666;font-weight:500;min-width:22px;flex-shrink:0}.category-info{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.category-name{font-weight:500;color:#333;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-sub{font-size:.7rem;color:#888;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-button,.save-button,.delete-button{width:24px;height:24px;border-radius:3px;cursor:pointer;font-size:.9rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background-color .15s;flex-shrink:0;border:none;background:transparent}.edit-button{color:#3b82f6}.edit-button:hover{background:#f0f0f0}.save-button{color:#10b981;font-size:1.1rem;font-weight:700}.save-button:hover{background:#f0f0f0}.delete-button{color:#ef4444;font-size:1.2rem}.delete-button:hover{background:#f0f0f0}.annotation-details{font-size:.75rem;color:#333;display:flex;flex-direction:column;gap:.25rem}.detail-row{display:flex;gap:.5rem}.detail-label{color:#666;font-weight:400;min-width:35px}.detail-value{color:#333;font-family:SF Mono,Monaco,Courier New,monospace;font-size:.75rem}.detail-value.live{color:#3b82f6;font-weight:600}.annotation-canvas-container{display:flex;flex:1;overflow:hidden;position:relative}.canvas-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:1rem;overflow:auto;background:#f5f5f5}.canvas-wrapper>div{position:relative;display:inline-block;margin:1rem 0}.canvas-wrapper canvas{border:1px solid #ddd;box-shadow:0 2px 8px #0000001a;background:#fff;display:block;cursor:crosshair!important;touch-action:none;-webkit-user-select:none;user-select:none}.canvas-container{position:relative!important;display:inline-block!important;margin:0!important}.upper-canvas{cursor:crosshair!important;pointer-events:auto!important}.lower-canvas{pointer-events:none!important}.canvas-toolbar{display:flex;gap:1rem;margin-top:1rem;position:relative;z-index:10}.save-button,.delete-button{border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:opacity .3s}.save-button{background:#4caf50;color:#fff}.save-button:hover{opacity:.9}.delete-button{background:#f44336;color:#fff}.delete-button:hover{opacity:.9}.annotation-sidebar{display:flex;flex-direction:column;width:500px;background:#fff;border-left:1px solid #e0e0e0;overflow:hidden}.annotation-sidebar label,.annotation-sidebar span,.annotation-sidebar div,.annotation-sidebar select,.annotation-sidebar option{color:#333}.image-uploader{padding:1rem;border-bottom:1px solid #e0e0e0}.upload-button{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:opacity .3s}.upload-button:hover:not(:disabled){opacity:.9}.upload-button:disabled{opacity:.6;cursor:not-allowed}.upload-hint{text-align:center;color:#999;font-size:.85rem;margin-top:.5rem}.annotation-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a}.app-header h1{font-size:1.5rem;color:#fff;margin:0;font-weight:600}.annotation-layout{display:flex;flex:1;overflow:hidden}.image-sidebar{width:300px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;overflow-y:auto}.image-list{flex:1;padding:1rem}.image-list h3{margin-bottom:1rem;color:#333;font-size:1rem}.image-item{display:flex;align-items:center;padding:.75rem;margin-bottom:.75rem;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;background:#fff}.image-item:hover{background-color:#f8f9fa;transform:translate(4px);box-shadow:0 2px 4px #0000001a}.image-item.active{background-color:#e3f2fd;border-color:#667eea;border-width:2px;box-shadow:0 2px 8px #667eea4d}.image-item img{width:60px;height:60px;object-fit:cover;border-radius:4px;margin-right:.75rem;border:1px solid #e0e0e0}.image-item span{flex:1;font-size:.9rem;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.annotation-main{flex:1;display:flex;flex-direction:column;background:#f5f5f5;overflow:hidden}.no-image-selected{display:flex;justify-content:center;align-items:center;height:100%;color:#999}.categories-page{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:#f8f9fa}.categories-header{display:flex;justify-content:space-between;align-items:center;padding:0 2rem;height:64px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #0000001a}.header-left{display:flex;align-items:baseline;gap:1rem}.categories-header h1{font-size:1.5rem;color:#fff;margin:0;font-weight:600}.header-subtitle{font-size:.85rem;color:#ffffffe6;font-weight:400}.header-nav{display:flex;align-items:center;gap:1.5rem}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff3;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:all .2s ease;border:1px solid rgba(255,255,255,.3)}.nav-button:hover{background:#ffffff4d;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.nav-icon{font-size:1.1rem}.user-info{display:flex;align-items:center;gap:1rem;padding:.5rem 1rem;background:#ffffff26;border-radius:8px;border:1px solid rgba(255,255,255,.2)}.user-name{color:#fff;font-size:.9rem;font-weight:500}.logout-button{padding:.4rem 1rem;background:#ffffff40;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:5px;cursor:pointer;font-weight:500;transition:all .2s ease;font-size:.85rem}.logout-button:hover{background:#ffffff59;transform:scale(1.05)}.categories-content{flex:1;overflow-y:auto;padding:2rem;position:relative}.categories-grid-container{max-width:1400px;margin:0 auto}.grid-header{margin-bottom:2rem;text-align:center}.grid-header h2{font-size:2rem;color:#333;margin:0 0 .5rem;font-weight:600}.category-stats{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:.9rem;color:#666}.category-stats span{display:inline-block}.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-bottom:2rem}.category-card-grid{background:#fff;border-radius:8px;border:1px solid #e0e0e0;border-left-width:4px;padding:1rem;transition:all .2s ease;display:flex;flex-direction:column;gap:.75rem;min-height:100px}.category-card-grid:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.card-content{flex:1}.card-header{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem}.card-header h3{font-size:1rem;color:#333;margin:0;font-weight:600;flex:1}.card-code{padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.card-subcategories{display:flex;flex-wrap:wrap;gap:.4rem;font-size:.8rem}.subcat-tag{background:#f0f0f0;padding:.2rem .5rem;border-radius:4px;color:#666;font-size:.75rem}.card-actions{display:flex;gap:.5rem;padding-top:.75rem;border-top:1px solid #f0f0f0}.card-action-btn{flex:1;padding:.4rem .75rem;background:#fff;border:1px solid #e0e0e0;border-radius:5px;cursor:pointer;font-weight:500;font-size:.8rem;transition:all .2s ease;color:#666}.card-action-btn:hover{background:#f8f9fa;border-color:#667eea;color:#667eea}.card-action-btn.edit:hover{background:#667eea;color:#fff}.card-action-btn.add:hover{background:#764ba2;border-color:#764ba2;color:#fff}.add-main-category-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;max-width:400px;margin:0 auto;padding:1.25rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d}.add-main-category-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.add-main-category-btn span{font-size:1.5rem}.category-form-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.category-form{background:#fff;padding:2rem;border-radius:16px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.form-header h2{color:#333;margin:0;font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;color:#ccc;cursor:pointer;padding:.25rem .5rem;border-radius:6px;transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.close-button:hover{color:#333;background:#f0f0f0}.form-error{padding:1rem;background:#fee;border:2px solid #fcc;border-radius:8px;color:#c33;font-size:.9rem;margin-bottom:1.5rem;font-weight:500}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:600;font-size:.95rem}.form-group input{width:100%;padding:.875rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed;color:#999}.form-actions{display:flex;gap:1rem;margin-top:2rem}.submit-button,.cancel-button{flex:1;padding:.875rem 1.5rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .2s}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.submit-button:disabled{opacity:.5;cursor:not-allowed}.cancel-button{background:#fff;color:#666;border:2px solid #e0e0e0}.cancel-button:hover{border-color:#333;color:#333;background:#f8f9fa}*{margin:0;padding:0;box-sizing:border-box}body{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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
