.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-left{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.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;flex-shrink:0}.mobile-menu-toggle:hover{background-color:var(--bg-tertiary)}.mobile-menu-toggle-hidden{display:none}.main-content{flex-grow:1;padding:2rem 0}@media (max-width: 768px){.mobile-menu-toggle{display:block}.navbar-content{padding:.75rem 1rem;gap:1rem;position:relative}.navbar-left{gap:.75rem}.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}}@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;margin-bottom:2rem}.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}}.advanced-upload-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 1.25rem;margin-bottom:1.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;font-size:.9rem;color:var(--text-secondary);flex-wrap:wrap}.advanced-upload-banner .btn-sm{white-space:nowrap;flex-shrink:0}.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}.character-header-banner{position:relative;margin-bottom:2rem;padding:2rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border);overflow:hidden}.character-header-top{position:relative;z-index:1;display:flex;justify-content:flex-end;margin-bottom:1rem}.character-banner-bg{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.15;z-index:0}.character-header-content{position:relative;z-index:1;display:flex;align-items:flex-start;gap:2rem}.character-back-button{margin-left:auto;flex-shrink:0;align-self:flex-start}.character-header-avatar{flex-shrink:0;width:120px;height:120px;border-radius:50%;overflow:hidden;background:var(--bg-primary);border:3px solid var(--border);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000001a}.character-banner-image{width:100%;height:100%;object-fit:cover}.character-header-placeholder{width:50%;height:50%;color:var(--text-tertiary);display:none;align-items:center;justify-content:center}.character-header-placeholder svg{width:100%;height:100%}.character-header-info{max-width:800px}.character-header-title{margin:0 0 .75rem;font-size:2rem;font-weight:700;color:var(--text-primary)}.character-header-description{margin:0 0 1rem;font-size:1rem;line-height:1.6;color:var(--text-secondary)}.character-children-section{margin:1.5rem 0;padding:1.5rem;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border)}.character-children-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.character-children-scroll{display:flex;gap:1.5rem;overflow-x:auto;padding:.5rem 0;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.character-children-scroll::-webkit-scrollbar{height:8px}.character-children-scroll::-webkit-scrollbar-track{background:transparent}.character-children-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.character-children-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.character-child-card{display:flex;flex-direction:column;align-items:center;text-decoration:none;transition:transform .2s ease;flex-shrink:0;width:100px}.character-child-card:hover{transform:translateY(-4px)}.character-child-avatar{width:100px;height:100px;border-radius:50%;overflow:hidden;background:var(--bg-secondary);border:3px solid var(--border);transition:border-color .2s ease;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.character-child-card:hover .character-child-avatar{border-color:var(--accent)}.character-child-avatar img{width:100%;height:100%;object-fit:cover}.character-child-placeholder{width:50%;height:50%;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center}.character-child-placeholder svg{width:100%;height:100%}.character-child-name{font-size:.9rem;font-weight:500;color:var(--text-primary);text-align:center;line-height:1.3;transition:color .2s ease}.character-child-card:hover .character-child-name{color:var(--accent)}.character-parent-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.9rem;font-weight:500;text-decoration:none;transition:all .2s ease}.character-parent-link:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent);transform:translate(-2px)}.character-parent-link svg{flex-shrink:0}.sort-controls{display:flex;justify-content:space-between;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-left{display:flex;gap:1.5rem;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)}.sort-controls .toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:var(--text-primary);position:relative}.sort-controls .toggle-checkbox{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.sort-controls .toggle-switch{position:relative;display:inline-block;width:44px;height:24px;background:var(--border);border-radius:12px;transition:background .3s}.sort-controls .toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.sort-controls .toggle-checkbox:checked+.toggle-switch{background:var(--accent)}.sort-controls .toggle-checkbox:checked+.toggle-switch:after{transform:translate(20px)}.sort-controls .toggle-label:hover .toggle-switch{opacity:.8}.sort-controls .toggle-text{font-weight:500;color:var(--text-primary)}.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:row;align-items:flex-start;position:relative}.lightbox-main-column{display:flex;flex-direction:column;gap:1rem;flex:1;max-height:95vh;transition:transform .2s ease-out;position:relative;z-index:1}.lightbox-main-column:has(.zoom-mode){transition:none}.lightbox-main-column.panel-open{transform:translate(-80px)}.lightbox-main-column.panel-open:has(.zoom-mode){transform:none}.lightbox-main-column.panel-open .lightbox-image-container.zoom-mode{transform:none}.lightbox-image-container{flex-shrink:0;height:70vh;max-width:90vw;align-self:center;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#000;border-radius:8px}.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-mode .lightbox-tag-button,.zoom-mode .lightbox-info-button,.zoom-mode .lightbox-view-button,.zoom-mode .lightbox-link-button,.zoom-mode .lightbox-delete-button{opacity:0!important;pointer-events:none}.lightbox-main-column:has(.zoom-mode)~.lightbox-close{opacity:0!important;pointer-events:none}.lightbox-content:has(.zoom-mode) .lightbox-close{display:none}.zoom-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#000000ba;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px)}.zoom-slider-container{position:absolute;left:1rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:.75rem;background:var(--bg-secondary);padding:1rem .75rem;border-radius:12px;border:1px solid var(--border);box-shadow:0 4px 12px var(--shadow);z-index:10;pointer-events:auto;-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px)}.zoom-button{width:36px;height:36px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:1.3rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1}.zoom-button:hover{background:var(--accent-transparent);color:var(--accent);transform:scale(1.05)}.zoom-button:active{transform:scale(.95)}.zoom-slider{width:6px;height:160px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:3px;outline:none;cursor:pointer;writing-mode:bt-lr;-webkit-appearance:slider-vertical}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.zoom-slider::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.zoom-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.zoom-slider::-moz-range-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.zoom-level-text{color:var(--text-primary);font-size:.8rem;font-weight:600;min-width:45px;text-align:center;padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:4px}.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:.3rem;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:3.5rem;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.3rem;border-radius:50%;font-size:1rem;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-info-button:hover{opacity:1;transform:scale(1.1)}.lightbox-link-button{position:absolute;top:1rem;left:6rem;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.3rem;border-radius:50%;font-size:1rem;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-link-button:hover{opacity:1;transform:scale(1.1)}.lightbox-view-button{position:absolute;top:1rem;left:8.5rem;background:#0009;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.3rem;border-radius:50%;font-size:1rem;opacity:.7;transition:opacity .2s ease,transform .2s ease;z-index:10;width:36px;height:36px;display:flex;align-items:center;justify-content:center;text-decoration:none}.lightbox-view-button:hover{opacity:1;transform:scale(1.1)}.lightbox-delete-button{position:absolute;top:1rem;left:11rem;background:#dc2626cc;border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;padding:.3rem;border-radius:50%;font-size:1rem;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-delete-button:hover{opacity:1;transform:scale(1.1);background:#dc2626}.lightbox-info-panel{position:absolute;right:0;top:0;width:350px;height:70vh;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);overflow-y:auto;animation:slideFromBehind .2s ease-out forwards;flex-shrink:0;z-index:0}.lightbox-info-panel.closing{animation:slideBackBehind .2s ease-out forwards}@keyframes slideFromBehind{0%{right:0;opacity:.5}to{right:-300px;opacity:1}}@keyframes slideBackBehind{0%{right:-300px;opacity:1}to{right:0;opacity:.5}}.info-panel-content{padding:1.5rem}.info-panel-close{display:none;position:absolute;top:1rem;right:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;color:var(--text-primary);transition:all .2s ease;z-index:10}.info-panel-close:hover{background:var(--bg-primary);color:var(--accent);transform:scale(1.1)}.lightbox-info-panel .info-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.lightbox-info-panel .info-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.lightbox-info-panel .info-section h4{margin:0 0 .5rem;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.lightbox-info-panel .info-section>div{margin-bottom:.4rem}.lightbox-info-panel .info-section>div:last-child{margin-bottom:0}.lightbox-info-panel .color-info{display:flex;align-items:center;gap:.5rem}.lightbox-info-panel .color-tag{display:inline-block;padding:.25rem .6rem;border-radius:4px;font-size:.85rem;font-weight:500;border:1px solid var(--border-color);min-width:60px;text-align:center;text-transform:capitalize}.lightbox-info-panel .color-tag[data-color=red]{background-color:#e74c3c;color:#fff}.lightbox-info-panel .color-tag[data-color=green]{background-color:#2ecc71;color:#fff}.lightbox-info-panel .color-tag[data-color=blue]{background-color:#3498db;color:#fff}.lightbox-info-panel .color-tag[data-color=yellow]{background-color:#f1c40f;color:#333}.lightbox-info-panel .color-tag[data-color=orange]{background-color:#e67e22;color:#fff}.lightbox-info-panel .color-tag[data-color=purple]{background-color:#9b59b6;color:#fff}.lightbox-info-panel .color-tag[data-color=pink]{background-color:#ff69b4;color:#fff}.lightbox-info-panel .color-tag[data-color=brown]{background-color:#8b4513;color:#fff}.lightbox-info-panel strong{margin-right:.5rem;color:var(--text-secondary)}.processed-checkmark{position:absolute;top:53%;left:50%;transform:translate(-50%,-50%);color:#0009;width:9px;height:9px;pointer-events:none}.stats-row{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.stats-row:last-child{margin-bottom:0}.stat-item{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.stat-item.balance{margin-left:auto;font-weight:600;color:var(--accent)}.stat-item svg{flex-shrink:0;opacity:.7}.color-bubbles{display:flex;gap:.75rem}.color-bubble{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;border:2px solid var(--border-color);cursor:help;transition:transform .2s ease}.color-bubble:hover{transform:scale(1.1)}.color-bubble[data-color=red]{background-color:#e74c3c;color:#fff}.color-bubble[data-color=green]{background-color:#2ecc71;color:#fff}.color-bubble[data-color=blue]{background-color:#3498db;color:#fff}.color-bubble[data-color=yellow]{background-color:#f1c40f;color:#333}.color-bubble[data-color=orange]{background-color:#e67e22;color:#fff}.color-bubble[data-color=purple]{background-color:#9b59b6;color:#fff}.color-bubble[data-color=pink]{background-color:#ff69b4;color:#fff}.color-bubble[data-color=brown]{background-color:#8b4513;color:#fff}.color-bubble:not([data-color]),.color-bubble[data-color=""]{background-color:#666;color:#fff}.character-list{display:flex;flex-direction:column;gap:.75rem}.character-item{display:flex;align-items:center;gap:.75rem}.character-item.clickable{cursor:pointer;padding:.5rem;border-radius:8px;margin:-.5rem;transition:all .2s ease}.character-item.clickable:hover{background:var(--bg-hover);transform:translate(4px)}.character-item.clickable:hover .character-avatar-wrapper{border-color:var(--accent);transform:scale(1.05)}.character-item.clickable:hover .character-name{color:var(--accent)}.character-avatar-wrapper{width:48px;height:48px;border-radius:50%;overflow:hidden;background:var(--bg-tertiary);border:2px solid var(--border-color);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.character-avatar{width:100%;height:100%;object-fit:cover;display:block}.character-avatar.avatar-error{opacity:0}.character-name{font-size:.95rem;font-weight:500;color:var(--text-primary);transition:color .2s ease}.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:.5rem;width:100%;max-width:90vw;min-width:0}.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:4px 4px .5rem;flex-wrap:nowrap;align-items:center;min-width:0}.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:border-color .15s,box-shadow .15s;background:#ffffff0d;flex-shrink:0;width:100px;height:100px}.variant-thumbnail:hover{border-color:#fff9}.variant-thumbnail.current-variant{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent);cursor:default}.variant-thumbnail.current-variant:hover{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.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: 1680px){.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%}.lightbox-info-panel{width:100%;right:auto;left:0;height:70vh}@keyframes slideFromBehind{0%{left:100%;opacity:.5}to{left:0;opacity:1}}@keyframes slideBackBehind{0%{left:0;opacity:1}to{left:100%;opacity:.5}}.lightbox-main-column.panel-open{transform:translate(-110%)}.lightbox-main-column.panel-open:has(.zoom-mode){transform:none}.info-panel-close{display:flex}.lightbox-content:has(.panel-open)>.lightbox-close{display:none}}@media (max-width: 768px){.gallery-page .quick-actions-section{margin-top:1rem;margin-bottom:1rem}.gallery-page .actions-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.gallery-page .action-card{flex-direction:column;align-items:center;text-align:center;padding:.65rem .4rem;min-height:unset;gap:.4rem;border-radius:10px}.gallery-page .action-icon{width:34px;height:34px;border-radius:8px}.gallery-page .action-icon svg{width:18px;height:18px}.gallery-page .action-title{font-size:.75rem;font-weight:600}.gallery-page .action-description{display:none}}@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}}.link-modal .modal-header h2{margin:0}.sort-toggle-btn svg{flex-shrink:0}.link-search-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem}.link-result-thumbnail{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.link-tabs{display:flex;gap:0;margin-bottom:1rem;border-bottom:2px solid var(--border)}.sort-right{display:flex;align-items:center;gap:1.5rem}.view-controls{display:flex;align-items:center;gap:10px}.view-label{font-size:.9rem;color:var(--text-secondary)}.slider-container{display:flex;align-items:center;gap:8px}.btn-icon-sm{padding:4px;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:0}.btn-icon-sm:hover{border-color:var(--accent);color:var(--accent)}.theme-slider{-webkit-appearance:none;width:100px;height:4px;background:var(--bg-tertiary);border-radius:2px;outline:none;cursor:pointer}.theme-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-secondary);transition:transform .1s}.theme-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.theme-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);cursor:pointer;border:2px solid var(--bg-secondary);transition:transform .1s}.theme-slider::-moz-range-thumb:hover{transform:scale(1.1)}.gallery-toolbar{margin-bottom:1rem}.search-bar-container{position:relative;margin-bottom:8px}.search-input{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.search-input:focus{border-color:var(--accent);outline:none}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;z-index:100;max-height:300px;overflow-y:auto;margin-top:4px;box-shadow:0 4px 20px #0000004d}.autocomplete-item{padding:10px 14px;cursor:pointer;display:flex;justify-content:space-between;border-bottom:1px solid var(--border);align-items:center}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background-color:var(--bg-tertiary)}.tag-name{font-weight:500}.tag-meta{color:var(--text-secondary);font-size:.85rem}.active-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem}.filter-chip{background:var(--accent);color:#fff;padding:6px 12px;border-radius:20px;font-size:.9rem;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0003}.filter-chip button{background:none;border:none;color:#fffc;cursor:pointer;padding:0;display:flex;align-items:center}.filter-chip button:hover{color:#fff}.clear-filters-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:6px 12px;border-radius:20px;cursor:pointer;font-size:.9rem;transition:all .2s}.clear-filters-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.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}.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:#00000037;color:#fff;padding:1rem;border-radius:8px}.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}}.champ-page{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:2rem}.champ-loading-page{flex-direction:column;gap:1.25rem;color:var(--text-secondary)}.champ-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:champSpin .75s linear infinite}@keyframes champSpin{to{transform:rotate(360deg)}}.champ-setup{display:flex;flex-direction:column;align-items:center;gap:2rem;max-width:580px;width:100%}.champ-setup-logo{color:var(--accent);filter:drop-shadow(0 0 20px color-mix(in srgb,var(--accent) 40%,transparent));animation:logoFloat 3s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.champ-setup-title{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin:0;letter-spacing:-.02em}.champ-setup-sub{font-size:1rem;color:var(--text-secondary);margin:-1.25rem 0 0;text-align:center}.champ-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;width:100%}.champ-mode-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2rem 1.5rem;background:var(--card-bg);border:2px solid var(--border);border-radius:16px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .2s;text-decoration:none;color:inherit}.champ-mode-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 8px 24px var(--shadow);transform:translateY(-2px)}.champ-mode-icon{font-size:2.25rem;line-height:1}.champ-mode-name{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.champ-mode-desc{font-size:.8125rem;color:var(--text-secondary);text-align:center}.champ-mode-tournament{cursor:default}.champ-mode-tournament:hover{transform:none}.champ-size-select{margin-top:.5rem;padding:.4rem .75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;cursor:pointer;width:100%}.champ-mode-start-btn{margin-top:.375rem;width:100%}.champ-summary{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:900px;width:100%}.champ-summary-title{font-size:2rem;font-weight:800;color:var(--text-primary);margin:0}.champ-summary-sub{font-size:1rem;color:var(--text-secondary);margin:-1rem 0 0}.champ-summary-note{color:var(--text-tertiary);font-style:italic}.champ-elim-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;width:100%}.champ-elim-item{display:flex;align-items:center;gap:.75rem;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:.75rem}.champ-elim-loser,.champ-elim-winner{display:flex;flex-direction:column;align-items:center;gap:.375rem;flex:1}.champ-elim-loser img,.champ-elim-winner img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;border:2px solid transparent}.champ-elim-loser img{filter:grayscale(70%) brightness(.7);border-color:#ef4444}.champ-elim-winner img{border-color:#22c55e}.champ-elim-arrow{font-size:1.25rem;color:var(--text-tertiary);flex-shrink:0}.champ-elim-lbl{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.champ-elim-lbl--out{color:#ef4444}.champ-elim-lbl--in{color:#22c55e}.champ-winner-page{background:radial-gradient(ellipse at 50% 30%,color-mix(in srgb,var(--accent) 12%,transparent) 0%,transparent 65%)}.champ-winner{display:flex;flex-direction:column;align-items:center;gap:1.5rem;text-align:center;max-width:480px;width:100%;animation:winnerReveal .6s cubic-bezier(.22,1,.36,1) both}@keyframes winnerReveal{0%{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:none}}.champ-winner-crown{font-size:3.5rem;line-height:1;animation:crownBounce .6s .2s cubic-bezier(.22,1,.36,1) both}@keyframes crownBounce{0%{transform:scale(0) rotate(-15deg)}to{transform:none}}.champ-winner-title{font-size:2.5rem;font-weight:900;color:var(--text-primary);margin:0;letter-spacing:-.02em}.champ-winner-img-wrap{position:relative;width:280px}.champ-winner-img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:16px;border:3px solid var(--accent);box-shadow:0 16px 48px var(--shadow);position:relative;z-index:1}.champ-winner-glow{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:22px;background:var(--accent);opacity:.25;filter:blur(20px);z-index:0;animation:winnerGlow 2s ease-in-out infinite alternate}@keyframes winnerGlow{0%{opacity:.15;transform:scale(.97)}to{opacity:.35;transform:scale(1.03)}}.champ-winner-name{font-size:.9375rem;color:var(--text-secondary);margin:-.75rem 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.champ-winner-stats{display:flex;align-items:center;gap:2rem;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;padding:1rem 2rem}.champ-winner-stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}.champ-winner-stat-val{font-size:1.75rem;font-weight:800;color:var(--accent);line-height:1}.champ-winner-stat-lbl{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em}.champ-winner-stat-divider{width:1px;height:36px;background:var(--border)}.champ-arena{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#07070d;display:flex;flex-direction:column;user-select:none;-webkit-user-select:none}.champ-hud{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 1.75rem;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.07);flex-shrink:0;transition:background .5s ease;gap:1rem}.champ-hud-left,.champ-hud-right{display:flex;align-items:center;gap:.625rem}.champ-hud-center{flex:1;display:flex;align-items:center;justify-content:center;gap:1rem}.champ-hud-vs{font-size:.75rem;font-weight:900;color:#ffffff8c;letter-spacing:.14em;padding:.25rem .75rem;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:99px}.champ-mode-badge{display:inline-flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:700;color:#ffffff8c;background:#ffffff14;border-radius:99px;padding:.3rem .875rem;letter-spacing:.04em}.champ-round-badge{font-size:.8125rem;font-weight:600;color:#fff6}.champ-vote-count{display:flex;align-items:center;gap:6px;font-size:.9375rem;font-weight:700;color:#ffffff80}.champ-vote-count svg{color:#ffffff59}.champ-quit-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffff80;cursor:pointer;transition:background .15s,color .15s}.champ-quit-btn:hover{background:#ef444440;color:#fca5a5;border-color:#ef444459}.champ-battle{flex:1;display:flex;min-height:0;overflow:hidden}.champ-vs-col{width:64px;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;z-index:20}.champ-vs-badge{font-size:.875rem;font-weight:900;color:#ffffffe6;letter-spacing:.12em;padding:10px 8px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:10px;box-shadow:0 0 24px #6366f140;animation:vsPulse 2.8s ease-in-out infinite}@keyframes vsPulse{0%,to{box-shadow:0 0 16px #6366f133}50%{box-shadow:0 0 32px #6366f18c,0 0 60px #6366f126}}.champ-card{flex:1;position:relative;overflow:hidden;cursor:pointer;touch-action:none;transition:transform .38s cubic-bezier(.22,1,.36,1),filter .38s ease,opacity .28s ease,box-shadow .38s ease;will-change:transform,opacity}.champ-swipe-hint{display:none}.champ-card-left{transform-origin:right center}.champ-card-right{transform-origin:left center}.champ-card:hover{transform:scale(1.012);z-index:2}.champ-bg-blur{position:absolute;top:-24px;right:-24px;bottom:-24px;left:-24px;background-size:cover;background-position:center;filter:blur(64px) saturate(1.4);opacity:.45;transform:scale(1.12);will-change:filter}.champ-img-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.champ-thumb,.champ-full{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 10px 36px rgba(0,0,0,.65))}.champ-thumb{z-index:1}.champ-full{z-index:2;opacity:0;transition:opacity .45s ease}.champ-full.loaded{opacity:1}.champ-wins-badge{position:absolute;top:14px;right:14px;display:flex;align-items:center;gap:4px;padding:4px 10px;background:#0000008c;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:99px;color:#fbbf24;font-size:.75rem;font-weight:700;z-index:10;border:1px solid rgba(251,191,36,.25)}.champ-card-footer{position:absolute;bottom:0;left:0;right:0;padding:40px 18px 18px;background:linear-gradient(to top,rgba(0,0,0,.82) 0%,transparent 100%);display:flex;align-items:flex-end;justify-content:space-between;z-index:10}.champ-fname{font-size:.8125rem;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:68%}.champ-fstats{display:flex;align-items:center;gap:4px;font-size:.75rem;color:#ffffff8c;flex-shrink:0}.champ-choose-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.25rem;font-weight:800;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.9);letter-spacing:.14em;text-transform:uppercase;opacity:0;pointer-events:none;transition:opacity .18s ease;z-index:20}.champ-hover-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,rgba(99,102,241,.08) 0%,transparent 70%);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:5}.champ-vote-up,.champ-vote-down{position:absolute;top:50%;left:50%;font-size:7rem;opacity:0;pointer-events:none;z-index:30;display:flex;align-items:center;justify-content:center;color:#fff;filter:drop-shadow(0 4px 20px rgba(0,0,0,.5))}.champ-vote-up2{position:absolute;top:44%;left:57%;font-size:5.5rem;opacity:0;pointer-events:none;z-index:30;display:flex;align-items:center;justify-content:center;color:#fff;filter:drop-shadow(0 4px 20px rgba(0,0,0,.5))}.champ-arena.pick-left .champ-card-left .champ-vote-up,.champ-arena.pick-right .champ-card-right .champ-vote-up{animation:champVoteUp .7s ease-out both}.champ-arena.pick-left .champ-card-right .champ-vote-down,.champ-arena.pick-right .champ-card-left .champ-vote-down{animation:champVoteDown .7s ease-out both}@keyframes champVoteUp{0%{opacity:0;transform:translate(-50%,-40%) scale(.5) rotate(-8deg)}25%{opacity:1;transform:translate(-50%,-52%) scale(1.15) rotate(6deg)}60%{opacity:1;transform:translate(-50%,-58%) scale(1.05) rotate(4deg)}to{opacity:0;transform:translate(-50%,-70%) scale(.95) rotate(5deg)}}@keyframes champVoteDown{0%{opacity:0;transform:translate(-50%,-60%) scale(.5) rotate(8deg)}25%{opacity:1;transform:translate(-50%,-50%) scale(1.1) rotate(-6deg)}60%{opacity:.9;transform:translate(-50%,-45%) scale(1) rotate(-4deg)}to{opacity:0;transform:translate(-50%,-34%) scale(.9) rotate(-5deg)}}.champ-arena.pick-left.boosted .champ-card-left .champ-vote-up,.champ-arena.pick-right.boosted .champ-card-right .champ-vote-up{animation:champVoteUpBoosted .85s ease-out both;color:#facc15;filter:drop-shadow(0 0 18px rgba(250,204,21,.85)) drop-shadow(0 4px 8px rgba(0,0,0,.5))}.champ-arena.pick-left.boosted .champ-card-left .champ-vote-up2,.champ-arena.pick-right.boosted .champ-card-right .champ-vote-up2{animation:champVoteUpBoosted2 .85s .08s ease-out both;color:#facc15;filter:drop-shadow(0 0 14px rgba(250,204,21,.75)) drop-shadow(0 4px 8px rgba(0,0,0,.5))}@keyframes champVoteUpBoosted{0%{opacity:0;transform:translate(-50%,-35%) scale(.3) rotate(-15deg)}20%{opacity:1;transform:translate(-50%,-58%) scale(1.55) rotate(10deg)}55%{opacity:1;transform:translate(-50%,-68%) scale(1.35) rotate(5deg)}to{opacity:0;transform:translate(-50%,-85%) scale(1.05) rotate(6deg)}}@keyframes champVoteUpBoosted2{0%{opacity:0;transform:translate(-50%,-30%) scale(.2) rotate(12deg)}20%{opacity:1;transform:translate(-50%,-52%) scale(1.3) rotate(-8deg)}55%{opacity:.9;transform:translate(-50%,-62%) scale(1.15) rotate(-3deg)}to{opacity:0;transform:translate(-50%,-78%) scale(.9) rotate(-5deg)}}.champ-arena.pick-left.boosted .champ-card-right .champ-vote-up,.champ-arena.pick-right.boosted .champ-card-left .champ-vote-up{animation:champVoteUp .7s ease-out both}.champ-arena.pick-left.boosted .champ-card-right .champ-vote-down,.champ-arena.pick-right.boosted .champ-card-left .champ-vote-down{animation:none}.champ-key-hint{display:flex;align-items:center;justify-content:space-between;padding:7px 28px;font-size:.6875rem;color:#fff3;letter-spacing:.04em;flex-shrink:0}.champ-arena.pick-left .champ-card-left{transform:scale(1.025);box-shadow:inset 0 0 0 3px #fbbf24b3,0 0 56px 8px #fbbf2440}.champ-arena.pick-left .champ-card-right{transform:scale(.975);filter:grayscale(1) brightness(.38);opacity:.45}.champ-arena.pick-right .champ-card-right{transform:scale(1.025);box-shadow:inset 0 0 0 3px #fbbf24b3,0 0 56px 8px #fbbf2440}.champ-arena.pick-right .champ-card-left{transform:scale(.975);filter:grayscale(1) brightness(.38);opacity:.45}.champ-arena.exiting .champ-card-left,.champ-arena.exiting .champ-card-right{opacity:0;transform:scale(.97);transition:opacity .22s ease,transform .22s ease}.champ-arena.entering .champ-card-left{animation:enterLeft .38s cubic-bezier(.22,1,.36,1) both}.champ-arena.entering .champ-card-right{animation:enterRight .38s cubic-bezier(.22,1,.36,1) both}@keyframes enterLeft{0%{opacity:0;transform:scale(.97) translate(-18px)}to{opacity:1;transform:none}}@keyframes enterRight{0%{opacity:0;transform:scale(.97) translate(18px)}to{opacity:1;transform:none}}.champ-arena.pick-left .champ-vs-badge,.champ-arena.pick-right .champ-vs-badge{animation:vsPop .22s cubic-bezier(.22,1,.36,1) both}@keyframes vsPop{0%{transform:scale(1.25)}to{transform:none}}.champ-magnifier{position:fixed;width:600px;height:600px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 8px 56px #000c,0 0 0 1px #ffffff0f inset;pointer-events:none;z-index:9999;background-repeat:no-repeat;overflow:hidden}.champ-hud-boost-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:20px;border:1.5px solid rgba(250,204,21,.35);background:#facc1512;color:#facc15bf;font-size:.8125rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:background .2s,border-color .2s,color .2s,box-shadow .2s}.champ-hud-boost-btn:hover{background:#facc1524;border-color:#facc15a6;color:#facc15}.champ-hud-boost-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#facc152e;font-size:.6875rem;font-weight:700}.champ-hud-boost-btn.armed{background:#facc152e;border-color:#facc15;color:#facc15;animation:boostArmedBtn 1.1s ease-in-out infinite}@keyframes boostArmedBtn{0%,to{box-shadow:0 0 8px #facc154d}50%{box-shadow:0 0 20px #facc15a6,0 0 40px #facc1533}}.champ-arena.boost-armed .champ-hud{border-bottom-color:#facc1533;box-shadow:0 2px 32px #facc1514}.champ-arena.boost-armed{animation:boostWindowGlow 1.1s ease-in-out infinite}@keyframes boostWindowGlow{0%,to{box-shadow:inset 0 0 40px 4px #facc151f}50%{box-shadow:inset 0 0 80px 12px #facc1559}}.champ-arena.boost-armed .champ-card:hover{box-shadow:inset 0 0 0 2px #facc158c,0 0 60px 12px #facc152e}.champ-arena.boost-armed .champ-card:hover .champ-hover-glow{opacity:1;background:radial-gradient(ellipse at center,rgba(250,204,21,.13) 0%,transparent 65%)}.champ-bookmark-btn{position:absolute;top:10px;left:10px;width:32px;height:32px;border-radius:50%;border:none;background:#0006;color:#ffffff80;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20;opacity:0;transition:opacity .2s ease,color .15s ease,background .15s ease,transform .15s ease;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.champ-card:hover .champ-bookmark-btn{opacity:1;pointer-events:auto}.champ-bookmark-btn:hover{background:#000000a6;color:#ffffffe6;transform:scale(1.1)}.champ-bookmark-btn.active{opacity:1;color:#f59e0b;pointer-events:auto}.champ-bookmark-btn.active:hover{color:#fbbf24}.champ-bookmarks-section{width:100%;max-width:680px;margin-top:2.5rem}.champ-bookmarks-title{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin:0 0 1rem}.champ-bookmarks-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent-transparent);color:var(--accent);font-size:.7rem;font-weight:700}.champ-bookmarks-grid{display:flex;flex-direction:column;gap:6px}.champ-bookmark-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border);transition:background .15s ease}.champ-bookmark-link{display:flex;align-items:center;gap:12px;flex:1;min-width:0;text-decoration:none}.champ-bookmark-link:hover .champ-bookmark-name{color:var(--accent)}.champ-bookmark-item:hover{background:var(--bg-tertiary)}.champ-bookmark-item img{width:48px;height:48px;object-fit:cover;border-radius:6px;flex-shrink:0}.champ-bookmark-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.champ-bookmark-name{font-size:.8125rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.champ-bookmark-date{font-size:.6875rem;color:var(--text-tertiary)}.champ-bookmark-remove{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:none;background:transparent;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,color .15s ease}.champ-bookmark-remove:hover{background:#ef44441f;color:#ef4444}.champ-elim-img-wrap{position:relative;display:inline-block}.champ-elim-img-wrap img{display:block}.champ-elim-bookmark{position:absolute;top:4px;right:4px;width:26px;height:26px;border-radius:50%;border:none;background:#00000080;color:#fff9;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,color .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.champ-elim-bookmark:hover{background:#000000bf;color:#fff}.champ-elim-bookmark.active{color:#f59e0b}@media (max-width: 768px){.champ-mode-grid{grid-template-columns:1fr}.champ-setup-title{font-size:2rem}.champ-vs-col{width:40px}.champ-vs-badge{font-size:.7rem;padding:7px 5px}.champ-key-hint{display:none}.champ-choose-hint{font-size:1rem}.champ-magnifier{width:260px;height:260px}.champ-elim-grid{grid-template-columns:1fr}.champ-winner-img-wrap{width:220px}.champ-winner-title{font-size:2rem}.champ-bookmark-btn{opacity:.7;pointer-events:auto}.champ-bookmark-btn.active{opacity:1}.champ-battle{flex-direction:column}.champ-card-left{transform-origin:bottom center}.champ-card-right{transform-origin:top center}.champ-swipe-hint{display:flex;align-items:center;justify-content:center;position:absolute;left:50%;transform:translate(-50%);color:#ffffff80;pointer-events:none;z-index:10}.champ-card-left .champ-swipe-hint{bottom:10px;animation:swipeHintDown 2s ease-in-out infinite}.champ-card-right .champ-swipe-hint{top:10px;animation:swipeHintUp 2s ease-in-out infinite}}@keyframes swipeHintDown{0%,to{opacity:.35;transform:translate(-50%) translateY(0)}50%{opacity:.7;transform:translate(-50%) translateY(5px)}}@keyframes swipeHintUp{0%,to{opacity:.35;transform:translate(-50%) translateY(0)}50%{opacity:.7;transform:translate(-50%) translateY(-5px)}}@media (max-width: 480px){.champ-hud{padding:0 .75rem}.champ-wins-badge{top:10px;right:10px}}.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}.variant-images-container{background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);padding:12px;margin-top:10px}.variant-images-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:10px}.variant-images-header svg{color:var(--accent)}.variant-images-grid{display:flex;gap:8px;flex-wrap:wrap}.variant-thumbnail{width:80px;height:80px;border-radius:6px;overflow:hidden;border:2px solid var(--border-color);cursor:pointer;transition:all .2s ease;position:relative;background:#000}.variant-thumbnail:hover{border-color:var(--accent);transform:scale(1.05);box-shadow:0 4px 12px #0003}.variant-thumbnail .variant-img{width:100%;height:100%;object-fit:cover;display:block}.variant-thumbnail:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;transition:background .2s ease}.variant-thumbnail:hover:after{background:#ffffff1a}.copy-tags-modal{max-width:700px;max-height:85vh;overflow-y:auto}.copy-tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;padding:20px}.copy-tags-option{background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s ease}.copy-tags-option:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 6px 16px #00000026}.copy-tags-preview{width:100%;height:150px;background:#000;display:flex;align-items:center;justify-content:center;overflow:hidden}.copy-tags-img{width:100%;height:100%;object-fit:contain}.copy-tags-info{padding:12px;background:var(--bg-secondary)}.copy-tags-filename{font-size:13px;font-weight:500;color:var(--text-primary);margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.copy-tags-count{font-size:12px;color:var(--accent);font-weight:600;display:flex;align-items:center;gap:4px}.copy-tags-count svg{width:14px;height:14px;flex-shrink:0}.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:8px}.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 .btn-sm{padding:4px 8px;font-size:11px;align-self:flex-start}.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;padding-left:8px;position:relative}.tree-children:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:repeating-linear-gradient(to bottom,var(--border-color) 0,var(--border-color) 4px,transparent 4px,transparent 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}.nav-options-modal{width:100%;max-width:8050px;max-height:90vh;overflow-y:auto}.nav-options-body{padding:24px}.nav-section{margin-bottom:24px}.nav-section-divider{display:flex;align-items:center;margin:24px 0 16px;border-top:1px solid var(--border-color);padding-top:24px}.divider-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.nav-options-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}.nav-filter-toggle{display:flex;background:var(--bg-tertiary);border-radius:10px;padding:4px;gap:4px}.nav-filter-btn{flex:1;padding:8px 12px;border-radius:7px;border:none;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.nav-filter-btn.active{background:var(--card-bg);color:var(--accent);font-weight:600;box-shadow:0 1px 4px #0000001f}.nav-filter-btn:not(.active):hover{background:var(--bg-primary);color:var(--text-primary)}.nav-option-checkbox-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.nav-option-checkbox-card:hover{border-color:var(--text-secondary);background:var(--card-bg)}.nav-option-checkbox-card input{display:none}.checkbox-indicator{width:24px;height:24px;border-radius:6px;border:2px solid var(--text-placeholder);background:var(--bg-primary);position:relative;transition:all .2s ease;flex-shrink:0}.nav-option-checkbox-card input:checked~.checkbox-indicator{background:var(--accent);border-color:var(--accent)}.nav-option-checkbox-card input:checked~.checkbox-indicator:after{content:"?";position:absolute;color:#fff;font-size:16px;font-weight:700;left:50%;top:50%;transform:translate(-50%,-50%)}.nav-option-radio-card{display:flex;align-items:flex-start;gap:12px;padding:16px;background:transparent;border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);-webkit-user-select:none;user-select:none;position:relative}.nav-option-radio-card:hover{border-color:var(--text-secondary);transform:translateY(-2px);background:var(--bg-secondary)}.nav-option-radio-card.selected{border-color:var(--accent);background:rgba(var(--accent-rgb),.05);background:var(--bg-secondary);box-shadow:0 4px 12px #0000001a}.nav-option-radio-card.selected{border-color:var(--accent)}.nav-option-radio-card input{display:none}.radio-indicator{width:20px;height:20px;border-radius:50%;border:2px solid var(--text-placeholder);background:var(--bg-primary);margin-top:2px;flex-shrink:0;position:relative;transition:all .2s ease}.nav-option-radio-card.selected .radio-indicator{border-color:var(--accent)}.nav-option-radio-card.selected .radio-indicator:after{content:"";position:absolute;width:10px;height:10px;background:var(--accent);border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%)}.nav-option-content{flex:1}.nav-option-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:4px}.nav-option-radio-card.selected .nav-option-title{color:var(--accent)}.nav-option-desc{font-size:12px;color:var(--text-secondary);line-height:1.4}.context-menu{position:fixed;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #0000004d;padding:4px 0;z-index:1000;min-width:160px}.context-menu-item{padding:8px 12px;display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-primary);cursor:pointer;transition:background .2s}.context-menu-item:hover{background:var(--hover-bg)}.context-menu-item svg{color:var(--text-secondary)}.context-menu-item.danger{color:var(--error)}.context-menu-item.danger svg{color:var(--error)}.context-menu-separator{height:1px;background:var(--border-color);margin:4px 0}.canvas-wrapper.redraw-mode{border:4px solid var(--accent);position:relative}.redraw-overlay{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:50;pointer-events:none}.redraw-message{background:var(--bg-secondary);border:1px solid var(--accent);padding:8px 16px;border-radius:20px;color:var(--text-primary);display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0006;pointer-events:auto}.redraw-message strong{color:var(--accent);margin-left:4px}.redraw-cancel-btn{background:none;border:none;color:var(--text-secondary);font-size:20px;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;transition:all .2s}.redraw-cancel-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.mobile-editor{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;overflow:hidden;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.transform-wrapper{width:100%;height:100vh;position:relative}.canvas-container{position:relative;display:inline-block;touch-action:none}.overlay-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.overlay-svg rect,.overlay-svg text{pointer-events:auto}.selected-tag-panel{position:fixed;bottom:16px;left:16px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);padding:0 16px;border-radius:28px;font-size:13px;z-index:1000;display:flex;align-items:center;gap:12px;box-shadow:0 4px 12px #0000004d;border:2px solid var(--border, #444);max-width:calc(100% - 250px);height:56px}.selected-tag-content{display:flex;flex-direction:row;align-items:center;gap:8px;flex:1;min-width:0}.selected-tag-panel .tag-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-tag-panel .tag-properties{font-size:11px;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-tag-actions{display:flex;align-items:center;gap:8px}.selected-tag-panel .btn-icon{background:none;border:none;color:var(--text-primary, white);font-size:18px;cursor:pointer;padding:4px 8px;opacity:.7;display:flex;align-items:center;justify-content:center;min-width:32px;height:32px}.selected-tag-panel .btn-icon:hover{opacity:1}.fab-container{position:fixed;right:16px;bottom:16px;display:flex;gap:12px;z-index:1000}.drawing-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999;touch-action:none;cursor:crosshair;pointer-events:auto}.fab{width:56px;height:56px;border-radius:50%;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);border:2px solid var(--border, #444);box-shadow:0 4px 12px #0000004d;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.fab:active{transform:scale(.95)}.bottom-sheet{position:fixed;left:0;right:0;bottom:0;background:var(--bg-primary, #1e1e1e);border-top-left-radius:20px;border-top-right-radius:20px;box-shadow:0 -4px 20px #0000004d;z-index:1001;max-height:70vh;overflow:hidden;display:flex;flex-direction:column}.sheet-header{padding:12px 20px;border-bottom:1px solid var(--border, #333);display:flex;align-items:center;justify-content:space-between;position:relative}.sheet-handle{position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:var(--text-tertiary, #666);border-radius:2px}.sheet-header h3{margin:0;font-size:18px;font-weight:600}.sheet-header button{background:none;border:none;color:var(--text-primary, #fff);font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.sheet-content{flex:1;overflow-y:auto;padding:16px}.tag-list-mobile{display:flex;flex-direction:column;gap:8px}.tag-item-mobile{background:var(--bg-secondary, #2a2a2a);border-radius:12px;padding:12px;display:flex;align-items:center;justify-content:space-between;min-height:56px;border:2px solid transparent;transition:all .2s}.tag-item-mobile.active{border-color:var(--primary, #007bff);background:#007bff1a}.tag-item-main{display:flex;align-items:center;gap:12px;flex:1;font-size:16px}.tag-item-main span:first-child{font-size:20px}.tag-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;font-size:20px;cursor:pointer;padding:8px;min-width:40px;min-height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .2s}.btn-icon:active{background:#ffffff1a}.modal-overlay-mobile{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.modal-content-mobile{background:var(--bg-primary, #1e1e1e);border-radius:16px;padding:24px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.modal-content-mobile h2{margin:0 0 8px;font-size:24px;font-weight:600}.subtitle-mobile{color:var(--text-secondary, #999);margin:0 0 20px;font-size:14px}.search-input-mobile{width:100%;padding:12px 16px;font-size:16px;border:2px solid var(--border, #333);border-radius:12px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);margin-bottom:16px}.tag-grid-mobile{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;margin-bottom:20px;max-height:50vh;overflow-y:auto}.tag-btn-mobile{padding:16px 12px;background:var(--bg-secondary, #2a2a2a);border:2px solid var(--border, #333);border-radius:12px;color:var(--text-primary, #fff);font-size:14px;cursor:pointer;transition:all .2s;min-height:56px;display:flex;align-items:center;justify-content:center;text-align:center}.tag-btn-mobile:active{transform:scale(.95);background:var(--primary, #007bff)}.btn-cancel-mobile,.btn-done-mobile{width:100%;padding:14px;font-size:16px;font-weight:600;border-radius:12px;border:none;cursor:pointer;transition:all .2s;min-height:48px}.btn-cancel-mobile{background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff)}.btn-done-mobile{background:var(--accent);color:var(--text-primary)}.btn-cancel-mobile:active,.btn-done-mobile:active{transform:scale(.98);opacity:.8}.metadata-section{margin:16px 0;padding:12px;background:var(--bg-secondary, #2a2a2a);border-radius:8px}.metadata-section h3{margin:0 0 12px;font-size:14px;color:var(--text-secondary, #999);text-transform:uppercase}.metadata-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border, #444)}.metadata-item:last-child{border-bottom:none}.metadata-label{font-weight:500;color:var(--text-secondary, #999)}.metadata-value{color:var(--text-primary, #fff)}.actions-section{display:flex;flex-direction:column;gap:12px;margin:16px 0}.btn-action-mobile{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff);border:1px solid var(--border, #444);border-radius:8px;font-size:16px;cursor:pointer;transition:all .2s}.btn-action-mobile:active{transform:scale(.98);background:var(--bg-tertiary, #3a3a3a)}.btn-action-mobile.btn-next{background:var(--bg-secondary, #2a2a2a)}.btn-action-mobile.btn-confirm{background:#d9534f;border-color:#d43f3a;color:#fff;font-weight:600}.btn-action-mobile.btn-confirm:active{background:#c9302c}.options-section{margin:20px 0;padding:12px;background:var(--bg-secondary, #2a2a2a);border-radius:8px}.options-section h3{margin:0 0 12px;font-size:14px;color:var(--text-secondary, #999);text-transform:uppercase}.metadata-field-mobile{margin-bottom:16px}.metadata-field-mobile label{display:block;font-size:14px;color:var(--text-secondary, #999);margin-bottom:6px;font-weight:500}.metadata-field-mobile select{width:100%;padding:10px;background:var(--bg-primary, #1e1e1e);color:var(--text-primary, #fff);border:1px solid var(--border, #444);border-radius:6px;font-size:16px;cursor:pointer}.metadata-field-mobile select:focus{outline:none;border-color:var(--primary, #007bff)}.color-picker-row{display:flex;align-items:center;gap:12px}.color-picker{width:60px;height:40px;border:2px solid var(--border, #444);border-radius:6px;cursor:pointer;background:transparent}.eyedropper-btn-mobile{width:40px;height:40px;border-radius:6px;background:var(--bg-tertiary, #3a3a3a);color:var(--text-primary, #fff);border:1px solid var(--border, #444);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.eyedropper-btn-mobile:active{transform:scale(.95);background:var(--bg-secondary, #2a2a2a)}.color-value{font-family:monospace;font-size:14px;color:var(--text-secondary, #999)}.color-picking-panel{position:fixed;top:70px;left:50%;transform:translate(-50%);background:var(--accent, #00b4d8);color:var(--text-primary, white);padding:12px 16px;border-radius:28px;font-size:14px;z-index:10000;display:flex;align-items:center;gap:12px;max-width:80%;box-shadow:0 4px 16px #0006;border:2px solid var(--border, #444);animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.picking-content{display:flex;align-items:center;font-weight:500}.toggle-option{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-primary, #1e1e1e);border-radius:6px;cursor:pointer;transition:background .2s}.toggle-option:active{background:var(--bg-tertiary, #3a3a3a)}.toggle-option input[type=checkbox]{width:24px;height:24px;cursor:pointer}.toggle-option span{font-size:16px;color:var(--text-primary, #fff)}.tree-node-item-mobile{position:relative;display:flex;align-items:center;gap:8px;padding:8px 12px 8px calc(12px + var(--level, 0) * 24px);min-height:44px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.tree-node-item-mobile:hover{background:#ffffff0d}.tree-node-item-mobile.active{background:#007bff26}.tree-node-item-mobile.dragging{opacity:.5}.tree-node-item-mobile.drag-over-inside{background:#007bff33;border:2px dashed var(--primary, #007bff)}.expand-btn-mobile{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary, #999);cursor:pointer;padding:0;font-size:12px;flex-shrink:0}.expand-spacer-mobile{width:20px;flex-shrink:0}.visibility-btn-mobile{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary, #999);cursor:pointer;padding:0;flex-shrink:0}.visibility-btn-mobile.hidden{color:var(--text-tertiary, #666);opacity:.5}.visibility-spacer-mobile{width:24px;flex-shrink:0}.node-icon-mobile{font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.node-label-mobile{flex:1;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bbox-indicator-mobile,.global-indicator-mobile{width:14px;height:14px;flex-shrink:0;opacity:.6}.active-indicator-mobile{color:var(--accent, #00b4d8);flex-shrink:0}.node-actions-mobile{display:flex;gap:4px;flex-shrink:0}.btn-icon-mobile{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary, #999);cursor:pointer;padding:0;border-radius:4px;font-size:16px}.btn-icon-mobile:active{background:#ffffff1a}.tree-children-mobile:before{content:"";position:absolute;left:calc(20px + var(--level, 0) * 24px);top:0;bottom:0;width:2px;background:repeating-linear-gradient(to bottom,var(--text-tertiary, #888) 0,var(--text-tertiary, #888) 4px,transparent 4px,transparent 8px)}.tree-root-node-mobile{position:relative}.drop-indicator-mobile{position:absolute;left:0;right:0;height:2px;background:var(--primary, #007bff);z-index:10}.properties-form-mobile,.property-field-mobile{margin-bottom:20px}.property-field-mobile label{display:block;margin-bottom:8px;font-weight:500;font-size:14px;color:var(--text-primary)}.property-field-mobile .required{color:var(--danger, #dc3545);margin-left:4px}.property-field-mobile input,.property-field-mobile select{width:100%;padding:12px 16px;font-size:16px;border:2px solid var(--border, #333);border-radius:12px;background:var(--bg-secondary, #2a2a2a);color:var(--text-primary, #fff)}.property-field-mobile input:focus,.property-field-mobile select:focus{outline:none;border-color:var(--accent)}.property-field-mobile input:disabled,.property-field-mobile select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-tertiary)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary, #999)}.empty-state p{margin:8px 0}.empty-state .hint{font-size:14px;color:var(--text-tertiary, #666)}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-primary, #fff);font-size:18px}.redraw-banner{position:fixed;top:12px;left:50%;transform:translate(-50%);background:var(--accent, #0078d4);color:#fff;padding:8px 16px;border-radius:20px;display:flex;align-items:center;gap:12px;font-size:14px;z-index:200;box-shadow:0 4px 12px #0000004d}.redraw-banner button{background:#ffffff40;border:none;color:#fff;padding:4px 10px;border-radius:12px;font-size:13px;cursor:pointer}.btn-icon-sheet{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--border, #444);border-radius:4px;color:var(--text-secondary, #999);cursor:pointer;padding:0;flex-shrink:0;transition:background .15s,color .15s}.btn-icon-sheet:active{background:#ffffff1a;color:var(--text-primary, #fff)}.nav-mode-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}.nav-mode-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:1px solid var(--border, #444);background:var(--bg-primary, #1a1a1a);color:var(--text-primary, #fff);font-size:14px;cursor:pointer;transition:background .15s,border-color .15s}.nav-mode-option.selected{border-color:var(--accent, #0078d4);background:#0078d426}.nav-mode-option input[type=radio]{accent-color:var(--accent, #0078d4);width:16px;height:16px;flex-shrink:0}@media (prefers-color-scheme: light){.mobile-editor{background:#f5f5f5}.mode-indicator{background:#fffffff2;color:#000}.bottom-sheet,.modal-content-mobile{background:#fff}.tag-item-mobile,.tag-btn-mobile,.search-input-mobile,.property-field-mobile input,.property-field-mobile select{background:#f5f5f5;color:#000}.btn-cancel-mobile{background:#e0e0e0;color:#000}}.characters-page{padding:2rem;max-width:1400px;margin:0 auto}.characters-page .page-header{margin-bottom:1rem}.characters-page .header-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:0}.characters-page .breadcrumb-link{color:var(--text-primary);text-decoration:none;transition:color .2s}.characters-page .breadcrumb-link:hover{color:var(--accent)}.characters-page .breadcrumb-separator{margin:0 .5rem;color:var(--text-tertiary)}.chars-toolbar{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.chars-toolbar label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.chars-toolbar select{padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .2s ease}.chars-toolbar select:hover{border-color:var(--accent)}.chars-toolbar select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha)}.chars-toolbar .toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500;color:var(--text-primary);position:relative}.chars-toolbar .toggle-checkbox{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.chars-toolbar .toggle-switch{position:relative;display:inline-block;width:44px;height:24px;background:var(--border);border-radius:12px;transition:background .3s;flex-shrink:0}.chars-toolbar .toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.chars-toolbar .toggle-checkbox:checked+.toggle-switch{background:var(--accent)}.chars-toolbar .toggle-checkbox:checked+.toggle-switch:after{transform:translate(20px)}.chars-toolbar .toggle-label:hover .toggle-switch{opacity:.8}.chars-toolbar .toggle-text{font-weight:500;color:var(--text-primary)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:2rem;padding:1rem 0}.character-tile{display:flex;flex-direction:column;align-items:center;text-decoration:none;transition:transform .2s}.character-tile:hover{transform:translateY(-4px)}.character-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;background:var(--bg-secondary);border:3px solid var(--border);transition:border-color .2s;display:flex;align-items:center;justify-content:center;margin-bottom:.75rem}.character-tile:hover .character-avatar{border-color:var(--accent)}.character-avatar img{width:100%;height:100%;object-fit:cover}.character-placeholder{width:60%;height:60%;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center}.character-placeholder svg{width:100%;height:100%}.character-name{font-weight:600;color:var(--text-primary);text-align:center;margin-bottom:.25rem;font-size:.95rem}.character-count{font-size:.85rem;color:var(--text-tertiary);text-align:center}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.characters-page{padding:1rem}.characters-page .header-top{flex-direction:column;gap:1rem}.chars-toolbar{gap:1rem;padding:.75rem}.chars-toolbar label{flex-direction:column;align-items:flex-start;gap:.35rem}.chars-toolbar select{width:100%}.characters-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1.5rem}.character-avatar{width:90px;height:90px}.character-name{font-size:.85rem}.character-count{font-size:.75rem}}.tags-page{padding:2rem;max-width:1400px;margin:0 auto}.tags-controls{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.tags-controls label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.tags-controls select,.tags-controls .sort-input{padding:.5rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:border-color .2s ease}.tags-controls .sort-input{min-width:200px}.tags-controls select:hover,.tags-controls .sort-input:hover{border-color:var(--accent)}.tags-controls select:focus,.tags-controls .sort-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-alpha)}.tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.tag-card{padding:1.25rem;cursor:pointer;transition:all .2s;border-left:4px solid transparent}.tag-card:hover{transform:translateY(-2px);box-shadow:0 8px 16px #00000026}.tag-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.tag-name{font-size:1.125rem;font-weight:600;color:var(--text);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tag-usage-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:24px;padding:0 .5rem;background:var(--accent);color:#fff;border-radius:12px;font-size:.8125rem;font-weight:600;flex-shrink:0}.tag-type-label{display:inline-block;padding:.25rem .625rem;background:var(--background);color:var(--text-secondary);border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.tag-description{font-size:.875rem;color:var(--text-secondary);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.empty-state svg{opacity:.3}.empty-state h3{font-size:1.25rem;color:var(--text);margin:0 0 .5rem}.empty-state p{font-size:.9375rem;margin:0}@media (max-width: 768px){.tags-page{padding:1rem}.tags-controls{gap:1rem;padding:.75rem}.tags-controls label{flex-direction:column;align-items:flex-start;gap:.35rem;width:100%}.tags-controls select,.tags-controls .sort-input{width:100%}.tags-controls .sort-input{min-width:unset}.tags-grid{grid-template-columns:1fr;gap:1rem}.tag-card{padding:1rem}.tag-name{font-size:1rem}}.statistics-page{padding:2rem;max-width:1400px;margin:0 auto}.page-subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{display:flex;align-items:flex-start;gap:1.125rem;padding:1.375rem 1.5rem}.stat-icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:12px;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);flex-shrink:0}.stat-icon svg{width:26px;height:26px;color:#fff}.stat-icon--images{background:linear-gradient(135deg,#6366f1,#4f46e5)}.stat-icon--tags{background:linear-gradient(135deg,#22c55e,#16a34a)}.stat-icon--views{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon--votes{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-content{flex:1;min-width:0}.stat-value{font-size:1.875rem;font-weight:700;color:var(--text-primary);line-height:1.1;margin-bottom:.2rem}.stat-label{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.stat-sub{font-size:.8125rem;color:var(--text-tertiary)}.stat-progress-wrap{display:flex;align-items:center;gap:.625rem;margin-top:.375rem}.stat-progress{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.stat-progress-bar{height:100%;background:var(--accent);border-radius:3px;transition:width .6s ease}.stat-votes-row{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;flex-wrap:wrap;margin-top:.375rem}.vote-up{color:#22c55e;font-weight:600}.vote-down{color:#ef4444;font-weight:600}.vote-sep,.vote-pct{color:var(--text-tertiary)}.stats-2col{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.stats-section{padding:1.5rem}.stats-section--full{margin-bottom:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin:0 0 .375rem}.section-title svg{color:var(--accent);flex-shrink:0}.section-desc{font-size:.8125rem;color:var(--text-secondary);margin:0 0 1.125rem}.hbar-list{display:flex;flex-direction:column;gap:.375rem}.hbar-link{display:block;text-decoration:none;color:inherit;border-radius:8px;transition:background .15s}a.hbar-link:hover{background:var(--bg-tertiary)}.hbar-row{display:grid;grid-template-columns:28px 1fr 1fr 56px;align-items:center;gap:.625rem;padding:.5rem .625rem}.hbar-rank{font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-align:center}.hbar-label{display:flex;align-items:center;gap:.375rem;min-width:0}.hbar-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;border:1.5px solid var(--bg-primary);box-shadow:0 0 0 1px #0000001a}.hbar-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hbar-sub{font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.hbar-track{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.hbar-fill{height:100%;border-radius:4px;transition:width .5s ease}.hbar-value{font-size:.8125rem;font-weight:700;text-align:right;white-space:nowrap}.vbar-chart{display:flex;align-items:flex-end;gap:4px;height:160px;padding-top:1.5rem}.vbar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative;min-width:0}.vbar-count{font-size:.625rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center;height:14px;line-height:14px;flex-shrink:0}.vbar-bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%;padding:0 1px}.vbar-bar{width:100%;background:var(--accent);border-radius:3px 3px 0 0;transition:height .5s ease;opacity:.85}.vbar-bar:hover{opacity:1}.vbar-label{font-size:.625rem;color:var(--text-tertiary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;height:16px;line-height:16px;flex-shrink:0}.score-chart{display:flex;align-items:flex-end;gap:4px;height:160px;padding-top:1.5rem}.score-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;min-width:0}.score-count{font-size:.625rem;color:var(--text-tertiary);white-space:nowrap;height:14px;line-height:14px;text-align:center;flex-shrink:0}.score-bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%;padding:0 1px}.score-bar{width:100%;border-radius:3px 3px 0 0;transition:height .5s ease}.score-label{font-size:.5625rem;color:var(--text-tertiary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;height:16px;line-height:16px;flex-shrink:0}.color-dist-list{display:flex;flex-direction:column;gap:.625rem}.color-dist-row{display:grid;grid-template-columns:20px 72px 1fr 48px;align-items:center;gap:.625rem}.color-dist-swatch{width:16px;height:16px;border-radius:4px;flex-shrink:0;box-shadow:0 0 0 1px #00000026}.color-dist-name{font-size:.875rem;color:var(--text-primary);font-weight:500;text-transform:capitalize}.color-dist-track{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.color-dist-bar{height:100%;border-radius:4px;transition:width .5s ease;opacity:.85}.color-dist-count{font-size:.8125rem;font-weight:600;color:var(--text-secondary);text-align:right}.cooc-grid{display:flex;flex-wrap:wrap;gap:.625rem}.cooc-pair{display:flex;align-items:center;gap:.375rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:999px;padding:.3125rem .75rem;font-size:.8125rem;transition:border-color .15s,background .15s}.cooc-pair:hover{border-color:var(--accent);background:var(--bg-tertiary)}.cooc-tag{font-weight:500;color:var(--text-primary);text-decoration:none;border:1.5px solid transparent;border-radius:4px;padding:0 3px;transition:color .15s}.cooc-tag:hover{text-decoration:underline}.cooc-sep{color:var(--text-tertiary);font-weight:600}.cooc-count{font-size:.75rem;color:var(--text-tertiary);font-weight:600;margin-left:2px}.empty-message{text-align:center;padding:2.5rem 1rem;color:var(--text-tertiary);font-size:.9375rem}@media (max-width: 1024px){.stats-2col{grid-template-columns:1fr}}@media (max-width: 768px){.statistics-page{padding:1rem}.stats-overview{grid-template-columns:1fr 1fr;gap:.875rem}.stat-card{padding:1rem 1.125rem}.stat-value{font-size:1.625rem}.stats-section{padding:1.125rem}.vbar-chart,.score-chart{height:120px}.cooc-grid{gap:.5rem}.hbar-row{grid-template-columns:22px 1fr 1fr 48px;gap:.4rem;padding:.4rem}}@media (max-width: 480px){.stats-overview{grid-template-columns:1fr}.color-dist-row{grid-template-columns:16px 60px 1fr 40px}}.imagesets-page{max-width:1400px;margin:0 auto;padding:2rem}.header-actions{display:flex;gap:1rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:8px}.breadcrumb-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s}.breadcrumb-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.breadcrumb-item.active{color:var(--text-primary);font-weight:500;cursor:default}.breadcrumb-separator{color:var(--border-color)}.folders-section{margin-bottom:2rem}.section-title{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.folders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.folder-card{position:relative;padding:1.5rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.folder-card-button{background:none;border:none;width:100%;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;color:var(--text-primary)}.folder-icon{width:48px;height:48px;color:var(--accent);opacity:.8}.folder-name{font-size:.95rem;font-weight:500;word-break:break-word}.folder-delete{position:absolute;top:.5rem;right:.5rem;background:var(--bg-tertiary);border:none;border-radius:4px;padding:.375rem;cursor:pointer;color:var(--text-secondary);opacity:0;transition:all .2s}.folder-card:hover .folder-delete{opacity:1}.folder-delete:hover{background:var(--error);color:#fff}.imagesets-section{margin-top:2rem}.imagesets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.imageset-card{position:relative;overflow:hidden;display:flex;flex-direction:column;background:var(--card-bg, #fff);border:1px solid var(--border-color);border-radius:12px;transition:all .3s ease;box-shadow:0 2px 4px #0000000d}.imageset-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026;border-color:var(--accent)}.imageset-card-link{flex:1;display:flex;flex-direction:column;text-decoration:none;color:inherit}.imageset-preview{width:100%;aspect-ratio:1;background:var(--bg-tertiary);overflow:hidden;position:relative}.imageset-preview-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;width:100%;height:100%;gap:2px;background:var(--bg-secondary)}.imageset-preview-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.imageset-card:hover .imageset-preview-image{transform:scale(1.05)}.imageset-preview-empty{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);background:var(--bg-tertiary)}.imageset-info{padding:1rem;flex:1;display:flex;flex-direction:column;gap:.5rem}.imageset-name{font-size:1.05rem;font-weight:600;margin:0;color:var(--text-primary)}.imageset-description{font-size:.875rem;color:var(--text-secondary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.imageset-meta{display:flex;align-items:center;gap:.75rem;margin-top:auto;font-size:.85rem}.imageset-type-badge{padding:.25rem .5rem;background:var(--accent-secondary);color:var(--accent);border-radius:4px;font-size:.75rem;font-weight:500;text-transform:uppercase}.imageset-count{color:var(--text-secondary)}.imageset-actions{display:flex;gap:.5rem;padding:0 1rem 1rem;justify-content:flex-end}.btn-icon{background:var(--bg-tertiary);border:none;border-radius:6px;padding:.5rem;cursor:pointer;color:var(--text-secondary);transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--accent-secondary);color:var(--accent)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;gap:1rem}.empty-state svg{color:var(--text-secondary);opacity:.5}.empty-state h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.empty-state p{margin:0;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-primary);border-radius:12px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 20px 50px #0000004d}.modal-content h3{margin:0 0 1rem;font-size:1.25rem}.modal-content .input{width:100%;margin-bottom:1rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}@media (max-width: 768px){.imagesets-page{padding:1rem}.header-actions{flex-direction:column}.folders-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.imagesets-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}}.block-filter-builder{border:1px solid var(--border);border-radius:8px;background:var(--bg-primary);padding:1rem}.block-filter-builder.disabled{opacity:.6;pointer-events:none}.block-canvas{min-height:200px;background:var(--bg-secondary);border:2px dashed var(--border);border-radius:6px;padding:1rem;margin-bottom:1rem}.empty-canvas{display:flex;align-items:center;justify-content:center;min-height:150px;color:var(--text-secondary);font-size:.95rem}.logic-block{background:var(--bg-tertiary);border:2px solid var(--accent);border-radius:6px;margin-bottom:.75rem;overflow:hidden}.logic-block.not-block{border-color:#ef4444}.logic-block-header{background:var(--accent);color:#fff;padding:.5rem .75rem;display:flex;justify-content:space-between;align-items:center}.not-block .logic-block-header{background:#ef4444}.logic-operator{font-weight:700;font-size:.9rem;letter-spacing:.5px}.block-actions{display:flex;gap:.5rem}.add-child-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background .2s}.add-child-btn:hover{background:#ffffff4d}.remove-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.remove-btn:hover{background:#f00c;border-color:red}.logic-block-children{padding:.75rem;background:var(--bg-primary)}.empty-logic-block{padding:1rem;text-align:center;color:var(--text-secondary);font-size:.9rem;background:var(--bg-secondary);border:1px dashed var(--border);border-radius:4px}.condition-block{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;padding:.75rem;margin-bottom:.75rem}.condition-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.nested-child-condition{margin-top:.75rem;padding-top:.75rem;border-top:2px dashed var(--border)}.with-indicator{padding:.4rem .8rem;border:1px solid var(--accent);border-radius:4px;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600}.condition-keyword{font-weight:700;color:var(--accent);font-size:.9rem;text-transform:uppercase}.tag-type-select,.category-select,.property-select{padding:.4rem .6rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer}.tag-search-btn{padding:.5rem 1rem;border:1px solid var(--accent);border-radius:4px;background:rgba(var(--accent-rgb),.1);color:var(--accent);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:6px}.full-width-btn{width:100%;justify-content:center;max-width:none;margin-top:.5rem;padding:.8rem;font-size:.95rem;border-width:2px}.tag-search-btn:before{content:"🏷️";font-size:.8rem}.property-name-btn{padding:.4rem .8rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:all .2s;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.property-name-btn:hover{border-color:var(--accent);color:var(--accent)}.with-btn{padding:.4rem .8rem;border:1px dashed var(--border);border-radius:4px;background:var(--bg-primary);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .2s}.with-btn:hover{border-color:var(--accent);color:var(--accent)}.with-btn.active{border-style:solid;border-color:var(--accent);background:var(--accent);color:#fff}.property-values-btn{padding:.4rem .8rem;border:1px solid var(--border);border-radius:4px;background:var(--accent);color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s}.property-values-btn:hover{background:var(--accent-hover)}.add-root-blocks{display:flex;gap:.5rem;flex-wrap:wrap}.add-root-blocks button{padding:.6rem 1rem;border:1px dashed var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.add-root-blocks button:hover{border-style:solid;border-color:var(--accent);background:var(--accent);color:#fff}.property-section{width:100%;margin-top:.5rem;padding-top:.5rem;border-top:1px dotted var(--border)}.property-section-header{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;margin-bottom:.25rem;letter-spacing:.5px}.property-values-display{margin-top:.5rem;padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:4px;cursor:pointer;transition:all .2s}.property-values-display:hover{border-color:var(--accent);background:var(--bg-primary)}.values-section{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.4rem}.values-section:last-child{margin-bottom:0}.values-section.empty{color:var(--text-secondary);font-style:italic}.value-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);min-width:60px;padding-top:2px}.value-tags{display:flex;flex-wrap:wrap;gap:4px;flex:1}.value-tag{font-size:.8rem;padding:2px 6px;border-radius:3px;background:var(--bg-tertiary);border:1px solid var(--border)}.value-tag.include{background:rgba(var(--accent-rgb),.1);border-color:var(--accent);color:var(--accent)}.value-tag.exclude{background:#ff44441a;border-color:#f44;color:#f44}.value-tag.any{background:transparent;border:1px dashed var(--border);color:var(--text-secondary)}.edit-hint{font-size:.7rem;color:var(--text-secondary);text-align:right;margin-top:4px;opacity:.6}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.modal-content{background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;padding:1.5rem;max-width:800px;width:100%;max-height:90vh;overflow-y:auto}.modal-content h3{margin:0 0 1rem;color:var(--text-primary);font-size:1.2rem}.modal-description{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.tag-search-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;margin-bottom:1rem}.tag-search-input:focus{outline:none;border-color:var(--accent)}.tag-list{max-height:300px;overflow-y:auto;margin-bottom:1rem}.no-results{padding:2rem;text-align:center;color:var(--text-secondary);font-style:italic}.tag-item{padding:.75rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-secondary);cursor:pointer;margin-bottom:.5rem;transition:all .2s}.tag-item:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent)}.property-values-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem;margin-bottom:1rem;max-height:400px;overflow-y:auto}.property-value-item{padding:.75rem;border:2px solid var(--border);border-radius:6px;background:var(--bg-secondary);cursor:pointer;transition:all .2s;display:flex;justify-content:space-between;align-items:center}.property-value-item.neutral{border-color:var(--border)}.property-value-item.include{border-color:#10b981;background:#10b9811a}.property-value-item.exclude{border-color:#ef4444;background:#ef44441a}.property-value-item:hover{transform:scale(1.02)}.value-text{color:var(--text-primary);font-size:.9rem}.mode-badge{font-size:.9rem;font-weight:700;padding:.125rem .5rem;border-radius:12px}.mode-badge.include{background:#10b981;color:#fff}.mode-badge.exclude{background:#ef4444;color:#fff}.modal-close-btn{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-close-btn:hover{background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent)}.tag-list::-webkit-scrollbar,.property-values-grid::-webkit-scrollbar,.modal-content::-webkit-scrollbar{width:8px}.tag-list::-webkit-scrollbar-track,.property-values-grid::-webkit-scrollbar-track,.modal-content::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}.tag-list::-webkit-scrollbar-thumb,.property-values-grid::-webkit-scrollbar-thumb,.modal-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.tag-list::-webkit-scrollbar-thumb:hover,.property-values-grid::-webkit-scrollbar-thumb:hover,.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 768px){.condition-block{flex-direction:column;align-items:stretch}.tag-type-select,.category-select,.property-select,.tag-search-btn,.with-btn,.property-values-btn{width:100%}.property-values-grid{grid-template-columns:1fr}.add-root-blocks{flex-direction:column}.add-root-blocks button{width:100%}}.condition-actions{width:100%;display:flex;gap:1.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px dotted var(--border)}.action-link-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:500;padding:0;text-decoration:none;display:flex;align-items:center;gap:.25rem;transition:color .2s}.action-link-btn:hover{text-decoration:underline;color:var(--accent)}.spacer{flex-grow:1}.property-section{width:100%;margin-top:.75rem;padding-top:.5rem;border-top:none;position:relative;padding-left:1.5rem}.property-section:before{content:"";position:absolute;left:.5rem;top:0;bottom:0;width:2px;background:var(--border);border-radius:1px}.imageset-editor{display:flex;height:calc(100vh - 64px);width:100%;overflow:hidden;margin:0;padding:0}.editor-left-pane{flex:1;padding:2rem;overflow-y:auto;min-width:600px}.editor-right-pane{width:400px;flex-shrink:0;background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column}.preview-header{padding:1rem;background:var(--bg-primary);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.preview-header-controls{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.preview-total-count{font-size:.9rem;color:var(--text-secondary)}.switch-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.switch-toggle input[type=checkbox]{display:none}.switch-track{position:relative;width:32px;height:18px;border-radius:9px;background:var(--border);transition:background .2s;flex-shrink:0}.switch-toggle input:checked~.switch-track{background:var(--accent)}.switch-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #00000040;transition:transform .2s}.switch-toggle input:checked~.switch-track .switch-thumb{transform:translate(14px)}.switch-label{font-size:.8rem;color:var(--text-secondary)}.icon-btn{width:28px;height:28px;padding:0;border:1px solid var(--border);border-radius:5px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}.icon-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent);color:var(--accent)}.icon-btn:disabled{opacity:.45;cursor:not-allowed}.icon-btn .spin{animation:spin .8s linear infinite}.cover-image-section{padding:.75rem 1rem;background:var(--bg-primary);border-bottom:1px solid var(--border)}.cover-image-label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.cover-image-preview{position:relative;display:inline-block}.cover-image-preview img{width:80px;height:80px;object-fit:cover;border-radius:6px;border:2px solid var(--accent);display:block}.remove-cover-btn{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;border:none;background:var(--text-secondary);color:#fff;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:background .15s}.remove-cover-btn:hover{background:#e05}.preview-header h2{margin:0;font-size:1.1rem;color:var(--text-primary)}.preview-content{flex:1;overflow-y:auto;padding:1rem}.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.preview-item{aspect-ratio:1;border-radius:4px;overflow:hidden;border:1px solid var(--border);background:var(--bg-tertiary);position:relative;cursor:pointer}.preview-item img{width:100%;height:100%;object-fit:cover;transition:transform .2s}.preview-item:hover img{transform:scale(1.05)}.preview-item .cover-badge{position:absolute;top:5px;right:5px;background:var(--accent);color:#fff;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;z-index:2;box-shadow:0 2px 4px #0000004d}.preview-item .set-cover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:1}.preview-item:hover .set-cover-overlay{opacity:1}.preview-item.is-cover{border:2px solid var(--accent)}.imageset-editor-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:1.2rem;color:var(--text-secondary)}.imageset-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.imageset-editor-header h1{margin:0;font-size:1.8rem;color:var(--text-primary)}.imageset-editor-actions{display:flex;gap:1rem}.imageset-editor-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;font-size:.95rem;color:var(--text-primary)}.form-group input[type=text],.form-group textarea,.form-group select{padding:.75rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;font-family:inherit;transition:border-color .2s}.form-group input[type=text]:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent)}.form-group textarea{resize:vertical;min-height:80px}.radio-group{display:flex;flex-direction:column;gap:.75rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.75rem;border-radius:6px;border:1px solid var(--border);transition:all .2s;background:var(--bg-primary)}.radio-label:hover{background:var(--bg-tertiary);border-color:var(--accent)}.radio-label input[type=radio]{cursor:pointer;accent-color:var(--accent)}.radio-label span{font-size:.95rem;color:var(--text-primary)}.filter-builder-placeholder,.manual-selector-placeholder{padding:2rem;background:var(--bg-secondary);border:2px dashed var(--border);border-radius:8px;text-align:center}.filter-builder-placeholder p,.manual-selector-placeholder p{margin:.5rem 0;color:var(--text-primary)}.filter-builder-placeholder p:first-child,.manual-selector-placeholder p:first-child{font-weight:600;font-size:1.1rem}.text-muted{color:var(--text-secondary);font-size:.9rem}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff;border:1px solid var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--accent)}@media (max-width: 768px){.imageset-editor{padding:1rem}.imageset-editor-header{flex-direction:column;align-items:flex-start;gap:1rem}.imageset-editor-actions{width:100%}.imageset-editor-actions button{flex:1}}.upload-dashboard{max-width:860px;margin:0 auto;padding:2rem 1.5rem 4rem}.ud-steps{display:flex;align-items:center;justify-content:center;margin-bottom:2.5rem;gap:0}.ud-step-item{display:flex;align-items:center;gap:0}.ud-step-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;background:var(--bg-secondary);border:2px solid var(--border);color:var(--text-tertiary);transition:background .3s,border-color .3s,color .3s;flex-shrink:0;position:relative;z-index:1}.ud-step-dot.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 4px var(--accent-alpha, rgba(99,102,241,.2))}.ud-step-dot.done{background:var(--accent);border-color:var(--accent);color:#fff}.ud-step-label{font-size:.8rem;font-weight:500;color:var(--text-tertiary);margin-left:.5rem;transition:color .3s;white-space:nowrap}.ud-step-label.active{color:var(--text-primary);font-weight:600}.ud-step-line{width:60px;height:2px;background:var(--border);margin:0 .5rem;flex-shrink:0;transition:background .4s}.ud-step-line.done{background:var(--accent)}.ud-step-content{animation:ud-fade-in .25s ease both}.ud-step-content.ud-fade-out{animation:ud-fade-out .25s ease both}@keyframes ud-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes ud-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.ud-step-header{margin-bottom:1.75rem}.ud-step-header h1{font-size:1.6rem;font-weight:700;margin:0 0 .35rem;color:var(--text-primary)}.ud-step-desc{color:var(--text-secondary);margin:0;font-size:.95rem}.ud-step-footer{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;gap:1rem}.ud-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;border-radius:8px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:background .2s,opacity .2s,transform .1s}.ud-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.ud-btn:not(:disabled):hover{transform:translateY(-1px)}.ud-btn-primary{background:var(--accent);color:#fff}.ud-btn-primary:not(:disabled):hover{background:var(--accent-hover, var(--accent));filter:brightness(1.1)}.ud-btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.ud-btn-secondary:not(:disabled):hover{background:var(--bg-tertiary, var(--bg-secondary));border-color:var(--accent)}.ud-upload-btn{padding:.5rem 1rem;font-size:.875rem}.ud-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:ud-spin .7s linear infinite;flex-shrink:0}.ud-spinner-sm{width:12px;height:12px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:ud-spin .7s linear infinite;flex-shrink:0;display:inline-block}@keyframes ud-spin{to{transform:rotate(360deg)}}.ud-file-input{display:none}.ud-drop-zone{border:2px dashed var(--border);border-radius:16px;background:var(--bg-secondary);cursor:pointer;transition:border-color .2s,background .2s,transform .15s;margin-bottom:1.5rem;overflow:hidden}.ud-drop-zone:hover{border-color:var(--accent);background:var(--bg-tertiary, var(--bg-secondary))}.ud-drop-zone.drag-active{border-color:var(--accent);background:var(--accent-alpha, rgba(99,102,241,.06));transform:scale(1.01);animation:ud-pulse-border .8s ease infinite alternate}@keyframes ud-pulse-border{0%{border-color:var(--accent)}to{border-color:color-mix(in srgb,var(--accent) 50%,transparent)}}.ud-drop-zone-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;gap:.5rem;pointer-events:none}.ud-drop-zone.compact .ud-drop-zone-inner{padding:1.25rem 2rem;flex-direction:row;gap:1rem}.ud-drop-icon{color:var(--text-tertiary);width:48px;height:48px;flex-shrink:0}.ud-drop-zone.compact .ud-drop-icon{width:28px;height:28px}.ud-drop-icon svg{width:100%;height:100%}.ud-drop-primary{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.ud-drop-hint{font-size:.8rem;color:var(--text-tertiary);margin:0}.ud-drop-zone.compact .ud-drop-primary{font-size:.95rem}.ud-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.875rem;gap:.75rem;flex-wrap:wrap}.ud-section-title{font-size:.9rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.ud-section-hint{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-tertiary);font-size:.8rem}.ud-pending-section,.ud-uploaded-section{margin-bottom:1.5rem}.ud-progress-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:1rem}.ud-progress-fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s ease}.ud-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.875rem}.ud-image-card{border-radius:10px;background:var(--bg-secondary);border:2px solid var(--border);overflow:hidden;position:relative;transition:border-color .2s,transform .15s,box-shadow .2s}.ud-image-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000002e}.ud-image-card.is-main{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.ud-image-card.is-variant{border-color:color-mix(in srgb,var(--accent) 50%,var(--border));opacity:.85}.ud-image-card.ud-pending{border-style:dashed;opacity:.9}.ud-card-remove{position:absolute;top:4px;right:4px;z-index:5;width:22px;height:22px;border-radius:50%;background:#0000008c;border:none;color:#fff;font-size:1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s;padding:0}.ud-image-card:hover .ud-card-remove{opacity:1}.ud-card-remove:hover{background:#dc2626d9!important}.ud-card-thumb{position:relative;width:100%;aspect-ratio:1;overflow:hidden;background:var(--bg-tertiary, #111)}.ud-card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.ud-star-btn{position:absolute;bottom:4px;left:4px;z-index:5;background:#0000008c;border:none;border-radius:6px;color:#fff;font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .15s,background .15s,color .15s;padding:0}.ud-image-card:hover .ud-star-btn{opacity:1}.ud-star-btn.is-main{opacity:1;color:#fbbf24;background:#0009}.ud-card-info{padding:.5rem .6rem;display:flex;flex-direction:column;gap:.2rem}.ud-card-name{font-size:.75rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ud-card-size{font-size:.7rem;color:var(--text-tertiary)}.ud-card-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);padding:1px 5px;background:var(--accent-alpha, rgba(99,102,241,.12));border-radius:4px;display:inline-block;width:fit-content}.ud-variant-toggle{display:flex;align-items:center;gap:.35rem;cursor:pointer;font-size:.72rem;color:var(--text-secondary);-webkit-user-select:none;user-select:none}.ud-variant-toggle input[type=checkbox]{width:12px;height:12px;margin:0;cursor:pointer;accent-color:var(--accent)}.ud-variant-toggle input:disabled{opacity:.4;cursor:not-allowed}.ud-scanning{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;color:var(--text-secondary)}.ud-scan-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:ud-spin .9s linear infinite}.ud-no-duplicates{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem 2rem;text-align:center}.ud-check-icon{width:64px;height:64px;border-radius:50%;background:#22c55e1f;display:flex;align-items:center;justify-content:center;color:#22c55e;animation:ud-pop-in .4s cubic-bezier(.34,1.56,.64,1) both}.ud-check-icon svg{width:34px;height:34px}@keyframes ud-pop-in{0%{transform:scale(.3);opacity:0}to{transform:scale(1);opacity:1}}.ud-no-duplicates h2{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin:0}.ud-no-duplicates p{color:var(--text-secondary);margin:0}.ud-dup-summary{margin-bottom:1.25rem}.ud-dup-count{display:inline-flex;align-items:center;padding:.35rem .875rem;border-radius:20px;font-size:.875rem;font-weight:600}.ud-dup-count.warning{background:#f59e0b1f;color:#d97706}.ud-dup-count.ok{background:#22c55e1f;color:#16a34a}.ud-duplicate-list{display:flex;flex-direction:column;gap:1.25rem}.ud-duplicate-group{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--bg-secondary);transition:border-color .2s}.ud-duplicate-group.resolved{border-color:#22c55e66;opacity:.85}.ud-resolution-badge{background:#22c55e1a;color:#16a34a;font-size:.8rem;font-weight:600;padding:.4rem 1rem;border-bottom:1px solid rgba(34,197,94,.2)}.ud-dup-group-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-bottom:1px solid var(--border)}.ud-dup-group-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.ud-dup-group-dist{font-size:.775rem;color:var(--text-tertiary);background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:.15rem .6rem}.ud-dup-image-grid{display:flex;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem}.ud-dup-img-card{display:flex;flex-direction:column;align-items:center;gap:.35rem;width:120px;flex-shrink:0}.ud-dup-img-card.is-upload .ud-dup-thumb{border-color:var(--accent)}.ud-dup-img-tag{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:.15rem .5rem;border-radius:4px;align-self:stretch;text-align:center}.ud-dup-img-tag.upload-tag{background:var(--accent-alpha, rgba(99,102,241,.15));color:var(--accent)}.ud-dup-img-tag.existing-tag{background:var(--bg-primary);color:var(--text-tertiary);border:1px solid var(--border)}.ud-dup-sides{display:grid;grid-template-columns:1fr auto 1fr;gap:0;padding:1.25rem;align-items:start}.ud-dup-vs{display:flex;align-items:center;justify-content:center;padding:0 .875rem;font-size:.75rem;font-weight:700;color:var(--text-tertiary);letter-spacing:1px;align-self:center}.ud-dup-side{display:flex;flex-direction:column;align-items:center;gap:.5rem;text-align:center}.ud-dup-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.ud-dup-new .ud-dup-label{color:var(--accent)}.ud-dup-thumb{width:120px;height:120px;border-radius:10px;overflow:hidden;background:var(--bg-primary);border:2px solid var(--border);flex-shrink:0}.ud-dup-thumb img{width:100%;height:100%;object-fit:cover;display:block}.ud-dup-filename{font-size:.78rem;font-weight:500;color:var(--text-primary);max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ud-dup-meta{font-size:.72rem;color:var(--text-tertiary)}.ud-transfer-opts{padding:.6rem 1.25rem;border-top:1px solid var(--border);background:var(--bg-primary)}.ud-transfer-check{display:inline-flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.ud-transfer-check input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.ud-dup-actions{display:flex;gap:.625rem;padding:.875rem 1.25rem;border-top:1px solid var(--border);flex-wrap:wrap}.ud-action-btn{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.6rem .75rem;border-radius:8px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:background .15s,transform .1s,opacity .2s}.ud-action-btn:not(:disabled):hover{transform:translateY(-1px)}.ud-action-btn:disabled{opacity:.5;cursor:not-allowed}.ud-action-keep-new{background:var(--accent);color:#fff}.ud-action-keep-new:not(:disabled):hover{filter:brightness(1.1)}.ud-action-keep-old{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border)}.ud-action-keep-old:not(:disabled):hover{border-color:var(--accent)}.ud-action-link{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}.ud-action-link:not(:disabled):hover{background:var(--accent-alpha, rgba(99,102,241,.08))}.ud-action-sub{font-size:.68rem;font-weight:400;opacity:.75;white-space:nowrap}@media (max-width: 640px){.upload-dashboard{padding:1rem 1rem 3rem}.ud-step-line{width:30px}.ud-step-label{display:none}.ud-steps .ud-step-item:last-child .ud-step-label,.ud-steps .ud-step-item:first-child .ud-step-label{display:block}.ud-drop-zone-inner{padding:2rem 1rem}.ud-image-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.625rem}.ud-dup-sides{grid-template-columns:1fr;gap:.75rem;padding:1rem}.ud-dup-vs{padding:0}.ud-dup-thumb{width:100px;height:100px}.ud-dup-actions{flex-direction:column;gap:.5rem}.ud-action-btn{flex-direction:row;justify-content:center;gap:.5rem;min-width:unset}.ud-step-footer{flex-direction:column-reverse;gap:.75rem}.ud-step-footer .ud-btn{width:100%;justify-content:center}}.ud-action-skip{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border)}.ud-action-skip:not(:disabled):hover{border-color:var(--text-secondary);color:var(--text-primary)}.ud-dup-selection-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;gap:.75rem}.ud-dup-checkbox-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;min-width:0}.ud-dup-checkbox-label input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--accent);cursor:pointer}.ud-dup-group-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.ud-group-selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.ud-select-all-label{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.ud-select-all-label input[type=checkbox]{accent-color:var(--accent);cursor:pointer}.ud-compare-btn{padding:.3rem .75rem;border-radius:6px;font-size:.78rem;font-weight:500;font-family:inherit;cursor:pointer;background:var(--bg-primary);color:var(--accent);border:1px solid var(--accent);transition:background .15s;white-space:nowrap}.ud-compare-btn:hover{background:var(--accent-alpha, rgba(99,102,241,.08))}.ud-dup-image-strip{display:flex;gap:.5rem;padding:.5rem 1.25rem .875rem;overflow-x:auto;scrollbar-width:thin}.ud-strip-card{display:flex;flex-direction:column;align-items:center;gap:.25rem;flex-shrink:0}.ud-strip-card.is-upload .ud-strip-thumb{border-color:var(--accent)}.ud-strip-thumb{width:80px;height:80px;border-radius:6px;overflow:hidden;border:2px solid var(--border)}.ud-strip-thumb img{width:100%;height:100%;object-fit:cover}.ud-strip-label{font-size:.65rem;font-weight:600;text-transform:uppercase;padding:.1rem .4rem;border-radius:4px}.ud-step-resolve{display:flex;flex-direction:column;gap:0}.ud-dup-img-card{position:relative;cursor:pointer;border:2px solid transparent;border-radius:8px;padding:2px;transition:border-color .15s,box-shadow .15s}.ud-dup-img-card.is-selected{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent-alpha, rgba(99,102,241,.3))}.ud-dup-img-card.is-main{border-color:#f59e0b!important;box-shadow:0 0 0 2px #f59e0b4d}.ud-dup-img-card.linking-mode{cursor:pointer}.ud-dup-img-card.linking-mode:hover{border-color:#f59e0b}.ud-main-badge,.ud-selected-badge{position:absolute;top:28px;right:4px;z-index:2;font-size:.65rem;font-weight:700;padding:.15rem .4rem;border-radius:4px}.ud-main-badge{background:#f59e0b;color:#fff}.ud-selected-badge{background:var(--accent);color:#fff;width:18px;height:18px;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0;right:4px;top:28px}.ud-deleting-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:4px}.ud-img-card-actions{display:flex;gap:.25rem;padding:.35rem 0;justify-content:center}.ud-img-action-btn{font-size:.65rem;padding:.15rem .4rem;border-radius:4px;border:1px solid var(--border);cursor:pointer;font-family:inherit;background:var(--bg-primary);color:var(--text-secondary);transition:background .12s,color .12s}.ud-img-delete-btn:hover{background:#ef4444;color:#fff;border-color:#ef4444}.ud-img-fp-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.ud-dup-group-header-left{display:flex;align-items:center;gap:.5rem}.ud-merge-panel{padding:1rem 1.25rem;border-top:1px solid var(--border);background:var(--bg-primary);display:flex;flex-direction:column;gap:.75rem}.ud-merge-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.ud-merge-options{display:flex;flex-wrap:wrap;gap:.75rem}.ud-merge-option{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;border-radius:8px;border:2px solid var(--border);cursor:pointer;transition:border-color .15s;background:var(--bg-secondary)}.ud-merge-option:hover{border-color:var(--accent)}.ud-merge-option.is-selected{border-color:var(--accent);background:var(--accent-alpha, rgba(99,102,241,.06))}.ud-merge-option input[type=radio]{accent-color:var(--accent);flex-shrink:0}.ud-merge-thumb{width:56px;height:56px;border-radius:4px;overflow:hidden;flex-shrink:0}.ud-merge-thumb img{width:100%;height:100%;object-fit:cover}.ud-merge-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.ud-merge-name{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.ud-merge-badge{font-size:.65rem;font-weight:700;text-transform:uppercase;padding:.1rem .4rem;border-radius:3px;align-self:flex-start}.ud-merge-actions{display:flex;gap:.625rem;justify-content:flex-end;flex-wrap:wrap}.ud-linking-instructions{padding:.75rem 1.25rem;border-top:1px solid var(--border);background:var(--bg-primary)}.ud-linking-instructions p{font-size:.83rem;color:var(--text-secondary);margin:0}.ud-step-overview{display:flex;flex-direction:column;gap:1.5rem}.ud-overview-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;overflow:hidden}.ud-overview-row{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;font-size:.875rem;border-bottom:1px solid var(--border)}.ud-overview-row:last-child{border-bottom:none}.ud-overview-label{color:var(--text-secondary)}.ud-overview-value{font-weight:600;color:var(--text-primary)}.ud-overview-ok{color:#22c55e}.ud-compare-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem}.ud-compare-content{background:var(--bg-secondary);border-radius:12px;width:100%;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;position:relative}.ud-compare-close{position:absolute;top:.75rem;right:.75rem;z-index:10;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0006;border:none;cursor:pointer;color:#fff;transition:background .15s}.ud-compare-close:hover{background:#000000b3}.ud-compare-main{display:flex;flex-direction:column;flex:1;overflow:hidden}.ud-compare-image-container{flex:1;position:relative;overflow:hidden;min-height:0;background:#000}.ud-compare-main-img{width:100%;height:100%;object-fit:contain;display:block;max-height:calc(90vh - 200px)}.ud-compare-image-info{position:absolute;bottom:0;left:0;right:0;padding:.75rem 1rem;background:linear-gradient(transparent,#000000bf);display:flex;flex-direction:column;gap:.15rem;pointer-events:none}.ud-compare-image-name{font-size:.875rem;font-weight:600;color:#fff}.ud-compare-image-meta{font-size:.75rem;color:#ffffffb3}.ud-compare-del-btn{position:absolute;top:.75rem;left:.75rem;z-index:10;display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:6px;background:#ef4444d9;color:#fff;border:none;cursor:pointer;font-size:.8rem;font-weight:600;font-family:inherit;transition:background .15s}.ud-compare-del-btn:hover{background:#ef4444}.ud-compare-thumbnails{background:var(--bg-primary);border-top:1px solid var(--border);padding:.625rem 1rem}.ud-compare-thumbnails-title{font-size:.75rem;color:var(--text-tertiary);margin:0 0 .5rem}.ud-compare-thumbnails-grid{display:flex;gap:.5rem;overflow-x:auto;scrollbar-width:thin;padding-bottom:.25rem;max-height:140px}.ud-compare-thumbnail{flex-shrink:0;width:90px;cursor:pointer;border-radius:6px;overflow:hidden;border:2px solid transparent;transition:border-color .15s;display:flex;flex-direction:column}.ud-compare-thumbnail img{width:90px;height:90px;object-fit:cover;display:block}.ud-compare-thumbnail.active{border-color:var(--accent)}.ud-compare-thumbnail:hover:not(.active){border-color:var(--border)}.ud-compare-thumbnail-label{display:flex;align-items:center;justify-content:center;gap:.2rem;padding:.15rem 0;font-size:.65rem;color:var(--text-tertiary);background:var(--bg-primary)}.ud-compare-active-dot{color:var(--accent);font-size:.55rem}@media (max-width: 640px){.ud-dup-selection-row{flex-wrap:wrap;gap:.5rem}.ud-merge-options{flex-direction:column}.ud-merge-option{width:100%}.ud-compare-content{max-height:95vh}.ud-compare-main-img{max-height:calc(95vh - 180px)}.ud-dup-image-strip{padding:.5rem 1rem .75rem}}.ud-step2-section{margin-bottom:1.75rem}.ud-step2-section h3{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem}.ud-step2-matches-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.ud-step2-uploads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.625rem}.ud-step2-upload-card{border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--bg-secondary)}.ud-step2-thumb-wrap{position:relative;width:100%;padding-bottom:75%;background:var(--bg-tertiary);overflow:hidden}.ud-step2-thumb-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.ud-step2-name{font-size:.7rem;color:var(--text-secondary);padding:.35rem .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.ud-candidate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.ud-candidate-card{position:relative;border-radius:10px;border:2px solid var(--border);background:var(--bg-secondary);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.ud-candidate-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:var(--accent)}.ud-candidate-card.is-selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-alpha, rgba(99,102,241,.25))}.ud-candidate-check{position:absolute;top:.5rem;left:.5rem;z-index:5}.ud-candidate-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.ud-candidate-thumb-wrap{position:relative;width:100%;padding-bottom:75%;background:var(--bg-tertiary);overflow:hidden}.ud-candidate-thumb-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.ud-candidate-info{padding:.5rem .625rem;display:flex;flex-direction:column;gap:.2rem}.ud-candidate-name{font-size:.78rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ud-candidate-sub{font-size:.7rem;color:var(--text-tertiary)}.ud-resolve-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;padding:1rem 1.25rem}.ud-resolve-card{position:relative;background:var(--bg-primary);border:2px solid var(--border);border-radius:8px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;cursor:default}.ud-resolve-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.ud-resolve-card.is-main{border-color:var(--accent);border-width:3px;box-shadow:0 0 0 3px var(--accent-alpha, rgba(99,102,241,.2))}.ud-resolve-card.is-variant{border-color:#22c55e;box-shadow:0 0 0 2px #22c55e33}.ud-resolve-card.is-deleting{opacity:.6;pointer-events:none}.ud-resolve-card.linking-mode{cursor:pointer}.ud-resolve-badge{position:absolute;top:.5rem;left:.5rem;z-index:5;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;padding:.15rem .45rem;border-radius:4px}.ud-resolve-badge.upload-tag{background:var(--accent-alpha, rgba(99,102,241,.15));color:var(--accent)}.ud-resolve-badge.existing-tag{background:#00000080;color:#ffffffd9}.ud-resolve-main-badge{position:absolute;bottom:.5rem;left:.5rem;z-index:5;font-size:.7rem;font-weight:700;padding:.15rem .45rem;border-radius:4px;background:var(--accent);color:#fff}.ud-resolve-delete-btn{position:absolute;top:.5rem;right:.5rem;z-index:5;width:26px;height:26px;border-radius:50%;background:#dc2626e0;border:none;color:#fff;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s;padding:0}.ud-resolve-card:hover .ud-resolve-delete-btn{opacity:1}.ud-resolve-delete-btn:hover{background:#dc2626}.ud-resolve-delete-btn:disabled{opacity:0!important}.ud-resolve-thumb-wrap{position:relative;width:100%;padding-bottom:75%;background:var(--bg-tertiary);overflow:hidden}.ud-resolve-thumb-wrap img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.ud-resolve-info{padding:.6rem .75rem;background:var(--bg-primary)}.ud-resolve-filename{font-size:.8rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.15rem}.ud-resolve-meta{font-size:.72rem;color:var(--text-tertiary)}@media (max-width: 640px){.ud-candidate-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.ud-resolve-grid{grid-template-columns:1fr;padding:.75rem 1rem}}.imgd-page{position:relative;isolation:isolate}.imgd-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,color-mix(in srgb,var(--img-color, var(--accent)) 38%,transparent),color-mix(in srgb,var(--img-color, var(--accent)) 22%,transparent) 35%,color-mix(in srgb,var(--img-color, var(--accent)) 12%,transparent) 65%,color-mix(in srgb,var(--img-color, var(--accent)) 6%,transparent));pointer-events:none;z-index:-1}.imgd-status-page{min-height:calc(100vh - 60px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;color:var(--text-secondary)}.imgd-spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:imgdSpin .75s linear infinite}@keyframes imgdSpin{to{transform:rotate(360deg)}}.imgd-topbar{display:flex;align-items:center;gap:.75rem;padding:0 1.25rem;height:52px;background:transparent;border-bottom:1px solid color-mix(in srgb,var(--border) 50%,transparent);position:sticky;top:0;z-index:50;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);flex-shrink:0}.imgd-back-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}.imgd-back-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent)}.imgd-topbar-title{flex:1;font-size:.875rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.imgd-topbar-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.imgd-action-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-decoration:none}.imgd-action-btn:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent)}.imgd-action-btn.active{color:#f59e0b;border-color:#f59e0b66;background:#f59e0b14}.imgd-action-btn--danger:hover{background:#ef44441a;color:#ef4444;border-color:#ef444459}.imgd-hero{display:grid;grid-template-columns:1fr 320px;height:calc(100vh - 112px);gap:0 12px;padding:0 12px 0 0}.imgd-viewer{position:relative;background:#06060e;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:zoom-in;margin:12px 0 12px 12px;border-radius:16px}.imgd-viewer.zoomed{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;z-index:200;border-radius:0;margin:0;background:#000;cursor:grab}.imgd-viewer.zoomed:active{cursor:grabbing}.imgd-viewer.zoomed .imgd-full,.imgd-viewer.zoomed .imgd-thumb{max-width:none;max-height:none}.imgd-zoom-slider-wrap{position:absolute;left:1rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:.75rem;background:var(--bg-secondary);padding:1rem .75rem;border-radius:12px;border:1px solid var(--border);box-shadow:0 4px 12px var(--shadow);z-index:20;pointer-events:auto;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px)}.imgd-zoom-btn{width:36px;height:36px;border-radius:6px;border:1px solid var(--border);background:var(--bg-tertiary);color:var(--text-secondary);font-size:1.3rem;font-weight:600;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;padding:0}.imgd-zoom-btn:hover{background:var(--accent-transparent);color:var(--accent);transform:scale(1.05)}.imgd-zoom-btn:active{transform:scale(.95)}.imgd-zoom-slider{width:6px;height:160px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:3px;outline:none;cursor:pointer;writing-mode:bt-lr;-webkit-appearance:slider-vertical}.imgd-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.imgd-zoom-slider::-webkit-slider-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.imgd-zoom-slider::-moz-range-thumb{width:20px;height:20px;background:var(--accent);border-radius:50%;cursor:pointer;border:none;box-shadow:0 2px 6px #0000004d;transition:all .2s ease}.imgd-zoom-slider::-moz-range-thumb:hover{background:var(--accent-hover);transform:scale(1.1)}.imgd-zoom-level{color:var(--text-primary);font-size:.8rem;font-weight:600;min-width:45px;text-align:center;padding:.25rem .5rem;background:var(--bg-tertiary);border-radius:4px;white-space:nowrap}.imgd-viewer-bg{position:absolute;top:-32px;right:-32px;bottom:-32px;left:-32px;background-size:cover;background-position:center;filter:blur(36px) saturate(1.3);opacity:.28;transform:scale(1.12);pointer-events:none;-webkit-user-select:none;user-select:none}.imgd-thumb{position:absolute;max-width:90%;max-height:90%;object-fit:contain;filter:drop-shadow(0 12px 40px rgba(0,0,0,.75));pointer-events:none;-webkit-user-select:none;user-select:none;z-index:1;transition:opacity .45s ease}.imgd-full{position:absolute;max-width:90%;max-height:90%;object-fit:contain;filter:drop-shadow(0 12px 40px rgba(0,0,0,.75));-webkit-user-select:none;user-select:none;z-index:2;opacity:0;transition:opacity .45s ease;transform-origin:center center;will-change:transform}.imgd-full.loaded{opacity:1}.imgd-zoom-hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#000000ba;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;white-space:nowrap;pointer-events:none;z-index:10;backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px)}.imgd-sidebar{border:1px solid var(--border);background:var(--card-bg, var(--bg-secondary));overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--border) transparent;margin:12px 0;border-radius:16px;box-shadow:0 8px 40px #00000047,0 2px 10px #0000001f,inset 0 1px #ffffff0f}.imgd-section{padding:1rem 1.125rem;border-bottom:1px solid var(--border)}.imgd-section-title{display:flex;align-items:center;gap:6px;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-tertiary);margin:0 0 .75rem}.imgd-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--accent-transparent);color:var(--accent);font-size:.5875rem;font-weight:700;letter-spacing:0;text-transform:none}.imgd-stats-row{display:flex;border-bottom:1px solid var(--border)}.imgd-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:.875rem .25rem .75rem}.imgd-stat+.imgd-stat{border-left:1px solid var(--border)}.imgd-stat-val{font-size:1.125rem;font-weight:800;color:var(--text-primary);line-height:1}.imgd-stat-lbl{font-size:.5875rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em}.imgd-stat-icon{margin-bottom:2px;color:var(--text-tertiary)}.imgd-balance{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.125rem;border-bottom:1px solid var(--border)}.imgd-balance-track{flex:1;height:4px;background:#ef444433;border-radius:99px;overflow:hidden}.imgd-balance-fill{height:100%;background:linear-gradient(to right,#22c55e,var(--accent));border-radius:99px;transition:width .6s cubic-bezier(.22,1,.36,1)}.imgd-balance-label{font-size:.6875rem;font-weight:700;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.imgd-characters{display:flex;flex-wrap:wrap;gap:.75rem}.imgd-char-card{display:flex;flex-direction:column;align-items:center;gap:5px;text-decoration:none;transition:transform .18s}.imgd-char-card:hover{transform:translateY(-2px)}.imgd-char-thumb,.imgd-char-fallback{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--border);background:var(--bg-secondary);transition:border-color .18s}.imgd-char-fallback{display:none;align-items:center;justify-content:center;color:var(--text-tertiary)}.imgd-char-card:hover .imgd-char-thumb,.imgd-char-card:hover .imgd-char-fallback{border-color:var(--accent)}.imgd-char-name{font-size:.6875rem;font-weight:600;color:var(--text-secondary);text-align:center;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.imgd-tag-chips{display:flex;flex-wrap:wrap;gap:5px}.imgd-tag-chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:.75rem;font-weight:500;text-decoration:none;color:var(--accent);background:var(--accent-transparent);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);transition:background .15s,border-color .15s}.imgd-tag-chip:hover{background:color-mix(in srgb,var(--accent) 20%,transparent);border-color:color-mix(in srgb,var(--accent) 50%,transparent)}.imgd-tag-chip[style*=--chip-color]{color:var(--chip-color);background:color-mix(in srgb,var(--chip-color) 10%,transparent);border-color:color-mix(in srgb,var(--chip-color) 30%,transparent)}.imgd-tag-chip[style*=--chip-color]:hover{background:color-mix(in srgb,var(--chip-color) 18%,transparent);border-color:color-mix(in srgb,var(--chip-color) 55%,transparent)}.imgd-no-tags{display:flex;flex-direction:column;align-items:center;gap:.625rem;padding:1.5rem 1.125rem;color:var(--text-tertiary);font-size:.8125rem;border-bottom:1px solid var(--border)}.imgd-file-grid{display:grid;grid-template-columns:auto 1fr;gap:.375rem .875rem;align-items:baseline}.imgd-file-key{font-size:.6875rem;color:var(--text-tertiary);white-space:nowrap}.imgd-file-val{font-size:.6875rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.imgd-status-ok{color:#22c55e;font-weight:600}.imgd-status-pending{color:var(--text-tertiary)}.imgd-colors{display:flex;flex-wrap:wrap;gap:.5rem}.imgd-color-chip{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:8px;border:1px solid var(--border);background:var(--bg-secondary)}.imgd-color-swatch{width:14px;height:14px;border-radius:50%;border:1px solid rgba(0,0,0,.15);flex-shrink:0}.imgd-color-name{font-size:.75rem;color:var(--text-secondary);text-transform:capitalize}.imgd-color-label{font-size:.5875rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em}.imgd-magnifier{position:fixed;width:400px;height:400px;border-radius:50%;transform:translate(-50%,-50%);border:3px solid color-mix(in srgb,var(--accent) 75%,transparent);box-shadow:0 8px 48px #000000a6,inset 0 0 0 1px #ffffff14;pointer-events:none;z-index:1000;background-repeat:no-repeat;overflow:hidden}.imgd-outer-section{padding:1.75rem 1.5rem;border-top:1px solid var(--border)}.imgd-outer-heading{display:flex;align-items:center;gap:8px;font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin:0 0 1.125rem}.imgd-outer-see-all{margin-left:auto;font-size:.75rem;font-weight:600;color:var(--accent);text-decoration:none;text-transform:none;letter-spacing:0;opacity:.8;transition:opacity .15s}.imgd-outer-see-all:hover{opacity:1}.imgd-char-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.625rem}.imgd-char-gallery-card{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid var(--border);text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s}.imgd-char-gallery-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px var(--shadow);border-color:var(--accent)}.imgd-char-gallery-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.imgd-char-gallery-card:hover img{transform:scale(1.04)}.imgd-outer-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent-transparent);color:var(--accent);font-size:.6875rem;font-weight:700}.imgd-variants-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem}.imgd-variants-outer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.625rem}.imgd-variant-card{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:2px solid var(--border);text-decoration:none;transition:border-color .18s,transform .18s,box-shadow .18s}.imgd-variant-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow)}.imgd-variant-card.current{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent);pointer-events:none}.imgd-variant-card img{width:100%;height:100%;object-fit:cover}.imgd-variant-badge{position:absolute;top:6px;left:6px;font-size:.5875rem;font-weight:700;padding:2px 6px;border-radius:4px;background:#000000a6;color:#fbbf24;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-transform:uppercase;letter-spacing:.06em}.imgd-variant-viewing{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;box-shadow:inset 0 0 0 3px var(--accent);pointer-events:none}.imgd-similar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.625rem}.imgd-similar-card{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid var(--border);text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s}.imgd-similar-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px var(--shadow);border-color:var(--accent)}.imgd-similar-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.imgd-similar-card:hover img{transform:scale(1.04)}.imgd-similar-overlay{position:absolute;bottom:0;left:0;right:0;padding:28px 10px 10px;background:linear-gradient(to top,rgba(0,0,0,.78) 0%,transparent 100%);opacity:0;transition:opacity .2s}.imgd-similar-card:hover .imgd-similar-overlay{opacity:1}.imgd-similar-name{display:block;font-size:.6875rem;color:#ffffffe6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:3px}.imgd-similar-stats{display:flex;gap:.625rem;font-size:.625rem;color:#fff9}@media (max-width: 900px){.imgd-hero{grid-template-columns:1fr;height:auto;gap:0;padding:0}.imgd-viewer{height:58vw;min-height:280px;max-height:60vh;margin:0;border-radius:0}.imgd-sidebar{margin:0;border-radius:0;border:none;border-top:1px solid var(--border);box-shadow:none;overflow-y:visible}.imgd-similar-grid,.imgd-char-gallery{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width: 600px){.imgd-topbar{padding:0 .875rem}.imgd-topbar-title{font-size:.8125rem}.imgd-outer-section{padding:1.25rem 1rem}.imgd-similar-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left: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);border-radius:16px;border:1px solid var(--border);box-shadow:0 20px 60px #0000004d;animation:imgdModalIn .2s ease-out}@keyframes imgdModalIn{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}.link-modal{width:90%;max-width:700px;height:80vh;display:flex;flex-direction:column;overflow:hidden;padding:0}.link-modal .modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.link-modal .modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.link-modal .modal-body{overflow-y:auto;flex:1 1 0;min-height:0;padding:1.5rem}.link-modal .modal-footer{padding:1rem 1.5rem;display:flex;gap:.75rem;justify-content:flex-end;border-top:1px solid var(--border);flex-shrink:0}.link-modal-description{font-size:.95rem;color:var(--text-secondary);margin-bottom:1rem}.linked-images-section{margin-bottom:1.25rem}.linked-images-title{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.linked-images-hint{font-size:.75rem;font-weight:400;color:var(--text-tertiary)}.link-tabs{display:flex;margin-bottom:1rem;border-bottom:2px solid var(--border)}.link-tab-btn{flex:1;padding:.6rem 1rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:color .15s,border-color .15s}.link-tab-btn:hover{color:var(--text-primary)}.link-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.link-tab-count{background:var(--accent);color:#fff;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:10px;line-height:1.4}.link-sort-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.sort-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;border:2px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.sort-toggle-btn:hover{border-color:var(--accent);color:var(--text-primary)}.sort-toggle-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.link-search-box{position:relative;margin-bottom:1rem}.link-search-input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.95rem;box-sizing:border-box}.link-search-input:focus{outline:none;border-color:var(--accent)}.link-searching{position:absolute;right:1rem;top:50%;transform:translateY(-50%);font-size:.85rem;color:var(--text-tertiary)}.link-search-results{border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary)}.link-result-item{display:flex;align-items:center;gap:1rem;padding:.75rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .2s}.link-result-item:last-child{border-bottom:none}.link-result-item:hover{background:var(--bg-hover)}.link-result-item.selected{background:var(--accent-alpha)}.link-result-item.linked-item{background:var(--bg-secondary)}.link-result-item.marked-remove{opacity:.45;text-decoration:line-through}.link-checkbox{width:18px;height:18px;cursor:pointer}.link-result-thumbnail{width:60px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border);flex-shrink:0}.link-result-info{flex:1;min-width:0}.link-result-filename{font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.link-result-meta{font-size:.8rem;color:var(--text-tertiary);margin-top:.25rem}.similarity-badge{color:var(--accent);font-weight:500}.link-main-btn{flex-shrink:0;background:none;border:none;cursor:pointer;padding:.25rem;color:var(--text-tertiary);border-radius:4px;display:flex;align-items:center;transition:color .15s}.link-main-btn:hover{color:var(--accent)}.link-main-btn.is-main{color:#f59e0b}.link-no-results{padding:2rem;text-align:center;color:var(--text-tertiary);font-size:.9rem}.link-selected-count{margin-top:1rem;padding:.5rem;background:var(--accent-alpha);border-radius:6px;text-align:center;font-size:.9rem;font-weight:500;color:var(--accent)}*,*: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}.bottom-sheet-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-sheet-modern{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top-left-radius:12px;border-top-right-radius:12px;box-shadow:0 -4px 20px #0000004d;z-index:1000;display:flex;flex-direction:column;transition:height .2s ease;will-change:height;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-modern.dragging{transition:none}.sheet-header-draggable{padding:12px 16px 8px;border-bottom:1px solid var(--border);cursor:grab;touch-action:none}.sheet-header-draggable:active{cursor:grabbing}.sheet-handle-modern{width:40px;height:4px;background:var(--text-secondary);border-radius:2px;margin:0 auto 12px;opacity:.5}.sheet-title-section{display:flex;justify-content:space-between;align-items:center;gap:12px}.sheet-title-section h3{color:var(--text-primary);font-size:18px;font-weight:600;flex:1}.sheet-header-actions{display:flex;align-items:center;gap:8px}.btn-add-tag-mobile{background:var(--accent);color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;white-space:nowrap;min-height:40px}.tag-count-mobile{color:var(--text-secondary);font-size:12px;white-space:nowrap}.btn-close-mobile{background:none;border:none;color:var(--text-secondary);font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer}.sheet-content-modern{flex:1;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.sheet-content-modern.no-scroll{overflow:hidden;touch-action:none}.empty-state-modern{text-align:center;padding:40px 20px}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-state-modern p{color:var(--text-secondary);margin-bottom:8px}.empty-state-modern .hint{font-size:14px;margin-bottom:20px}.btn-primary-mobile{background:var(--accent);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:500;min-height:48px}.annotation-tree-view-mobile{padding:0}.tree-root-node-mobile{margin-bottom:8px}.tree-node-wrapper-mobile{margin-bottom:2px;position:relative}.tree-children-mobile{position:relative}.tree-children-mobile:before{content:"";position:absolute;left:calc(12px + var(--level, 0) * 24px + 16px);top:0;bottom:0;width:2px;background:repeating-linear-gradient(to bottom,var(--text-tertiary, #888) 0,var(--text-tertiary, #888) 4px,transparent 4px,transparent 8px)}.tree-node-item-mobile{display:flex;align-items:center;gap:8px;padding:10px 12px;padding-left:calc(12px + var(--level, 0) * 24px);background:var(--bg-secondary);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;min-height:48px;position:relative}.tree-node-item-mobile:hover{background:var(--bg-hover);border-color:var(--border-color)}.tree-node-item-mobile.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.tree-node-item-mobile.active .node-label-mobile,.tree-node-item-mobile.active svg{color:#fff}.expand-btn-mobile{background:none;border:none;color:var(--text-secondary);font-size:14px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;padding:0}.expand-spacer-mobile{width:24px;height:24px;flex-shrink:0}.visibility-btn-mobile{background:none;border:none;width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7;padding:0;color:var(--text-primary)}.visibility-btn-mobile.hidden{opacity:.3}.visibility-spacer-mobile{width:32px;height:32px;flex-shrink:0}.node-icon-mobile{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;color:var(--text-primary)}.node-icon-mobile svg{width:18px;height:18px;fill:currentColor;color:inherit}.tree-node-item-mobile.active .node-icon-mobile{color:#fff}.tree-node-item-mobile.active .node-icon-mobile svg{fill:#fff}.node-label-mobile{flex:1;font-size:15px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tree-node-item-mobile.active .node-label-mobile{color:#fff}.bbox-indicator-mobile,.global-indicator-mobile{display:inline-flex;align-items:center;justify-content:center;opacity:.7;flex-shrink:0;width:20px;height:20px;color:var(--text-primary)}.bbox-indicator-mobile svg,.global-indicator-mobile svg{width:14px;height:14px;fill:currentColor;color:inherit}.tree-node-item-mobile.active .bbox-indicator-mobile,.tree-node-item-mobile.active .global-indicator-mobile{color:#fff;opacity:.9}.tree-node-item-mobile.active .bbox-indicator-mobile svg,.tree-node-item-mobile.active .global-indicator-mobile svg{fill:#fff}.active-indicator-mobile{color:var(--accent);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.active-indicator-mobile svg{width:10px;height:10px;fill:currentColor}.tree-node-item-mobile.active .active-indicator-mobile{color:#fff}.tree-node-item-mobile.active .active-indicator-mobile svg{fill:#fff}.node-actions-mobile{display:flex;gap:6px;flex-shrink:0}.btn-icon-mobile{background:none;border:none;color:var(--text-secondary);font-size:18px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;opacity:.7;padding:0}.btn-icon-mobile svg{fill:currentColor;stroke:currentColor}.btn-icon-mobile:hover,.btn-icon-mobile:active{background:var(--bg-hover);opacity:1;color:var(--text-primary)}.tree-node-item-mobile.active .btn-icon-mobile{color:#ffffffb3}.tree-node-item-mobile.active .btn-icon-mobile:hover{color:#fff;background:#ffffff1a}.remove-btn-mobile{color:var(--error);font-size:28px;font-weight:700;line-height:1}.tree-children-mobile{margin-left:0}.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}.tag-selector-modal-mobile{max-height:70vh;display:flex;flex-direction:column}.modal-header-mobile{margin-bottom:12px;padding-bottom:10px;border-bottom:2px solid var(--border)}.modal-header-mobile h2{margin:0 0 6px;font-size:20px;color:var(--text-primary);display:flex;align-items:center}.modal-subtitle-mobile{margin:0;font-size:13px;color:var(--text-secondary)}.modal-subtitle-mobile strong{color:var(--accent);font-weight:600}.tag-search-input-mobile{width:100%;padding:12px;margin-bottom:12px;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-mobile:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3498db1a}.tag-results-container-mobile{flex:1;overflow-y:auto;max-height:40vh;border:1px solid var(--border);border-radius:8px;padding:8px;background:var(--bg-secondary);margin-bottom:12px}.tag-result-item-mobile{display:flex;align-items:center;gap:12px;width:100%;padding:12px;margin-bottom:4px;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:15px;text-align:left;cursor:pointer;transition:all .2s}.tag-result-item-mobile:hover,.tag-result-item-mobile:active{background:var(--bg-hover);border-color:var(--accent);transform:translateY(-1px)}.tag-result-item-mobile.tagged{background:#3498db1a;border-color:var(--accent)}.tag-icon-mobile{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.tag-name-mobile{flex:1;font-weight:500}.tag-badges-mobile{display:flex;gap:6px;align-items:center;flex-shrink:0}.badge-global-mobile,.badge-tagged-mobile{display:flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;background:var(--bg-tertiary);color:var(--text-secondary)}.badge-tagged-mobile{color:var(--success);background:#2ecc7126}.no-results-mobile{text-align:center;padding:32px 16px;color:var(--text-secondary)}.no-results-mobile p{margin:0 0 8px}.hint-mobile{font-size:13px;opacity:.7}.drag-handle-mobile{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary, #666);cursor:grab;opacity:.5;transition:opacity .2s;touch-action:none}.tree-node-item-mobile:hover .drag-handle-mobile,.tree-node-item-mobile.active .drag-handle-mobile{opacity:1}.tree-node-item-mobile.dragging{opacity:.5;background:var(--bg-hover);border:2px dashed var(--accent);transform:scale(1.02)}.tree-node-item-mobile.drag-over-inside{background:var(--accent);border-color:var(--accent);opacity:.7}.drop-indicator-mobile{position:absolute;left:12px;right:12px;height:3px;background:var(--accent, #00b4d8);border-radius:2px;pointer-events:none;z-index:10}.drop-indicator-mobile:before{content:"";position:absolute;left:-6px;top:-3px;width:9px;height:9px;background:var(--accent, #00b4d8);border-radius:50%}.tree-node-wrapper-mobile{position:relative}input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);display:inline-grid;place-content:center;margin:0;cursor:pointer;transition:all .2s ease;vertical-align:middle;flex-shrink:0}input[type=checkbox]:hover{border-color:var(--accent)}input[type=checkbox]:checked{background-color:var(--accent);border-color:var(--accent)}input[type=checkbox]:checked:before{content:"✓";color:#fff;font-size:14px;font-weight:700;line-height:1}input[type=checkbox]:disabled{opacity:.6;cursor:not-allowed;background-color:var(--bg-secondary)}input[type=radio]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:20px;height:20px;border:2px solid var(--border-color);border-radius:50%;background-color:var(--bg-primary);display:grid;place-content:center;margin:0;cursor:pointer;transition:all .2s ease;vertical-align:middle;flex-shrink:0}input[type=radio]:hover{border-color:var(--accent)}input[type=radio]:checked{border-color:var(--accent);background-color:var(--bg-primary)}input[type=radio]:checked:before{content:"";width:10px;height:10px;border-radius:50%;background-color:var(--accent);transform:scale(1)}: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}[data-theme=sunset-orange][data-mode=light]{--bg-primary: #fff7ed;--bg-secondary: #ffedd5;--bg-tertiary: #fed7aa;--text-primary: #7c2d12;--text-secondary: #f97316;--text-tertiary: #fb923c;--border: #fdba74;--accent: #f97316;--accent-hover: #ea580c;--accent-transparent: rgba(249, 115, 22, .15);--shadow: rgba(124, 45, 18, .1);--card-bg: #ffffff;--navbar-bg: #ffedd5}[data-theme=sunset-orange][data-mode=dark]{--bg-primary: #120905;--bg-secondary: #1c100b;--bg-tertiary: #2e1810;--text-primary: #fff7ed;--text-secondary: #fdba74;--text-tertiary: #fb923c;--border: #431407;--accent: #f97316;--accent-hover: #fb923c;--accent-transparent: rgba(249, 115, 22, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #1c100b;--navbar-bg: #1c100b}[data-theme=midnight-purple][data-mode=light]{--bg-primary: #faf5ff;--bg-secondary: #f3e8ff;--bg-tertiary: #e9d5ff;--text-primary: #581c87;--text-secondary: #7e22ce;--text-tertiary: #a855f7;--border: #d8b4fe;--accent: #9333ea;--accent-hover: #7e22ce;--accent-transparent: rgba(147, 51, 234, .15);--shadow: rgba(88, 28, 135, .1);--card-bg: #ffffff;--navbar-bg: #f3e8ff}[data-theme=midnight-purple][data-mode=dark]{--bg-primary: #0f0a14;--bg-secondary: #191021;--bg-tertiary: #281836;--text-primary: #faf5ff;--text-secondary: #e9d5ff;--text-tertiary: #d8b4fe;--border: #3b0764;--accent: #a855f7;--accent-hover: #c084fc;--accent-transparent: rgba(168, 85, 247, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #191021;--navbar-bg: #191021}[data-theme=forest-green][data-mode=light]{--bg-primary: #f0fdf4;--bg-secondary: #dcfce7;--bg-tertiary: #bbf7d0;--text-primary: #14532d;--text-secondary: #166534;--text-tertiary: #15803d;--border: #86efac;--accent: #22c55e;--accent-hover: #16a34a;--accent-transparent: rgba(34, 197, 94, .15);--shadow: rgba(20, 83, 45, .1);--card-bg: #ffffff;--navbar-bg: #dcfce7}[data-theme=forest-green][data-mode=dark]{--bg-primary: #051207;--bg-secondary: #0a1f10;--bg-tertiary: #112d18;--text-primary: #f0fdf4;--text-secondary: #bbf7d0;--text-tertiary: #86efac;--border: #14532d;--accent: #22c55e;--accent-hover: #4ade80;--accent-transparent: rgba(34, 197, 94, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #0a1f10;--navbar-bg: #0a1f10}[data-theme=royal-gold][data-mode=light]{--bg-primary: #fefce8;--bg-secondary: #fef9c3;--bg-tertiary: #fde047;--text-primary: #713f12;--text-secondary: #854d0e;--text-tertiary: #a16207;--border: #fde047;--accent: #ca8a04;--accent-hover: #a16207;--accent-transparent: rgba(202, 138, 4, .15);--shadow: rgba(113, 63, 18, .1);--card-bg: #ffffff;--navbar-bg: #fef9c3}[data-theme=royal-gold][data-mode=dark]{--bg-primary: #141103;--bg-secondary: #1f1a05;--bg-tertiary: #30260a;--text-primary: #fefce8;--text-secondary: #fef08a;--text-tertiary: #fde047;--border: #422006;--accent: #eab308;--accent-hover: #facc15;--accent-transparent: rgba(234, 179, 8, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #1f1a05;--navbar-bg: #1f1a05}[data-theme=coffee-bean][data-mode=light]{--bg-primary: #fffbeb;--bg-secondary: #fef3c7;--bg-tertiary: #fde68a;--text-primary: #451a03;--text-secondary: #78350f;--text-tertiary: #92400e;--border: #fcd34d;--accent: #d97706;--accent-hover: #b45309;--accent-transparent: rgba(217, 119, 6, .15);--shadow: rgba(69, 26, 3, .1);--card-bg: #ffffff;--navbar-bg: #fef3c7}[data-theme=coffee-bean][data-mode=dark]{--bg-primary: #120c06;--bg-secondary: #1f150a;--bg-tertiary: #33210f;--text-primary: #fffbeb;--text-secondary: #fde68a;--text-tertiary: #fcd34d;--border: #451a03;--accent: #d97706;--accent-hover: #fbbf24;--accent-transparent: rgba(217, 119, 6, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #1f150a;--navbar-bg: #1f150a}[data-theme=sky-blue][data-mode=light]{--bg-primary: #f0f9ff;--bg-secondary: #e0f2fe;--bg-tertiary: #bae6fd;--text-primary: #0c4a6e;--text-secondary: #0369a1;--text-tertiary: #0284c7;--border: #7dd3fc;--accent: #0284c7;--accent-hover: #0369a1;--accent-transparent: rgba(2, 132, 199, .15);--shadow: rgba(12, 74, 110, .1);--card-bg: #ffffff;--navbar-bg: #e0f2fe}[data-theme=sky-blue][data-mode=dark]{--bg-primary: #051016;--bg-secondary: #0a1c29;--bg-tertiary: #0f2c40;--text-primary: #f0f9ff;--text-secondary: #bae6fd;--text-tertiary: #7dd3fc;--border: #0c4a6e;--accent: #38bdf8;--accent-hover: #7dd3fc;--accent-transparent: rgba(56, 189, 248, .2);--shadow: rgba(0, 0, 0, .3);--card-bg: #0a1c29;--navbar-bg: #0a1c29}
