.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:10px;background-color:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}.theme-toggle:hover{background-color:var(--accent);color:#fff;transform:scale(1.05)}.theme-toggle svg{transition:transform .3s ease}.theme-toggle:hover svg{transform:rotate(15deg)}.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background-color:var(--navbar-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar-content{max-width:1600px;margin:0 auto;padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}.navbar-brand{flex-shrink:0}.brand-link{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text-primary);text-decoration:none}.brand-link:hover{color:var(--accent)}.navbar-menu{display:flex;align-items:center;gap:.5rem;flex-grow:1;justify-content:center}.nav-link{padding:.5rem 1rem;border-radius:8px;color:var(--text-secondary);font-weight:500;transition:all .2s ease}.nav-link:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.nav-link.active{color:var(--accent);background-color:var(--accent-transparent)}.navbar-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.user-menu{display:flex;align-items:center;gap:.5rem}.user-avatar{width:40px;height:40px;border-radius:10px;background-color:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;text-decoration:none;transition:transform .2s ease}.user-avatar:hover{transform:scale(1.05);color:#fff}.logout-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:10px;background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.logout-btn:hover{background-color:#ef4444;color:#fff}.mobile-menu-toggle{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:.5rem;border-radius:8px;transition:background-color .2s ease}.mobile-menu-toggle:hover{background-color:var(--bg-tertiary)}.main-content{flex-grow:1;padding:2rem 0}@media (max-width: 768px){.mobile-menu-toggle{display:block;order:2}.navbar-content{padding:.75rem 1rem;gap:1rem;position:relative}.navbar-menu{display:none;position:absolute;top:100%;left:0;right:0;background-color:var(--navbar-bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);flex-direction:column;padding:.5rem;gap:0;z-index:1000;box-shadow:0 4px 12px var(--shadow)}.navbar-menu.mobile-open{display:flex}.nav-link{padding:.75rem 1rem;font-size:.95rem;width:100%;text-align:left;border-radius:8px}.brand-link{font-size:1.1rem}.user-avatar{width:36px;height:36px;font-size:.9rem}.logout-btn{width:36px;height:36px}.navbar-actions{gap:.5rem;order:3}.navbar-brand{order:1}}@media (max-width: 600px){.brand-link span{display:none}.navbar-actions{gap:.25rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:2rem}.login-container{width:100%;max-width:420px;background-color:var(--card-bg);border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px var(--shadow);border:1px solid var(--border)}.login-header{text-align:center;margin-bottom:2rem}.login-logo{margin-bottom:1rem}.login-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.login-subtitle{color:var(--text-secondary);font-size:.95rem}.login-form{margin-bottom:1.5rem}.login-btn{width:100%;margin-top:.5rem}.login-footer{text-align:center;color:var(--text-tertiary);font-size:.875rem}.dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:dialogFadeIn .2s ease-out;padding:1rem}@keyframes dialogFadeIn{0%{opacity:0}to{opacity:1}}.dialog-content{background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;animation:dialogSlideUp .3s ease-out;border:1px solid var(--border-color)}@keyframes dialogSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dialog-header{display:flex;align-items:center;gap:1rem;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border-color)}.dialog-icon{width:3rem;height:3rem;flex-shrink:0}.dialog-icon-success{color:#10b981}.dialog-icon-error{color:#ef4444}.dialog-icon-confirm{color:#f59e0b}.dialog-icon-info{color:var(--primary-color)}.dialog-title{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0}.dialog-body{padding:1.5rem}.dialog-message{color:var(--text-primary);font-size:1rem;line-height:1.6;margin:0;white-space:pre-wrap;word-wrap:break-word}.dialog-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.5rem;border-top:1px solid var(--border-color)}.dialog-footer .btn{min-width:100px}@media (max-width: 640px){.dialog-content{max-width:90%}.dialog-header{padding:1.25rem 1.25rem .75rem}.dialog-icon{width:2.5rem;height:2.5rem}.dialog-title{font-size:1.25rem}.dialog-body{padding:1.25rem}.dialog-message{font-size:.9375rem}.dialog-footer{padding:.75rem 1.25rem 1.25rem;flex-direction:column-reverse}.dialog-footer .btn{width:100%}}.dashboard{padding:1rem 0;max-width:1400px;margin:0 auto}.hero-banner{position:relative;margin-bottom:2.5rem;background:linear-gradient(135deg,var(--card-bg) 0%,var(--hover-bg) 100%);border-radius:24px;overflow:hidden;padding:3rem 2rem;border:1px solid var(--border-color);box-shadow:0 8px 32px #00000014}.hero-content{position:relative;z-index:2;max-width:600px}.hero-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary);text-shadow:0 2px 8px rgba(0,0,0,.1)}.hero-subtitle{font-size:1.125rem;color:var(--text-secondary);margin:0}.hero-images{position:absolute;top:0;right:0;bottom:0;width:50%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:1rem;padding:1.5rem;opacity:.9;pointer-events:none}.hero-image{position:relative;border-radius:12px;overflow:hidden;animation:fadeInUp .6s ease-out both;transition:all .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-image:nth-child(1){grid-column:1;grid-row:1 / 3}.hero-image:nth-child(2){grid-column:2;grid-row:1}.hero-image:nth-child(3){grid-column:3;grid-row:1}.hero-image:nth-child(4){grid-column:2;grid-row:2}.hero-image-split{grid-column:3;grid-row:2;width:calc(50% - .5rem)}.hero-gallery-button{grid-column:3;grid-row:2;width:calc(50% - .5rem);margin-left:calc(50% + .5rem);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(135deg,#6366f1e6,#8b5cf6e6);border-radius:12px;color:#fff;text-decoration:none;font-weight:600;font-size:.875rem;transition:all .3s ease;pointer-events:auto;z-index:2;animation:fadeInUp .6s ease-out both}.hero-gallery-button:hover{transform:translateY(-2px);box-shadow:0 8px 16px #6366f166}.hero-gallery-button svg{width:2rem;height:2rem}.hero-image:nth-child(6){display:none}.hero-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.hero-image:hover img{transform:scale(1.05)}.hero-image:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,#6366f133,#8b5cf633,#14b8a633 66%,#f59e0b33);opacity:.4;mix-blend-mode:overlay}.dashboard-header{margin-bottom:2rem}.page-title{font-size:2rem;margin-bottom:.5rem}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001a}.stat-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0}.stat-icon svg{width:28px;height:28px;color:#fff}.stat-icon-images{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.stat-icon-pending{background:linear-gradient(135deg,#f59e0b,#ef4444)}.stat-icon-duplicates{background:linear-gradient(135deg,#14b8a6,#06b6d4)}.stat-value{font-size:2.5rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.unprocessed-banner{margin:2rem 0;padding:1rem 1.5rem;background:var(--card-bg);border-left:4px solid var(--primary-color);border-radius:8px;display:flex;align-items:center;transition:all .3s ease}.unprocessed-banner:hover{border-left-width:6px;box-shadow:0 4px 12px #0000001a}.unprocessed-content{display:flex;align-items:center;gap:1rem;width:100%}.unprocessed-icon{width:2rem;height:2rem;color:var(--primary-color);flex-shrink:0}.unprocessed-text{display:flex;flex-direction:column;gap:.25rem;flex:1}.unprocessed-count{font-size:1rem;font-weight:600;color:var(--text-primary)}.unprocessed-hint{font-size:.875rem;color:var(--text-secondary)}.unprocessed-btn{flex-shrink:0}.quick-actions-section{margin-top:2.5rem}.quick-actions-section .section-title{margin-bottom:1.5rem}.actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.action-card{position:relative;display:flex;align-items:center;gap:1rem;padding:1.5rem;text-decoration:none;border-radius:16px;transition:all .3s ease;overflow:hidden;min-height:120px}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--action-color-1),var(--action-color-2));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}.action-card:hover:before{transform:scaleX(1)}.action-card:hover{transform:translateY(-4px);text-decoration:none}.action-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--action-color-1),var(--action-color-2));color:#fff;transition:transform .3s ease;flex-shrink:0}.action-icon svg{width:28px;height:28px}.action-card:hover .action-icon{transform:scale(1.1) rotate(5deg)}.action-text{flex:1;min-width:0}.action-title{font-size:1.125rem;font-weight:600;margin-bottom:.25rem;color:var(--text-primary)}.action-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:0}.action-upload{--action-color-1: #6366f1;--action-color-2: #8b5cf6}.action-gallery{--action-color-1: #14b8a6;--action-color-2: #06b6d4}.action-duplicates{--action-color-1: #f59e0b;--action-color-2: #ef4444}.action-compare{--action-color-1: #ec4899;--action-color-2: #f43f5e}.action-tags{--action-color-1: #8b5cf6;--action-color-2: #d946ef}.action-tag-editor{--action-color-1: #06b6d4;--action-color-2: #3b82f6}.action-badge{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,var(--action-color-1),var(--action-color-2));color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@media (max-width: 1200px){.actions-grid{grid-template-columns:repeat(2,1fr)}.hero-images{width:45%}}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.actions-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-icon{font-size:1.75rem;width:45px;height:45px}.stat-value{font-size:1.75rem}.stat-label{font-size:.8rem}.unprocessed-header{flex-direction:column;align-items:flex-start;gap:1rem}.unprocessed-thumbnail,.unprocessed-more{width:100px;height:100px}.action-card{padding:1.25rem}.action-icon{width:50px;height:50px}.action-icon svg{width:24px;height:24px}.action-title{font-size:1rem}.action-description{font-size:.85rem}.hero-banner{padding:1.5rem 1rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9rem}.hero-images{position:relative;width:100%;opacity:.2;padding:.5rem;margin-top:1rem;height:120px;grid-template-columns:repeat(6,1fr);grid-template-rows:1fr}.hero-image:nth-child(1),.hero-image:nth-child(2),.hero-image:nth-child(3),.hero-image:nth-child(4),.hero-image:nth-child(5),.hero-image:nth-child(6){grid-column:auto;grid-row:1;display:block}}@media (max-width: 600px){.page-title{font-size:1.5rem}.section-title{font-size:1.25rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:.9rem}}.upload-page{padding:1rem 0}.upload-dropzone{border:2px dashed var(--border);border-radius:16px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background-color:var(--bg-secondary);margin-bottom:2rem}.upload-dropzone:hover{border-color:var(--accent);background-color:var(--accent-transparent)}.upload-dropzone.drag-active{border-color:var(--accent);background-color:var(--accent-transparent);transform:scale(1.01)}.upload-input{display:none}.dropzone-content{pointer-events:none}.dropzone-icon{color:var(--accent);margin-bottom:1rem}.dropzone-text{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}.dropzone-hint{font-size:.875rem;color:var(--text-tertiary)}.preview-section{background-color:var(--bg-secondary);border-radius:16px;padding:1.5rem;border:1px solid var(--border)}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.preview-header h2{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.preview-actions{display:flex;gap:.75rem}.upload-progress{margin-bottom:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:8px}.progress-bar-container{width:100%;height:32px;background:var(--bg-primary);border-radius:16px;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#4f46e5);transition:width .3s ease;display:flex;align-items:center;justify-content:center;min-width:50px;position:relative}.progress-text{color:#fff;font-weight:600;font-size:.875rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.progress-message{margin-top:.75rem;text-align:center;color:var(--text-secondary);font-size:.9rem;margin-bottom:0}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.preview-item{position:relative;background-color:var(--bg-tertiary);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.preview-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background-color:#0009;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.preview-remove:hover{background-color:#ef4444;transform:scale(1.1)}.preview-image{width:100%;height:150px;object-fit:cover}.preview-info{padding:.75rem}.preview-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.preview-size{font-size:.75rem;color:var(--text-tertiary)}.upload-errors{margin-top:.5rem;padding-left:1.25rem;font-size:.875rem}.loading-spinner-sm{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 600px){.preview-header{flex-direction:column;align-items:stretch}.preview-actions{justify-content:stretch}.preview-actions .btn{flex:1}}.gallery-page{padding:1rem 0}.sort-controls{display:flex;gap:1.5rem;margin-bottom:1.5rem;padding:1rem;background-color:var(--bg-secondary);border-radius:12px;border:1px solid var(--border);align-items:center}.sort-controls label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.sort-controls select{padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border);background-color:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s ease}.sort-controls select:hover{border-color:var(--accent)}.sort-controls select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.gallery-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;background-color:var(--bg-tertiary);border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 12px 30px var(--shadow)}.gallery-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-item:hover .gallery-image{transform:scale(1.05)}.gallery-overlay{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(transparent,#000c);opacity:0;transition:opacity .2s ease}.gallery-item:hover .gallery-overlay{opacity:1}.gallery-item-name{color:#fff;font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.variant-badge{position:absolute;top:.5rem;right:.5rem;background:var(--accent);color:#fff;padding:.35rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;box-shadow:0 2px 8px #0000004d;z-index:10}.lightbox{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease}.lightbox-content{max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;position:relative}.lightbox-image-container{flex-shrink:0;max-height:70vh;max-width:90vw;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;position:relative;overflow:hidden}.lightbox-image-container.zoom-mode{position:fixed;top:0;left:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;margin:0;z-index:10001;background:#000000f2;cursor:grab}.lightbox-image-container.zoom-mode:active{cursor:grabbing}.zoom-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;pointer-events:none;z-index:10}.lightbox-close{position:absolute;top:-3rem;right:0;background:none;border:none;color:#fff;cursor:pointer;padding:.5rem;opacity:.7;transition:opacity .2s ease,transform .2s ease;z-index:10}.lightbox-close:hover{opacity:1;transform:scale(1.1)}.lightbox-tag-button{position:absolute;top:1rem;left:1rem;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.4rem .6rem;border-radius:50%;font-size:1.2rem;opacity:.7;transition:opacity .2s ease,transform .2s ease;z-index:10;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.lightbox-tag-button:hover{opacity:1;transform:scale(1.1)}.lightbox-info-button{position:absolute;top:1rem;left:5rem;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.4rem .6rem;border-radius:50%;font-size:1rem;opacity:.7;transition:opacity .2s ease,transform .2s ease;z-index:10;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.lightbox-info-button:hover{opacity:1;transform:scale(1.1)}.lightbox-info-tooltip{position:absolute;top:3.5rem;left:1rem;background:#000000e6;border:1px solid rgba(255,255,255,.3);color:#fff;padding:1rem;border-radius:8px;font-size:.9rem;z-index:10;min-width:280px;max-width:350px;max-height:80vh;overflow-y:auto}.lightbox-info-tooltip .info-section{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.2)}.lightbox-info-tooltip .info-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.lightbox-info-tooltip .info-section h4{margin:0 0 .5rem;font-size:.85rem;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.lightbox-info-tooltip .info-section>div{margin-bottom:.4rem}.lightbox-info-tooltip .info-section>div:last-child{margin-bottom:0}.lightbox-info-tooltip .color-info{display:flex;align-items:center;gap:.5rem}.lightbox-info-tooltip .color-tag{display:inline-block;padding:.25rem .6rem;border-radius:4px;font-size:.85rem;font-weight:500;border:1px solid rgba(255,255,255,.3);min-width:60px;text-align:center;text-transform:capitalize}.lightbox-info-tooltip .color-tag[data-color=red]{background-color:#e74c3c;color:#fff}.lightbox-info-tooltip .color-tag[data-color=green]{background-color:#2ecc71;color:#fff}.lightbox-info-tooltip .color-tag[data-color=blue]{background-color:#3498db;color:#fff}.lightbox-info-tooltip .color-tag[data-color=yellow]{background-color:#f1c40f;color:#333}.lightbox-info-tooltip .color-tag[data-color=orange]{background-color:#e67e22;color:#fff}.lightbox-info-tooltip .color-tag[data-color=purple]{background-color:#9b59b6;color:#fff}.lightbox-info-tooltip .color-tag[data-color=pink]{background-color:#ff69b4;color:#fff}.lightbox-info-tooltip .color-tag[data-color=brown]{background-color:#8b4513;color:#fff}.lightbox-info-tooltip strong{margin-right:.5rem;opacity:.7}.lightbox-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px;transition:transform .1s ease-out;-webkit-user-select:none;user-select:none}.lightbox-image-container.zoom-mode .lightbox-image{max-width:none;max-height:none;width:auto;height:auto;border-radius:0}.variants-section{margin-top:1.5rem;width:100%;max-width:600px}.variants-title{font-size:1rem;margin-bottom:.75rem;color:#ffffffe6;font-weight:600}.variants-grid{display:flex;flex-direction:row;gap:.75rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem;flex-wrap:nowrap;align-items:center}.variants-divider{width:2px;height:80px;background:#ffffff4d;flex-shrink:0;margin:0 .5rem}.variant-thumbnail{cursor:pointer;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.2);transition:all .2s;background:#ffffff0d;flex-shrink:0;width:100px;height:100px}.variant-thumbnail:hover{border-color:var(--accent);transform:scale(1.05)}.variant-thumbnail.current-variant{border-color:var(--accent);box-shadow:0 0 0 2px #3b82f64d;cursor:default}.variant-thumbnail.current-variant:hover{transform:none}.variant-thumbnail img{width:100%;height:100px;object-fit:cover;display:block}.variant-name{padding:.5rem;font-size:.75rem;color:#fffc;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#00000080}.current-indicator{color:var(--accent);font-size:.9rem;margin-right:.25rem}.main-thumbnail{max-width:200px;border-color:var(--accent)}.gallery-page .empty-state{margin-top:2rem}.loading-more{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.loading-more .loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}.loading-more p{color:var(--text-secondary);font-size:.9rem}@media (max-width: 768px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.sort-controls{flex-direction:column;gap:1rem;align-items:stretch}.sort-controls label{flex-direction:column;align-items:flex-start;gap:.5rem}.sort-controls select{width:100%}}@media (max-width: 600px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.lightbox{padding:.5rem}.lightbox-close{top:.5rem;right:.5rem;width:40px;height:40px;font-size:1.5rem}.lightbox-content{max-width:95vw;max-height:85vh}.lightbox-nav{width:50px;height:50px;font-size:1.5rem}.lightbox-info{font-size:.8rem;padding:.75rem}}.duplicates-page{padding:2rem 0}.page-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--text-primary)}.subtitle{margin:0;color:var(--text-secondary);font-size:1rem}.scan-controls{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.threshold-control{flex:1;min-width:300px}.threshold-control label{display:block;margin-bottom:.5rem;color:var(--text-primary);font-size:.95rem}.threshold-hint{color:var(--text-secondary);font-weight:400;font-size:.85rem}.threshold-slider{width:100%;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none;-webkit-appearance:none}.threshold-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform .2s}.threshold-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.threshold-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;transition:transform .2s}.threshold-slider::-moz-range-thumb:hover{transform:scale(1.2)}.scan-btn{display:flex;align-items:center;gap:.5rem;white-space:nowrap}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state h3{margin:.5rem 0;color:var(--text-primary)}.empty-state p{margin:0}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:8px;margin-bottom:1rem}.duplicates-section{display:flex;flex-direction:column;gap:2rem}.duplicate-group{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color);gap:1rem;flex-wrap:wrap}.group-header>div{flex:1;min-width:200px}.group-header h3{margin:0 0 .25rem;font-size:1.2rem;color:var(--text-primary)}.compare-btn{white-space:nowrap;display:flex;align-items:center;gap:.5rem}.group-stats{color:var(--text-secondary);font-size:.9rem}.duplicate-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.duplicate-image-card{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;overflow:hidden;transition:all .2s;position:relative}.duplicate-image-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.image-wrapper{position:relative;width:100%;padding-bottom:75%;background:var(--bg-tertiary);overflow:hidden}.linked-icon{position:absolute;top:.5rem;left:.5rem;background:#000c;color:#fff;padding:.35rem .5rem;border-radius:4px;font-size:.9rem;z-index:2}.image-wrapper img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.delete-image-btn{position:absolute;top:.5rem;right:.5rem;background:#dc2626f2;color:#fff;border:none;border-radius:6px;padding:.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;z-index:10}.delete-image-btn:hover:not(:disabled){background:#dc2626;transform:scale(1.05)}.delete-image-btn:disabled{opacity:.6;cursor:not-allowed}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.selection-badge,.original-badge{position:absolute;top:.5rem;left:.5rem;background:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;z-index:5}.original-badge{background:#4ade80;top:auto;bottom:.5rem;left:.5rem}.image-details{padding:.75rem}.filename{margin:0 0 .5rem;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.75rem;color:var(--text-secondary)}.image-meta span{padding:.2rem .5rem;background:var(--bg-tertiary);border-radius:4px}.similarity{font-weight:600;color:var(--accent)!important;background:var(--accent-alpha)!important}.group-actions{padding-top:1rem;border-top:1px solid var(--border-color)}.action-section{display:flex;flex-direction:column;gap:1rem}.action-section>.action-hint{color:var(--text-secondary);font-size:.9rem;margin:0}.action-buttons{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-start}.action-buttons button{display:flex;align-items:center;gap:.5rem}.variant-action-inline{flex:1;min-width:300px;display:flex;gap:.5rem;align-items:center}.variant-name-input{flex:1;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.95rem}.variant-name-input:focus{outline:none;border-color:var(--accent)}.hidden-images-section{margin-bottom:2rem}.hidden-images-section h2{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.hidden-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.hidden-image-card{background:var(--bg-secondary);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.hidden-image-card img{width:100%;height:150px;object-fit:cover;display:block}.hidden-image-info{padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.hidden-image-info .filename{margin:0;font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--border-color)}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-small{padding:.5rem 1rem;font-size:.85rem}.notification{position:fixed;bottom:2rem;right:2rem;padding:1rem 1.5rem;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:1000;animation:slideIn .3s ease}.notification.success{background:#10b981;color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}@media (max-width: 768px){.scan-controls{flex-direction:column;align-items:stretch}.duplicate-images{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.group-header{flex-direction:column;align-items:stretch}.action-buttons{flex-direction:column}.variant-action-inline{flex-direction:column;min-width:100%}}.compare-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.compare-content{position:relative;width:100%;max-width:1400px;height:90vh;display:flex;flex-direction:column;background:var(--bg-primary);border-radius:12px;overflow:hidden}.compare-close{position:absolute;top:1rem;right:1rem;background:#000000b3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background .2s}.compare-close:hover{background:#000000e6}.compare-main{display:flex;flex-direction:column;height:100%;gap:1rem;padding:1rem}.compare-image-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:8px;padding:1rem;position:relative;overflow:hidden}.compare-main-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.compare-image-info{position:absolute;bottom:1rem;left:1rem;right:1rem;background:#000c;color:#fff;padding:1rem;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.compare-filename{margin:0 0 .5rem;font-weight:600;font-size:1rem}.compare-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.9rem;opacity:.9}.compare-delete-btn{position:absolute;top:1rem;left:1rem;background:#dc2626f2;color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:600;transition:all .2s;z-index:10}.compare-delete-btn:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.compare-delete-btn:disabled{opacity:.6;cursor:not-allowed}.compare-thumbnails{background:var(--bg-secondary);padding:1rem;border-radius:8px}.compare-thumbnails h4{margin:0 0 .75rem;font-size:.95rem;color:var(--text-primary)}.compare-thumbnails-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;max-height:180px;overflow-y:auto;padding:.5rem 0}.compare-thumbnail{position:relative;cursor:pointer;border:3px solid transparent;border-radius:8px;overflow:hidden;transition:all .2s;background:var(--bg-tertiary)}.compare-thumbnail:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003}.compare-thumbnail.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-alpha)}.compare-thumbnail img{width:100%;height:100px;object-fit:cover;display:block}.compare-thumbnail-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);color:#fff;padding:.5rem .5rem .25rem;font-size:.75rem;display:flex;align-items:center;justify-content:space-between}.active-indicator{color:var(--accent);font-size:1.2rem;line-height:1}.distance-label{font-weight:600}@media (max-width: 768px){.compare-content{height:95vh}.compare-thumbnails-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.compare-thumbnail img{height:80px}.compare-delete-btn{position:static;width:100%;justify-content:center;margin-bottom:.5rem}.compare-image-info{position:static;margin-top:.5rem}}.duplicate-image-card.is-main{border-color:var(--accent);border-width:3px;box-shadow:0 0 0 3px #3b82f633}.duplicate-image-card.is-variant{border-color:#10b981;border-width:2px;box-shadow:0 0 0 2px #10b9811a}.main-badge{position:absolute;top:.5rem;left:.5rem;background:var(--accent);color:#fff;padding:.35rem .75rem;border-radius:6px;font-size:.8rem;font-weight:600;z-index:10;box-shadow:0 2px 8px #0003}.variant-checkbox{position:absolute;bottom:.5rem;left:.5rem;background:#000000bf;color:#fff;padding:.5rem .75rem;border-radius:6px;display:flex;align-items:center;gap:.5rem;cursor:pointer;z-index:10;transition:all .2s}.variant-checkbox:hover{background:#000000e6}.variant-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#10b981}.checkbox-label{font-size:.85rem;font-weight:500}.linking-mode{background:#3b82f60d;border:2px dashed var(--accent);padding:1.5rem;border-radius:8px}.linking-instructions{margin-bottom:1rem}.linking-instructions h4{margin:0 0 .75rem;color:var(--accent);font-size:1.1rem}.linking-instructions ol{margin:.5rem 0;padding-left:1.5rem;color:var(--text-primary)}.linking-instructions li{margin:.35rem 0;line-height:1.5}.linking-instructions strong{color:var(--accent)}.linking-instructions .hint{margin:.75rem 0 0;color:var(--text-secondary);font-size:.9rem;font-style:italic}.profile-page{padding:1rem 0}.profile-sections{display:flex;flex-direction:column;gap:1.5rem}.profile-section{padding:2rem}.section-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.form-hint{font-size:.8rem;color:var(--text-tertiary);margin-top:.5rem}.theme-mode-toggle{margin-bottom:2rem}.mode-buttons{display:flex;gap:.75rem}.mode-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:2px solid var(--border);border-radius:10px;background-color:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .2s ease;font-weight:500}.mode-btn:hover{border-color:var(--accent);color:var(--text-primary)}.mode-btn.active{border-color:var(--accent);background-color:var(--accent-transparent);color:var(--accent)}.theme-selection{margin-top:1.5rem}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.75rem}.theme-option{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border:2px solid var(--border);border-radius:10px;background-color:var(--bg-secondary);cursor:pointer;transition:all .2s ease}.theme-option:hover{border-color:var(--accent);transform:translateY(-2px)}.theme-option.active{border-color:var(--accent);background-color:var(--accent-transparent)}.theme-color{width:24px;height:24px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 4px #00000026}.theme-name{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.profile-section{padding:1.5rem}.theme-grid{grid-template-columns:repeat(2,1fr)}.mode-buttons{flex-direction:column}.mode-btn{justify-content:center}}@media (max-width: 480px){.theme-grid{grid-template-columns:1fr}}.compare-page-normal{padding:1rem 0;min-height:100vh}.compare-page{position:fixed;top:0;left:0;width:100vw;height:100vh;padding:0;margin:0;overflow:hidden;background:#000;z-index:200}.compare-setup{max-width:1200px;margin:0 auto;padding:2rem 0}.mode-selection{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.mode-card{background:var(--bg-secondary);border:2px solid var(--border);border-radius:16px;padding:2rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;cursor:pointer}.mode-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px var(--shadow);border-color:var(--accent)}.mode-icon{font-size:4rem;margin-bottom:1rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.mode-card h3{margin:1rem 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.mode-card p{color:var(--text-secondary);margin-bottom:1.5rem}.tournament-size-label{display:block;margin:1.5rem 0;color:var(--text-primary);font-weight:500}.tournament-size-select{display:block;width:100%;margin-top:.5rem;padding:.75rem;border-radius:8px;border:1px solid var(--border);background-color:var(--bg-primary);color:var(--text-primary);font-size:1rem;cursor:pointer}.tournament-size-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha)}.compare-header{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:0;margin-bottom:0;z-index:100}.game-info{display:flex;gap:2rem;font-weight:600;color:#fff;font-size:1.1rem}.votes-count{color:var(--accent)}.btn-quit{padding:.5rem 1.5rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;cursor:pointer;transition:all .2s ease}.btn-quit:hover{background:#fff3;border-color:#fff}.compare-arena{display:flex;gap:0;height:100vh;width:100vw;align-items:stretch;position:relative}.compare-side{flex:1;cursor:pointer;border-radius:0;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1);border:none;transform-origin:center}.compare-side:hover{transform:none}.compare-side.selected{animation:none}.compare-side.left.selected,.compare-side.right.selected{transform:none}.compare-side.dimmed{opacity:.2;filter:grayscale(1)}.compare-side.left.dimmed .compare-image{transform:translate(-30px) scale(.95) rotate(-5deg)}.compare-side.right.dimmed .compare-image{transform:translate(30px) scale(.95) rotate(5deg)}.compare-side.left.selected .compare-image{transform:scale(1.12) rotate(-3deg) translateZ(0);filter:brightness(1.15);transition:all .4s cubic-bezier(.34,1.56,.64,1)}.compare-side.right.selected .compare-image{transform:scale(1.12) rotate(3deg) translateZ(0);filter:brightness(1.15);transition:all .4s cubic-bezier(.34,1.56,.64,1)}.background-blur{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;filter:blur(40px);opacity:.6;z-index:0;transition:transform .4s cubic-bezier(.4,0,.2,1)}.image-container{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;z-index:1}.compare-image{width:95%;height:95%;object-fit:contain;transition:transform .4s cubic-bezier(.4,0,.2,1);position:relative;z-index:2;filter:drop-shadow(0 10px 30px rgba(0,0,0,.5))}.compare-side:hover .compare-image{transform:scale(1.02);filter:drop-shadow(0 15px 40px rgba(0,0,0,.7))}.image-overlay{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(transparent,#000000e6);opacity:0;transition:opacity .3s ease;pointer-events:none}.image-name{color:#fff;font-weight:600;font-size:1.1rem;text-align:center}.magnifier{position:fixed;width:450px;height:450px;border:3px solid var(--accent);border-radius:50%;pointer-events:none;z-index:1000;transform:translate(-50%,-50%);box-shadow:0 8px 32px #00000080;background-repeat:no-repeat;cursor:none}.compare-divider{position:absolute;top:0;left:50%;transform:translate(-50%);height:100vh;display:flex;align-items:center;z-index:50;pointer-events:none}.divider-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;pointer-events:auto;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem 1rem;border-radius:50px;box-shadow:0 8px 32px #00000080}.divider-stat{color:#fff;font-weight:700;font-size:1.1rem;text-align:center;min-width:60px}.divider-remaining{color:#ffffffb3;font-size:.9rem;text-align:center}.vs-badge{background:var(--accent);color:#fff;font-weight:900;font-size:2rem;padding:1rem 1.5rem;border-radius:50%;box-shadow:0 8px 20px var(--shadow);animation:pulse 4s ease-in-out infinite}.btn-quit-center{background:#ffffff1a;border:2px solid rgba(255,255,255,.3);color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.btn-quit-center:hover{background:#fff3;border-color:#fff;transform:scale(1.1)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.round-complete{max-width:800px;margin:4rem auto;text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:16px;border:2px solid var(--border)}.round-complete h2{font-size:2.5rem;margin-bottom:1rem;color:var(--text-primary)}.round-complete p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem}.eliminated-section{margin:2rem 0}.eliminated-section h3{font-size:1.3rem;margin-bottom:1rem;color:var(--text-primary)}.eliminated-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.eliminated-item{background:var(--bg-tertiary);padding:1.5rem;border-radius:12px;border:1px solid var(--border)}.eliminated-images{display:flex;align-items:center;gap:1rem;justify-content:space-between}.eliminated-loser,.eliminated-winner{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.eliminated-loser img,.eliminated-winner img{width:100%;max-width:120px;height:120px;object-fit:cover;border-radius:8px;box-shadow:0 4px 12px var(--shadow)}.eliminated-loser img{opacity:.5;filter:grayscale(1)}.loser-label{font-size:.85rem;color:#f44;font-weight:600}.winner-label{font-size:.85rem;color:#4f4;font-weight:600}.vs-arrow{font-size:1.5rem;color:var(--text-secondary);font-weight:700}.defeated-by{font-size:.85rem;color:var(--text-secondary)}.tournament-complete{max-width:800px;margin:4rem auto;text-align:center;padding:3rem;background:var(--bg-secondary);border-radius:16px;border:2px solid var(--accent)}.victory-title{font-size:3rem;margin-bottom:.5rem;color:var(--accent);animation:victoryBounce 1s ease-out}@keyframes victoryBounce{0%,to{transform:translateY(0)}25%{transform:translateY(-20px)}75%{transform:translateY(-10px)}}.victory-subtitle{font-size:1.3rem;color:var(--text-secondary);margin-bottom:2rem}.winner-display{margin:2rem 0}.winner-image{max-width:400px;max-height:400px;border-radius:12px;box-shadow:0 12px 40px var(--shadow);margin-bottom:1.5rem;animation:victoryGlow 2s ease-in-out infinite}@keyframes victoryGlow{0%,to{box-shadow:0 12px 40px var(--shadow)}50%{box-shadow:0 12px 60px var(--accent-alpha)}}.winner-display h3{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.winner-stats{display:flex;gap:2rem;justify-content:center;margin-top:1.5rem}.stat{display:flex;flex-direction:column;gap:.5rem}.stat-label{font-size:.9rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--accent)}.btn-large{padding:1rem 3rem;font-size:1.2rem;margin-top:2rem}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.loading-spinner{width:50px;height:50px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@media (max-width: 768px){.compare-arena{flex-direction:column;height:100vh}.compare-side{flex:1;min-height:0}.compare-divider{width:100%;height:50px;flex-direction:row;flex-shrink:0;position:relative;left:0;top:0;transform:none}.divider-content{flex-direction:row;width:100%;justify-content:space-around;align-items:center;padding:.5rem 1rem;border-radius:0}.vs-badge{font-size:1.25rem;padding:.5rem 1rem}.divider-stat{font-size:.9rem}.divider-remaining{font-size:.8rem}.btn-quit-center{position:relative;top:auto;right:auto;width:36px;height:36px;font-size:1.25rem}.compare-image{width:90%;height:90%}.image-overlay{padding:.75rem}.image-name{font-size:.75rem}.mode-selection{grid-template-columns:1fr;padding:1rem}.mode-card{padding:1.5rem}.tournament-complete,.round-complete{padding:1rem}.winner-image{max-width:90vw;max-height:50vh}.eliminated-grid{grid-template-columns:1fr}}.color-picker-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px;padding:4px;max-width:400px}.color-swatch{width:40px;height:40px;border:2px solid var(--border-color, #ddd);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative;padding:0;opacity:.85}.color-swatch:hover{transform:scale(1.1);border-color:var(--primary-color, #007bff);box-shadow:0 2px 8px #0003;opacity:1}.color-swatch.selected{border-color:var(--primary-color, #007bff);border-width:3px;box-shadow:0 0 0 2px var(--bg-primary, white),0 0 0 4px var(--primary-color, #007bff)}.color-swatch.clear{background:linear-gradient(135deg,transparent 0%,transparent 45%,#ff4444 45%,#ff4444 55%,transparent 55%,transparent 100%);background-color:var(--bg-secondary, #f5f5f5);font-size:18px;color:var(--text-secondary, #666);font-weight:700}.color-swatch.clear:hover{background-color:var(--bg-hover, #e0e0e0)}[data-theme=dark] .color-swatch{border-color:var(--border-color, #444)}[data-theme=dark] .color-swatch.clear{background-color:var(--bg-secondary, #2a2a2a)}[data-theme=dark] .color-swatch.selected{box-shadow:0 0 0 2px var(--bg-primary, #1a1a1a),0 0 0 4px var(--primary-color, #0d6efd)}.tag-manager-page{display:flex;flex-direction:column;height:100vh;max-height:100vh;overflow:hidden}.page-header{padding:1.5rem 2rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.page-title{margin:0 0 .5rem;font-size:2rem;color:var(--text-primary);display:flex;align-items:center}.page-subtitle{margin:0 0 1.5rem;color:var(--text-secondary);font-size:1rem}.tab-navigation{display:flex;gap:.5rem;border-top:1px solid var(--border);padding-top:1rem;margin-top:1rem;flex-shrink:0}.tab-btn{padding:.6rem 1.2rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.tab-btn:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--text-primary)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.tab-btn svg{opacity:.8}.tag-manager-container{display:grid;grid-template-columns:350px 1fr;flex:1;min-height:0;overflow:hidden;gap:0;max-width:1600px;margin:0 auto;width:100%}.tag-tree-panel{display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-primary);overflow:hidden}.panel-header{padding:1rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);display:flex;flex-direction:column;gap:.75rem}.search-input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem}.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.category-filter{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer}.category-filter:hover{border-color:var(--accent)}.category-filter:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.filter-row{display:flex;gap:.5rem;width:100%}.btn-block{width:100%;justify-content:center}.header-actions{display:flex;gap:.5rem}.header-actions .btn{flex:1;font-size:.9rem}.tag-tree{flex:1;overflow-y:auto;padding:.75rem;background:var(--bg-primary)}.tree-node-container{margin-bottom:.25rem}.tree-node{display:flex;align-items:center;gap:.4rem;padding:.4rem .5rem;border-radius:4px;background:var(--bg-secondary);border:1px solid transparent;transition:all .15s;cursor:pointer;font-size:.9rem}.tree-node:hover{background:var(--bg-tertiary);border-color:var(--border)}.tree-node.selected{background:var(--accent-transparent)!important;border-color:var(--accent)!important}.tree-node.selected .node-name{color:var(--accent)!important;font-weight:600}.tree-node.selected .node-icon,.tree-node.selected .expand-btn,.tree-node.selected .lock-badge,.tree-node.selected .folder-badge{color:var(--accent)!important}.tree-node.selected .node-count{background:var(--accent)!important;color:#fff!important;font-weight:600;border-color:var(--accent)!important}.expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:0;font-size:.7rem;transition:transform .15s;width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.expand-btn:hover{color:var(--accent);transform:scale(1.2)}.expand-spacer{width:16px;height:16px;flex-shrink:0}.node-icon{font-size:1rem;display:flex;align-items:center;color:var(--text-secondary)}.node-name{flex:1;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lock-badge,.folder-badge{font-size:.7rem;opacity:.7;flex-shrink:0}.node-count{background:var(--bg-tertiary);color:var(--text-secondary);padding:.25rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid var(--border)}.node-usage{color:var(--text-secondary);font-size:.85rem}.node-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.tree-node-header:hover .node-actions{opacity:1}.btn-icon{background:none;border:none;padding:.4rem;cursor:pointer;border-radius:4px;font-size:.9rem;transition:all .2s}.btn-icon:hover{background:#ffffff1a;transform:scale(1.1)}.btn-icon.btn-danger:hover{background:#ef444433;color:#ef4444}.tree-children{margin-left:1.2rem;margin-top:.25rem;padding-left:.75rem;border-left:2px dashed var(--border)}.character-node .tree-node-header{background:var(--bg-primary);font-weight:400}.empty-folder{padding:1.5rem;text-align:center;color:var(--text-secondary);border:2px dashed var(--border);border-radius:8px;background:var(--bg-primary)}.empty-folder p{margin:0 0 1rem;font-size:.9rem}.empty-tree{padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.empty-tree p{margin:0 0 1.5rem;font-size:1.1rem}.tag-details-panel{overflow-y:auto;padding:2rem;background:var(--bg-primary)}.tag-details-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--border)}.tag-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.tag-title-row h2{display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.75rem;color:var(--text-primary)}.tag-icon-large{font-size:2rem}.tag-description{margin:0;color:var(--text-secondary);font-size:1rem;line-height:1.6}.tag-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item label{font-size:.85rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-item span,.info-item code{font-size:1rem;color:var(--text-primary)}.info-item code{background:var(--bg-tertiary);padding:.4rem .6rem;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem}.implications-section,.child-tags-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.implications-section h3,.child-tags-section h3{margin:0 0 1rem;font-size:1.25rem;color:var(--text-primary)}.section-description{margin:0 0 1rem;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.implications-list{display:flex;flex-direction:column;gap:.5rem}.implication-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border)}.impl-arrow{color:var(--accent);font-weight:700;font-size:1.2rem}.impl-tag{flex:1;color:var(--text-primary);font-weight:500}.child-tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.child-tag-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-tertiary);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.child-tag-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.child-icon{font-size:2rem}.child-name{font-weight:600;color:var(--text-primary);text-align:center}.child-usage{font-size:.85rem;color:var(--text-secondary)}.empty-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:3rem}.empty-selection svg{margin-bottom:1.5rem}.empty-selection h3{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.empty-selection>p{margin:0 0 1rem;color:var(--text-secondary);font-size:1rem}.no-selection{display:flex;align-items:center;justify-content:center;height:100%}.no-selection-content{max-width:500px;text-align:center}.no-selection-content h2{margin:0 0 2rem;font-size:1.75rem;color:var(--text-primary)}.help-section{text-align:left;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border);max-width:500px;margin:0 auto}.help-section h3{margin:0 0 .75rem;font-size:1rem;color:var(--accent);font-weight:600}.help-section p{margin:0 0 1rem;color:var(--text-secondary);line-height:1.6;font-size:.95rem}.help-section p:last-child{margin-bottom:0}.help-text{color:var(--text-secondary);line-height:1.6;font-size:.95rem}.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;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-primary);padding:2rem;border-radius:16px;width:90%;max-width:500px;max-height:85vh;overflow-y:auto;border:1px solid var(--border);box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{margin:0 0 1rem;font-size:1.5rem;color:var(--text-primary)}.modal-subtitle{margin:0 0 1.5rem;color:var(--text-secondary);font-size:.95rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary);font-size:.95rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}.form-group small{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.85rem}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.modal-actions .btn{flex:1}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--accent)}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.btn-danger:disabled{background:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;opacity:.5}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.loading{padding:3rem;text-align:center;color:var(--text-secondary);font-size:1rem}.tag-tree::-webkit-scrollbar,.tag-details-panel::-webkit-scrollbar{width:8px}.tag-tree::-webkit-scrollbar-track,.tag-details-panel::-webkit-scrollbar-track{background:var(--bg-primary)}.tag-tree::-webkit-scrollbar-thumb,.tag-details-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.tag-tree::-webkit-scrollbar-thumb:hover,.tag-details-panel::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.delete-property-btn:hover{opacity:1}.property-description{font-size:.85rem;color:var(--text-secondary);margin-bottom:.5rem}.property-meta{display:flex;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.property-type{padding:.125rem .5rem;background:var(--bg-primary);border-radius:3px;font-size:.75rem;text-transform:uppercase}.property-default{font-style:italic}.property-options{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem}.property-option{padding:.25rem .5rem;background:var(--accent);color:#fff;border-radius:3px;font-size:.75rem}.property-option-more{padding:.25rem .5rem;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);border-radius:3px;font-size:.75rem}.no-options{color:var(--text-secondary);font-size:.85rem;font-style:italic}.modal-large{max-width:700px;max-height:80vh;overflow-y:auto}.current-options{margin:1.5rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px}.current-options h3{margin:0 0 1rem;font-size:1rem;color:var(--text-primary)}.options-grid{display:flex;flex-wrap:wrap;gap:.5rem}.option-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;font-size:.9rem}.option-color{width:20px;height:20px;border-radius:50%;border:2px solid var(--border)}.option-name{color:var(--text-primary)}.option-delete{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1;transition:color .2s}.option-delete:hover{color:#f44336}.add-option-form{margin:1.5rem 0;padding:1rem;background:var(--bg-secondary);border-radius:8px}.add-option-form h3{margin:0 0 1rem;font-size:1rem;color:var(--text-primary)}.form-row{display:flex;gap:1rem;align-items:flex-end}.flex-1{flex:1}.color-picker{width:60px;height:38px;border:1px solid var(--border);border-radius:4px;cursor:pointer}.expand-spacer{display:inline-block;width:20px}.lock-badge{margin-left:.5rem;font-size:.9rem}.lock-badge-large{margin-left:.5rem;font-size:1.2rem}.folder-badge{margin-left:.5rem;font-size:.8rem;opacity:.7}.header-actions-row{display:flex;gap:.5rem}.tag-path{padding:.5rem 0;font-size:.9rem;color:var(--text-secondary)}.tag-flags{display:flex;gap:.5rem;flex-wrap:wrap}.flag-badge{padding:.25rem .75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;font-size:.85rem}.flag-badge.group{background:#e3f2fd;border-color:#2196f3;color:#1976d2}.flag-badge.folder{background:#f3e5f5;border-color:#9c27b0;color:#7b1fa2}.flag-badge.global{background:#e8f5e9;border-color:#4caf50;color:#388e3c}.tag-behavior-info{margin-top:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:8px}.tag-behavior-info h3{margin:0 0 .75rem;font-size:1rem;color:var(--text-primary)}.tag-behavior-info p{margin:.5rem 0;font-size:.9rem;line-height:1.5;color:var(--text-secondary)}.context-menu{position:fixed;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:180px;padding:.5rem 0}.context-menu-item{padding:.75rem 1rem;cursor:pointer;color:var(--text-primary);transition:background .2s}.context-menu-item:hover{background:var(--bg-secondary)}.context-menu-item.danger{color:#f44336}.context-menu-item.danger:hover{background:#ffebee}.context-menu-separator{height:1px;background:var(--border);margin:.5rem 0}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background .2s}.checkbox-label:hover{background:var(--bg-secondary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.warning-text{color:#ff9800;padding:.75rem;background:#fff3e0;border-radius:4px;margin-bottom:1rem;font-size:.9rem}.properties-tab-container{flex:1;display:flex;flex-direction:column;padding:2rem;max-width:2200px;margin:0 auto;width:100%;background:var(--bg-primary)}.properties-tab-header{margin-bottom:2rem}.properties-tab-header h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.properties-tab-header p{margin:0 0 1rem;color:var(--text-secondary)}.properties-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.property-card{padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s}.property-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.property-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.property-card-header h3{margin:0;font-size:1.1rem;color:var(--text-primary)}.property-folder-tag{display:inline-block;padding:.25rem .6rem;background:var(--accent-transparent);color:var(--accent);border-radius:4px;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.property-card-desc{margin:0 0 .75rem;font-size:.9rem;color:var(--text-secondary)}.property-card-options{display:flex;flex-wrap:wrap;gap:.5rem}.option-chip{padding:.35rem .75rem;background:var(--bg-tertiary);border-radius:16px;font-size:.85rem;font-weight:500}.no-options-text{color:var(--text-secondary);font-size:.85rem;font-style:italic}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state h3{margin:1rem 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.empty-state p{margin:0 0 1.5rem;color:var(--text-secondary)}.property-details{padding:2rem}.property-details h2{margin:0 0 .5rem;color:var(--text-primary)}.property-details .text-secondary{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.property-options-section{margin-top:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h3{margin:0;font-size:1.1rem}.options-list{display:flex;flex-direction:column;gap:.75rem}.option-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px}.option-item-actions{display:flex;gap:.5rem}.property-actions{margin-top:2rem;display:flex;gap:.75rem;padding-top:2rem;border-top:2px solid var(--border)}.property-checkbox-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;max-height:200px;overflow-y:auto;padding:.5rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px}.form-help-text{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary)}.empty-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:4rem 2rem;text-align:center}.empty-selection h3{margin:1rem 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.empty-selection p{margin:0;color:var(--text-secondary)}.empty-state p{margin:0 0 2rem;color:var(--text-secondary);font-size:1rem}.modal-wide{max-width:600px}.property-selection-tree{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);padding:.5rem}.property-tree-folder{margin-bottom:.5rem}.property-tree-folder-header{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;border-radius:6px;transition:background .15s;-webkit-user-select:none;user-select:none}.property-tree-folder-header:hover{background:var(--bg-tertiary)}.property-tree-folder-header .tree-arrow{font-size:.7rem;color:var(--text-secondary);width:12px;display:inline-block}.property-tree-folder-header svg{width:16px;height:16px;color:var(--text-secondary)}.property-tree-folder-header .folder-name{flex:1;font-weight:600;color:var(--text-primary)}.property-tree-folder-header .node-count{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary);padding:.15rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.property-tree-items{margin-left:1.5rem;display:flex;flex-direction:column;gap:.25rem;padding:.5rem 0}.property-selection-button{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;font-size:.95rem;color:var(--text-primary);width:100%}.property-selection-button:hover{background:var(--accent-transparent);border-color:var(--accent);transform:translate(2px)}.property-selection-button:active{transform:translate(1px)}.property-button-name{font-weight:500;color:var(--text-primary)}.property-button-count{font-size:.85rem;color:var(--text-secondary);font-weight:400}.empty-search{padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.empty-search p{margin:0 0 .5rem;font-weight:600;color:var(--text-primary)}.empty-search small{font-size:.9rem;color:var(--text-secondary)}.tag-properties-section{margin-top:2rem;padding-top:2rem;border-top:2px solid var(--border)}.tag-properties-section h3{margin:0 0 .5rem;font-size:1.2rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.section-subtitle{margin:0 0 1.5rem;color:var(--text-secondary);font-size:.9rem}.assigned-properties-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.assigned-property-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;padding:1rem;transition:all .2s}.assigned-property-item:hover{border-color:var(--accent);box-shadow:0 2px 8px #0000001a}.property-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.property-item-header strong{font-size:1rem;color:var(--text-primary)}.btn-icon-small{background:none;border:none;padding:.25rem;cursor:pointer;color:var(--text-secondary);opacity:.6;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon-small:hover{opacity:1;color:#f44336}.btn-icon-small:disabled{opacity:.3;cursor:not-allowed}.property-item-controls{display:flex;flex-direction:column;gap:.75rem}.form-group-inline{display:flex;align-items:center;gap:.75rem}.form-group-inline label{font-size:.9rem;font-weight:600;color:var(--text-primary);min-width:100px}.form-group-inline select{flex:1;padding:.5rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s}.form-group-inline select:hover{border-color:var(--accent)}.form-group-inline select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-transparent)}.form-group-inline select:disabled{opacity:.5;cursor:not-allowed}.property-item-flags{display:flex;gap:1.5rem;padding-left:100px}.checkbox-label-inline{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.9rem;color:var(--text-primary)}.checkbox-label-inline input[type=checkbox]{width:16px;height:16px;cursor:pointer}.checkbox-label-inline input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.property-item-hints{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.hint-meta{font-size:.85rem;color:var(--text-secondary);font-style:italic}.hint-required{font-size:.85rem;color:#ff9800;font-weight:500}.empty-properties{text-align:center;padding:2rem;color:var(--text-secondary);background:var(--bg-secondary);border:1px dashed var(--border);border-radius:8px}.empty-properties p{margin:0;font-size:.95rem}.tag-detail-panel{display:flex;flex-direction:column;overflow-y:auto;background:var(--bg-primary)}.detail-header{padding:1.5rem;border-bottom:1px solid var(--border);background:var(--bg-secondary);flex-shrink:0}.detail-content{flex:1;overflow-y:auto}.category-description{color:var(--text-secondary);margin:.5rem 0 1.5rem;font-size:.95rem}.automation-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px}.automation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.automation-header h4{margin:0;font-size:1rem;display:flex;align-items:center;gap:.5rem;color:var(--text-primary)}.automation-list{display:flex;flex-direction:column;gap:.5rem}.automation-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;transition:border-color .2s}.automation-item:hover{border-color:var(--accent)}.automation-item span{flex:1;color:var(--text-primary);font-size:.95rem}.btn-icon-sm{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem .5rem;border-radius:4px;font-size:1rem;transition:all .2s}.btn-icon-sm:hover{background:var(--bg-hover);color:var(--error)}.empty-state{text-align:center;padding:1rem;color:var(--text-secondary);font-size:.9rem;font-style:italic}.section-description{color:var(--text-secondary);font-size:.9rem;margin-bottom:1.5rem}.property-select-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding:.5rem}.property-selection-button{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s;text-align:left}.property-selection-button:hover{background:var(--bg-hover);border-color:var(--accent)}.property-button-name{flex:1;color:var(--text-primary);font-size:.95rem}.property-button-count{color:var(--text-secondary);font-size:.85rem}.tag-editor-page{padding:20px;max-width:1800px;margin:0 auto}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.editor-container{display:grid;grid-template-columns:1fr 400px;gap:20px;height:calc(100vh - 180px)}.canvas-panel{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:20px;display:flex;flex-direction:column;gap:15px}.canvas-wrapper{flex:1;max-height:80vh;display:flex;align-items:center;justify-content:center;background:#000;border-radius:8px;overflow:hidden;position:relative}.tag-canvas{max-width:100%;max-height:100%;display:block;cursor:crosshair}.tag-canvas.picking-color{cursor:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 16 16"><path fill="white" stroke="black" d="M13.354.646a1.207 1.207 0 0 0-1.708 0L8.5 3.793l-.646-.647a.5.5 0 1 0-.708.708L8.293 5l-7.147 7.146A.5.5 0 0 0 1 12.5v1.793l-.854.853a.5.5 0 1 0 .708.707L1.707 15H3.5a.5.5 0 0 0 .354-.146L11 7.707l1.146 1.147a.5.5 0 0 0 .708-.708l-.647-.646 3.147-3.146a1.207 1.207 0 0 0 0-1.708l-2-2zM2 12.707l7-7L10.293 7l-7 7H2v-1.293z"/></svg>') 2 14,crosshair}.canvas-info{display:flex;justify-content:space-between;align-items:center;gap:15px;padding:12px 15px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.info-left{display:flex;align-items:center;gap:15px;flex:1}.image-name{margin:0;font-size:14px;font-weight:500;color:var(--text-primary)}.autosave-status{font-size:12px;color:var(--text-secondary)}.navigation-buttons{display:flex;gap:10px}.image-metadata{padding:12px 15px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.image-metadata h4{margin:0 0 10px;font-size:13px;font-weight:600;color:var(--text-primary)}.metadata-grid{display:grid;grid-template-columns:minmax(120px,1.2fr) minmax(120px,1.2fr) minmax(100px,1fr) auto;gap:10px;align-items:end}.metadata-field{display:flex;flex-direction:column;gap:5px}.metadata-field label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;display:flex;align-items:center;gap:6px}.metadata-field input[type=checkbox]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;cursor:pointer;position:relative;background:var(--bg-primary);transition:all .2s ease}.metadata-field input[type=checkbox]:hover{border-color:var(--accent)}.metadata-field input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.metadata-field input[type=checkbox]:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:12px;font-weight:700}.metadata-field select{padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer}.metadata-field select:focus{outline:none;border-color:var(--accent)}.color-picker-wrapper{display:flex;align-items:center;gap:6px}.color-picker-wrapper input[type=color]{width:40px;height:28px;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;background:none}.eyedropper-btn{padding:4px 6px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease;height:28px}.eyedropper-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.color-value{font-size:12px;color:var(--text-secondary);flex:1}.canvas-instructions{padding:15px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.canvas-instructions p{margin:8px 0;font-size:14px;color:var(--text-secondary)}.canvas-instructions strong{color:var(--text-primary)}.tags-panel{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.tags-section{flex:1}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-header h3{margin:0;font-size:18px;color:var(--text-primary)}.empty-tags{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-tags p{margin:8px 0}.empty-tags .hint{font-size:14px;font-style:italic;color:var(--text-tertiary)}.tags-tree{display:flex;flex-direction:column;gap:8px}.annotation-item{border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);transition:all .2s}.annotation-item.selected{border-color:var(--primary-color);background:var(--primary-color-light)}.annotation-header{display:flex;align-items:center;gap:8px;padding:10px;cursor:pointer}.annotation-header:hover{background:var(--bg-hover)}.expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:12px;padding:4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.annotation-icon{font-size:20px}.annotation-name{flex:1;font-weight:600;color:var(--text-primary);font-size:14px}.bbox-badge{font-size:16px}.annotation-actions{display:flex;gap:4px}.annotation-children{padding-left:30px;padding-bottom:8px;display:flex;flex-direction:column;gap:6px}.selected-annotation-info{padding:15px;background:var(--primary-color-light);border:2px solid var(--primary-color);border-radius:8px}.selected-annotation-info h4{margin:0 0 8px;color:var(--text-primary);font-size:16px}.selected-annotation-info p{margin:0 0 8px;font-size:14px;color:var(--text-secondary)}.bbox-info{font-size:12px;color:var(--text-tertiary)}.tag-selector-modal{max-width:600px;max-height:80vh}.tag-selector-modal-large{max-width:700px;max-height:85vh;display:flex;flex-direction:column}.modal-header-custom{margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border)}.modal-header-custom h2{margin:0 0 8px;font-size:24px;color:var(--text-primary)}.modal-subtitle{margin:0;font-size:14px;color:var(--text-secondary)}.modal-subtitle strong{color:var(--accent);font-weight:600}.tag-search-input{width:100%;padding:12px;margin-bottom:15px;border:2px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:16px;transition:border-color .2s}.tag-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-transparent, rgba(52, 152, 219, .1))}.tag-selector-tree{flex:1;overflow-y:auto;min-height:300px;max-height:500px;border:1px solid var(--border);border-radius:8px;padding:10px;background:var(--bg-secondary)}.tree-browser{display:flex;flex-direction:column;gap:4px}.selector-tree-node{margin-bottom:2px}.selector-node{display:flex;align-items:center;padding:10px;background:var(--card-bg);border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s}.selector-node:hover{background:var(--bg-hover);border-color:var(--accent);transform:translate(2px)}.selector-node.suggested{background:var(--warning-bg, #fff9e6);border-color:var(--warning, #ffd700)}.selector-node.tagged{opacity:.5;cursor:not-allowed}.selector-node.tagged:hover{transform:none;border-color:transparent;background:var(--card-bg)}.selector-node.selector-group{background:var(--bg-tertiary);cursor:default;border-color:var(--border)}.selector-node.selector-group:hover{transform:none;border-color:var(--border);background:var(--bg-tertiary)}.selector-node-content{display:flex;align-items:center;gap:8px;flex:1}.selector-node-content.group-header{font-weight:600;color:var(--text-primary)}.group-hint{font-size:11px;color:var(--text-tertiary);font-style:italic;margin-left:auto}.expand-btn-small{background:none;border:none;font-size:12px;cursor:pointer;padding:4px;margin-right:4px;color:var(--text-secondary);transition:color .2s}.expand-btn-small:hover{color:var(--text-primary)}.expand-spacer-small{width:24px;display:inline-block}.node-icon-small{font-size:18px}.node-name-small{font-size:14px;font-weight:500;color:var(--text-primary)}.global-badge-small{font-size:14px;margin-left:auto}.tagged-badge{background:var(--success, #27ae60);color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:600}.suggested-badge{background:var(--warning, #f39c12);color:#fff;font-size:11px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:600}.selector-tree-children{margin-left:20px;margin-top:2px}.search-results{display:flex;flex-direction:column;gap:6px}.tag-search-result{display:flex;align-items:center;gap:12px;padding:12px;background:var(--card-bg);border:2px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.tag-search-result:hover{background:var(--bg-tertiary);border-color:var(--accent);transform:translate(4px);box-shadow:0 2px 8px var(--shadow, rgba(0, 0, 0, .1))}.tag-search-result.tagged{opacity:.5;cursor:not-allowed}.tag-search-result.tagged:hover{transform:none;border-color:var(--border);box-shadow:none;background:var(--card-bg)}.result-icon{font-size:24px;flex-shrink:0}.result-info{flex:1;min-width:0}.result-name{font-weight:600;color:var(--text-primary);font-size:15px;margin-bottom:2px}.result-desc{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-badges{display:flex;gap:6px;flex-shrink:0;align-items:center}.badge-global,.badge-tagged{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:600;white-space:nowrap}.badge-global{background:var(--accent);color:#fff}.badge-tagged{background:#4caf50e6;color:#fff}.no-results{text-align:center;padding:40px 20px;color:var(--text-secondary)}.no-results p{margin:8px 0;color:var(--text-primary)}.no-results .hint{font-size:13px;color:var(--text-tertiary)}.suggested-tags-section{margin-bottom:20px;padding:15px;background:var(--warning-bg, rgba(255, 215, 0, .1));border:2px solid var(--warning, #ffd700);border-radius:8px}.suggested-tags-section h3{margin:0 0 12px;font-size:16px;color:var(--warning-dark, #f39c12)}.suggested-tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.suggested-tag-btn{display:flex;align-items:center;gap:8px;padding:10px;background:var(--card-bg);border:2px solid var(--warning, #ffd700);border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px;color:var(--text-primary)}.suggested-tag-btn:hover{background:var(--warning, #ffd700);transform:scale(1.05);color:#000}.suggested-tag-btn .tag-icon{font-size:20px}.suggested-tag-btn .tag-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-options-list{max-height:400px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.tag-option{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.tag-option:hover{background:var(--bg-hover);border-color:var(--primary-color);transform:translate(4px)}.tag-option .tag-icon{font-size:24px}.tag-option .tag-info{flex:1}.tag-option .tag-name{font-weight:600;color:var(--text-primary);font-size:16px;margin-bottom:4px}.tag-option .tag-meta{display:flex;gap:10px;font-size:12px}.tag-option .tag-type{color:var(--text-secondary);padding:2px 6px;background:var(--bg-tertiary);border-radius:4px}.tag-option .tag-usage{color:var(--text-tertiary)}.no-tags{text-align:center;padding:40px 20px;color:var(--text-secondary)}.no-tags p{margin-bottom:15px}.loading,.error{text-align:center;padding:60px 20px;font-size:18px;color:var(--text-secondary)}.error{color:#e74c3c}@media (max-width: 1200px){.editor-container{grid-template-columns:1fr;height:auto}.canvas-panel{min-height:500px}.tags-panel{max-height:none}}.tag-properties-editor{margin-top:15px;padding-top:15px;border-top:1px solid var(--border-color)}.tag-properties-editor h5{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.property-field{margin-bottom:12px}.property-field label{display:block;margin-bottom:4px;font-size:13px;color:var(--text-secondary);font-weight:500}.property-field .required-asterisk{color:#e74c3c;margin-left:4px}.property-field .meta-badge-inline{background:var(--info-color);color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;margin-left:6px;font-weight:600}.property-field select,.property-field input[type=text]{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:13px;transition:border-color .2s}.property-field select:focus,.property-field input[type=text]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-transparent)}.property-field select:disabled,.property-field input[type=text]:disabled{background:var(--bg-tertiary);color:var(--text-tertiary);cursor:not-allowed;opacity:.6}.tag-properties-inline{display:inline-flex;gap:4px;margin-left:8px}.property-badge{background:var(--accent-color, #3498db);color:#fff;font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500}.annotation-tree-view{flex:1;overflow-y:auto;padding:10px}.tree-root-node{margin-bottom:10px}.tree-node-item{display:flex;align-items:center;gap:6px;padding:8px 10px;margin-bottom:2px;background:var(--bg-secondary);border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s;font-size:14px}.tree-node-item:hover{background:var(--bg-hover);border-color:var(--border-color)}.tree-node-item.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.tree-node-item.active .node-label-main,.tree-node-item.active .node-icon-tiny,.tree-node-item.active svg{color:#fff}.tree-node-item.dragging{opacity:.4;cursor:move}.tree-node-item.drag-over-inside{background:var(--accent-transparent);border-color:var(--accent);border-style:solid;box-shadow:0 0 0 2px var(--accent-transparent)}.drop-indicator{height:2px;background:var(--accent);border-radius:2px;z-index:10;pointer-events:none;margin:2px 0}.drag-handle{cursor:grab;opacity:.3;transition:opacity .2s;display:flex;align-items:center}.tree-node-item:hover .drag-handle{opacity:.7}.drag-handle:active{cursor:grabbing}.drag-handle:hover{opacity:1}.node-icon-tiny svg,.visibility-btn-small svg,.bbox-indicator-tiny svg,.global-indicator-tiny svg{vertical-align:middle;display:inline-block}.tree-node{margin-left:calc(var(--level, 0) * 20px);margin-bottom:4px;position:relative}.tree-children{margin-left:12px;border-left:2px dashed var(--border-color);padding-left:8px}.node-icon{font-size:18px;flex-shrink:0}.node-icon-tiny{font-size:14px;flex-shrink:0}.node-label{flex:1;font-weight:500;color:var(--text-primary)}.node-label-main{flex:1;font-size:13px;color:var(--text-primary);word-break:break-word}.active-indicator{color:var(--primary-color);font-size:10px;animation:pulse 1.5s ease-in-out infinite}.tree-node-item.active .active-indicator{color:#fff}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.visibility-btn-small{background:none;border:none;font-size:14px;cursor:pointer;padding:2px;opacity:.6;transition:opacity .2s;color:var(--text-primary)}.visibility-btn-small svg{fill:currentColor}.visibility-btn-small:hover{opacity:1}.visibility-btn-small.hidden{opacity:.3}.expand-btn-tiny{background:none;border:none;font-size:10px;cursor:pointer;padding:2px 4px;color:var(--text-secondary)}.expand-spacer-tiny{width:18px;display:inline-block}.bbox-indicator-tiny,.global-indicator-tiny{font-size:12px;opacity:.7}.remove-btn-tiny{background:none;border:none;font-size:18px;cursor:pointer;color:#e74c3c;padding:0 4px;opacity:0;transition:opacity .2s}.tree-node-item:hover .remove-btn-tiny{opacity:.7}.remove-btn-tiny:hover{opacity:1!important}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:15px;border-bottom:2px solid var(--border-color)}.panel-header h3{margin:0;font-size:18px}.tag-count{background:var(--primary-color);color:#fff;font-size:12px;padding:4px 10px;border-radius:12px;font-weight:600}.active-tag-info{padding:15px;background:var(--bg-secondary);border-top:2px solid var(--border-color);margin-top:auto}.active-tag-info h4{margin:0 0 10px;font-size:14px;font-weight:600;color:var(--text-primary)}.active-tag-name{font-size:13px;font-weight:600;color:var(--primary-color);margin:0 0 8px;word-break:break-word}.bbox-coords{font-size:12px;color:var(--text-tertiary);margin:0 0 10px}.tree-group-wrapper{margin-bottom:8px}.tree-group-header{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s;font-weight:600;color:var(--text-primary)}.tree-group-header:hover{background:var(--bg-tertiary);border-color:var(--accent)}.tree-group-header .expand-indicator{font-size:10px;color:var(--text-secondary);width:12px}.tree-group-header .group-icon{font-size:16px}.tree-group-header .group-name{flex:1;font-size:14px}.tree-group-header .child-count{font-size:12px;color:var(--text-tertiary);font-weight:400}.tree-group-children{margin-left:8px;margin-top:4px;padding-left:12px;border-left:2px solid var(--border)}.tree-tag-wrapper{margin-bottom:2px}.tree-tag-item{display:flex;align-items:center;padding:8px 12px;background:var(--card-bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s}.tree-tag-item:hover{background:var(--bg-tertiary);border-color:var(--accent);transform:translate(2px)}.tree-tag-item.suggested{background:#ffd7001a;border-color:#ffd70080}.tree-tag-item.already-tagged{opacity:.5;cursor:not-allowed}.tree-tag-item.already-tagged:hover{transform:none;border-color:var(--border);background:var(--card-bg)}.tree-tag-main{display:flex;align-items:center;gap:10px;flex:1}.tree-tag-main .tag-icon{font-size:18px}.tree-tag-main .tag-name{font-size:14px;font-weight:500;color:var(--text-primary);flex:1}.tree-tag-main .tag-badges{display:flex;gap:6px;align-items:center}.tree-tag-item .badge{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:600}.tree-tag-item .badge-global{background:var(--accent);color:#fff}.tree-tag-item .badge-suggested{background:#ffc107e6;color:#000}.tree-tag-item .badge-count{background:#ff9800e6;color:#fff;font-weight:600}.tree-tag-children{margin-top:4px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.6;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit;font-size:inherit}input,textarea,select{font-family:inherit;font-size:inherit}img{max-width:100%;height:auto}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.container{max-width:1600px;margin:0 auto;padding:0 1.5rem}.page-header{margin-bottom:2rem}.page-title{font-size:1.75rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:500;transition:all .2s ease;gap:.5rem}.btn-primary{background-color:var(--accent);color:#fff}.btn-primary:hover{background-color:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--bg-secondary)}.btn-danger{background-color:#ef4444;color:#fff}.btn-danger:hover{background-color:#dc2626}.btn-outline{background-color:transparent;border:2px solid var(--accent);color:var(--accent)}.btn-outline:hover{background-color:var(--accent);color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:.75rem 1rem;border:2px solid var(--border);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-transparent)}.form-input::placeholder{color:var(--text-tertiary)}.form-error{color:#ef4444;font-size:.875rem;margin-top:.5rem}.form-success{color:#22c55e;font-size:.875rem;margin-top:.5rem}.card{background-color:var(--bg-secondary);border-radius:12px;padding:1.5rem;border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.card-hover:hover{transform:translateY(-2px);box-shadow:0 8px 25px var(--shadow)}.card-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.card-description{color:var(--text-secondary);font-size:.9rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.alert{padding:1rem 1.25rem;border-radius:8px;margin-bottom:1rem}.alert-error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.alert-success{background-color:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.alert-info{background-color:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-secondary)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border: #e2e8f0;--accent: #6366f1;--accent-hover: #4f46e5;--accent-transparent: rgba(99, 102, 241, .15);--shadow: rgba(0, 0, 0, .1);--card-bg: #ffffff;--navbar-bg: #ffffff}[data-theme=default][data-mode=light]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--text-tertiary: #94a3b8;--border: #e2e8f0;--accent: #6366f1;--accent-hover: #4f46e5;--accent-transparent: rgba(99, 102, 241, .15);--shadow: rgba(0, 0, 0, .1);--card-bg: #ffffff;--navbar-bg: #ffffff}[data-theme=default][data-mode=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--border: #334155;--accent: #818cf8;--accent-hover: #a5b4fc;--accent-transparent: rgba(129, 140, 248, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #1e293b;--navbar-bg: #1e293b}[data-theme=love-pink][data-mode=light]{--bg-primary: #fffbfc;--bg-secondary: #fdf2f8;--bg-tertiary: #fce7f3;--text-primary: #831843;--text-secondary: #9d174d;--text-tertiary: #be185d;--border: #fbcfe8;--accent: #ec4899;--accent-hover: #db2777;--accent-transparent: rgba(236, 72, 153, .15);--shadow: rgba(190, 24, 93, .1);--card-bg: #ffffff;--navbar-bg: #fdf2f8}[data-theme=love-pink][data-mode=dark]{--bg-primary: #1a0a12;--bg-secondary: #2d1221;--bg-tertiary: #4a1d34;--text-primary: #fdf2f8;--text-secondary: #f9a8d4;--text-tertiary: #f472b6;--border: #4a1d34;--accent: #f472b6;--accent-hover: #f9a8d4;--accent-transparent: rgba(244, 114, 182, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #2d1221;--navbar-bg: #2d1221}[data-theme=retro-red][data-mode=light]{--bg-primary: #fffbf7;--bg-secondary: #fef3e9;--bg-tertiary: #fed7aa;--text-primary: #7c2d12;--text-secondary: #9a3412;--text-tertiary: #c2410c;--border: #fed7aa;--accent: #ea580c;--accent-hover: #c2410c;--accent-transparent: rgba(234, 88, 12, .15);--shadow: rgba(124, 45, 18, .1);--card-bg: #ffffff;--navbar-bg: #fef3e9}[data-theme=retro-red][data-mode=dark]{--bg-primary: #1c0f08;--bg-secondary: #2d1a10;--bg-tertiary: #4a2c1a;--text-primary: #fef3e9;--text-secondary: #fdba74;--text-tertiary: #fb923c;--border: #4a2c1a;--accent: #fb923c;--accent-hover: #fdba74;--accent-transparent: rgba(251, 146, 60, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #2d1a10;--navbar-bg: #2d1a10}[data-theme=ocean-blue][data-mode=light]{--bg-primary: #f0fdfa;--bg-secondary: #ccfbf1;--bg-tertiary: #99f6e4;--text-primary: #134e4a;--text-secondary: #115e59;--text-tertiary: #0f766e;--border: #5eead4;--accent: #14b8a6;--accent-hover: #0d9488;--accent-transparent: rgba(20, 184, 166, .15);--shadow: rgba(19, 78, 74, .1);--card-bg: #ffffff;--navbar-bg: #ccfbf1}[data-theme=ocean-blue][data-mode=dark]{--bg-primary: #042f2e;--bg-secondary: #0d3d3b;--bg-tertiary: #115e59;--text-primary: #ccfbf1;--text-secondary: #5eead4;--text-tertiary: #2dd4bf;--border: #115e59;--accent: #2dd4bf;--accent-hover: #5eead4;--accent-transparent: rgba(45, 212, 191, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #0d3d3b;--navbar-bg: #0d3d3b}[data-theme=wood-green][data-mode=light]{--bg-primary: #fafdf7;--bg-secondary: #ecfccb;--bg-tertiary: #d9f99d;--text-primary: #365314;--text-secondary: #3f6212;--text-tertiary: #4d7c0f;--border: #bef264;--accent: #84cc16;--accent-hover: #65a30d;--accent-transparent: rgba(132, 204, 22, .15);--shadow: rgba(54, 83, 20, .1);--card-bg: #ffffff;--navbar-bg: #ecfccb}[data-theme=wood-green][data-mode=dark]{--bg-primary: #1a2e05;--bg-secondary: #263c0a;--bg-tertiary: #365314;--text-primary: #ecfccb;--text-secondary: #bef264;--text-tertiary: #a3e635;--border: #365314;--accent: #a3e635;--accent-hover: #bef264;--accent-transparent: rgba(163, 230, 53, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #263c0a;--navbar-bg: #263c0a}[data-theme=static-grey][data-mode=light]{--bg-primary: #fafafa;--bg-secondary: #f4f4f5;--bg-tertiary: #e4e4e7;--text-primary: #27272a;--text-secondary: #52525b;--text-tertiary: #71717a;--border: #d4d4d8;--accent: #71717a;--accent-hover: #52525b;--accent-transparent: rgba(113, 113, 122, .15);--shadow: rgba(39, 39, 42, .1);--card-bg: #ffffff;--navbar-bg: #f4f4f5}[data-theme=static-grey][data-mode=dark]{--bg-primary: #18181b;--bg-secondary: #27272a;--bg-tertiary: #3f3f46;--text-primary: #fafafa;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--border: #3f3f46;--accent: #a1a1aa;--accent-hover: #d4d4d8;--accent-transparent: rgba(161, 161, 170, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #27272a;--navbar-bg: #27272a}
