*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}#root{min-height:100vh}a{color:#38bdf8;text-decoration:none}a:hover{text-decoration:underline}input,select,textarea,button{font:inherit}button{cursor:pointer}.layout{min-height:100vh;display:flex;flex-direction:column}.layout-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:#1e293b;border-bottom:1px solid #334155}.layout-header nav{display:flex;gap:1.5rem}.layout-header button{background:#475569;color:#e2e8f0;border:none;padding:.4rem .8rem;border-radius:6px}.layout-header button:hover{background:#64748b}.layout-main{flex:1;padding:1.5rem}.card{background:#1e293b;border-radius:8px;padding:1rem 1.5rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;color:#94a3b8}.form-group input,.form-group select,.form-group textarea{width:100%;max-width:28rem;padding:.5rem .75rem;background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#38bdf8}.btn-primary{background:#0ea5e9;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px}.btn-primary:hover{background:#0284c7}.btn-primary:disabled{background:#475569;cursor:not-allowed}.status-badge{display:inline-block;padding:.2rem .5rem;border-radius:4px;font-size:.875rem}.status-badge.completed{background:#065f46;color:#a7f3d0}.status-badge.processing{background:#1e3a8a;color:#93c5fd}.status-badge.submitted{background:#78350f;color:#fde68a}.status-badge.failed{background:#7f1d1d;color:#fecaca}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(148,163,184,.5);border-top-color:#38bdf8;border-radius:9999px;animation:spin .8s linear infinite;margin-left:.4rem;vertical-align:-2px}.spinner-lg{width:28px;height:28px;margin-left:0;margin-bottom:.5rem;vertical-align:0}.saving-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ab3;display:flex;align-items:center;justify-content:center;z-index:50}.saving-overlay-card{background:#020617;border-radius:.75rem;padding:1.25rem 1.75rem;box-shadow:0 20px 40px #0f172acc;display:flex;flex-direction:column;align-items:center;color:#e2e8f0;min-width:220px}.saving-overlay-card p{margin:0}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ae6;display:flex;align-items:center;justify-content:center;z-index:60}.lightbox-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.lightbox-image{max-width:100%;max-height:80vh;border-radius:.75rem;box-shadow:0 30px 60px #000c}.lightbox-caption{margin-top:.5rem;color:#e2e8f0;font-size:.9rem}.lightbox-close{position:absolute;top:-.5rem;right:-.5rem;width:32px;height:32px;border-radius:9999px;border:none;background:#0f172ad9;color:#e2e8f0;font-size:1rem}.lightbox-close:hover{background:#1e40afe6}.stats-banner{display:flex;flex-wrap:wrap;gap:1rem;margin:.75rem 0;padding:.75rem 1rem;background:#1e293b;border-radius:8px;border:1px solid #334155}.stat-item{display:flex;flex-direction:column;align-items:center;min-width:80px}.stat-value{font-size:1.5rem;font-weight:700;color:#e2e8f0}.stat-label{font-size:.75rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em}.stat-info{display:inline-flex;align-items:center;justify-content:center;width:13px;height:13px;border-radius:9999px;border:1px solid #64748b;font-size:.55rem;font-weight:700;font-style:normal;color:#94a3b8;cursor:help;vertical-align:1px;margin-left:2px}.has-tooltip{position:relative;cursor:help}.has-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#020617;color:#e2e8f0;font-size:.75rem;font-weight:400;text-transform:none;letter-spacing:normal;line-height:1.4;padding:.5rem .75rem;border-radius:6px;border:1px solid #334155;box-shadow:0 8px 24px #00000080;white-space:normal;width:max-content;max-width:260px;text-align:center;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:100}.has-tooltip:hover:after{opacity:1;visibility:visible}.stat-flagged .stat-value{color:#f97316}.badge-pills{display:flex;flex-wrap:wrap;gap:3px;justify-content:center;max-width:144px;min-height:18px}.pill{font-size:.55rem;font-weight:700;padding:1px 7px;border-radius:9999px;color:#fff;letter-spacing:.04em;white-space:nowrap;line-height:1.4}.pill-excluded{background:#ef4444e0}.pill-duplicate{background:#8b5cf6e0}.pill-auto-flagged{background:#fb923ccc}.pill-blurry{background:#eab308e0}.pill-crop{background:#a855f7e0}.stat-auto-flagged .stat-value{color:#fb923c}.stat-duplicate .stat-value{color:#a78bfa}.stat-included .stat-value{color:#34d399}.btn-secondary{background:#475569!important}.btn-secondary:hover:not(:disabled){background:#64748b!important}.crop-edge{position:absolute;background:#a855f78c;pointer-events:none}.crop-edge-top{top:0;left:0;right:0;height:3px}.crop-edge-bottom{bottom:0;left:0;right:0;height:3px}.crop-edge-left{top:0;bottom:0;left:0;width:3px}.crop-edge-right{top:0;bottom:0;right:0;width:3px}.btn-flag{font-size:.7rem;padding:2px 8px;border-radius:4px;border:1px solid;background:transparent;cursor:pointer;line-height:1.3}.btn-flag:disabled{opacity:.5;cursor:not-allowed}.btn-unflag{border-color:#22c55e;color:#22c55e}.btn-unflag:hover:not(:disabled){background:#22c55e26}.btn-reflag{border-color:#64748b;color:#94a3b8}.btn-reflag:hover:not(:disabled){border-color:#f97316;color:#f97316;background:#f973161a}@keyframes spin{to{transform:rotate(360deg)}}.video-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:70;padding:1rem}.video-modal-card{background:#1e293b;border:1px solid #334155;border-radius:.75rem;padding:1.25rem 1.5rem;max-width:28rem;width:100%;max-height:90vh;overflow-y:auto;color:#e2e8f0}.video-modal-title{margin:0 0 .5rem;font-size:1.15rem}.video-modal-hint{margin:0 0 1rem;font-size:.85rem;color:#94a3b8;line-height:1.45}.video-modal-card .form-group{margin-bottom:.85rem}.video-sync-fieldset{border:1px solid #334155;border-radius:6px;padding:.65rem .85rem;margin:.75rem 0}.video-sync-fieldset legend{padding:0 .35rem;font-size:.8rem;color:#94a3b8}.video-radio{display:flex;gap:.5rem;align-items:flex-start;font-size:.85rem;color:#e2e8f0;margin-bottom:.5rem;cursor:pointer;line-height:1.35}.video-radio:last-child{margin-bottom:0}.video-radio input{margin-top:.2rem;flex-shrink:0}.video-modal-error{color:#f87171;font-size:.85rem;margin:.5rem 0 0;white-space:pre-line}.video-modal-progress{color:#7dd3fc;font-size:.85rem;margin:.5rem 0 0}.video-modal-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.video-result-card{margin:1rem 0 1.5rem;padding:1rem 1.25rem;background:#1e293b;border:1px solid #334155;border-radius:8px;max-width:42rem}.video-result-card h2{margin:0 0 .75rem;font-size:1rem}.video-preview{width:100%;max-height:360px;border-radius:6px;background:#020617}.video-download-link{font-size:.9rem}.video-banner{color:#7dd3fc;font-size:.9rem;margin:.5rem 0}
