:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#ffffffde;background-color:#000;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;overflow-x:hidden}body{display:block}a{color:#4c8bf5;text-decoration:none}a:hover{text-decoration:underline}.webgpu-canvas{position:fixed;top:50%;transform:translateY(-50%);left:0;display:block;margin:0 auto;background-color:#222}.toggle-button{padding:8px 12px;background-color:#2c2c2c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s ease}.toggle-button:hover{background-color:#3c3c3c}.toggle-button.active{background-color:#f54c4c}.webgpu-canvas.selection-mode{cursor:crosshair}.selection-box{position:absolute;border:2px solid rgba(76,139,245,.8);background-color:#4c8bf533;pointer-events:none;z-index:1000}#selection-info{font-family:monospace;font-size:14px;max-width:300px;box-shadow:0 2px 10px #0000004d;z-index:200}#selection-info h3{margin-top:0;margin-bottom:8px;font-size:16px}#selection-info p{margin:4px 0}h1{font-size:3.2em;line-height:1.1}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:Avenir,sans-serif;background-color:#1a1a1a;color:#fff;cursor:pointer;transition:border-color .25s}button:hover{background-color:#333}#selection-panel{position:fixed;top:0;right:0;width:320px;height:100vh;background-color:#161616f2;overflow-y:auto;padding:20px;box-sizing:border-box;z-index:100;box-shadow:-2px 0 10px #00000080;display:none;scrollbar-width:thin;scrollbar-color:#666 #333;transition:width .3s ease}#selection-panel.expanded{width:1200px}#panel-expand-toggle{position:fixed;top:50%;right:300px;transform:translateY(-50%);width:30px;height:60px;background-color:#1e1e1ee6;border-radius:4px 0 0 4px;box-shadow:-2px 0 5px #0000004d;cursor:pointer;z-index:101;display:none;transition:right .3s ease}#panel-expand-toggle.expanded{right:1200px}#panel-expand-toggle:before{content:"◀";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:16px}#panel-expand-toggle.expanded:before{content:"▶"}#selected-images.expanded{display:grid;grid-template-columns:repeat(3,1fr);gap:25px;width:100%}#selected-images.expanded .selected-image-wrapper{margin-bottom:0;width:100%}#selected-images.expanded .selection-count{grid-column:1 / -1;margin-bottom:15px}#selected-images.expanded .more-images-message{grid-column:1 / -1;margin-top:15px}#selection-panel::-webkit-scrollbar{width:8px}#selection-panel::-webkit-scrollbar-track{background:#333}#selection-panel::-webkit-scrollbar-thumb{background-color:#666;border-radius:6px;border:2px solid #333}#selection-panel h2{color:#fff;margin-top:0;text-align:center;padding-bottom:10px;border-bottom:1px solid #444;margin-bottom:20px}.selected-image-wrapper{margin-bottom:30px;transition:transform .2s ease;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:25px}.selected-image-wrapper:last-child{border-bottom:none}.selected-image-wrapper:hover{transform:scale(1.02)}.selected-image-wrapper img{max-width:100%;max-height:300px;display:block;margin:0 auto 15px;border:1px solid #333;background-color:#111;transition:box-shadow .3s ease}.selected-image-wrapper:hover img{box-shadow:0 5px 15px #00000080}.image-metadata{padding:15px 10px;color:#eaeaea;text-align:left;font-family:Avenir,sans-serif;background-color:#0000004d;border-radius:4px;margin-top:15px}.metadata-title-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px;position:relative}.metadata-title{font-size:17px;font-weight:700;line-height:1.3;color:#fff;margin:0;flex:1;padding-right:10px}.metadata-title-container:empty{min-height:28px;display:flex;justify-content:flex-end}.metadata-link{display:flex;align-items:center;justify-content:center;color:#4c8bf5;text-decoration:none;background-color:#4c8bf51a;border-radius:50%;width:28px;height:28px;transition:all .2s ease;border:1px solid rgba(76,139,245,.2);flex-shrink:0;margin-left:auto}.metadata-link:hover{color:#fff;background-color:#4c8bf5cc;transform:translateY(-2px) scale(1.1);box-shadow:0 3px 10px #0003}.metadata-link .link-icon{width:14px;height:14px}.metadata-link-container{display:none}.metadata-artist{font-size:15px;margin-bottom:8px;color:#c9c9c9;font-weight:500}.metadata-info{font-size:14px;margin-bottom:6px;color:#b0b0b0}.metadata-date{font-size:14px;margin-bottom:6px;color:#b0b0b0;font-style:italic}.metadata-medium{font-size:13px;margin-bottom:8px;color:#a0a0a0;line-height:1.5;max-height:100px;overflow-y:auto;padding-right:5px}.metadata-medium::-webkit-scrollbar{width:4px}.metadata-medium::-webkit-scrollbar-track{background:#33333380}.metadata-medium::-webkit-scrollbar-thumb{background-color:#66666680;border-radius:4px}.metadata-dimensions{font-size:13px;margin-bottom:8px;color:#a0a0a0}.metadata-credit{font-size:12px;margin-bottom:12px;color:#888;font-style:italic;border-top:1px solid rgba(255,255,255,.05);padding-top:8px;margin-top:8px}.selection-panel-title{color:#fff;margin-top:0}.selection-count{color:#fff;margin-bottom:20px;font-size:16px;text-align:center}.selected-image{max-width:100%;max-height:256px;display:block;margin:0 auto;border:1px solid #444;background-color:#222}.selected-image-error{color:#ff6b6b;padding:10px;text-align:center;background-color:#333;border:1px solid #444}.selected-image-index{color:#fff;margin-top:4px;font-size:12px;text-align:center}.more-images-message{color:#fff;text-align:center;font-style:italic}.close-panel-button{display:block;margin:20px auto;padding:8px 16px;background-color:#333;color:#fff;border:none;border-radius:4px;cursor:pointer}.close-panel-button:hover{background-color:#444}#panel-close-button{top:10px;right:320px;width:30px;height:30px;background-color:#1e1e1ee6;color:#fff;border-radius:4px 0 0 4px;box-shadow:-2px 0 5px #0000004d;cursor:pointer;z-index:1000;margin:0;padding:0;box-sizing:border-box;position:fixed;font-size:24px;line-height:0;text-align:center}#panel-close-button:before{content:"×";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:block;margin:0;padding:0}#panel-close-button:hover{background-color:#323232e6}.button-container{position:absolute;top:10px;left:10px;z-index:100;display:flex;flex-direction:column;gap:12px;background-color:#000000b3;border-radius:8px;padding:12px;width:300px}.search-input{padding:8px 12px;border-radius:4px;border:1px solid #444;background-color:#222;color:#fff;width:100%;box-sizing:border-box;margin-bottom:8px}.search-input::placeholder{color:#ffffff80}.search-input:focus{background-color:#333;outline:none;border-color:#4c8bf5}.search-status{position:fixed;top:70px;left:50%;transform:translate(-50%);background-color:#000000b3;color:#fff;padding:10px 20px;border-radius:4px;font-size:14px;z-index:1000;animation:fadeIn .3s ease-in-out}.search-status.error{background-color:#dc3545cc}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}.layout-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%}.layout-button{padding:8px;background-color:#2c2c2c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;width:100%;box-sizing:border-box;display:flex;justify-content:center;align-items:center;height:40px}.layout-button:hover{background-color:#3c3c3c;transform:translateY(-2px)}.layout-button.active{background-color:#4c8bf5;box-shadow:0 2px 4px #0003}.layout-icon{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.layout-svg{width:24px;height:24px;transition:transform .2s ease}.white-svg{filter:brightness(0) invert(1)}.layout-button:hover .layout-svg{transform:scale(1.1)}.layout-button.active .layout-svg{filter:drop-shadow(0 0 2px rgba(255,255,255,.5))}.umap-button .button-text,.tsne-button .button-text{color:#fff}.text-button{position:relative;overflow:hidden}.button-text{position:relative;z-index:2;font-weight:600;font-size:13px;letter-spacing:.5px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.grid-bg{position:relative}.grid-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(to right,rgba(255,255,255,.4) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.4) 1px,transparent 1px);background-size:15px 15px;opacity:.6;z-index:1}.circles-bg,.saturation-bg{position:relative}.saturation-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(to right,#80808066,#00fc);opacity:.6;z-index:1}.value-bg{position:relative}.value-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(to right,#000c,#fffc);opacity:.6;z-index:1}.circles-bg:before{content:"";position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.2) 9px,transparent 9px);background-size:20px 20px;opacity:.6;z-index:1}.rainbow-bg{position:relative}.rainbow-bg:before{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,red,orange 16.6%,#ff0,#0f0 50%,#00f 66.6%,purple,red);opacity:.4;z-index:1}.text-button.active .button-text{text-shadow:0 0 5px rgba(255,255,255,.7)}.text-button.active.grid-bg:before,.text-button.active.circles-bg:before,.text-button.active.rainbow-bg:before{opacity:.7}.canvas-controls{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:100}body.has-selection-panel #panel-close-button.expanded{right:1220px}.entropy-bg{position:relative;background-color:#222}.entropy-bg:before,.entropy-bg:after{content:none;display:none}.entropy-bg .button-text{color:#fff;font-weight:700;text-shadow:none;display:block;position:static;z-index:auto}.entropy-bg.active{background-color:#444}.entropy-bg{background-image:linear-gradient(40deg,transparent 48%,#666666 49%,#666666 51%,transparent 52%),linear-gradient(131deg,transparent 48%,#666666 49%,#666666 51%,transparent 52%),linear-gradient(17deg,transparent 48%,#666666 49%,#666666 51%,transparent 52%),linear-gradient(56deg,transparent 48%,#666666 49%,#666666 51%,transparent 52%),linear-gradient(23deg,transparent 49%,#666666 49.5%,#666666 50.5%,transparent 51%),linear-gradient(78deg,transparent 49%,#666666 49.5%,#666666 50.5%,transparent 51%),linear-gradient(111deg,transparent 49%,#666666 49.5%,#666666 50.5%,transparent 51%),linear-gradient(168deg,transparent 49%,#666666 49.5%,#666666 50.5%,transparent 51%)!important;background-size:35px 35px,35px 35px,35px 35px,35px 35px,35px 35px,35px 35px,35px 35px,35px 35px!important}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:1;transition:opacity .3s ease-out}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-modal{background-color:#333;padding:30px 40px;border-radius:8px;box-shadow:0 5px 15px #00000080;text-align:center;width:640px;box-sizing:border-box}.loading-text{font-family:monospace;font-size:1.5em;color:#e0e0e0;margin-bottom:20px;white-space:nowrap}.progress-bar-container{width:90%;height:10px;background-color:#555;border-radius:5px;overflow:hidden;margin:0 auto}.progress-bar{height:100%;background:#007bff;border-radius:5px;transition:width .1s linear}.progress-bar.indeterminate{width:100%;background:#007bff;animation:pulse-opacity 2s ease-in-out infinite;transition:none}@keyframes pulse-opacity{0%{opacity:1}50%{opacity:0}to{opacity:1}}.info-modal-container{position:fixed;bottom:70px;left:70px;z-index:1000;max-width:500px;width:calc(100% - 40px);display:none}.info-modal{background-color:#333;color:#e0e0e0;padding:0;border-radius:12px 12px 12px 0;box-shadow:0 5px 15px #00000080;position:relative;max-height:64vh;display:flex;flex-direction:column}.info-modal-header{position:relative;padding:15px 20px;border-bottom:1px solid #444;display:flex;justify-content:space-between;align-items:center;background-color:#333;border-radius:12px 12px 0 0}.info-modal-header h2{margin:0;font-size:1.5em;color:#fff}.info-modal-close-button{background-color:transparent;border:none;font-size:24px;cursor:pointer;color:#e0e0e0;transition:color .2s ease,background-color .2s ease;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;padding:0}.info-modal-close-button:hover{color:#fff;background-color:#444}.info-modal-content{padding:20px;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.info-modal-content p,.info-modal-content h2{font-family:Helvetica,sans-serif}.info-modal-content h2{margin-top:20px;margin-bottom:10px;font-size:1.2em;color:#fff;border-bottom:1px solid #555;padding-bottom:5px}.info-modal-content::-webkit-scrollbar{display:none}.info-modal-content p{line-height:1.5;margin-bottom:15px;font-size:14px}.feature-item{margin-bottom:16px}.feature-label{display:inline-block;padding:4px 10px;background-color:#4a4a4a;color:#e0e0e0;border-radius:4px;margin-bottom:5px;font-family:Helvetica,sans-serif;font-size:.9em}.feature-description{font-family:Helvetica,sans-serif;font-size:14px;padding-left:2px;line-height:1.4}.feature-description .code{font-family:monospace;background-color:#444;padding:0 3px;border-radius:3px}.bottom-left-controls{position:absolute;bottom:20px;left:20px;z-index:10;display:flex;gap:10px}.info-button{background-color:#333c;border:1px solid rgba(128,128,128,.5);color:#e0e0e0;border-radius:50%;width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease,border-color .2s ease;box-shadow:0 2px 5px #0000004d}.info-button:hover{background-color:#444444e6;border-color:#969696b3}.info-button img{width:20px;height:20px;display:block}
