*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:#0f1117;color:#e4e4e7;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:#6366f1;text-decoration:none}a:hover{color:#4f46e5}.main{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.main:has(.job-results),.main:has(.subtitle-editor){max-width:1100px}.loading{display:flex;align-items:center;gap:.5rem;color:#71717a;padding:2rem 0}.empty{text-align:center;padding:4rem 0;color:#71717a}.empty__icon{opacity:.3;margin-bottom:1rem}.empty p{margin-bottom:1.5rem}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hero{text-align:center;margin-bottom:2.5rem}.hero__icon{color:#6366f1;margin-bottom:1rem}.hero h2{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.hero p{color:#71717a;max-width:500px;margin:0 auto}.auth{display:flex;align-items:center;justify-content:center;min-height:100vh}.auth__card{text-align:center}.auth__card h1{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.auth__card form{display:flex;flex-direction:column;gap:.75rem;width:280px}.auth__input{padding:.6rem .75rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:6px;color:#e4e4e7;font-size:.9rem;outline:none;text-align:center}.auth__input:focus{border-color:#6366f1}.auth__error{font-size:.8rem;color:#ef4444}.auth__btn{width:100%}.header{border-bottom:1px solid #2a2d3a;background:#1a1d27}.header__inner{max-width:800px;margin:0 auto;padding:0 1.5rem;height:60px;display:flex;align-items:center;justify-content:space-between}.header__logo,.header__logo:hover{color:#e4e4e7}.header__logo h1{font-size:1.25rem;font-weight:700;letter-spacing:-.02em}.header__nav{display:flex;gap:1.5rem}.header__link{color:#71717a;font-size:.875rem;font-weight:500;transition:color .15s ease}.header__link:hover,.header__link.router-link-active{color:#e4e4e7}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid #2a2d3a;border-radius:6px;background:#1a1d27;color:#e4e4e7;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn:hover{background:#22252f;color:#e4e4e7}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:#6366f1;border-color:#6366f1;color:#fff}.btn--primary:hover{background:#4f46e5;border-color:#4f46e5;color:#fff}.btn--ghost{background:transparent;border-color:transparent;color:#71717a}.btn--ghost:hover{color:#e4e4e7;background:#1a1d27}.btn--lg{width:100%;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;border-radius:10px}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:flex;gap:1.5rem;align-items:flex-start}@media(max-width:600px){.form-row{flex-direction:column}}.form-group{flex:1}.form-group label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:#71717a;margin-bottom:.5rem}.form-group select{width:100%;padding:.5rem .75rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:6px;color:#e4e4e7;font-size:.875rem;outline:none;transition:border-color .15s ease}.form-group select:focus{border-color:#6366f1}.toggle-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-row__text{font-size:.875rem;color:#71717a}.toggle{position:relative;width:36px;height:20px;background:#2a2d3a;border-radius:10px;transition:background .15s ease;flex-shrink:0}.toggle__knob{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#e4e4e7;border-radius:50%;transition:transform .15s ease}.toggle--active{background:#6366f1}.toggle--active .toggle__knob{transform:translate(16px)}.style-picker{display:flex;gap:.75rem}@media(max-width:600px){.style-picker{flex-wrap:wrap}}.style-card{flex:1;padding:.75rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;cursor:pointer;text-align:left;color:#e4e4e7;transition:all .15s ease}.style-card:hover{border-color:#6366f1}.style-card--active{border-color:#6366f1;background:#6366f11a}.style-card__name{display:block;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.style-card__desc{display:block;font-size:.75rem;color:#71717a;line-height:1.3}.dropzone{border:2px dashed #2a2d3a;border-radius:10px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .15s ease;background:#1a1d27}.dropzone:hover,.dropzone--active{border-color:#6366f1;background:#6366f10d}.dropzone--has-file{border-color:#22c55e;border-style:solid;background:#22c55e0d}.dropzone__icon{color:#71717a;margin-bottom:.75rem}.dropzone__icon--file{color:#22c55e}.dropzone__text{font-weight:500;margin-bottom:.25rem}.dropzone__hint{font-size:.8125rem;color:#71717a}.jobs h2{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.jobs__list{display:flex;flex-direction:column;gap:.5rem}.job-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;color:#e4e4e7;transition:all .15s ease}.job-card:hover{background:#22252f;color:#e4e4e7}.job-card__icon{flex-shrink:0;color:#71717a}.job-card--completed .job-card__icon{color:#22c55e}.job-card--failed .job-card__icon{color:#ef4444}.job-card--uploaded .job-card__icon{color:#71717a}.job-card--processing .job-card__icon,.job-card--transcribing .job-card__icon,.job-card--diarizing .job-card__icon,.job-card--generating .job-card__icon{color:#f59e0b}.job-card--review .job-card__icon{color:#3b82f6}.job-card__info{flex:1;min-width:0}.job-card__name{display:block;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-card__meta{display:block;font-size:.75rem;color:#71717a}.job-card__status{flex-shrink:0}.job-card__delete{flex-shrink:0;background:none;border:none;color:#71717a;cursor:pointer;padding:.25rem;border-radius:6px;transition:all .15s ease}.job-card__delete:hover{color:#ef4444;background:#ef44441a}.quote{background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;padding:1.5rem;max-width:400px;margin:0 auto}.quote h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.quote__details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.quote__line{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.quote__line--total{border-top:1px solid #2a2d3a;padding-top:.75rem;font-weight:700;font-size:1rem}.quote__toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.quote__note{font-size:.75rem;color:#71717a;margin-bottom:1.25rem}.quote__actions{display:flex;gap:.75rem;justify-content:flex-end}.job-results{display:flex;gap:1.5rem;align-items:flex-start;justify-content:center}@media(max-width:768px){.job-results{flex-direction:column}}.job-completed__video{margin-bottom:.75rem;display:flex;justify-content:center}.job-completed__video video{max-width:100%;max-height:50vh;display:block;border-radius:10px}.job-completed__downloads{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.dl-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.8rem;font-weight:500;color:#e4e4e7;background:#1a1d27;border:1px solid #2a2d3a;border-radius:6px;cursor:pointer;transition:all .15s ease;text-decoration:none}.dl-btn:hover{border-color:#6366f1;color:#e4e4e7}.dl-btn--primary{background:#6366f1;border-color:#6366f1;color:#fff}.dl-btn--primary:hover{background:#4f46e5;border-color:#4f46e5;color:#fff}.dl-btn--ghost{background:none;border-color:transparent;color:#71717a}.dl-btn--ghost:hover{color:#e4e4e7;border-color:#2a2d3a}.job-detail__header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1.5rem 0 1rem}.job-detail__header h2{font-size:1.25rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-detail__meta{display:flex;gap:1.5rem;color:#71717a;font-size:.875rem;margin-bottom:1.5rem}.video-preview{flex:1;min-width:0}.video-preview h3{font-size:1rem;font-weight:600;margin-bottom:.75rem}.video-preview__wrapper{position:relative;width:100%;aspect-ratio:16/9;background:#000;border-radius:10px;overflow:hidden}.video-preview video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;display:block}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.badge--uploaded,.badge--pending{background:#71717a26;color:#71717a}.badge--processing,.badge--transcribing,.badge--diarizing,.badge--generating{background:#f59e0b26;color:#f59e0b}.badge--review{background:#3b82f626;color:#3b82f6}.badge--completed{background:#22c55e26;color:#22c55e}.badge--failed{background:#ef444426;color:#ef4444}.badge--lg{padding:.25rem .75rem;font-size:.8125rem}.alert{padding:.75rem 1rem;border-radius:6px;font-size:.875rem}.alert--error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.progress{position:relative;height:2rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;overflow:hidden;margin-bottom:1.5rem}.progress__bar{height:100%;background:linear-gradient(90deg,#6366f1,#4f46e5);border-radius:10px;transition:width .5s ease}.progress__text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:600}.downloads{flex-shrink:0;width:220px}@media(max-width:768px){.downloads{width:100%}}.downloads h3{font-size:1rem;font-weight:600;margin-bottom:1rem}.downloads__grid{display:flex;flex-direction:column;gap:.75rem}@media(max-width:768px){.downloads__grid{flex-direction:row}}.download-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1rem;background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;color:#e4e4e7;transition:all .15s ease;text-align:center}.download-card:hover{background:#22252f;border-color:#6366f1;color:#e4e4e7}.download-card__label{font-size:1.125rem;font-weight:600}.download-card__desc{font-size:.75rem;color:#71717a}.download-card__action{color:#6366f1;margin-top:.25rem}.subtitle-preview{margin-top:2rem}.subtitle-preview h3{font-size:1rem;font-weight:600;margin-bottom:1rem}.subtitle-preview__list{max-height:400px;overflow-y:auto;background:#1a1d27;border:1px solid #2a2d3a;border-radius:10px;padding:.5rem 0}.subtitle-preview__segment{display:flex;gap:1rem;padding:.5rem 1rem;transition:background .15s ease}.subtitle-preview__segment:hover{background:#22252f}.subtitle-preview__time{flex-shrink:0;font-size:.8rem;font-variant-numeric:tabular-nums;color:#71717a;min-width:4.5rem;padding-top:.1rem}.subtitle-preview__text{font-size:.9rem;line-height:1.5;white-space:pre-line}.subtitle-editor{margin-top:2rem}.se-video{margin-bottom:1rem;display:flex;justify-content:center}.se-video video{max-width:100%;max-height:40vh;display:block;border-radius:10px}.se-audio{margin-bottom:1rem}.se-audio audio{width:100%;display:block}.se-speakers{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.se-speaker{display:flex;align-items:center;gap:.4rem}.se-speaker__color{width:22px;height:22px;border:1px solid #2a2d3a;border-radius:4px;background:none;cursor:pointer;padding:1px}.se-speaker__name{font-size:.8rem;cursor:pointer;padding:.1rem .3rem;border-radius:3px;transition:background .15s ease}.se-speaker__name:hover{background:#22252f}.se-speaker__rename{font-size:.8rem;font-family:inherit;background:#0f1117;border:1px solid #6366f1;border-radius:3px;color:#e4e4e7;padding:.1rem .3rem;outline:none;width:8rem}.se-list{display:flex;flex-direction:column;max-height:60vh;overflow-y:auto;border-radius:10px;border:1px solid #2a2d3a}.se-gap{height:3px;transition:all .15s ease}.se-gap--active{height:2rem;background:#6366f126;border:1px dashed #6366f1;border-radius:3px;margin:2px .5rem}.se-row{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;background:#1a1d27;min-height:2rem;border-bottom:1px solid #2a2d3a;transition:background .15s ease}.se-row:last-of-type{border-bottom:none}.se-row--drop-target{background:#6366f11a}.se-row__play{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:none;border:none;color:#71717a;cursor:pointer;border-radius:50%;transition:all .15s ease}.se-row__play:hover{color:#6366f1;background:#6366f11a}.se-row__play--active{color:#6366f1}.se-row__speaker-label{flex-shrink:0;font-size:.75rem;font-weight:600;width:5.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.se-row__time{flex-shrink:0;font-size:.75rem;font-variant-numeric:tabular-nums;color:#71717a;width:3rem}.se-row__speaker{flex-shrink:0;font-size:.75rem;font-weight:600;width:5.5rem;background:none;border:none;cursor:pointer;outline:none;padding:.1rem 0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.se-row__speaker:hover{text-decoration:underline}.se-row__speaker option{background:#1a1d27}.se-row__position{flex-shrink:0;font-size:.8rem;width:1.2rem;text-align:center;cursor:pointer;color:#71717a;transition:color .15s ease}.se-row__position:hover{color:#e4e4e7}.se-row__words{flex:1;min-width:0;white-space:pre-wrap;font-size:.85rem;line-height:1.5}.se-row__delete{flex-shrink:0;background:none;border:none;color:#71717a;cursor:pointer;padding:.2rem;border-radius:3px;opacity:0;transition:all .15s ease}.se-row__delete:hover{color:#ef4444}.se-row:hover .se-row__delete{opacity:1}.se-word{display:inline;border-radius:2px;transition:background .15s ease}.se-word--draggable{cursor:grab}.se-word--draggable:hover{background:#6366f126}.se-word--dragging{opacity:.3}.se-word__input{font-size:.85rem;font-family:inherit;background:#0f1117;border:1px solid #6366f1;border-radius:2px;color:#e4e4e7;padding:0 .15rem;outline:none;width:auto;min-width:1.5rem}.se-actions{margin-top:1.5rem;display:flex;justify-content:flex-end}
