@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";:root{--bg-base:#040d1a;--bg-surface:#071224;--bg-card:#0c1a30;--bg-card-hover:#0f2040;--bg-inset:#060f1e;--accent-purple:#8b5cf6;--accent-magenta:#ec4899;--accent-cyan:#06b6d4;--accent-green:#10b981;--accent-amber:#f59e0b;--accent-red:#ef4444;--grad-primary:linear-gradient(135deg, #8b5cf6 0%, #ec4899 100%);--grad-cyan:linear-gradient(135deg, #06b6d4 0%, #8b5cf6 100%);--glow-purple:0 0 20px #8b5cf640;--glow-cyan:0 0 20px #06b6d433;--glow-sm:0 0 10px #8b5cf626;--text-primary:#e2e8f0;--text-secondary:#64748b;--text-muted:#334155;--border:#8b5cf61f;--border-bright:#8b5cf659;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--sidebar-width:220px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;font-weight:300;line-height:1.6}.app{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border);z-index:100;background:linear-gradient(#060e1e 0%,#040b18 100%);flex-direction:column;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--border);align-items:center;gap:.5rem;padding:2rem 1.5rem 1.5rem;display:flex}.sidebar-logo{width:20%;height:auto;display:block}.sidebar-brand-text{letter-spacing:.04em;color:#e2e8f0;white-space:nowrap;font-size:1.1rem;font-weight:600}.page-header{margin-bottom:2rem}.page-header h1{letter-spacing:-.01em;color:#e2e8f0;margin-bottom:.35rem;font-size:1.75rem;font-weight:300}.page-header p{color:var(--text-secondary);font-size:.875rem;font-weight:300;line-height:1.5}.sidebar-nav{flex-direction:column;flex:1;gap:1rem;padding:1rem .75rem 0;display:flex;overflow-y:auto}.sidebar-user{border-top:1px solid var(--border);flex-direction:column;gap:.4rem;margin-top:auto;padding:.75rem 0 1rem;display:flex}.sidebar-user-email{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;padding:0 .25rem;font-size:.7rem;overflow:hidden}.sidebar-signout-btn{width:100%;color:var(--text-secondary);justify-content:flex-start;gap:.4rem;font-size:.78rem}.nav-section{flex-direction:column;gap:2px;display:flex}.nav-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:0 .875rem .35rem;font-size:.68rem;font-weight:500}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);letter-spacing:.01em;align-items:center;gap:.75rem;padding:.65rem .875rem;font-size:.875rem;font-weight:400;text-decoration:none;transition:background .15s,color .15s,box-shadow .15s;display:flex}.nav-item:hover{color:var(--text-primary);background:#8b5cf614}.nav-item.active{color:var(--text-primary);background:#8b5cf626;box-shadow:inset 0 0 0 1px #8b5cf633}.nav-item.active svg{color:var(--accent-purple)}.coming-soon-section{max-width:640px}.coming-soon-message{color:var(--text-secondary);font-size:.95rem}.main{margin-left:var(--sidebar-width);background:radial-gradient(ellipse 80% 50% at 60% -10%, #8b5cf60f 0%, transparent 60%), var(--bg-base);flex:1;min-height:100vh;padding:2.5rem}.section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1.25rem;padding:1.75rem;transition:border-color .2s}.section:hover{border-color:#8b5cf633}.section h2{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:1.25rem;font-size:.875rem;font-weight:500}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.25rem;display:flex}.section-header h2{margin-bottom:0}.section-actions{gap:.5rem;display:flex}.btn{border-radius:var(--radius-md);cursor:pointer;letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:.4rem;padding:.6rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;text-decoration:none;transition:opacity .15s,box-shadow .2s,transform .1s,background .15s,color .15s;display:inline-flex}.btn-sm{border-radius:var(--radius-sm);padding:.35rem .8rem;font-size:.8125rem}.btn-block{justify-content:center;width:100%}.btn-ghost{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--text-primary);border-color:var(--border-bright);background:#ffffff0a}.btn-primary,.btn-secondary,.btn-danger{border-radius:var(--radius-md);cursor:pointer;letter-spacing:.01em;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:opacity .15s,box-shadow .2s,transform .1s;display:inline-flex}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 0 #0000}.btn-primary:hover:not(:disabled){box-shadow:var(--glow-purple);transform:translateY(-1px)}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border);background:#64748b26}.btn-secondary:hover:not(:disabled){color:var(--text-primary);border-color:var(--border-bright);background:#64748b40}.btn-danger{color:var(--accent-red);background:#ef444426;border:1px solid #ef444433}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-download{color:#fff;background:linear-gradient(135deg,#10b981 0%,#06b6d4 100%)}.btn-download:hover:not(:disabled){box-shadow:var(--glow-cyan);transform:translateY(-1px)}.btn-delete{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#f97316 100%)}.btn-delete:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 12px #ef444480}.btn-large{padding:.8rem 1.75rem;font-size:.9375rem}.btn-small{padding:.35rem .75rem;font-size:.8125rem}button:disabled{opacity:.4;cursor:not-allowed;transform:none!important}input,textarea,select{font-family:Inter,sans-serif;font-weight:300}.input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);color:var(--text-primary);outline:none;padding:.55rem .75rem;font-family:inherit;font-size:.875rem;font-weight:300;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 2px #8b5cf61a}.setting-item{flex-direction:column;gap:.4rem;display:flex}.setting-item.full-width{grid-column:1/-1}.setting-item label{color:var(--text-secondary);letter-spacing:.02em;font-size:.8125rem;font-weight:400}.setting-item input,.setting-item select{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);color:var(--text-primary);padding:.55rem .75rem;font-size:.875rem;font-weight:300;transition:border-color .15s,box-shadow .15s}.setting-item input:focus,.setting-item select:focus{border-color:var(--accent-purple);outline:none;box-shadow:0 0 0 2px #8b5cf61a}.setting-item select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2rem}.setting-item select option{background:var(--bg-card);color:var(--text-primary)}.settings-panel h3{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:1rem;font-size:.8125rem;font-weight:500}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.setting-help{color:var(--text-muted);margin-top:.2rem;font-size:.75rem}.checkbox-item{flex-direction:row!important;align-items:flex-start!important}.checkbox-item label{cursor:pointer;align-items:center;gap:.5rem;display:flex}.checkbox-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--accent-purple)}.prompt-cell textarea,.instruction-textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);width:100%;color:var(--text-primary);resize:vertical;padding:.6rem .75rem;font-family:Inter,sans-serif;font-size:.875rem;font-weight:300;line-height:1.5;transition:border-color .15s,box-shadow .15s}.prompt-cell textarea:focus,.instruction-textarea:focus{border-color:var(--accent-purple);outline:none;box-shadow:0 0 0 2px #8b5cf61a}.prompt-cell textarea{min-height:58px}.video-prompt-textarea{min-height:240px!important}.instruction-textarea{min-height:80px}.prompt-cell textarea:disabled,.instruction-textarea:disabled{opacity:.5;cursor:not-allowed}.folder-picker{flex-direction:column;align-items:center;gap:1rem;padding:3rem 2rem;display:flex}.image-list{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.image-list-header{background:var(--bg-inset);letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);grid-template-columns:240px 1fr 140px 100px;gap:1rem;padding:.6rem 1rem;font-size:.75rem;font-weight:500;display:grid}.image-item-row{border-top:1px solid var(--border);grid-template-columns:240px 1fr 140px 100px;align-items:flex-start;gap:1rem;padding:.75rem 1rem;transition:background .15s;display:grid}.image-item-row:hover{background:var(--bg-card-hover)}.style-import-divider{color:var(--text-muted);align-items:center;gap:.75rem;margin:1rem 0;font-size:.8125rem;display:flex}.style-import-divider:before,.style-import-divider:after{content:"";background:var(--border);flex:1;height:1px}.style-import-storyboard{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.style-image-list{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.style-list-header{background:var(--bg-inset);letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);gap:1rem;padding:.6rem 1rem;font-size:.75rem;font-weight:500;display:grid}.style-list-header.with-notes{grid-template-columns:80px 150px 1fr 140px 80px 100px}.style-list-header.no-notes{grid-template-columns:80px 150px 140px 80px 100px}.style-item-row{border-top:1px solid var(--border);align-items:center;gap:1rem;padding:.75rem 1rem;transition:background .15s;display:grid}.style-item-row.with-notes{grid-template-columns:80px 150px 1fr 140px 80px 100px}.style-item-row.no-notes{grid-template-columns:80px 150px 140px 80px 100px}.style-item-row:hover{background:var(--bg-card-hover)}.image-list-header>div,.image-item-row>div,.style-list-header>div,.style-item-row>div,.shot-list-header>div,.shot-row>div{min-width:0}.thumbnail{object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border);width:60px;height:60px}.video-thumbnail-wrap{width:240px;height:240px;position:relative}.video-thumbnail{border-radius:var(--radius-md);width:240px;height:240px}.video-shot-index{letter-spacing:.05em;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8b5cf6d9;border-radius:4px;padding:.15rem .4rem;font-size:.7rem;font-weight:600;position:absolute;top:6px;left:6px}.filename{width:100%;max-width:100%;color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;display:block;overflow:hidden}.filename-cell,.prompt-cell,.notes-cell,.status-cell,.actions-cell{min-width:0}.notes-cell input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);width:100%;color:var(--text-primary);padding:.45rem .65rem;font-family:inherit;font-size:.8125rem;font-weight:300}.notes-cell input:focus{border-color:var(--accent-purple);outline:none;box-shadow:0 0 0 2px #8b5cf61a}.notes-cell input:disabled{opacity:.5;cursor:not-allowed}.result-cell{justify-content:center;display:flex}.result-thumbnail{object-fit:cover;border-radius:var(--radius-sm);border:1px solid #10b98166;width:60px;height:60px;box-shadow:0 0 8px #10b98126}.status-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:.2rem .65rem;font-size:.7rem;font-weight:500;display:inline-flex}.status-pending{color:var(--text-secondary);border:1px solid var(--border);background:#64748b26}.status-progress{color:var(--accent-purple);background:#8b5cf626;border:1px solid #8b5cf640}.status-complete{color:var(--accent-green);background:#10b9811f;border:1px solid #10b98140}.status-error{color:var(--accent-red);background:#ef44441f;border:1px solid #ef444440}.progress-bar{background:var(--border);border-radius:2px;height:3px;margin-top:.5rem;overflow:hidden}.progress-fill{background:var(--grad-primary);height:100%;transition:width .3s}.error-message{color:var(--accent-red);margin-top:.2rem;font-size:.75rem}.error-banner{color:var(--accent-red);border-radius:var(--radius-md);background:#ef444414;border:1px solid #ef444433;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.actions-section{flex-direction:column;align-items:center;gap:1rem;display:flex}.action-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.processing-status{color:var(--text-secondary);align-items:center;gap:.75rem;font-size:.875rem;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent-purple);border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.prompt-tools{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.apply-all{flex:1;gap:.5rem;min-width:300px;display:flex}.apply-all input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);color:var(--text-primary);flex:1;padding:.55rem .75rem;font-family:inherit;font-size:.875rem;font-weight:300}.apply-all input:focus{border-color:var(--accent-purple);outline:none;box-shadow:0 0 0 2px #8b5cf61a}.reference-upload-container{text-align:left}.reference-header{justify-content:space-between;align-items:center;margin-bottom:.875rem;display:flex}.reference-header h3{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin:0;font-size:.8125rem;font-weight:500}.reference-count{color:var(--accent-purple);background:#8b5cf61a;border:1px solid #8b5cf633;border-radius:999px;padding:.15rem .6rem;font-size:.75rem}.reference-dropzone{border:1px dashed var(--border-bright);border-radius:var(--radius-lg);cursor:pointer;justify-content:center;align-items:center;min-height:140px;padding:2.5rem 2rem;transition:border-color .2s,background .2s,box-shadow .2s;display:flex}.reference-dropzone:hover:not(.disabled){border-color:var(--accent-purple);box-shadow:var(--glow-sm);background:#8b5cf60a}.reference-dropzone.dragging{border-color:var(--accent-purple);box-shadow:var(--glow-purple);background:#8b5cf614}.reference-dropzone.has-images{border-style:solid;align-items:stretch;padding:1rem}.reference-dropzone.full{cursor:default}.reference-dropzone.disabled{opacity:.5;cursor:not-allowed}.dropzone-placeholder{text-align:center}.dropzone-icon{opacity:.5;margin-bottom:.5rem;font-size:2.25rem}.dropzone-text{color:var(--text-primary);margin-bottom:.25rem;font-size:.9375rem}.dropzone-subtext{color:var(--text-secondary);font-size:.8125rem}.reference-images-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem;width:100%;display:grid}.reference-image-item{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-inset);position:relative;overflow:hidden}.reference-thumbnail{object-fit:cover;width:100%;height:110px;display:block}.reference-remove-btn{width:22px;height:22px;color:var(--text-secondary);cursor:pointer;background:#040d1ad9;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;transition:background .15s,color .15s;display:flex;position:absolute;top:5px;right:5px}.reference-remove-btn:hover:not(:disabled){color:#fff;background:#ef4444cc}.reference-filename-overlay{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(#0000,#040d1ad9);padding:.3rem .4rem;font-size:.68rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.reference-add-more{border:1px dashed var(--border-bright);border-radius:var(--radius-md);min-height:110px;color:var(--text-secondary);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;font-size:.75rem;transition:border-color .15s,background .15s,color .15s;display:flex}.reference-add-more:hover{border-color:var(--accent-purple);color:var(--text-primary);background:#8b5cf60f}.reference-footer{justify-content:space-between;align-items:center;gap:1rem;margin-top:.75rem;display:flex}.help-text{color:var(--text-secondary);font-size:.8125rem}.help-text.warning{color:var(--accent-amber)}.page-content{animation:.2s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (width<=1024px){:root{--sidebar-width:64px}.sidebar-logo,.sidebar-brand-text{display:none}.sidebar-header{justify-content:center;padding:1.25rem 0;display:flex}.nav-section-title,.nav-item span{display:none}.nav-item{justify-content:center;padding:.75rem}.main{padding:1.5rem}}.empty-storyboard{text-align:center;cursor:pointer;border:1px dashed var(--border-bright);border-radius:var(--radius-lg);flex-direction:column;justify-content:center;align-items:center;gap:.4rem;padding:3.5rem 2rem;transition:border-color .2s,background .2s;display:flex}.empty-storyboard:hover{border-color:var(--accent-purple);background:#8b5cf60a}.storyboard-frames{scrollbar-width:thin;scrollbar-color:var(--border) transparent;gap:.75rem;padding-bottom:.75rem;display:flex;overflow-x:auto}.storyboard-frames::-webkit-scrollbar{height:4px}.storyboard-frames::-webkit-scrollbar-track{background:0 0}.storyboard-frames::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.frame-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-inset);cursor:grab;-webkit-user-select:none;user-select:none;flex-direction:column;flex-shrink:0;min-width:130px;max-width:130px;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.frame-card:hover{box-shadow:var(--glow-sm);border-color:#8b5cf64d}.frame-card:active{cursor:grabbing}.frame-index-badge{color:var(--text-secondary);z-index:2;background:#040d1ac7;border-radius:4px;padding:.1rem .35rem;font-size:.68rem;position:absolute;top:5px;left:5px}.frame-delete-btn{width:20px;height:20px;color:var(--text-secondary);cursor:pointer;z-index:2;background:#040d1ac7;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.7rem;transition:background .15s,color .15s;display:flex;position:absolute;top:5px;right:5px}.frame-delete-btn:hover{color:#fff;background:#ef4444d9}.frame-thumb{object-fit:cover;width:100%;height:90px;display:block}.frame-info{flex-direction:column;gap:.3rem;padding:.4rem .45rem;display:flex}.frame-filename{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.67rem;display:block;overflow:hidden}.frame-notes-input{border:1px solid var(--border);background:var(--bg-surface);width:100%;color:var(--text-primary);border-radius:4px;padding:.22rem .35rem;font-family:inherit;font-size:.68rem;font-weight:300}.frame-notes-input:focus{border-color:var(--accent-purple);outline:none}.frame-notes-input::placeholder{color:var(--text-muted)}.multishot-stats{color:var(--text-secondary);background:#8b5cf614;border:1px solid #8b5cf626;border-radius:999px;padding:.2rem .7rem;font-size:.8rem}.shot-list{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.shot-list-header{background:var(--bg-inset);letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);grid-template-columns:52px 120px 1fr 130px 90px;gap:.75rem;padding:.6rem 1rem;font-size:.72rem;font-weight:500;display:grid}.shot-row{border-top:1px solid var(--border);grid-template-columns:52px 120px 1fr 130px 90px;align-items:center;gap:.75rem;padding:.55rem 1rem;transition:background .15s;display:grid}.shot-row:hover{background:var(--bg-card-hover)}.shot-index{color:var(--text-secondary);font-variant-numeric:tabular-nums;font-size:.8rem;font-weight:500}.shot-thumb-pair{align-items:center;gap:.3rem;display:flex}.shot-mini-thumb{object-fit:cover;border:1px solid var(--border);border-radius:4px;width:44px;height:33px}.shot-arrow{color:var(--text-muted);font-size:1rem;line-height:1}.shot-prompt-cell{align-items:center;display:flex}.shot-prompt-input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-inset);width:100%;color:var(--text-primary);padding:.35rem .5rem;font-family:inherit;font-size:.8125rem;font-weight:300}.shot-prompt-input:focus{border-color:var(--accent-purple);outline:none;box-shadow:0 0 0 2px #8b5cf61a}.shot-prompt-input:disabled{opacity:.5}.shot-status-cell{flex-direction:column;gap:.2rem;display:flex}.shot-action-cell{align-items:center;gap:.4rem;display:flex}.multishot-overall-progress{width:100%;max-width:480px;margin-top:.25rem}.composed-video-container{flex-direction:column;align-items:center;gap:1rem;width:100%;display:flex}.composed-video-container h3{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);font-size:.8125rem;font-weight:500}.composed-video-player{border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:840px;max-height:520px;box-shadow:var(--glow-purple);background:#000}@media (width<=768px){.shot-list-header,.shot-row{grid-template-columns:40px 90px 1fr 100px}.shot-action-cell{display:none}.image-list-header,.image-item-row{grid-template-columns:120px 1fr 100px}.style-list-header.with-notes,.style-item-row.with-notes,.style-list-header.no-notes,.style-item-row.no-notes{grid-template-columns:60px 1fr 100px}.filename-cell,.actions-cell,.notes-cell{display:none}.prompt-tools{flex-direction:column}.apply-all{min-width:auto}.reference-footer{flex-direction:column;align-items:flex-start}.video-thumbnail-wrap,.video-thumbnail{width:120px;height:120px}.video-prompt-textarea{min-height:120px!important}}.screenplay-settings{flex-direction:column;gap:1.5rem;display:flex}.form-row{flex-direction:column;gap:.5rem;display:flex}.form-label{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;display:flex}.form-label-hint{text-transform:none;letter-spacing:0;color:var(--text-muted);font-size:.75rem;font-weight:400}.duration-inputs{align-items:center;gap:.75rem;display:flex}.duration-field{align-items:center;gap:.375rem;display:flex}.duration-input{text-align:center;width:72px}.duration-unit{color:var(--text-secondary);font-size:.8125rem}.duration-hint{color:var(--text-muted);border-left:1px solid var(--border);padding-left:.5rem;font-size:.8rem}.premise-wrapper{flex-direction:column;gap:.5rem;display:flex}.textarea{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);resize:vertical;box-sizing:border-box;outline:none;padding:.75rem 1rem;font-family:inherit;font-size:.9rem;font-weight:300;transition:border-color .15s}.textarea:focus{border-color:var(--border-bright)}.textarea::placeholder{color:var(--text-muted)}.premise-actions{gap:.5rem;display:flex}.style-ref-zone{border:1px dashed var(--border-bright);border-radius:var(--radius-lg);cursor:pointer;align-items:center;min-height:90px;padding:1rem;transition:border-color .15s,background .15s;display:flex}.style-ref-zone:hover,.style-ref-zone.drag-over{border-color:var(--accent-purple);background:#8b5cf60d}.style-ref-zone.zone-full{cursor:default;border-style:solid;border-color:var(--border)}.style-ref-empty{width:100%;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:.375rem;padding:.5rem 0;font-size:.875rem;display:flex}.style-ref-hint{color:var(--text-muted);font-size:.75rem}.style-ref-thumbs{flex-wrap:wrap;gap:.5rem;width:100%;display:flex}.style-ref-thumb{border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0;width:72px;height:72px;position:relative;overflow:hidden}.style-ref-thumb img{object-fit:cover;width:100%;height:100%}.style-ref-remove{color:#fff;cursor:pointer;opacity:0;background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;transition:opacity .15s;display:flex;position:absolute;top:3px;right:3px}.style-ref-thumb:hover .style-ref-remove{opacity:1}.style-ref-add{border-radius:var(--radius-sm);border:1px dashed var(--border-bright);width:72px;height:72px;color:var(--text-secondary);justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.style-ref-add:hover{border-color:var(--accent-purple);color:var(--accent-purple)}.screenplay-output{flex-direction:column;gap:1rem;margin-top:2rem;display:flex}.screenplay-toolbar{justify-content:space-between;align-items:center;gap:1rem;display:flex}.screenplay-meta{align-items:center;gap:.5rem;display:flex}.screenplay-badge{color:var(--accent-purple);background:#8b5cf61f;border:1px solid #8b5cf640;border-radius:20px;padding:.2rem .65rem;font-size:.75rem;font-weight:500}.screenplay-badge-mode{color:var(--text-secondary);background:var(--bg-inset);border-color:var(--border)}.screenplay-title{color:var(--text-primary);margin-right:.25rem;font-size:.875rem;font-weight:500}.screenplay-toolbar-actions{gap:.5rem;display:flex}.btn-ghost.btn-danger{color:var(--accent-red);border-color:#ef444440}.btn-ghost.btn-danger:hover:not(:disabled){color:var(--accent-red);background:#ef444414;border-color:#ef444466}.script-table-wrapper{border-radius:var(--radius-lg);border:1px solid var(--border);overflow-x:auto}.script-table{border-collapse:collapse;width:100%;font-size:.8375rem;font-weight:300;line-height:1.55}.script-header-row th{background:var(--bg-inset);text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);border-bottom:1px solid var(--border);padding:.6rem 1rem;font-size:.72rem;font-weight:500}.script-col-shot{width:64px;text-align:center!important}.script-col-scene{width:38%}.script-col-movement{width:22%}.script-col-sound{width:auto}.script-vo-row{background:#8b5cf60a}.script-vo{color:var(--text-secondary);border-bottom:1px solid var(--border);padding:.875rem 1.5rem;font-size:.875rem;font-style:italic;line-height:1.7}.script-vo-label{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-purple);opacity:.8;margin-right:.75rem;font-size:.68rem;font-style:normal;font-weight:600;display:inline-block}.script-shot-row{border-bottom:1px solid var(--border);transition:background .1s}.script-shot-row:last-child{border-bottom:none}.script-shot-row:hover{background:#ffffff05}.script-shot-num{text-align:center;color:var(--accent-purple);vertical-align:top;white-space:nowrap;padding:.875rem .5rem;font-size:.8rem;font-weight:600}.script-cell{color:var(--text-primary);vertical-align:top;padding:.875rem 1rem}.script-scene{color:var(--text-primary)}.script-movement,.script-sound{color:var(--text-secondary)}.screenplay-modes{flex-wrap:wrap;align-items:center;gap:.375rem;display:flex}.mode-group{border:1px solid var(--border);border-radius:var(--radius-md);flex-shrink:0;display:flex;overflow:hidden}.mode-group .mode-toggle{border:none;border-right:1px solid var(--border);border-radius:0}.mode-group .mode-toggle:last-child{border-right:none}.mode-toggle{color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;background:0 0;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.78rem;font-weight:500;transition:color .15s,background .15s,border-color .15s;display:inline-flex}.mode-toggle:hover{color:var(--text-primary);background:#ffffff0a}.mode-toggle.active{color:var(--accent-purple);background:#8b5cf61f;border-color:#8b5cf659}.form-hint{color:var(--text-muted);margin:0;font-size:.78rem;line-height:1.5}.script-voiceover-block{border-radius:var(--radius-lg);color:var(--text-secondary);background:#8b5cf60a;border:1px solid #8b5cf626;align-items:flex-start;gap:.75rem;padding:.875rem 1.25rem;font-size:.875rem;font-style:italic;line-height:1.7;display:flex}.script-vo-text{flex:1}.script-characters-bar{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;align-items:center;gap:.5rem;padding:.625rem 1rem;display:flex}.script-characters-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);flex-shrink:0;align-items:center;gap:.35rem;margin-right:.25rem;font-size:.72rem;font-weight:600;display:inline-flex}.script-character-chip{color:var(--text-primary);border:1px solid var(--border-bright);background:#ffffff0d;border-radius:20px;padding:.15rem .6rem;font-size:.78rem;font-weight:500}.script-dialogue-row{background:#ffffff04;border-bottom:1px dashed #ffffff0f}.script-dialogue-row:last-child{border-bottom:none}.script-dialogue-cell{padding:.625rem 1rem .625rem 3rem;font-size:.85rem}.script-dialogue-char{letter-spacing:.08em;text-transform:uppercase;color:var(--accent-purple);opacity:.9;vertical-align:top;min-width:5rem;margin-right:.875rem;font-size:.72rem;font-weight:700;display:inline-block}.script-dialogue-line{color:var(--text-secondary);font-style:italic;line-height:1.6}.script-chars-present{color:var(--text-muted);margin-top:.3rem;font-size:.72rem;font-style:italic;display:block}.char-workspace{height:calc(100vh - 60px);margin:-1.5rem;display:flex;overflow:hidden}.char-list-panel{border-right:1px solid var(--border);background:var(--bg-surface);flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow:hidden}.char-list-scroll{flex:1;overflow-y:auto}.char-detail-panel{flex:1;padding:1.5rem;overflow-y:auto}.char-list-controls{border-bottom:1px solid var(--border);flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.char-list-control-row{justify-content:space-between;align-items:center;gap:.25rem;display:flex}.char-new-input-row{border-bottom:1px solid var(--border);background:var(--bg-inset);gap:.4rem;padding:.5rem .75rem;display:flex}.char-list-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:.65rem;padding:.65rem .75rem;transition:background .15s;display:flex;position:relative}.char-list-item:hover{background:var(--bg-card-hover)}.char-list-item.selected{border-left:2px solid var(--accent-purple);background:#8b5cf614;padding-left:calc(.75rem - 2px)}.char-list-thumb{border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;width:40px;height:40px}.char-list-thumb-ph{border-radius:var(--radius-sm);background:var(--bg-inset);border:1px solid var(--border);width:40px;height:40px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.char-list-meta{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.char-list-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.char-list-role{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;overflow:hidden}.char-list-delete{opacity:0;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:.25rem;transition:opacity .15s,color .15s;display:flex;position:absolute;top:50%;right:.5rem;transform:translateY(-50%)}.char-list-item:hover .char-list-delete{opacity:1}.char-list-delete:hover{color:var(--accent-red)}.char-source-badge{letter-spacing:.04em;text-transform:uppercase;border:1px solid;border-radius:999px;width:fit-content;padding:.1rem .4rem;font-size:.62rem;font-weight:500;display:inline-block}.char-source-screenplay{color:var(--accent-cyan);background:#06b6d414;border-color:#06b6d44d}.char-source-manual{color:var(--text-secondary);border-color:var(--border);background:0 0}.char-source-generated{color:var(--accent-purple);background:#8b5cf614;border-color:#8b5cf64d}.char-source-merged{color:var(--accent-green);background:#10b98114;border-color:#10b9814d}.char-detail-header{flex-wrap:wrap;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.char-detail-name-row{flex-direction:column;flex:1;gap:.4rem;min-width:180px;display:flex}.char-detail-name-input{color:var(--text-primary);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;width:100%;padding:.1rem 0;font-size:1.1rem;font-weight:600;transition:border-color .15s}.char-detail-name-input:focus{border-bottom-color:var(--border-bright)}.char-detail-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:.5rem;display:flex}.char-sheet-area{background:var(--bg-inset);border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:1.25rem;overflow:hidden}.char-sheet-img{object-fit:contain;width:100%;max-height:360px;display:block}.char-sheet-ph{height:160px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:1rem;font-size:.8125rem;display:flex}.char-tabs{border-bottom:1px solid var(--border);margin-bottom:1.25rem;display:flex;overflow-x:auto}.char-tab-btn{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;flex-shrink:0;margin-bottom:-1px;padding:.5rem .9rem;font-size:.8rem;font-weight:500;transition:color .15s,border-color .15s}.char-tab-btn:hover{color:var(--text-primary)}.char-tab-btn.active{color:var(--accent-purple);border-bottom-color:var(--accent-purple)}.char-empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2.5rem 1rem;font-size:.875rem;display:flex}.char-no-selection{height:60%;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.char-visual-style-row{color:var(--text-secondary);flex-wrap:wrap;align-items:center;gap:.4rem;font-size:.8125rem;display:flex}.spinner-sm{border:2px solid #ffffff40;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:13px;height:13px;animation:.6s linear infinite spin;display:inline-block}.error-banner{border-radius:var(--radius-md);color:var(--accent-red);background:#ef44441a;border:1px solid #ef44444d;padding:.625rem 1rem;font-size:.85rem}@media (width<=768px){.script-col-movement,.script-movement{display:none}.script-col-shot{width:48px}}.storyboard-actions-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.storyboard-actions-left{flex-wrap:wrap;gap:.5rem;display:flex}.storyboard-actions-right{gap:.5rem;display:flex}.storyboard-empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:4rem 2rem;font-size:.9rem;display:flex}.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.storyboard-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);cursor:grab;flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.storyboard-card:hover{border-color:var(--border-bright);box-shadow:var(--glow-sm)}.storyboard-card:active{cursor:grabbing}.storyboard-card.card-busy{opacity:.85;cursor:default}.storyboard-card.card-dragging{opacity:.45;transform:scale(.98)}.storyboard-card.card-drop-target{border-color:var(--accent-purple);box-shadow:var(--glow-purple), inset 0 0 0 1px #8b5cf640}.storyboard-card-thumb-wrap{aspect-ratio:16/9;background:var(--bg-inset);width:100%;position:relative;overflow:hidden}.storyboard-card-thumb{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.storyboard-card-placeholder{background:linear-gradient(135deg, var(--bg-inset) 0%, var(--bg-surface) 100%);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.storyboard-index-badge{letter-spacing:.05em;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8b5cf6d9;border-radius:4px;padding:.15rem .4rem;font-size:.7rem;font-weight:600;position:absolute;top:6px;left:6px}.storyboard-status-overlay{position:absolute;bottom:6px;left:6px}.storyboard-generating-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#040d1a99;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.storyboard-card-body{flex:1;padding:.6rem .75rem}.storyboard-card-prompt{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-size:.78rem;line-height:1.45;display:-webkit-box;overflow:hidden}.storyboard-card-prompt em{color:var(--text-muted);font-style:italic}.storyboard-card-actions{border-top:1px solid var(--border);background:var(--bg-inset);gap:.25rem;padding:.4rem .5rem;display:flex}.storyboard-card-add{cursor:pointer;border:1px solid var(--border);min-height:224px;color:var(--text-secondary);background:#64748b26;transition:background .15s,color .15s,border-color .15s}.storyboard-card-add .storyboard-card-thumb-wrap{background:0 0}.storyboard-card-add-body{background:0 0;min-height:3.35rem}.storyboard-card-add-actions{background:0 0;border-top:none;min-height:2.05rem}.storyboard-card-add:hover,.storyboard-card-add:focus-visible{color:var(--text-primary);border-color:var(--border-bright);background:#64748b40;outline:none}.storyboard-card-add:hover .storyboard-card-thumb-wrap,.storyboard-card-add:focus-visible .storyboard-card-thumb-wrap{background:0 0}.storyboard-card-add-content{color:var(--text-secondary);pointer-events:none;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;transition:color .18s;display:flex;position:absolute;inset:0}.storyboard-card-add:hover .storyboard-card-add-content,.storyboard-card-add:focus-visible .storyboard-card-add-content{color:var(--text-primary)}.storyboard-card-add-content span{letter-spacing:.12em;text-transform:uppercase;font-size:.8rem;font-weight:600}.modal-backdrop{z-index:1000;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#040d1ad9;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius-xl);width:min(940px,95vw);max-height:90vh;box-shadow:var(--glow-purple), 0 32px 64px #00000080;flex-direction:row;display:flex;position:relative;overflow:hidden}.modal-close{z-index:10;position:absolute;top:.75rem;right:.75rem}.modal-img-panel{background:#000;flex:3;justify-content:center;align-items:center;min-height:320px;display:flex;position:relative;overflow:hidden}.modal-img{object-fit:contain;width:100%;height:100%;position:absolute;inset:0}.modal-img-placeholder{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;font-size:.875rem;display:flex}.modal-canvas{pointer-events:none;touch-action:none;width:100%;height:100%;position:absolute;inset:0}.modal-canvas.draw-active{pointer-events:auto;cursor:crosshair}.modal-draw-toolbar{border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#071224d9;border-radius:30px;align-items:center;gap:.4rem;padding:.35rem .6rem;display:flex;position:absolute;bottom:.75rem;left:50%;transform:translate(-50%)}.draw-color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:18px;height:18px;transition:border-color .1s,transform .1s}.draw-color-swatch.active{border-color:var(--accent-purple);transform:scale(1.2)}.draw-width-btn{min-width:24px;padding:0 .25rem}.draw-width-btn.active{color:var(--accent-purple);border-color:var(--border-bright)}.modal-side{border-left:1px solid var(--border);flex-direction:column;flex:2;gap:1rem;min-width:280px;max-width:360px;padding:1.25rem;display:flex;overflow-y:auto}.modal-side-header{flex-wrap:wrap;align-items:center;gap:.5rem;padding-right:2rem;display:flex}.modal-shot-num{font-size:.8rem;position:static}.modal-source-label{color:var(--text-muted);font-size:.72rem;font-style:italic}.modal-section-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);align-items:center;gap:.4rem;margin-bottom:.35rem;font-size:.72rem;font-weight:500;display:flex}.modal-history-row{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.modal-actions{border-top:1px solid var(--border);flex-wrap:wrap;gap:.4rem;margin-top:auto;padding-top:.75rem;display:flex}@media (width<=768px){.modal{flex-direction:column;max-height:95vh}.modal-img-panel{flex:none;height:240px}.modal-side{border-left:none;border-top:1px solid var(--border);max-width:none}.storyboard-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.storyboard-card-add{min-height:190px}.storyboard-actions-bar{flex-direction:column;align-items:flex-start}}.touchup-settings-bar{align-items:center;padding:1rem 1.25rem;display:flex}.touchup-settings-fields{flex-wrap:wrap;align-items:flex-end;gap:1.5rem;display:flex}.touchup-setting-group{flex-direction:column;gap:.35rem;display:flex}.touchup-setting-label{letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);font-size:.72rem;font-weight:500}.select-wrap{align-items:center;display:inline-flex;position:relative}.touchup-select{appearance:none;background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;padding:.45rem 2rem .45rem .75rem;font-family:inherit;font-size:.85rem;transition:border-color .15s}.touchup-select:hover,.touchup-select:focus{border-color:var(--border-bright);outline:none}.touchup-select:disabled{opacity:.5;cursor:not-allowed}.select-chevron{color:var(--text-secondary);pointer-events:none;position:absolute;right:.6rem}.touchup-dropzone{border:1.5px dashed var(--border-bright);border-radius:var(--radius-lg);background:var(--bg-inset);color:var(--text-secondary);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;transition:border-color .15s,background .15s,color .15s;display:flex}.touchup-dropzone:hover{border-color:var(--accent-purple);color:var(--text-primary);background:#8b5cf60f}.touchup-dropzone-title{color:var(--text-primary);font-size:1rem;font-weight:500}.touchup-dropzone-hint{color:var(--text-secondary);font-size:.8rem}.touchup-apply-bar{align-items:flex-start;gap:.75rem;padding:.75rem 1.25rem;display:flex}.touchup-apply-textarea{resize:vertical;flex:1;min-height:56px}.touchup-apply-actions{flex-direction:column;flex-shrink:0;gap:.4rem;display:flex}.touchup-table-section{padding:0;overflow:hidden}.touchup-table{flex-direction:column;display:flex}.touchup-table-header,.touchup-table-row{grid-template-columns:36px 120px 1fr 160px 110px 72px;align-items:start;gap:0;display:grid}.touchup-table-header{background:var(--bg-inset);border-bottom:1px solid var(--border);letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);padding:.55rem 1.25rem;font-size:.7rem;font-weight:600}.touchup-table-header>div,.touchup-table-row>div{padding:.6rem .5rem}.touchup-table-header>div:first-child,.touchup-table-row>div:first-child{padding-left:1.25rem}.touchup-table-header>div:last-child,.touchup-table-row>div:last-child{padding-right:1.25rem}.touchup-table-row{border-bottom:1px solid var(--border);align-items:center;transition:background .1s}.touchup-table-row:hover{background:#8b5cf608}.touchup-table-row.row-complete{background:#10b98108}.touchup-table-row.row-error{background:#ef44440a}.tu-col-num{align-items:center;display:flex}.tu-col-thumb{flex-direction:column;align-items:center;gap:.3rem;display:flex}.tu-col-prompt{align-self:stretch;align-items:center;display:flex}.tu-col-tools{flex-direction:column;justify-content:center;align-self:stretch;gap:.4rem;display:flex}.tu-col-status{flex-direction:column;justify-content:center;align-self:stretch;gap:.35rem;display:flex}.tu-col-actions{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.tu-row-num{letter-spacing:.05em;color:var(--text-muted);background:#8b5cf626;border-radius:4px;padding:.15rem .35rem;font-size:.72rem;font-weight:600}.tu-thumb-wrap{aspect-ratio:16/9;border-radius:var(--radius-sm);background:var(--bg-inset);flex-shrink:0;width:96px;position:relative;overflow:hidden}.tu-thumb{object-fit:cover;width:100%;height:100%}.tu-filename{color:var(--text-secondary);text-align:center;word-break:break-all;font-size:.68rem;line-height:1.3}.tu-markup-indicator{background:var(--accent-purple);border-radius:50%;width:8px;height:8px;position:absolute;top:4px;right:4px;box-shadow:0 0 6px #8b5cf699}.tu-thumb-overlay{background:#040d1a99;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.tu-prompt-textarea{resize:vertical;width:100%;min-height:64px}.touchup-omni-ref-group{border-left:1px solid var(--border);margin-left:.5rem;padding-left:1.5rem}.tu-omni-ref-thumb,.tu-omni-ref-add{width:40px;height:40px}.tu-refs-row{flex-wrap:wrap;align-items:center;gap:.3rem;display:flex}.tu-ref-thumb{border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0;width:32px;height:32px;position:relative;overflow:hidden}.tu-ref-thumb img{object-fit:cover;width:100%;height:100%}.tu-ref-remove{color:#fff;cursor:pointer;opacity:0;background:#040d1abf;border:none;border-radius:2px;justify-content:center;align-items:center;width:14px;height:14px;transition:opacity .15s;display:flex;position:absolute;top:1px;right:1px}.tu-ref-thumb:hover .tu-ref-remove{opacity:1}.tu-ref-add{border:1.5px dashed var(--border-bright);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);flex-shrink:0;justify-content:center;align-items:center;transition:border-color .15s,color .15s;display:flex}.tu-ref-add:hover{border-color:var(--accent-purple);color:var(--accent-purple)}.tu-markup-btn{align-self:flex-start}.tu-markup-btn.has-markup{color:var(--accent-purple);border-color:#8b5cf64d}.tu-progress-bar{background:var(--bg-inset);border-radius:2px;width:100%;height:3px;overflow:hidden}.tu-progress-fill{background:var(--grad-primary);border-radius:2px;height:100%;transition:width .4s}.tu-error-text{color:var(--accent-red);font-size:.68rem;line-height:1.3}.touchup-markup-modal{max-width:860px}.spin{animation:.8s linear infinite spin}@media (width<=900px){.touchup-table-header,.touchup-table-row{grid-template-columns:36px 100px 1fr 130px 90px 60px}}.sidebar-project-ctx{border-bottom:1px solid var(--border);align-items:center;gap:.4rem;margin-bottom:.25rem;padding:.5rem .75rem .6rem;display:flex}.sidebar-project-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.78rem;font-weight:600;overflow:hidden}.sidebar-project-switch{color:var(--text-secondary);flex-shrink:0;gap:.25rem;padding:.2rem .5rem;font-size:.7rem}.sidebar-project-switch:hover{color:var(--accent-purple)}.projects-page-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.project-create-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.project-create-icon{color:var(--text-secondary);align-items:center;display:flex}.project-name-input{flex:1;min-width:160px}.project-create-error{width:100%;color:var(--accent-red);font-size:.78rem}.project-hero{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:5rem 2rem;display:flex}.project-hero-icon{color:var(--text-muted);opacity:.6}.project-hero-title{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:600}.project-hero-subtitle{color:var(--text-secondary);max-width:320px;margin:0;font-size:.9rem}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.project-card:hover{border-color:var(--border-bright);box-shadow:var(--glow-sm)}.project-card-confirming{border-color:var(--accent-red)}.project-card-body{flex-direction:column;flex:1;gap:.35rem;padding:1.1rem 1.1rem .75rem;display:flex}.project-card-name{color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.3}.project-card-meta{color:var(--text-secondary);font-size:.75rem}.project-card-actions{border-top:1px solid var(--border);align-items:center;gap:.4rem;padding:.6rem .75rem;display:flex}.project-card-confirm{border-top:1px solid #ef44444d;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.6rem .75rem;display:flex}.project-confirm-label{color:var(--accent-red);flex:1;font-size:.78rem}.project-rename-row{align-items:center;gap:.4rem;display:flex}.project-rename-row .input{flex:1;padding:.3rem .5rem;font-size:.85rem}.char-tag{color:var(--accent-purple);white-space:nowrap;background:#8b5cf61f;border:1px solid #8b5cf640;border-radius:999px;align-items:center;gap:2px;padding:.1rem .4rem;font-size:.65rem;font-weight:500;display:inline-flex}.char-tag-list{flex-wrap:wrap;gap:.25rem;display:flex}.char-picker{flex-wrap:wrap;gap:.3rem;display:flex}.char-picker-chip{border:1px solid var(--border);cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border-radius:999px;padding:.2rem .55rem;font-size:.75rem;transition:border-color .15s,color .15s,background .15s}.char-picker-chip:hover{color:var(--accent-purple);border-color:#8b5cf680}.char-picker-chip.active{color:var(--accent-purple);background:#8b5cf626;border-color:#8b5cf666}.auth-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--glow-purple), 0 32px 64px #00000080;padding:2.5rem 2rem}.auth-logo{justify-content:center;align-items:center;gap:.6rem;margin-bottom:2rem;display:flex}.auth-logo-img{width:28px;height:28px}.auth-brand{background:var(--grad-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:600}.auth-title{color:var(--text-primary);text-align:center;margin:0 0 .4rem;font-size:1.5rem;font-weight:600}.auth-subtitle{color:var(--text-secondary);text-align:center;margin:0 0 1.5rem;font-size:.9rem;line-height:1.5}.auth-subtitle strong{color:var(--text-primary)}.auth-form{flex-direction:column;gap:1rem;margin-bottom:1rem;display:flex}.auth-error{margin-bottom:1rem}.auth-forgot{text-align:right;margin-top:-.5rem;font-size:.8rem}.auth-forgot a,.auth-switch a{color:var(--accent-purple);text-decoration:none}.auth-forgot a:hover,.auth-switch a:hover{text-decoration:underline}.auth-switch{color:var(--text-secondary);text-align:center;margin:1rem 0 0;font-size:.875rem}.auth-icon-row{justify-content:center;margin-bottom:1.25rem;display:flex}.auth-icon-mail{color:var(--accent-purple);opacity:.8}.sidebar-user-actions{gap:4px;width:100%;display:flex}.sidebar-billing-btn{flex:1;justify-content:center}.sidebar-billing-btn.active{color:var(--accent-purple)}.billing-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:1.25rem;padding:1.5rem}.billing-section-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.billing-section-title{color:var(--text-primary);margin:0;font-size:.9375rem;font-weight:600}.billing-empty{color:var(--text-secondary);margin:0;font-size:.875rem}.billing-pm-row{border-radius:var(--radius-md);background:var(--bg-inset);border:1px solid var(--border);justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.625rem .75rem;display:flex}.billing-pm-row.billing-pm-default{border-color:#8b5cf64d}.billing-pm-info{color:var(--text-primary);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.billing-pm-icon{color:var(--text-secondary);flex-shrink:0}.billing-pm-brand{font-weight:500}.billing-pm-last4{color:var(--text-secondary);letter-spacing:.05em;font-family:monospace}.billing-pm-exp{color:var(--text-secondary);font-size:.8125rem}.billing-pm-badge{color:var(--accent-purple);background:#8b5cf61f;border:1px solid #8b5cf633;border-radius:999px;align-items:center;gap:3px;padding:1px 6px;font-size:.75rem;display:inline-flex}.billing-pm-actions{flex-shrink:0;align-items:center;gap:.375rem;display:flex}.billing-pm-remove{opacity:.7;color:var(--accent-red)!important}.billing-pm-remove:hover{opacity:1}.billing-add-card-panel{background:var(--bg-inset);border:1px solid var(--border);border-radius:var(--radius-md);margin-top:1rem;padding:1rem}.billing-add-card-form{flex-direction:column;gap:.75rem;display:flex}.billing-card-element-wrap{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.625rem .75rem}.billing-card-element-wrap:focus-within{border-color:var(--border-bright)}.billing-card-error{font-size:.8125rem}.billing-add-card-actions{justify-content:flex-end;gap:.5rem;display:flex}.billing-action-msg{margin-bottom:.75rem}.billing-section-coming-soon{opacity:.6}.billing-coming-soon-text{color:var(--text-secondary);margin:0;font-size:.875rem}.success-banner{border-radius:var(--radius-sm);color:var(--accent-green);background:#10b9811a;border:1px solid #10b98140;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:flex}.auth-success{text-align:center;color:var(--accent-green);margin:.5rem 0;font-size:.875rem}
