@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;700&family=IBM+Plex+Mono:wght@400;500&display=swap");:root{color-scheme:light;--font-display:"Space Grotesk",sans-serif;--font-mono:"IBM Plex Mono",monospace;--bg-start:#fff8d7;--bg-mid:#eaf4ff;--bg-end:#fff1ef;--card-bg:hsla(0,0%,100%,.85);--text-main:#1f2333;--text-muted:#5a6178;--accent:#0f6ad8;--accent-light:#e8f1fc;--danger:#a83333;--danger-light:#fef0f0;--success:#1a7a3a;--success-light:#edf8f0;--warning:#9a6700;--warning-light:#fff8e1;--border:rgba(12,24,48,.1);--border-strong:rgba(12,24,48,.18);--radius:12px;--radius-sm:8px;font-family:var(--font-display);background:radial-gradient(1400px 900px at 10% 0,var(--bg-start) 0,transparent 70%),radial-gradient(1000px 700px at 90% 10%,var(--bg-mid) 0,transparent 70%),linear-gradient(155deg,#fefefe 0,var(--bg-end) 100%);color:var(--text-main)}*{box-sizing:border-box}body{margin:0;min-height:100vh}h1{font-size:clamp(2rem,5vw,2.8rem);letter-spacing:-.03em}h1,h2{margin-top:0}h2{font-size:1.25rem;letter-spacing:-.02em}h3{font-size:1.05rem;font-weight:600;letter-spacing:-.01em}h3,p{margin-top:0}p{line-height:1.6}.lede{font-size:1.05rem}.lede,.muted{color:var(--text-muted)}.error{color:var(--danger);font-weight:500}code{font-family:var(--font-mono)}button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:999px;padding:.6rem 1rem;background:var(--accent);color:#fff;font-family:var(--font-display);font-weight:600;font-size:.875rem;cursor:pointer;transition:opacity .15s,transform .1s}button:hover{opacity:.9}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:var(--font-display);font-size:.875rem;padding:.55rem 2rem .55rem .75rem;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235a6178'/%3E%3C/svg%3E") no-repeat right .75rem center;color:var(--text-main);cursor:pointer;transition:border-color .15s}select:focus{outline:none;border-color:var(--accent)}.signin-main{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.signin-card{max-width:420px;width:100%;padding:2.5rem;border-radius:16px;background:var(--card-bg);box-shadow:0 20px 60px rgba(15,23,42,.12);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-align:center;animation:fadeInUp .4s ease-out}.signin-card h1{margin-bottom:.5rem}.signin-card .lede{margin-bottom:2rem}.auth-section{display:flex;flex-direction:column;align-items:center;gap:.75rem}.auth-submitting{color:var(--text-muted);font-size:.875rem}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:hsla(0,0%,100%,.7);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100}.app-brand{font-weight:700;font-size:1.1rem;letter-spacing:-.02em}.user-info{display:flex;align-items:center;gap:.6rem}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-name{font-size:.85rem;color:var(--text-muted)}.signout-btn{background:transparent;color:var(--text-muted);font-size:.8rem;font-weight:500;padding:.35rem .65rem;border:1px solid var(--border)}.signout-btn:hover{border-color:var(--danger);color:var(--danger)}.app-main{max-width:720px;width:100%;margin:0 auto;padding:1.5rem;flex:1 1}.tab-switcher{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:1.5rem}.tab-btn{background:transparent;color:var(--text-muted);font-size:.9rem;font-weight:500;padding:.65rem 1.25rem;border-radius:0;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text-main);opacity:1}.tab-active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{animation:fadeIn .2s ease-out}.new-job-tab{gap:1.25rem}.drop-zone,.new-job-tab{display:flex;flex-direction:column}.drop-zone{align-items:center;justify-content:center;min-height:160px;padding:2rem;border:2px dashed var(--border-strong);border-radius:var(--radius);background:hsla(0,0%,100%,.5);cursor:pointer;transition:border-color .2s,background .2s;text-align:center}.drop-zone-active,.drop-zone:hover{border-color:var(--accent);background:var(--accent-light)}.drop-zone-has-file,.drop-zone-has-file:hover{border-style:solid;border-color:#5b9ee6;background:#5b9ee6}.drop-zone-input{display:none}.drop-zone-placeholder{gap:.4rem;color:var(--text-muted);font-size:.9rem}.drop-zone-complete,.drop-zone-placeholder{display:flex;flex-direction:column;align-items:center}.drop-zone-complete{gap:.5rem}.drop-zone-check-icon{width:36px;height:36px}.drop-zone-uploaded-text{font-size:.9rem;font-weight:600;color:#fff}.drop-zone-upload-progress{width:100%;padding:0 1rem}.upload-progress{position:relative;height:28px;border-radius:999px;background:var(--accent-light);overflow:hidden}.upload-progress-bar{position:absolute;top:0;left:0;height:100%;background:var(--accent);border-radius:999px;transition:width .25s ease}.upload-progress-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--text-main);z-index:1}.job-selector{display:flex;flex-direction:column;gap:.35rem}.character-selector-header label,.job-selector>label{font-size:.8rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.character-selector-header{display:flex;align-items:center;justify-content:space-between}.character-select-all{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:500;color:var(--text-muted);cursor:pointer;padding:.15rem 0}.character-select-all input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.character-grid{display:flex;gap:.5rem;padding:.5rem 0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.char-thumb{display:flex;flex-direction:column;align-items:center;gap:.3rem;background:transparent;padding:.35rem;border-radius:var(--radius-sm);color:var(--text-main);font-size:.7rem;flex-shrink:0;transition:opacity .15s}.char-thumb:hover{opacity:.85}.char-thumb:disabled{opacity:.45;cursor:not-allowed}.char-thumb-img-wrap{position:relative;width:56px;height:56px;border-radius:50%;overflow:hidden;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;background:#f0f0f2;transition:border-color .15s}.char-thumb-selected .char-thumb-img-wrap{border-color:var(--accent);border-width:3px}.char-thumb-img{width:100%;height:100%;object-fit:cover}.char-thumb-selected .char-thumb-img{opacity:.65}.char-thumb-initials{font-size:.85rem;font-weight:600;color:var(--text-muted);-webkit-user-select:none;-moz-user-select:none;user-select:none}.char-thumb-check{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--accent);pointer-events:none}.char-thumb-name{text-align:center;line-height:1.2;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.duration-picker{display:flex;gap:.4rem}.duration-option{padding:.45rem 1rem;font-size:.8rem;font-weight:500;border-radius:var(--radius-sm);background:hsla(0,0%,100%,.6);color:var(--text-main);border:1px solid var(--border-strong);transition:border-color .15s,background .15s}.duration-option:hover{border-color:var(--accent);background:var(--accent-light);opacity:1}.duration-option-selected,.duration-option-selected:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.submit-job-btn{align-self:flex-start;padding:.7rem 2rem;font-size:.9rem}.job-feedback{margin:0}.job-success{color:var(--success);font-weight:500;margin:0}.my-jobs-tab{display:flex;flex-direction:column;gap:1rem}.jobs-toolbar{display:flex;align-items:center;justify-content:space-between}.jobs-count{font-size:.85rem;color:var(--text-muted)}.refresh-btn{background:transparent;color:var(--accent);font-size:.8rem;padding:.35rem .7rem;border:1px solid var(--accent)}.refresh-btn:hover{background:var(--accent-light)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.jobs-list{gap:.5rem}.job-card,.jobs-list{display:flex;flex-direction:column}.job-card{padding:.75rem 1rem;border-radius:var(--radius);background:var(--card-bg);border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-align:left;color:var(--text-main);width:100%;transition:border-color .15s,box-shadow .15s}.job-card:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(15,106,216,.08)}.job-card-main{display:flex;align-items:center;gap:.75rem}.job-thumbnail{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;background:#f0f0f2}.job-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-muted)}.job-card-content{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:.3rem}.job-card-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.job-card-title{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-card-bottom{display:flex;align-items:center;justify-content:space-between}.job-card-subtitle{font-size:.78rem;color:var(--text-muted)}.stage-dots{display:flex;gap:4px}.stage-dot{width:8px;height:8px;border-radius:50%;background:#ddd}.stage-dot-completed{background:var(--success)}.stage-dot-running{background:var(--accent);animation:pulse 1.2s ease-in-out infinite}.stage-dot-failed{background:var(--danger)}.stage-dot-queued{background:var(--warning)}.status-badge{display:inline-flex;align-items:center;padding:.15rem .55rem;border-radius:999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;line-height:1.4}.badge-queued{background:var(--warning-light);color:var(--warning)}.badge-running{background:var(--accent-light);color:var(--accent)}.badge-completed{background:var(--success-light);color:var(--success)}.badge-failed{background:var(--danger-light);color:var(--danger)}.badge-pending{background:#f0f0f2;color:var(--text-muted)}.job-detail{display:flex;flex-direction:column;gap:1.25rem;animation:fadeIn .2s ease-out}.back-btn{align-self:flex-start;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;padding:.35rem 0;border-radius:0}.back-btn:hover{color:var(--accent)}.job-detail-header{display:flex;align-items:center;gap:.75rem}.job-detail-header h2{margin:0}.job-detail-date{font-size:.85rem;color:var(--text-muted);margin:0}.job-failure{padding:.85rem 1rem;border-radius:var(--radius-sm);background:var(--danger-light);color:var(--danger);font-size:.85rem}.job-failure strong{display:block;margin-bottom:.25rem}.job-failure p{margin:0}.job-hero{padding:1rem;border-radius:var(--radius);background:hsla(0,0%,100%,.6);border:1px solid var(--border)}.job-hero h3{margin-bottom:.75rem}.stages-container{display:flex;flex-direction:column;gap:.5rem}.stages-container h3{margin-bottom:.25rem}.stage-section{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.stage-section.stage-failed{border-color:rgba(168,51,51,.25)}.stage-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:hsla(0,0%,100%,.5);border-radius:0;color:var(--text-main);font-size:.85rem;font-weight:500;text-align:left}.stage-header:hover{background:hsla(0,0%,100%,.8);opacity:1}.stage-expand-icon{font-size:.75rem;width:12px;color:var(--text-muted)}.stage-label{flex:1 1}.stage-meta{font-size:.7rem;font-family:var(--font-mono);color:var(--text-muted);font-weight:400}.stage-body{padding:1rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.75rem;animation:fadeIn .15s ease-out}.stage-meta-grid{display:flex;flex-wrap:wrap;gap:1.25rem;font-size:.8rem}.stage-meta-grid>div{display:flex;flex-direction:column;gap:.15rem}.stage-meta-label{font-size:.7rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.stage-error{padding:.65rem .85rem;border-radius:var(--radius-sm);background:var(--danger-light);color:var(--danger);font-size:.8rem}.stage-error strong{display:block;margin-bottom:.15rem}.stage-error p{margin:0}.retry-stage-btn{align-self:flex-start;background:transparent;color:var(--danger);font-size:.8rem;padding:.35rem .7rem;border:1px solid var(--danger)}.retry-stage-btn:hover{background:var(--danger-light)}.stage-payload{display:flex;flex-direction:column;gap:.35rem}.payload-json{font-family:var(--font-mono);font-size:.75rem;line-height:1.5;background:#f7f8fa;border:1px solid var(--border);border-radius:var(--radius-sm);padding:.85rem;overflow-x:auto;max-height:360px;overflow-y:auto;margin:0}.signed-media-error{color:var(--danger);font-size:.8rem}.signed-media-loading{font-size:.8rem;color:var(--text-muted);padding:1rem 0}.signed-media-label{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.35rem}.video-player-container{display:flex;flex-direction:column;gap:.35rem}.video-player{width:100%;border-radius:var(--radius-sm);background:#000}.video-download-link{align-self:flex-start;font-size:.75rem;color:var(--accent);text-decoration:none;font-weight:500}.video-download-link:hover{text-decoration:underline}.signed-image-container{display:flex;flex-direction:column;gap:.35rem}.signed-image{max-width:100%;border-radius:var(--radius-sm)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@media (max-width:600px){.app-header{padding:.6rem 1rem}.app-main{padding:1rem}.user-name{display:none}.signin-card{padding:1.5rem}}