:root{--bg-primary: #1e1e1e;--bg-secondary: #252526;--bg-tertiary: #2d2d2d;--bg-hover: #333333;--border-primary: #424242;--border-secondary: #505050;--accent-primary: #6272a4;--accent-secondary: #8e9ecc;--accent-tertiary: #506d9e;--success: #50fa7b;--warning: #ffb86c;--danger: #ff5555;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-muted: #808080;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--glow-primary: 0 0 15px rgba(98, 114, 164, .3);--glow-secondary: 0 0 15px rgba(142, 158, 204, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Consolas,Courier New,monospace;background:var(--bg-primary);color:var(--text-primary);line-height:1.5}.max-w-7xl{max-width:80rem;margin-left:auto;margin-right:auto}.app{display:flex;flex-direction:column;min-height:100vh}.navbar{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:100}.navbar-container{max-width:7xl;margin:0 auto;padding:0 1rem}@media (min-width: 640px){.navbar-container{padding:0 1.5rem}}@media (min-width: 768px){.navbar-container{padding:0 1.75rem}}.navbar-content{display:flex;justify-content:space-between;align-items:center;height:4rem}.navbar-logo{font-size:1.25rem;font-weight:700;color:var(--accent-primary);text-decoration:none;padding:.5rem 0}.navbar-logo:hover{color:var(--accent-secondary)}.navbar-menu{display:flex;align-items:center;gap:1rem}.navbar-link,.navbar-button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;font-family:inherit;transition:all .2s ease;text-decoration:none}.navbar-link:hover,.navbar-button:hover{color:var(--text-primary)}.navbar-link.active,.navbar-button.active{color:var(--accent-primary)}.navbar-btn-primary{background:var(--accent-primary);color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;transition:all .2s ease}.navbar-btn-primary:hover{background:var(--accent-secondary);transform:translateY(-1px)}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.1rem;font-weight:600;color:var(--accent-primary)}.logo-icon{width:32px;height:32px;background:var(--accent-primary);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-shadow:var(--shadow-md)}.header-nav{display:flex;gap:.5rem}.nav-btn{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-radius:4px}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.nav-btn.active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.main-content{display:flex;flex:1;overflow:hidden}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;overflow:hidden}.sidebar-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.sidebar-header h3{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.sidebar-content{flex:1;overflow-y:auto;padding:1rem}.sidebar-item{padding:.75rem 1rem;margin-bottom:.5rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.sidebar-item:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.sidebar-item.active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.sidebar-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.sidebar-item-title{font-size:.85rem;font-weight:500}.sidebar-item-meta{display:flex;gap:.5rem;font-size:.7rem;color:var(--text-muted)}.sidebar-item.active .sidebar-item-meta{color:#0a0a0fb3}.upload-btn{width:100%;padding:.75rem 1rem;margin-bottom:1rem;background:var(--accent-primary);border:none;color:#fff;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;border-radius:6px;transition:all .2s ease;box-shadow:var(--shadow-md)}.upload-btn:hover{background:var(--accent-secondary);transform:translateY(-1px);box-shadow:var(--glow-primary)}.panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.panel-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between}.panel-header h2{font-size:.9rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.panel-content{flex:1;overflow-y:auto;padding:1rem}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);position:relative;overflow:hidden}.canvas-wrapper{overflow:hidden;position:relative;box-shadow:var(--shadow-lg)}.canvas-overlay{position:absolute;top:1rem;left:1rem;right:1rem;display:flex;justify-content:space-between;pointer-events:none;z-index:10}.canvas-tools{display:flex;gap:.5rem;pointer-events:auto}.tool-btn{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.8rem;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.tool-btn:disabled{opacity:.5;cursor:not-allowed}.tool-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent-primary)}.tool-btn.active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.tool-group{display:flex;gap:.25rem;padding:.25rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:6px}.tool-btn-group{display:flex;gap:.25rem}.info-panel{width:300px;background:var(--bg-secondary);border-left:1px solid var(--border-primary);display:flex;flex-direction:column}.info-panel-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-primary)}.info-panel-header h3{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-panel-content{flex:1;overflow-y:auto;padding:1rem}.info-section{margin-bottom:1.5rem}.info-section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border-secondary);font-size:.8rem}.info-row:last-child{border-bottom:none}.info-label{color:var(--text-secondary)}.info-value{color:var(--accent-primary);font-family:inherit}.annotation-list{display:flex;flex-direction:column;gap:.75rem}.annotation-controls{padding:1rem;border-bottom:1px solid var(--border-secondary);background:var(--bg-tertiary)}.annotation-controls .label-input{margin-bottom:0}.annotation-item{padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.annotation-item:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.annotation-item.selected{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.annotation-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.annotation-item-label{font-size:.8rem;font-weight:500}.annotation-item-type{font-size:.7rem;padding:.2rem .5rem;background:var(--bg-primary);border-radius:3px;color:var(--text-muted)}.annotation-item.selected .annotation-item-type{background:#0a0a0f4d;color:#0a0a0fb3}.annotation-item-data{font-size:.75rem;color:var(--text-muted);font-family:inherit}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.empty-state-desc{font-size:.85rem}.loading{display:flex;align-items:center;justify-content:center;padding:2rem;color:var(--text-muted)}.loading:after{content:"";width:20px;height:20px;border:2px solid var(--border-secondary);border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.badge{display:inline-flex;align-items:center;padding:.2rem .5rem;font-size:.7rem;font-weight:500;border-radius:3px;background:var(--bg-primary);border:1px solid var(--border-secondary)}.badge.success{background:#10b98133;border-color:var(--success);color:var(--success)}.badge.warning{background:#f59e0b33;border-color:var(--warning);color:var(--warning)}.badge.danger{background:#ef444433;border-color:var(--danger);color:var(--danger)}.grid-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.stat-card{padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;text-align:center}.stat-card-value{font-size:1.5rem;font-weight:700;color:var(--accent-primary);margin-bottom:.25rem}.stat-card-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.full-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--bg-primary)}.selection-container{max-width:900px;width:100%}.selection-container .title{font-size:2rem;font-weight:700;color:var(--accent-primary);text-align:center;margin-bottom:.5rem;text-shadow:1px 1px 3px rgba(0,0,0,.1)}.selection-container .subtitle{font-size:1rem;color:var(--text-secondary);text-align:center;margin-bottom:2rem}.projects-list{margin-bottom:2rem}.section-title{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:1rem}.project-card{display:flex;gap:1rem;padding:1rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:.75rem}.project-card:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.project-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px}.project-info{flex:1}.project-info h4{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.project-type{font-size:.75rem;color:var(--accent-primary);font-weight:500;margin-bottom:.5rem}.project-desc{font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem}.project-stats{display:flex;flex-direction:column;gap:.5rem}.progress-label{font-size:.7rem;color:var(--text-muted)}.progress-bar{width:100%;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--accent-primary);transition:width .3s ease}.create-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-primary)}.btn-create{width:100%;padding:1rem;background:var(--bg-tertiary);border:2px dashed var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease}.btn-create:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.create-form{margin-top:1rem}.type-selector{margin-bottom:1.5rem}.type-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem}.type-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.type-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.85rem;cursor:pointer;border-radius:8px;transition:all .2s ease}.type-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.type-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.type-icon{font-size:1.5rem}.type-name{font-weight:500}.form-fields{display:flex;flex-direction:column;gap:1rem}.form-input,.form-textarea{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);color:var(--text-primary);font-family:inherit;font-size:.9rem;border-radius:6px;transition:all .2s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.form-textarea{min-height:80px;resize:vertical}.form-actions{display:flex;gap:.75rem}.btn-cancel,.btn-create-new{flex:1;padding:.75rem;font-family:inherit;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.btn-cancel{background:var(--bg-hover);border:1px solid var(--border-secondary);color:var(--text-secondary)}.btn-cancel:hover{background:var(--bg-tertiary)}.btn-create-new{background:var(--accent-primary);border:1px solid var(--accent-primary);color:#fff}.btn-create-new:hover:not(:disabled){background:var(--accent-secondary);border-color:var(--accent-secondary)}.btn-create-new:disabled{opacity:.5;cursor:not-allowed}.project-header{display:flex;align-items:center;gap:1rem}.project-name{font-size:.9rem;font-weight:500;color:var(--text-primary)}.btn-back{padding:.4rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.75rem;cursor:pointer;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-back:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--accent-primary)}.project-header .btn-back{padding:.5rem .75rem;font-size:.8rem;background:var(--bg-tertiary)}.project-header .btn-back:hover{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.project-selector{padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary)}.project-selector-header{display:flex;align-items:center;justify-content:space-between}.project-selector-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.project-type-badge{font-size:.7rem;padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:4px;color:var(--text-primary)}.type-object_detection{background:#00d4ff33;color:#00d4aa}.type-instance_segmentation{background:#ff6b6b33;color:#ff6b6b}.type-contrastive_learning{background:#4ecdc433;color:#4ecdc4}.project-info-container{padding:2rem;background:var(--bg-primary)}.project-info-container .project-header{margin-bottom:1.5rem}.project-info-container .project-title{display:flex;align-items:center;gap:1rem}.project-info-container h2{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.project-info-container .project-type-badge{font-size:.75rem;padding:.35rem .75rem;border-radius:4px;font-weight:500}.project-description{font-size:.9rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.project-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px}.stat-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:6px}.stat-info h3{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.stat-info p{font-size:1.25rem;font-weight:700;color:var(--accent-primary)}.project-meta{display:flex;flex-direction:column;gap:.5rem;font-size:.8rem;color:var(--text-muted)}.project-meta p{margin:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.upload-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-primary)}.upload-modal-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.upload-drop-zone{flex:1;min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;border:2px dashed var(--border-secondary);border-radius:8px;margin:1.5rem;cursor:pointer;transition:all .3s ease;background:var(--bg-tertiary)}.upload-drop-zone:hover{border-color:var(--accent-primary);background:var(--bg-hover)}.upload-drop-zone.dragging{border-color:var(--accent-primary);background:#00d4ff1a;border-style:solid}.upload-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.7}.upload-text{text-align:center}.upload-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.upload-subtitle{font-size:.9rem;color:var(--text-muted)}.upload-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-primary);display:flex;justify-content:flex-end;gap:.75rem}.upload-progress-container{padding:0 1.5rem 1rem;display:flex;flex-direction:column;gap:.5rem}.upload-progress-bar{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent-primary);border-radius:3px;transition:width .3s ease;animation:progress-glow 2s ease-in-out infinite}@keyframes progress-glow{0%,to{opacity:1}50%{opacity:.7}}.upload-progress-text{font-size:.75rem;color:var(--text-secondary);text-align:center}.upload-error{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#ef4444;font-size:.875rem}.error-icon{font-size:1rem}.error-retry-btn{padding:.25rem .75rem;background:#ef444433;border:1px solid rgba(239,68,68,.4);color:#ef4444;font-family:inherit;font-size:.75rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .2s ease;margin-left:auto}.error-retry-btn:hover{background:#ef44444d;border-color:#ef4444}.btn-danger{padding:.625rem 1.25rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease;margin-right:auto}.modal-cancel{padding:.625rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.9rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.modal-cancel:hover{background:var(--bg-hover);border-color:var(--border-primary);color:var(--text-primary)}.modal-cancel:disabled{opacity:.5;cursor:not-allowed}.modal-actions{display:flex;gap:.75rem;margin-left:auto}.btn-add{padding:.625rem 1.25rem;background:var(--accent-primary);border:none;color:#fff;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.btn-add:hover:not(:disabled){background:var(--accent-secondary)}.empty-labels .small{font-size:.75rem;background:var(--bg-hover);border-color:var(--border-primary);color:var(--text-primary)}.annotations-panel{position:absolute;top:100px;right:20px;width:320px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;display:flex;flex-direction:column;max-height:calc(100% - 120px);overflow:hidden;z-index:20;box-shadow:var(--shadow-lg)}.panel-header{padding:1rem;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;align-items:center;background:var(--bg-tertiary)}.panel-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.btn-save{padding:.5rem 1rem;background:var(--accent-primary);border:none;color:#fff;font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .2s ease}.btn-save:hover:not(:disabled){background:var(--accent-secondary)}.btn-save:disabled{opacity:.5;cursor:not-allowed}.panel-content{flex:1;overflow-y:auto;padding:0}.annotations-panel .label-input{display:flex;align-items:center;gap:.5rem;margin-bottom:0}.annotations-panel .label-input label{font-weight:500;color:var(--text-primary);white-space:nowrap;font-size:.875rem}.annotations-panel .label-input select{flex:1;min-width:0;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border-secondary);color:var(--text-primary);font-family:inherit;font-size:.875rem;border-radius:4px;cursor:pointer;transition:all .2s ease;height:2.5rem}.annotations-panel .label-input select:hover{border-color:var(--border-primary)}.annotations-panel .label-input select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d4ff1a}.annotation-list{list-style:none;padding:0;margin:0}.annotation-item{padding:.75rem 1rem;border-bottom:1px solid var(--border-secondary);display:flex;align-items:center;gap:.75rem;transition:background .2s ease}.annotation-item:hover{background:var(--bg-tertiary)}.annotation-info{flex:1;display:flex;align-items:center;gap:.5rem}.annotation-type{font-size:1.25rem}.annotation-label{font-size:.875rem;color:var(--text-primary);font-weight:500}.annotation-coords{font-size:.75rem;color:var(--text-secondary)}.btn-delete{padding:.25rem .5rem;background:transparent;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;border-radius:4px;transition:all .2s ease}.btn-delete:hover{color:#ef4444;background:#ef44441a}.empty-state{padding:2rem 1rem;text-align:center}.empty-state-icon{font-size:2rem;margin-bottom:.5rem}.empty-state-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.empty-state-desc{font-size:.75rem;color:var(--text-secondary);margin-bottom:0}.canvas-area{position:relative;flex:1;overflow:hidden}.project-settings-modal{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.settings-section{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-primary)}.settings-section:last-child{border-bottom:none}.settings-section h3{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.section-desc{margin:0 0 1rem;font-size:.875rem;color:var(--text-secondary)}.label-input{display:flex;gap:.5rem;margin-bottom:1rem}.label-input input{flex:1;padding:.625rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-secondary);color:var(--text-primary);font-family:inherit;font-size:.875rem;border-radius:6px;transition:all .2s ease}.label-input input:focus{outline:none;border-color:var(--accent-primary);background:var(--bg-tertiary)}.btn-add{padding:.625rem 1.25rem;background:var(--accent-primary);border:none;color:var(--bg-primary);font-family:inherit;font-size:.875rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all .2s ease}.btn-add:hover:not(:disabled){background:var(--accent-hover)}.btn-add:disabled{opacity:.5;cursor:not-allowed}.empty-labels{padding:1rem;text-align:center}.empty-labels p{margin:.25rem 0;font-size:.875rem;color:var(--text-secondary)}.empty-labels .small{font-size:.75rem}.labels-list{display:flex;flex-wrap:wrap;gap:.5rem}.label-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:6px;font-size:.875rem;color:var(--text-primary)}.label-name{font-size:.875rem}.btn-remove{padding:.25rem .5rem;background:transparent;border:none;color:var(--text-secondary);font-size:1rem;cursor:pointer;border-radius:4px;transition:all .2s ease}.btn-remove:hover{color:#ef4444;background:#ef44441a}.type-info,.contrastive-info{padding:1rem;background:var(--bg-tertiary);border-radius:6px}.type-info p,.contrastive-info p{margin:0 0 .5rem;font-size:.875rem;color:var(--text-primary)}.type-info .small,.contrastive-info .small{font-size:.75rem;color:var(--text-secondary)}.btn-settings{padding:.375rem .75rem;background:transparent;border:1px solid var(--border-secondary);color:var(--text-secondary);font-family:inherit;font-size:.75rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .2s ease;margin-top:.5rem}.btn-settings:hover{background:var(--bg-tertiary);border-color:var(--border-primary);color:var(--text-primary)}.image-list{display:flex;flex-direction:column;gap:.5rem}.image-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.image-list-item:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.image-list-item.active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}.image-thumbnail{width:48px;height:48px;flex-shrink:0;overflow:hidden;border-radius:4px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.image-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{font-size:20px}.image-info{flex:1;overflow:hidden}.image-name{font-size:.85rem;font-weight:500;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-stats{font-size:.75rem;color:var(--text-muted)}.canvas-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0fd9;z-index:1000;gap:1.5rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--border-secondary);border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);border-radius:50%;animation:spin 1s linear infinite;box-shadow:0 0 15px #8b5a3c4d}.loading-message{color:var(--text-secondary);font-size:.9rem;text-align:center}.loading-progress{width:200px;height:4px;background:var(--bg-secondary);border-radius:2px;overflow:hidden;margin-top:.5rem}.loading-progress-fill{height:100%;background:var(--accent-primary);animation:progress-pulse 2s ease-in-out infinite;width:40%;border-radius:2px}@keyframes progress-pulse{0%{width:30%;opacity:.7}50%{width:60%;opacity:1}to{width:30%;opacity:.7}}.login-form-container{max-width:400px;width:100%;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg)}.login-form-header{text-align:center;margin-bottom:1.5rem}.login-form-title{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.login-form-error{background:#ff55551a;border:1px solid rgba(255,85,85,.3);color:var(--danger);padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-bottom:1.25rem}.login-form-group{margin-bottom:1.25rem}.login-form-label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.login-form-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-primary);font-family:Consolas,Courier New,monospace;font-size:.9rem;transition:all .2s ease}.login-form-input::placeholder{color:var(--text-muted)}.login-form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.login-form-button{width:100%;padding:.875rem 1rem;background:var(--accent-primary);border:none;border-radius:6px;color:#fff;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.login-form-button:hover:not(:disabled){background:var(--accent-secondary);transform:translateY(-1px)}.login-form-button:disabled{opacity:.6;cursor:not-allowed}.login-form-footer{margin-top:1.5rem;text-align:center}.login-form-link{color:var(--accent-primary);text-decoration:none;font-size:.85rem;transition:color .2s ease}.login-form-link:hover{color:var(--accent-secondary);text-decoration:underline}.signup-form-container{max-width:450px;width:100%;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:12px;padding:2rem;box-shadow:var(--shadow-lg)}.signup-form-header{text-align:center;margin-bottom:1.5rem}.signup-form-title{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.signup-form-error{background:#ff55551a;border:1px solid rgba(255,85,85,.3);color:var(--danger);padding:.75rem 1rem;border-radius:6px;font-size:.875rem;margin-bottom:1rem}.signup-form-group{margin-bottom:1rem}.signup-form-label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.signup-form-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:6px;color:var(--text-primary);font-family:Consolas,Courier New,monospace;font-size:.9rem;transition:all .2s ease}.signup-form-input::placeholder{color:var(--text-muted)}.signup-form-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:var(--glow-primary)}.signup-form-button{width:100%;padding:.875rem 1rem;background:var(--accent-primary);border:none;border-radius:6px;color:#fff;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.signup-form-button:hover:not(:disabled){background:var(--accent-secondary);transform:translateY(-1px)}.signup-form-button:disabled{opacity:.6;cursor:not-allowed}.signup-form-footer{margin-top:1.5rem;text-align:center}.signup-form-link{color:var(--accent-primary);text-decoration:none;font-size:.85rem;transition:color .2s ease}.signup-form-link:hover{color:var(--accent-secondary);text-decoration:underline}.auth-page{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:1rem}
