:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#eee;background-color:#1a1a2e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh}.app{max-width:1600px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #333;margin-bottom:20px}.header h1{font-size:24px;font-weight:600}.header-nav{display:flex;gap:10px}.nav-btn{padding:8px 16px;background:transparent;color:#888;border:1px solid #444;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none}.nav-btn:hover{color:#eee;border-color:#666}.nav-btn.active{background:#0f8;color:#1a1a2e;border-color:#0f8;font-weight:600}.app-layout{display:flex;gap:20px;margin-bottom:30px}.sidebar{width:200px;flex-shrink:0;background:#252540;border-radius:8px;padding:15px}.sidebar h3{font-size:14px;margin-bottom:15px;color:#888;text-transform:uppercase;letter-spacing:.05em}.video-list{display:flex;flex-direction:column;gap:8px}.video-list-item{display:flex;align-items:center;gap:10px;padding:10px;background:#1a1a2e;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:border-color .2s,background .2s}.video-list-item:hover{border-color:#444}.video-list-item.active{border-color:#0f8;background:#1e2a3a}.video-list-thumbnail{width:40px;height:40px;background:#333;border-radius:4px;display:flex;align-items:center;justify-content:center}.video-icon{font-size:20px}.video-list-info{flex:1;min-width:0}.video-list-name{font-size:13px;color:#ccc;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.video-badge{font-size:10px;color:#888;background:#333;padding:2px 6px;border-radius:3px;margin-top:4px;display:inline-block}.no-videos{font-size:12px;color:#666;text-align:center;padding:20px 0}.main-content{display:flex;gap:30px;flex:1}.video-section{flex:1;min-width:0}.video-container{position:relative;width:100%;background:#000;border-radius:8px;overflow:hidden}.video-player{width:100%;display:block}.crop-overlay{position:absolute;top:0;border:3px solid #00ff88;cursor:ew-resize;z-index:10;transition:border-color .2s}.crop-overlay:hover,.crop-overlay.dragging{border-color:#0fa}.crop-handle{position:absolute;top:50%;width:8px;height:40px;background:#0f8;border-radius:4px;transform:translateY(-50%)}.crop-handle.left{left:-4px}.crop-handle.right{right:-4px}.crop-label{position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#000000b3;padding:5px 10px;border-radius:4px;font-size:12px;white-space:nowrap}.crop-mask{position:absolute;top:0;height:100%;background:#0009;pointer-events:none}.crop-mask.left{left:0}.crop-mask.right{right:0}.main-video-overlay{position:absolute;top:0;height:100%;pointer-events:none;z-index:5;overflow:hidden}.main-overlay-frame{position:relative;width:100%;height:100%;container-type:size}.main-overlay-gradient{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,.7),transparent)}.main-overlay-title{position:absolute;bottom:25%;left:50%;transform:translate(-50%);color:#fff;font-size:2.2cqh;font-weight:700;text-align:center;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}.main-overlay-author{position:absolute;bottom:22%;left:50%;transform:translate(-50%);color:#fff;font-size:2.2cqh;font-weight:400;text-align:center;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.02em}.main-overlay-subtitle{position:absolute;bottom:35%;left:15%;right:15%;color:#fff;font-size:2.05cqh;font-weight:700;text-align:center;line-height:1.3;letter-spacing:-.02em}.video-controls{display:flex;align-items:center;gap:15px;padding:15px;background:#252540;border-radius:0 0 8px 8px;margin-top:-4px}.play-btn{background:#0f8;color:#1a1a2e;border:none;padding:10px 20px;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.play-btn:hover{background:#00cc6a}.time-display{font-family:monospace;font-size:14px;min-width:100px}.seek-slider{flex:1;height:6px;-webkit-appearance:none;background:#444;border-radius:3px;outline:none}.seek-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:#0f8;border-radius:50%;cursor:pointer}.clip-range{margin-top:20px;padding:15px;background:#252540;border-radius:8px}.clip-range h3{font-size:16px;margin-bottom:15px}.range-inputs{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.range-inputs label{display:flex;align-items:center;gap:8px;font-size:14px}.range-inputs input[type=number]{width:80px;padding:6px 10px;background:#1a1a2e;border:1px solid #444;border-radius:4px;color:#eee;font-family:monospace}.range-inputs button{background:#444;color:#eee;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px}.range-inputs button:hover{background:#555}.clip-duration{color:#0f8;font-weight:600;margin-left:auto}.controls-section{width:280px;flex-shrink:0}.preview-container{background:#000;border-radius:8px;overflow:hidden}.preview-frame{position:relative;width:100%;aspect-ratio:9/16;overflow:hidden;container-type:size}.preview-video-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden}.preview-video{position:absolute;top:0;left:50%;height:100%;width:auto}.preview-gradient{position:absolute;bottom:0;left:0;right:0;height:50%;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);pointer-events:none}.preview-title{position:absolute;bottom:25%;left:50%;transform:translate(-50%);color:#fff;font-size:1.9cqh;font-weight:700;text-align:center;width:90%;letter-spacing:-.02em}.preview-author{position:absolute;bottom:22%;left:50%;transform:translate(-50%);color:#fff;font-size:1.9cqh;font-weight:400;text-align:center;width:90%;letter-spacing:-.02em}.preview-subtitle{position:absolute;bottom:35%;left:15%;right:15%;color:#fff;font-size:1.8cqh;font-weight:700;text-align:center;line-height:1.3;letter-spacing:-.02em}.text-editor{margin-top:20px;padding:15px;background:#252540;border-radius:8px}.text-editor h3{font-size:16px;margin-bottom:15px}.text-editor label{display:block;margin-bottom:12px;font-size:14px}.text-input{display:block;width:100%;margin-top:6px;padding:8px 12px;background:#1a1a2e;border:1px solid #444;border-radius:4px;color:#eee;font-size:14px}.text-input:focus{outline:none;border-color:#0f8}.export-section{margin-top:20px}.export-btn{width:100%;padding:15px;background:#0f8;color:#1a1a2e;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.export-btn:hover:not(:disabled){background:#00cc6a}.export-btn:disabled{background:#444;color:#888;cursor:not-allowed}.export-progress{margin-top:10px;font-size:12px;color:#888;text-align:center}.subtitle-timeline-section{padding:20px;background:#252540;border-radius:8px}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.timeline-header h3{font-size:18px;margin:0}.zoom-controls{display:flex;align-items:center;gap:8px}.zoom-controls button{width:28px;height:28px;background:#1a1a2e;color:#eee;border:1px solid #444;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center}.zoom-controls button:hover{background:#333;border-color:#0f8}.zoom-controls .zoom-fit{width:auto;padding:0 10px;font-size:12px;font-weight:400}.zoom-label{font-size:12px;color:#888;min-width:45px;text-align:center}.timeline-container{overflow-x:auto;overflow-y:hidden;border-radius:6px;background:#1a1a2e}.timeline-container::-webkit-scrollbar{height:8px}.timeline-container::-webkit-scrollbar-track{background:#1a1a2e}.timeline-container::-webkit-scrollbar-thumb{background:#444;border-radius:4px}.timeline-container::-webkit-scrollbar-thumb:hover{background:#555}.timeline{position:relative;height:100px;min-width:100%;background:#1a1a2e;cursor:pointer;-webkit-user-select:none;user-select:none}.timeline-markers{position:absolute;top:0;left:0;right:0;height:20px;border-bottom:1px solid #333}.timeline-marker{position:absolute;top:0;font-size:10px;color:#666;transform:translate(-50%);padding-top:2px}.timeline-track{position:absolute;top:28px;left:0;right:0;height:50px}.timeline-subtitle{position:absolute;height:100%;background:#3a5a7c;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid #4a7a9c;transition:background .15s;min-width:4px}.timeline-subtitle:hover{background:#4a6a8c}.timeline-subtitle.active{background:#0a6;border-color:#0f8}.timeline-subtitle-text{font-size:10px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px;pointer-events:none}.timeline-edge{position:absolute;top:0;width:8px;height:100%;cursor:ew-resize;background:transparent;z-index:2}.timeline-edge:hover,.timeline-edge:active{background:#00ff884d}.timeline-edge.left{left:0;border-radius:4px 0 0 4px}.timeline-edge.right{right:0;border-radius:0 4px 4px 0}.timeline-playhead{position:absolute;top:0;bottom:0;width:3px;background:#f33;z-index:20;pointer-events:none;box-shadow:0 0 6px #ff3232cc}.timeline-playhead:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:14px;height:14px;background:#f33;border-radius:50%;box-shadow:0 0 6px #ff3232cc}.timeline-playhead:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:14px;height:14px;background:#f33;border-radius:50%;box-shadow:0 0 6px #ff3232cc}.timeline-clip-start,.timeline-clip-end{position:absolute;top:0;bottom:0;width:2px;background:#0f8;pointer-events:none;z-index:5;opacity:.7}.timeline-clip-start:before,.timeline-clip-end:before{content:"";position:absolute;bottom:0;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:6px solid #00ff88}.timeline-clip-start:before{left:-4px}.timeline-clip-end:before{left:-4px}.current-subtitle-editor{margin-top:15px;background:#1a1a2e;border-radius:6px;padding:15px}.subtitle-editor-header{margin-bottom:10px}.subtitle-editor-label{font-size:13px;color:#0f8;font-family:monospace}.subtitle-editor-input{width:100%;min-height:80px;padding:12px;background:#252540;border:1px solid #444;border-radius:4px;color:#eee;font-size:16px;font-family:inherit;resize:vertical;line-height:1.5}.subtitle-editor-input:focus{outline:none;border-color:#0f8}.subtitle-editor-input:disabled{background:#1e1e30;color:#666;cursor:not-allowed}.upload-page{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 150px);padding:40px 20px}.upload-container{max-width:600px;width:100%;text-align:center}.upload-container h2{font-size:28px;margin-bottom:10px}.upload-description{color:#888;margin-bottom:30px}.upload-dropzone-large{border:2px dashed #444;border-radius:12px;padding:60px 40px;cursor:pointer;transition:all .2s;background:#252540}.upload-dropzone-large:hover,.upload-dropzone-large.dragover{border-color:#0f8;background:#2a2a4a}.upload-dropzone-large.has-file{border-color:#0f8;border-style:solid}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px}.dropzone-icon{font-size:48px;color:#0f8}.dropzone-text{font-size:18px;color:#ccc}.dropzone-hint{font-size:14px;color:#666}.file-info{display:flex;flex-direction:column;align-items:center;gap:8px}.file-name-large{font-size:16px;color:#eee;word-break:break-all}.file-size{font-size:14px;color:#888}.upload-form{margin-top:20px;text-align:left}.upload-form label{display:block;font-size:14px;color:#888;margin-bottom:8px}.upload-name-input-large{width:100%;padding:12px 16px;background:#1a1a2e;border:1px solid #444;border-radius:8px;color:#eee;font-size:16px;margin-top:6px}.upload-name-input-large:focus{outline:none;border-color:#0f8}.upload-start-btn-large{width:100%;margin-top:20px;padding:16px;background:#0f8;color:#1a1a2e;border:none;border-radius:8px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.upload-start-btn-large:hover:not(:disabled){background:#00cc6a}.upload-start-btn-large:disabled{background:#444;color:#888;cursor:not-allowed}.processing-status-large{padding:40px;background:#252540;border-radius:12px}.processing-step-large{font-size:18px;margin-bottom:20px;color:#eee}.processing-progress-bar-large{height:8px;background:#1a1a2e;border-radius:4px;overflow:hidden;margin-bottom:15px}.processing-progress-fill{height:100%;background:#0f8;transition:width .3s}.processing-percent-large{font-size:24px;font-weight:700;color:#0f8}.processing-note{margin-top:20px;font-size:14px;color:#666}.processing-error-large{padding:40px;background:#402525;border-radius:12px;border:1px solid #ff4444}.processing-error-large p{color:#f88;margin-bottom:20px}.processing-complete-large{padding:40px;background:#254025;border-radius:12px;border:1px solid #00ff88}.success-icon{font-size:48px;color:#0f8;margin-bottom:15px}.processing-complete-large p{font-size:18px;color:#eee}.success-note{margin-top:10px;font-size:14px;color:#888}.btn-secondary{padding:10px 20px;background:#444;color:#eee;border:none;border-radius:6px;cursor:pointer;font-size:14px}.btn-secondary:hover{background:#555}
