:root{--bg-light: #f4f4f4;--card-bg-light: #fff;--text-light: #333;--text-secondary-light: #555;--border-light: #ddd;--border-input-light: #ccc;--header-bg-light: #f9f9f9;--scroll-track-light: #eee;--scroll-thumb-light: #ccc;--placeholder-bg-light: #e9ecef;--placeholder-icon-light: #adb5bd;--ghost-bg-light: #c8ebfb;--bg-dark: #1a202c;--card-bg-dark: #2d3748;--text-dark: #e2e8f0;--text-secondary-dark: #a0aec0;--border-dark: #4a5568;--border-input-dark: #4a5568;--header-bg-dark: #1f2738;--scroll-track-dark: #2d3748;--scroll-thumb-dark: #4a5568;--placeholder-bg-dark: #4a5568;--placeholder-icon-dark: #718096;--ghost-bg-dark: #3c5b7e;--btn-primary-bg: #007bff;--btn-primary-hover: #0056b3;--btn-secondary-bg: rgb(31, 39, 56);--btn-secondary-hover: rgb(45, 55, 72);--btn-danger-bg: #dc3545;--btn-danger-hover: #c82333;--btn-text: white}body{font-family:sans-serif;line-height:1.6;margin:0;padding:20px;background-color:var(--bg-light);transition:background-color .3s ease}body.dark-theme{background-color:var(--bg-dark)}.app-container{max-width:1200px;margin:20px auto;padding:20px;background-color:var(--card-bg-light);border-radius:8px;box-shadow:0 2px 10px #0000001a;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.dark-theme .app-container{background-color:var(--card-bg-dark);color:var(--text-dark);box-shadow:0 2px 10px #0000004d}.header-controls{display:flex;align-items:center;margin-bottom:20px;position:relative;gap:15px;min-height:40px}.import-export-buttons{display:flex;gap:10px;margin-right:auto}.theme-toggle-btn{white-space:nowrap;flex-shrink:0;margin-left:auto}h1{color:var(--text-light);position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 300px)}.dark-theme h1{color:var(--text-dark)}.btn{display:inline-block;padding:8px 15px;border:none;border-radius:4px;cursor:pointer;font-size:1rem;text-align:center;transition:background-color .2s ease;margin:5px}.btn-primary{background-color:var(--btn-primary-bg);color:var(--btn-text)}.btn-primary:hover{background-color:var(--btn-primary-hover)}.btn-secondary{background-color:var(--btn-secondary-bg);color:var(--btn-text)}.btn-secondary:hover{background-color:var(--btn-secondary-hover)}.btn-danger{background-color:var(--btn-danger-bg);color:var(--btn-text)}.btn-danger:hover{background-color:var(--btn-danger-hover)}.btn-sm{padding:5px 10px;font-size:.875rem}.btn-xs{padding:2px 5px;font-size:.75rem}.add-category-btn{display:block;width:fit-content;margin:0 auto 25px}.hidden-input{display:none}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.category-card{background-color:var(--card-bg-light);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 2px 5px #0000001a;display:flex;flex-direction:column;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.dark-theme .category-card{background-color:var(--card-bg-dark);border-color:var(--border-dark);color:var(--text-dark);box-shadow:0 2px 5px #0003}.category-card-header{display:flex;align-items:center;gap:10px;padding:10px 15px;border-bottom:1px solid var(--border-light);background-color:var(--header-bg-light);transition:background-color .3s ease,border-color .3s ease}.dark-theme .category-card-header{background-color:var(--header-bg-dark);border-color:var(--border-dark)}.category-handle{cursor:grab;font-size:1.4rem;color:#aaa;padding:5px}.dark-theme .category-handle{color:var(--text-secondary-dark)}.category-handle:active{cursor:grabbing}.category-card-illustration{position:relative}.category-card-illustration label{display:block;width:60px;height:60px;border-radius:4px;overflow:hidden;cursor:pointer;background-color:var(--placeholder-bg-light);display:flex;align-items:center;justify-content:center;position:relative;transition:background-color .3s ease}.dark-theme .category-card-illustration label{background-color:var(--placeholder-bg-dark)}.illustration-preview{width:100%;height:100%;object-fit:cover}.illustration-placeholder{font-size:2rem;color:var(--placeholder-icon-light);transition:color .3s ease}.dark-theme .illustration-placeholder{color:var(--placeholder-icon-dark)}.edit-illustration-text{position:absolute;bottom:0;left:0;right:0;background-color:#00000080;color:#fff;font-size:.7rem;text-align:center;padding:2px 0;opacity:0;transition:opacity .2s ease}.category-card-illustration label:hover .edit-illustration-text{opacity:1}.category-name-input{flex-grow:1;min-width:0;padding:8px;border:1px solid var(--border-input-light);border-radius:4px;font-size:1.1rem;font-weight:700;margin:0 10px;color:var(--text-light);background-color:var(--card-bg-light);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.dark-theme .category-name-input{border-color:var(--border-input-dark);color:var(--text-dark);background-color:var(--card-bg-dark)}.dark-theme .category-name-input::placeholder{color:var(--text-secondary-dark);opacity:.7}.remove-btn{margin-left:auto}.category-card-body{padding:15px;flex-grow:1;display:flex;flex-direction:column}.images-title{margin-top:0;margin-bottom:10px;color:var(--text-secondary-light);font-size:.9rem;font-weight:400;text-transform:uppercase;letter-spacing:.5px;transition:color .3s ease}.dark-theme .images-title{color:var(--text-secondary-dark)}.image-carousel{display:flex;overflow-x:auto;overflow-y:hidden;padding-bottom:15px;margin-bottom:10px;gap:10px;min-height:100px;flex-grow:1;scrollbar-width:thin;scrollbar-color:var(--scroll-track-light) var(--scroll-track-light)}.image-carousel::-webkit-scrollbar{height:8px}.image-carousel::-webkit-scrollbar-track{background:var(--scroll-track-light);border-radius:4px;transition:background-color .3s ease}.image-carousel::-webkit-scrollbar-thumb{background-color:var(--scroll-thumb-light);border-radius:4px;border:2px solid var(--scroll-track-light);transition:background-color .3s ease,border-color .3s ease}.image-carousel::-webkit-scrollbar-thumb:hover{background-color:#aaa}.dark-theme .image-carousel{scrollbar-color:var(--scroll-thumb-dark) var(--scroll-track-dark)}.dark-theme .image-carousel::-webkit-scrollbar-track{background:var(--scroll-track-dark)}.dark-theme .image-carousel::-webkit-scrollbar-thumb{background-color:var(--scroll-thumb-dark);border-color:var(--scroll-track-dark)}.dark-theme .image-carousel::-webkit-scrollbar-thumb:hover{background-color:var(--text-secondary-dark)}.image-item{position:relative;border:1px solid var(--border-light);padding:0;border-radius:4px;background-color:var(--placeholder-bg-light);flex-shrink:0;width:100px;height:100px;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.dark-theme .image-item{border-color:var(--border-dark);background-color:var(--placeholder-bg-dark)}.image-item:active{cursor:grabbing}.image-preview{display:block;width:100%;height:100%;object-fit:cover;border-radius:3px;transition:transform .2s ease-in-out}.image-item:hover .image-preview{transform:scale(1.05)}.remove-img-btn{position:absolute;top:2px;right:2px;border-radius:50%;line-height:1;background-color:#dc3545cc;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10;border:none;color:#fff;padding:2px 4px;font-size:.8rem}.remove-img-btn:hover{background-color:#c82734}.add-image-btn{align-self:flex-start;margin-top:auto}.ghost{opacity:.5;background:var(--ghost-bg-light);border:1px dashed var(--btn-primary-bg);transition:background-color .3s ease}.dark-theme .ghost{background:var(--ghost-bg-dark);border-color:#4299e1}.sortable-chosen{box-shadow:0 4px 10px #0003;transform:scale(1.02)}.no-categories-msg{text-align:center;color:#777;margin-top:30px;grid-column:1 / -1;transition:color .3s ease}.dark-theme .no-categories-msg{color:var(--text-secondary-dark)}.lightbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1200;cursor:pointer}.lightbox-container{position:relative;max-width:90vw;max-height:90vh;background-color:var(--card-bg-light);padding:0;border-radius:5px;box-shadow:0 5px 15px #0000004d;cursor:default;display:flex;flex-direction:column;overflow:hidden;transition:background-color .3s ease}.dark-theme .lightbox-container{background-color:var(--card-bg-dark)}.lightbox-image-area{position:relative;padding:20px;display:flex;justify-content:center;align-items:center;flex-shrink:1;min-height:100px;overflow:hidden}.lightbox-image{display:block;max-width:100%;max-height:75vh;object-fit:contain}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background-color:#0000004d;color:#fff;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1002;transition:background-color .2s ease;padding:0}.lightbox-nav:hover{background-color:#0009}.lightbox-prev{left:15px}.lightbox-next{right:15px}.dark-theme .lightbox-nav{background-color:#ffffff26;color:var(--text-dark)}.dark-theme .lightbox-nav:hover{background-color:#ffffff4d}.lightbox-fade-enter-active,.lightbox-fade-leave-active{transition:opacity .3s ease}.lightbox-fade-enter-from,.lightbox-fade-leave-to{opacity:0}.met-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:900}.met-modal-content{background-color:var(--card-bg-light);color:var(--text-light);padding:25px;border-radius:8px;box-shadow:0 5px 20px #0003;width:80%;max-width:700px;height:85%;max-height:600px;position:relative;display:flex;flex-direction:column;overflow:hidden;transition:background-color .3s ease,color .3s ease}.dark-theme .met-modal-content{background-color:var(--card-bg-dark);color:var(--text-dark);box-shadow:0 5px 20px #0006}.met-modal-close{position:absolute;top:10px;right:10px;background:none;border:none;font-size:1.8rem;line-height:1;cursor:pointer;color:#aaa;padding:5px}.dark-theme .met-modal-close{color:var(--text-secondary-dark)}.met-modal-close:hover{color:#777}.dark-theme .met-modal-close:hover{color:var(--text-dark)}.met-modal-content h3{margin-top:0;margin-bottom:20px;text-align:center;color:inherit}.met-search-form{display:flex;gap:10px;margin-bottom:20px}.met-search-form input[type=text]{flex-grow:1;padding:10px;border:1px solid var(--border-input-light);border-radius:4px;font-size:1rem;background-color:var(--card-bg-light);color:var(--text-light);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.dark-theme .met-search-form input[type=text]{border-color:var(--border-input-dark);background-color:var(--card-bg-dark);color:var(--text-dark)}.dark-theme .met-search-form input[type=text]::placeholder{color:var(--text-secondary-dark);opacity:.7}.met-error-message{color:var(--btn-danger-bg);background-color:#dc35451a;border:1px solid rgba(220,53,69,.3);padding:10px;border-radius:4px;margin-bottom:15px;text-align:center}.dark-theme .met-error-message{background-color:#dc354533;border-color:#dc354580}.met-search-results{flex-grow:1;overflow-y:auto;padding:5px;margin-bottom:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px;border:1px solid var(--border-light);border-radius:4px;background-color:#00000005}.dark-theme .met-search-results{border-color:var(--border-dark);background-color:#ffffff08}.loading-spinner{grid-column:1 / -1;text-align:center;padding:30px;font-style:italic;color:var(--text-secondary-light)}.dark-theme .loading-spinner{color:var(--text-secondary-dark)}.met-search-results p{grid-column:1 / -1;text-align:center;padding:30px;margin:0;color:var(--text-secondary-light)}.dark-theme .met-search-results p{color:var(--text-secondary-dark)}.met-result-item{border:2px solid transparent;border-radius:4px;padding:5px;cursor:pointer;transition:border-color .2s ease,background-color .2s ease;text-align:center;background-color:var(--card-bg-light)}.dark-theme .met-result-item{background-color:var(--card-bg-dark)}.met-result-item img{display:block;width:100%;height:100px;object-fit:contain;margin-bottom:5px;background-color:#eee}.dark-theme .met-result-item img{background-color:#333}.met-result-item p{font-size:.8rem;margin:0;padding:0;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.met-result-item.selected{border-color:var(--btn-primary-bg);background-color:#007bff1a}.dark-theme .met-result-item.selected{border-color:#4299e1;background-color:#4299e133}.add-selected-btn{margin-top:auto;display:block;width:100%}.load-more-btn{display:block;width:100%;margin-top:10px;margin-bottom:10px}.modal-fade-enter-active,.modal-fade-leave-active{transition:opacity .3s ease}.modal-fade-enter-from,.modal-fade-leave-to{opacity:0}.add-image-buttons{display:flex;gap:10px;margin-top:auto}.add-image-buttons .btn{flex:1;text-align:center;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 15px}.add-image-buttons .btn svg{width:1em;height:1em}.toast-notification{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:12px 20px;border-radius:6px;color:#fff;font-size:.95rem;z-index:1100;box-shadow:0 3px 10px #0003;transition:opacity .3s ease,transform .3s ease}.toast-success{background-color:#28a745}.dark-theme .toast-success{background-color:#38a169}.toast-error{background-color:var(--btn-danger-bg)}.dark-theme .toast-error{background-color:#c53030}.toast-fade-enter-active,.toast-fade-leave-active{transition:opacity .5s ease,transform .5s ease}.toast-fade-enter-from,.toast-fade-leave-to{opacity:0;transform:translate(-50%,20px)}.lightbox-notes-area{padding:15px 20px;border-top:1px solid var(--border-light);background-color:var(--header-bg-light);flex-shrink:0;transition:border-color .3s ease,background-color .3s ease}.dark-theme .lightbox-notes-area{border-top-color:var(--border-dark);background-color:var(--header-bg-dark)}.lightbox-notes-textarea{display:block;width:100%;height:60px;padding:8px;margin:0;border:1px solid var(--border-input-light);border-radius:4px;font-family:inherit;font-size:.9rem;resize:vertical;background-color:var(--card-bg-light);color:var(--text-light);transition:background-color .3s ease,color .3s ease,border-color .3s ease;box-sizing:border-box}.dark-theme .lightbox-notes-textarea{border-color:var(--border-input-dark);background-color:var(--card-bg-dark);color:var(--text-dark)}.dark-theme .lightbox-notes-textarea::placeholder{color:var(--text-secondary-dark);opacity:.7}.lightbox-close{position:absolute;top:10px;right:10px;background-color:#1a202c;color:#fff;border:none;border-radius:50%;width:30px;height:30px;font-size:1.5rem;line-height:30px;text-align:center;cursor:pointer;padding:0;z-index:1003;box-shadow:0 2px 5px #0000004d;transition:background-color .2s ease}.lightbox-close:hover{background-color:#2d3748}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:15px;margin-top:30px;padding:10px}.pagination-controls span{color:var(--text-secondary-light);font-size:.9rem}.dark-theme .pagination-controls span{color:var(--text-secondary-dark)}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed}.image-carousel-preview{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px;min-height:50px}.image-item-preview{position:relative;border:1px solid var(--border-light);border-radius:4px;background-color:var(--placeholder-bg-light);width:70px;height:70px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}.dark-theme .image-item-preview{border-color:var(--border-dark);background-color:var(--placeholder-bg-dark)}.image-item-preview .image-preview{display:block;width:100%;height:100%;object-fit:cover;border-radius:3px;transition:transform .2s ease-in-out}.image-item-preview:hover .image-preview{transform:scale(1.05)}.image-item-preview .remove-img-btn{top:2px;right:2px;padding:1px 3px;font-size:.7rem}.image-item-more{border:1px dashed var(--border-light);width:70px;height:70px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-secondary-light);background-color:transparent}.dark-theme .image-item-more{border-color:var(--border-dark);color:var(--text-secondary-dark)}.view-all-images-btn{display:block;width:fit-content;margin-left:auto;margin-right:auto;margin-bottom:15px;text-align:center}.add-image-buttons{margin-top:auto}.gallery-modal-overlay[data-v-73e67889]{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1050}.gallery-modal-content[data-v-73e67889]{background-color:var(--card-bg-light);color:var(--text-light);padding:25px;border-radius:8px;box-shadow:0 5px 20px #00000040;width:90%;max-width:900px;height:90%;max-height:700px;position:relative;display:flex;flex-direction:column;overflow:hidden;transition:background-color .3s ease,color .3s ease}.dark-theme .gallery-modal-content[data-v-73e67889]{background-color:var(--card-bg-dark);color:var(--text-dark)}.gallery-modal-close[data-v-73e67889]{position:absolute;top:10px;right:10px;background:none;border:none;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--text-secondary-light);padding:5px}.dark-theme .gallery-modal-close[data-v-73e67889]{color:var(--text-secondary-dark)}.gallery-modal-close[data-v-73e67889]:hover{color:var(--text-light)}.dark-theme .gallery-modal-close[data-v-73e67889]:hover{color:var(--text-dark)}.gallery-modal-content h3[data-v-73e67889]{margin-top:0;margin-bottom:20px;text-align:center;color:inherit;flex-shrink:0}.gallery-empty-message[data-v-73e67889]{text-align:center;color:var(--text-secondary-light);margin-top:30px;flex-grow:1;display:flex;align-items:center;justify-content:center}.dark-theme .gallery-empty-message[data-v-73e67889]{color:var(--text-secondary-dark)}.gallery-grid[data-v-73e67889]{flex-grow:1;overflow-y:auto;padding:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px;border:1px solid var(--border-light);border-radius:4px;background-color:#00000005;margin-bottom:15px}.dark-theme .gallery-grid[data-v-73e67889]{border-color:var(--border-dark);background-color:#ffffff08}.gallery-item[data-v-73e67889]{border:1px solid var(--border-light);border-radius:4px;overflow:hidden;cursor:pointer;aspect-ratio:1 / 1;background-color:var(--placeholder-bg-light);transition:border-color .2s ease,transform .2s ease;position:relative}.dark-theme .gallery-item[data-v-73e67889]{border-color:var(--border-dark);background-color:var(--placeholder-bg-dark)}.gallery-item[data-v-73e67889]:hover{border-color:var(--btn-primary-bg);transform:scale(1.03)}.gallery-item img[data-v-73e67889]{display:block;width:100%;height:100%;object-fit:cover}.gallery-delete-btn[data-v-73e67889]{position:absolute;top:3px;right:3px;z-index:2;border-radius:50%;line-height:1;padding:2px 4px;font-size:.9rem;background-color:#dc3545b3;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);color:#fff;border:none;opacity:0;transition:opacity .2s ease-in-out}.gallery-item:hover .gallery-delete-btn[data-v-73e67889]{opacity:1}.gallery-delete-btn[data-v-73e67889]:hover{background-color:#c82734}.gallery-pagination-controls[data-v-73e67889]{display:flex;justify-content:center;align-items:center;gap:15px;padding-top:15px;border-top:1px solid var(--border-light);flex-shrink:0}.dark-theme .gallery-pagination-controls[data-v-73e67889]{border-top-color:var(--border-dark)}.gallery-pagination-controls span[data-v-73e67889]{color:var(--text-secondary-light);font-size:.9rem}.dark-theme .gallery-pagination-controls span[data-v-73e67889]{color:var(--text-secondary-dark)}.modal-fade-enter-active[data-v-73e67889],.modal-fade-leave-active[data-v-73e67889]{transition:opacity .3s ease}.modal-fade-enter-from[data-v-73e67889],.modal-fade-leave-to[data-v-73e67889]{opacity:0}
