.header{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1.5rem;padding:.875rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.header-brand{display:flex;align-items:baseline;gap:.875rem;flex-shrink:0}.header-logo{font-family:var(--font-mono);font-size:1rem;font-weight:500;color:var(--color-accent-green);letter-spacing:.04em}.header-count{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-dim)}.header-search{flex:1;max-width:600px}.search-wrap{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.75rem;width:16px;height:16px;color:var(--color-text-dim);pointer-events:none}.search-input{width:100%;padding:.5rem 2.25rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-family:var(--font-mono);font-size:.875rem;transition:border-color .15s}.search-input:focus{outline:none;border-color:var(--color-accent-green)}.search-input::placeholder{color:var(--color-text-dim)}.search-clear{position:absolute;right:.625rem;background:none;border:none;color:var(--color-text-dim);font-size:1.125rem;cursor:pointer;line-height:1;padding:.125rem .25rem}.search-clear:hover{color:var(--color-text)}.header-actions{flex-shrink:0;margin-left:auto}.btn-refresh{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;font-family:var(--font-mono);cursor:pointer;transition:border-color .15s,color .15s}.btn-refresh:hover{border-color:var(--color-accent-green);color:var(--color-accent-green)}.btn-refresh svg{width:15px;height:15px}.sidebar{width:220px;flex-shrink:0;overflow-y:auto;padding:1rem 0;border-right:1px solid var(--color-border)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:0 1rem .75rem;margin-bottom:.25rem}.sidebar-title{font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim)}.sidebar-clear{background:none;border:none;font-family:var(--font-mono);font-size:.6875rem;color:var(--color-accent-green);cursor:pointer;padding:0}.sidebar-clear:hover{text-decoration:underline}.filter-group{margin-bottom:.25rem}.filter-group-label{padding:.5rem 1rem .25rem;font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim)}.filter-list{list-style:none;margin:0;padding:0}.filter-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.3125rem 1rem;background:none;border:none;color:var(--color-text);font-size:.8125rem;cursor:pointer;text-align:left;transition:background .1s}.filter-item:hover:not(:disabled){background:#ffffff0a}.filter-item.active{color:var(--color-accent-green);background:#c8f06014}.filter-item.empty{opacity:.35;cursor:default}.filter-item-count{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-dim);margin-left:.25rem}.filter-item.active .filter-item-count{color:var(--color-accent-green)}.folder-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.video-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column}.video-card:hover{border-color:#3a3a3a;box-shadow:0 4px 16px #0006}.video-card.selected{border-color:var(--color-accent-green);box-shadow:0 0 0 1px var(--color-accent-green)}.card-thumb{position:relative;aspect-ratio:16 / 9;background:#111;overflow:hidden}.card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-dim)}.card-thumb-placeholder svg{width:40px;height:40px;opacity:.3}.card-type-badge{position:absolute;bottom:6px;right:6px;width:26px;height:26px;background:#000000a6;border-radius:4px;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#ffffffbf}.card-type-badge svg{width:14px;height:14px}.card-type-badge.video{color:var(--color-accent-green)}.card-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000;transition:background .15s;opacity:0}.video-card:hover .card-play-overlay{opacity:1;background:#00000059}.card-play-ring{width:44px;height:44px;border-radius:50%;border:2px solid var(--color-accent-green);display:flex;align-items:center;justify-content:center;color:var(--color-accent-green);box-shadow:0 0 20px #c8f0604d}.card-play-ring svg{width:18px;height:18px;margin-left:2px}.card-processing-badge{position:absolute;top:6px;left:6px;background:var(--color-accent-blue);color:#0e0e0e;font-family:var(--font-mono);font-size:.6875rem;padding:2px 6px;border-radius:3px;font-weight:600}.card-body{padding:.625rem .75rem;display:flex;flex-direction:column;gap:.375rem;flex:1}.card-name{font-size:.8125rem;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.card-tags{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.tag-chip{display:inline-block;padding:2px 7px;background:var(--color-tag-bg);border:1px solid var(--color-tag-border);border-radius:3px;color:var(--color-text);font-family:var(--font-mono);font-size:.6875rem;cursor:pointer;transition:background .1s,border-color .1s}.tag-chip:hover{background:#c8f0601a;border-color:var(--color-accent-green);color:var(--color-accent-green)}.tag-more{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-dim);padding:2px 4px}.card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:.25rem}.card-date,.card-size{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-dim)}.grid-container{flex:1;overflow-y:auto;display:flex;flex-direction:column;min-width:0}.grid-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);gap:.75rem;flex-wrap:wrap}.active-filters{display:flex;flex-wrap:wrap;gap:6px;align-items:center;flex:1}.active-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#c8f0601f;border:1px solid var(--color-accent-green);border-radius:4px;color:var(--color-accent-green);font-family:var(--font-mono);font-size:.75rem}.active-chip-remove{background:none;border:none;color:var(--color-accent-green);cursor:pointer;padding:0;font-size:.875rem;line-height:1;opacity:.7}.active-chip-remove:hover{opacity:1}.grid-sort{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.sort-label{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-dim)}.sort-select{background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-family:var(--font-mono);font-size:.75rem;padding:.3125rem .5rem;cursor:pointer}.sort-select:focus{outline:none;border-color:var(--color-accent-green)}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:2px;padding:2px}.grid-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--color-text-dim);padding:4rem}.grid-empty svg{width:48px;height:48px;opacity:.3}.grid-empty p{font-size:1rem;color:var(--color-text);margin:0}.grid-empty span{font-family:var(--font-mono);font-size:.75rem}.detail-panel{width:340px;flex-shrink:0;border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;background:var(--color-surface)}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.detail-title{font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim)}.detail-close{background:none;border:none;color:var(--color-text-dim);font-size:1.25rem;cursor:pointer;line-height:1;padding:.125rem .25rem;border-radius:3px}.detail-close:hover{color:var(--color-text);background:#ffffff0f}.detail-preview{aspect-ratio:16 / 9;background:#111;flex-shrink:0;position:relative;overflow:hidden}.detail-preview-img{width:100%;height:100%;object-fit:cover;display:block}.detail-preview-video{width:100%;height:100%;object-fit:contain;display:block;background:#000}.detail-preview-loading,.detail-preview-empty{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.75rem}.detail-preview-empty svg{width:40px;height:40px;opacity:.2}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--color-accent-green);border-radius:50%;animation:spin .8s linear infinite}.keyframe-strip{display:flex;gap:2px;padding:4px;background:#0a0a0a;overflow-x:auto;flex-shrink:0}.keyframe-thumb{flex-shrink:0;width:56px;aspect-ratio:16/9;background:#111;border:1px solid transparent;border-radius:3px;overflow:hidden;cursor:pointer;padding:0;transition:border-color .1s}.keyframe-thumb.active{border-color:var(--color-accent-green)}.keyframe-thumb img{width:100%;height:100%;object-fit:cover;display:block}.detail-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:0}.detail-section{padding:1rem;border-bottom:1px solid var(--color-border)}.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.625rem;gap:.5rem}.detail-section-title{font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-dim);display:flex;align-items:center;gap:.5rem}.claude-badge{display:inline-flex;align-items:center;padding:1px 6px;background:#60c8f01a;border:1px solid rgba(96,200,240,.3);border-radius:3px;color:var(--color-accent-blue);font-size:.625rem;letter-spacing:.04em;text-transform:none;font-weight:500}.tag-actions{display:flex;gap:4px}.btn-sm{padding:2px 8px;background:#ffffff0f;border:1px solid var(--color-border);border-radius:3px;color:var(--color-text);font-family:var(--font-mono);font-size:.6875rem;cursor:pointer;transition:background .1s}.btn-sm:hover:not(:disabled){background:#ffffff1a}.btn-sm:disabled{opacity:.5;cursor:default}.btn-sm.btn-primary{background:var(--color-accent-green);color:#0e0e0e;border-color:var(--color-accent-green);font-weight:600}.detail-tags-grouped{display:flex;flex-direction:column;gap:.5rem}.tag-group{display:flex;flex-direction:column;gap:.25rem}.tag-group-label{font-family:var(--font-mono);font-size:.625rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-dim)}.tag-group-chips{display:flex;flex-wrap:wrap;gap:4px}.detail-tags{display:flex;flex-wrap:wrap;gap:5px}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--color-tag-bg);border:1px solid var(--color-tag-border);border-radius:3px;color:var(--color-text);font-family:var(--font-mono);font-size:.6875rem}.tag-chip.editable{padding-right:4px}.tag-remove{background:none;border:none;color:var(--color-text-dim);cursor:pointer;padding:0;font-size:.875rem;line-height:1}.tag-remove:hover{color:#ff6b6b}.no-tags{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-dim);font-style:italic}.tag-add{margin-top:.625rem;position:relative}.tag-input{width:100%;padding:.375rem .625rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);font-family:var(--font-mono);font-size:.8125rem;box-sizing:border-box}.tag-input:focus{outline:none;border-color:var(--color-accent-green)}.tag-suggestions{position:absolute;top:calc(100% + 2px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;list-style:none;margin:0;padding:4px 0;z-index:20;box-shadow:0 8px 24px #00000080}.tag-suggestions li button{width:100%;text-align:left;padding:.3125rem .75rem;background:none;border:none;color:var(--color-text);font-family:var(--font-mono);font-size:.8125rem;cursor:pointer}.tag-suggestions li button:hover{background:#ffffff0f;color:var(--color-accent-green)}.detail-meta{display:grid;grid-template-columns:auto 1fr;gap:.375rem 1rem;margin:0}.detail-meta dt{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text-dim)}.detail-meta dd{font-family:var(--font-mono);font-size:.6875rem;color:var(--color-text);margin:0}.status-processed{color:var(--color-accent-green)}.status-processing{color:var(--color-accent-blue)}.status-failed{color:#ff6b6b}.detail-actions{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.btn-action{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem;background:var(--color-accent-green);color:#0e0e0e;border:none;border-radius:5px;font-size:.875rem;font-weight:600;cursor:pointer;text-decoration:none;transition:opacity .15s}.btn-action:hover{opacity:.85}.btn-action svg{width:14px;height:14px}.btn-action-secondary{background:#ffffff0f;color:var(--color-text);border:1px solid var(--color-border);font-weight:400}.btn-action-secondary:hover{background:#ffffff1a;opacity:1}:root{--color-bg: #0e0e0e;--color-surface: #161616;--color-border: #2a2a2a;--color-accent-green: #c8f060;--color-accent-blue: #60c8f0;--color-text: #e8e8e0;--color-text-dim: #666666;--color-tag-bg: #1a2a1a;--color-tag-border: #3a5a2a;--font-title: "Fraunces", Georgia, serif;--font-mono: "DM Mono", "Fira Mono", "Consolas", monospace}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-title),sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}#root{display:flex;flex-direction:column}.app-body{display:flex;flex:1;overflow:hidden;height:calc(100vh - 54px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#444}.app-loading{flex:1;display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.875rem}.app-loading-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--color-accent-green);border-radius:50%;animation:spin .8s linear infinite}.app-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-dim);font-family:var(--font-mono);font-size:.875rem;padding:2rem;text-align:center}.app-error strong{color:#ff6b6b;font-size:1rem}.login-gate{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg, #0e0e0e)}.login-spinner{width:32px;height:32px;border:2px solid #333;border-top-color:var(--color-accent, #c8f060);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-box{width:100%;max-width:340px;padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}.login-logo{display:flex;flex-direction:column;align-items:center;gap:1.25rem}.login-logo-img{width:160px;opacity:.92}.login-logo-label{display:flex;align-items:baseline;gap:.5rem;font-family:Fraunces,serif;font-size:1.5rem;font-weight:700}.login-logo-label{color:var(--color-accent, #c8f060);font-family:Fraunces,serif;font-size:1.1rem;font-weight:500;letter-spacing:.02em}.login-form{display:flex;flex-direction:column;gap:.75rem;width:100%}.login-input{width:100%;box-sizing:border-box;padding:.75rem 1rem;background:#1a1a1a;border:1px solid #333;border-radius:6px;color:var(--color-text, #f0f0f0);font-size:1rem;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--color-accent, #c8f060)}.login-input--error{border-color:#e05555}.login-error{font-size:.8125rem;color:#e05555}.login-btn{padding:.75rem;background:var(--color-accent, #c8f060);color:#0e0e0e;border:none;border-radius:6px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:opacity .15s}.login-btn:disabled{opacity:.45;cursor:default}.login-btn:hover:not(:disabled){opacity:.88}
