@import"https://fonts.googleapis.com/css2?family=Cutive+Mono&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--color-primary: #3a8cae;--color-secondary: #74b49b;--color-background: #f9fafb;--color-surface: #ffffff;--color-text: #263238;--color-border: #d9e2e8;--color-muted: #9ca9b3;--color-accent-violet: #9b5de5;--color-accent-fuchsia: #ff2e7e;--color-accent-yellow: #ffcc00;font-family:Cutive Mono,monospace;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--color-muted);background-color:var(--color-text);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh}#root{width:100vw;min-height:100vh}h1{font-size:1.5em;line-height:1.1}button{border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--color-text);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--color-primary)}button:focus,button:focus-visible{outline:2px solid var(--color-primary)}.landing-page{min-height:100vh;background:var(--color-text);color:var(--color-muted);display:flex;align-items:flex-start;justify-content:center;padding:2rem}.landing-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;max-width:1400px;width:100%;align-items:flex-start;padding:2rem 0;margin-bottom:2rem}.landing-text{padding:2rem}.landing-title{font-size:3rem;font-weight:800;margin:0 0 .5rem;display:flex;align-items:center;gap:1rem;color:var(--color-primary)}.landing-subtitle{font-size:1.25rem;margin:0 0 2rem;color:var(--color-accent-fuchsia);font-weight:300}.landing-description{color:var(--color-muted);line-height:1.7}.landing-description h2{font-size:1.75rem;margin:1.5rem 0 1rem;color:var(--color-secondary);font-weight:600}.landing-description h3{font-size:1.25rem;margin:1.5rem 0 1rem;color:var(--color-primary);font-weight:600}.landing-description p{margin:.75rem 0;font-size:1rem;color:var(--color-muted)}.landing-description ul{list-style:decimal-leading-zero;padding:0;margin:1rem 0}.landing-description ul li{margin:.75rem 0;padding-left:0;font-size:1rem;color:var(--color-muted)}.landing-description ul li strong{color:var(--color-primary)}.landing-description ol{margin:1rem 0;padding-left:1.5rem;color:var(--color-muted)}.landing-description ol li{margin:.5rem 0;font-size:1rem}.landing-footer-text{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border);font-size:.95rem;color:var(--color-muted);font-style:italic}.landing-login{display:flex;justify-content:center;align-items:center;padding:2rem}@media (max-width: 1024px){.landing-page{align-items:flex-start;padding:1.5rem 1rem;min-height:100vh}.landing-grid{grid-template-columns:1fr;gap:2rem;padding:0;margin-bottom:2rem}.landing-text{text-align:left;padding:0}.landing-title{justify-content:flex-start;font-size:2.5rem}.landing-login{padding:0;width:100%;margin-bottom:2rem}}@media (max-width: 768px){.landing-page{padding:1rem}.landing-grid{gap:1.5rem}.landing-text{padding:0}.landing-title{font-size:1.75rem}.landing-subtitle{font-size:1rem}.landing-description h2{font-size:1.4rem}.landing-description h3{font-size:1.1rem}.landing-description p,.landing-description ul li,.landing-description ol li{font-size:.9rem}.landing-login{padding:0;margin-bottom:2rem}}.descriptor-card{display:flex;gap:12px;padding:10px;background:#0003;border:1px solid rgba(255,255,255,.1);border-left:3px solid var(--color-primary);cursor:pointer;transition:all .2s ease}.descriptor-card:hover{background:#0000004d;border-color:#fff3}.descriptor-card.selected{background:#3a8cae1a;border-left-width:4px;box-shadow:0 0 0 1px #3a8cae4d}.descriptor-thumbnail{flex-shrink:0;width:60px;height:60px;overflow:hidden;background:#0006;display:flex;align-items:center;justify-content:center}.descriptor-thumbnail img{width:100%;height:100%;object-fit:cover}.descriptor-loading{font-size:20px;opacity:.5}.descriptor-metadata{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}.descriptor-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.descriptor-class{font-size:14px;font-weight:600;color:var(--color-muted);text-transform:capitalize;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.descriptor-confidence{font-size:12px;font-weight:600;color:var(--color-secondary);background:#74b49b1a;padding:2px 6px}.descriptor-data{display:flex;flex-direction:column;gap:3px}.data-item{font-size:11px;font-family:Monaco,Courier New,monospace;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-selector{position:relative;display:inline-block;z-index:1000;width:100%}.file-selector-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;box-shadow:0 4px 6px #0000001a;width:100%}.file-selector-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.file-selector-icon{font-size:18px}.file-selector-label{flex:1;text-align:left;white-space:nowrap}.file-selector-arrow{font-size:10px;transition:transform .3s ease}.file-selector-arrow.open{transform:rotate(180deg)}.file-selector-dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:200px;background:var(--color-surface);border-radius:8px;box-shadow:0 8px 24px #00000026;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.file-selector-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;background:var(--color-surface);border:none;text-align:left;cursor:pointer;font-size:14px;color:var(--color-text);transition:background .2s ease}.file-selector-option:hover{background:var(--color-background)}.file-selector-option.active{background:#3a8cae1a;color:var(--color-primary);font-weight:500}.check-mark{color:var(--color-primary);font-size:16px}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden}.control-panel{width:420px;min-width:420px;background:var(--color-text);padding:20px;height:100vh;overflow-y:auto;z-index:1000;order:1;font-family:Cutive Mono,monospace}.control-panel h1{font-size:1.5rem;margin-bottom:20px;color:var(--color-primary);text-align:center;font-family:Cutive Mono,monospace;font-weight:400}.control-panel h2{font-size:1rem;margin:15px 0 10px;color:var(--color-secondary);border-bottom:1px solid var(--color-border);padding-bottom:5px;font-family:Cutive Mono,monospace;font-weight:400}.info-section h2{font-size:.85rem;margin:0 0 8px;color:var(--color-secondary);border-bottom:1px solid var(--color-secondary);padding-bottom:4px;font-weight:400}.info-section .descriptor-details{font-size:.8rem;line-height:1.5}.info-section .descriptor-details p{margin:3px 0}.section{margin-bottom:25px}.descriptor-count{margin:10px 0;font-size:.9rem;color:var(--color-secondary);text-align:center}.descriptors-grid{display:flex;flex-direction:column;gap:15px;max-height:400px;overflow-y:auto;padding-right:5px}.control-item{margin-bottom:15px}.control-item label{display:block;margin-bottom:5px;font-size:.9rem;color:var(--color-muted)}.control-item .value{color:var(--color-primary);font-weight:400}.control-item input[type=range]{width:100%;height:6px;background:var(--color-border);border-radius:3px;outline:none;-webkit-appearance:none;appearance:none}.control-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer}.control-item input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:none}.info-section{background:#263238f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 16px;border:1px solid var(--color-primary);box-shadow:0 4px 20px #0000004d}.floating-info-card{position:absolute;bottom:20px;right:20px;z-index:100;background:#263238f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 16px;border-radius:8px;border:1px solid var(--color-primary);box-shadow:0 4px 20px #0000004d;min-width:220px;max-width:280px;font-family:Cutive Mono,monospace}.floating-info-card h3{font-size:.75rem;margin:0 0 8px;color:var(--color-secondary);font-weight:400;border-bottom:1px solid var(--color-secondary);padding-bottom:4px}.floating-info-card .descriptor-details{font-size:.7rem;line-height:1.4}.floating-info-card .descriptor-details p{margin:3px 0;color:var(--color-muted)}.floating-info-card .descriptor-details strong{color:var(--color-primary);font-weight:400}.floating-controls{position:absolute;bottom:20px;right:20px;z-index:100;background:#263238f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:12px 16px;border-radius:8px;border:1px solid var(--color-border);box-shadow:0 4px 20px #0000004d;min-width:220px;max-width:280px;font-family:Cutive Mono,monospace}.floating-controls .control-item{margin-bottom:0}.floating-controls .control-item label{display:block;margin-bottom:8px;font-size:.85rem;color:var(--color-muted)}.floating-controls .control-item .value{color:var(--color-primary);font-weight:400}.floating-controls .control-item input[type=range]{width:100%;height:6px;background:var(--color-border);border-radius:3px;outline:none;-webkit-appearance:none;appearance:none}.floating-controls .control-item input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer}.floating-controls .control-item input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--color-primary);border-radius:50%;cursor:pointer;border:none}.descriptor-details{font-size:.9rem;line-height:1.6}.descriptor-details p{margin:5px 0}.descriptor-details strong{color:var(--color-primary)}.viewer-container{flex:1;position:relative;background:var(--color-text);order:2;display:flex;flex-direction:column}.view-mode-toggle{position:absolute;top:20px;right:20px;z-index:10;display:flex;gap:8px;background:#00000080;padding:4px;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.view-mode-toggle button{padding:8px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff9;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.view-mode-toggle button:hover{background:#ffffff1a;color:#ffffffe6}.view-mode-toggle button.active{background:#3a8cae33;border-color:#3a8cae80;color:var(--color-primary)}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;width:100vw;background:var(--color-text);color:var(--color-muted)}.spinner{width:50px;height:50px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:var(--color-muted);font-size:1.1rem}.control-panel::-webkit-scrollbar,.descriptors-grid::-webkit-scrollbar{width:8px}.control-panel::-webkit-scrollbar-track,.descriptors-grid::-webkit-scrollbar-track{background:var(--color-text)}.control-panel::-webkit-scrollbar-thumb,.descriptors-grid::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.control-panel::-webkit-scrollbar-thumb:hover,.descriptors-grid::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@media (max-width: 768px){.app-container{flex-direction:column}.control-panel{width:100%;height:50vh;order:1}.viewer-container{height:50vh;order:2}}
