:root{color-scheme:light;--bg: #f7f9fc;--bg-elevated: #ffffff;--bg-soft: #eef4f8;--surface: #ffffff;--surface-muted: #f4f7fa;--surface-strong: #e8eef4;--ink: #0f172a;--ink-soft: #334155;--muted: #64748b;--muted-strong: #475569;--line: #d8e0e8;--line-strong: #b9c6d3;--primary: #163a5f;--primary-strong: #0d2744;--primary-soft: #e6f0f8;--accent: #047857;--accent-strong: #065f46;--accent-soft: #dff7ed;--warning: #b45309;--warning-soft: #fff4de;--danger: #b42318;--danger-soft: #fff0ed;--focus: #2563eb;--shadow-sm: 0 1px 2px rgb(15 23 42 / 6%);--shadow-md: 0 10px 30px rgb(15 23 42 / 10%);--shadow-lg: 0 24px 60px rgb(15 23 42 / 12%);--radius: 8px;--radius-sm: 6px;--control: 3rem;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:16px}*{box-sizing:border-box}html{scroll-behavior:smooth}[hidden]{display:none!important}body{min-width:320px;margin:0;overflow-x:clip;color:var(--ink);background:linear-gradient(180deg,#ffffffdb,#f7f9fc00 18rem),linear-gradient(90deg,rgb(22 58 95 / 5%) 1px,transparent 1px),linear-gradient(rgb(22 58 95 / 5%) 1px,transparent 1px),var(--bg);background-size:auto,44px 44px,44px 44px,auto}body:before{position:fixed;inset:0;z-index:-1;pointer-events:none;content:"";background:linear-gradient(130deg,rgb(22 58 95 / 10%),transparent 34rem),linear-gradient(320deg,rgb(4 120 87 / 8%),transparent 30rem)}button,textarea,input,select{font:inherit}button,select,input,textarea,a{-webkit-tap-highlight-color:transparent}button,a,label.reference-drop{touch-action:manipulation}button{cursor:pointer}button:disabled{cursor:not-allowed}:focus{outline:none}:focus-visible{outline:3px solid rgb(37 99 235 / 55%);outline-offset:3px}.skip-link{position:fixed;top:.75rem;left:.75rem;z-index:100;min-height:2.75rem;padding:.7rem 1rem;border-radius:var(--radius-sm);color:#fff;background:var(--primary-strong);box-shadow:var(--shadow-md);transform:translateY(calc(-100% - 1rem));transition:transform .18s ease}.skip-link:focus-visible{transform:translateY(0)}.shell{position:relative;width:min(1720px,calc(100% - 2rem));min-height:100dvh;margin:0 auto;padding:1.5rem 0 3rem}.hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(25rem,36rem);gap:1.25rem;align-items:end;margin-bottom:1.25rem}.hero>div:first-of-type{min-width:0}.eyebrow{margin:0 0 .6rem;color:var(--accent-strong);font-size:.76rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.hero .eyebrow{grid-column:1 / -1}h1,h2{margin:0;color:var(--ink);letter-spacing:0}h1{max-width:17ch;font-size:4.25rem;font-weight:850;line-height:.98}h2{font-size:1.15rem;font-weight:800;line-height:1.2}.lede{max-width:58rem;margin:.95rem 0 0;color:var(--muted-strong);font-size:1.05rem;line-height:1.65}.status-card,.panel{min-width:0;border:1px solid var(--line);border-radius:var(--radius);background:#ffffffe0;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.status-card{padding:1rem}.status-kicker,.status-card small{display:block;color:var(--muted)}.status-card strong{display:block;margin:.3rem 0;color:var(--primary-strong);line-height:1.35;overflow-wrap:anywhere}.relay-controls{display:grid;gap:.75rem;margin-top:.9rem;padding-top:.9rem;border-top:1px solid var(--line)}.relay-form{display:flex;flex-wrap:wrap;gap:.65rem;align-items:end}.relay-form label{flex:1 1 10rem;min-width:0}.relay-form label:has([data-relay-scope]){flex-basis:11.5rem}.workspace{display:grid;grid-template-areas:"control history gallery";grid-template-columns:minmax(19rem,.68fr) minmax(21rem,.82fr) minmax(0,1.68fr);gap:1.25rem;align-items:start;min-width:0}.control-panel{grid-area:control;position:sticky;top:1rem;padding:1.25rem}.history-panel,.gallery-panel{display:flex;flex-direction:column;min-height:34rem;padding:1.25rem}.history-panel{grid-area:history}.gallery-panel{grid-area:gallery}.mode-group,.settings-group{min-width:0;margin:1rem 0;padding:0;border:0}.mode-group legend{margin-bottom:.7rem;padding:0}.mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(11rem,1fr));gap:.75rem}.mode-card{display:grid;gap:.35rem;min-width:0;padding:.9rem .95rem;border:1px solid var(--line-strong);border-radius:var(--radius);color:var(--ink);background:linear-gradient(180deg,#fffffff5,#f4f7faeb),var(--surface);text-align:left;box-shadow:var(--shadow-sm);transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease,transform .18s ease}.mode-card strong{color:var(--ink);font-size:.95rem;font-weight:850;line-height:1.25}.mode-card small{color:var(--muted-strong);line-height:1.5}.mode-card:hover{border-color:#a7b6c7;box-shadow:var(--shadow-md);transform:translateY(-1px)}.mode-card:focus-visible,.mode-card.is-active{border-color:#0478576b;box-shadow:0 0 0 1px #0478571a,var(--shadow-md)}.mode-card.is-active{background:linear-gradient(180deg,#fff,#dff7ed8c),var(--surface)}.mode-card.is-active strong{color:var(--accent-strong)}.mode-card.is-active small{color:var(--ink-soft)}.source-origin{display:flex;align-items:flex-start;gap:.5rem;margin-top:.65rem;padding:.7rem .8rem;border:1px solid rgb(4 120 87 / 18%);border-radius:var(--radius-sm);color:var(--accent-strong);background:var(--accent-soft);box-shadow:var(--shadow-sm);line-height:1.45;overflow-wrap:anywhere}.mask-field{display:grid;gap:.75rem;min-width:0;margin-top:1rem}.mask-toolbar{display:flex;flex-wrap:wrap;gap:.65rem;align-items:flex-end}.mask-toolbar label{flex:1 1 10rem;min-width:0}.mask-toolbar button{flex:1 1 6.5rem;min-width:0;padding:0 .95rem;white-space:nowrap}.mask-stage{position:relative;display:grid;min-height:18rem;overflow:hidden;border:1px solid var(--line-strong);border-radius:var(--radius);background:radial-gradient(circle at top left,rgb(22 58 95 / 10%),transparent 35%),linear-gradient(135deg,#fffffff5,#eef4f8eb);box-shadow:var(--shadow-sm)}.mask-stage-empty{display:grid;min-height:inherit;place-items:center;padding:1rem;color:var(--muted-strong);text-align:center;line-height:1.55;background:repeating-linear-gradient(45deg,rgb(15 23 42 / 3%) 0 10px,transparent 10px 20px)}.image-actions{display:grid;grid-template-columns:minmax(0,1fr);gap:.6rem;padding:0 .85rem .85rem}.image-actions .download,.ghost-button{width:100%;min-width:0;height:2.75rem;min-height:2.75rem;padding:0 .9rem;border:1px solid var(--line-strong);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-actions .download{display:flex;align-items:center;justify-content:center;border:1px solid var(--line-strong);background:var(--surface)}.ghost-button{color:var(--primary);background:var(--surface-muted);font-weight:850}.ghost-button:hover{border-color:var(--primary);color:var(--primary-strong);background:var(--primary-soft)}.ghost-button:disabled:hover{border-color:var(--line-strong);color:var(--primary);background:var(--surface-muted)}.output-copy-button.is-copied{border-color:#04785757;color:var(--accent-strong);background:var(--accent-soft)}.output-copy-button.is-copied:hover{border-color:#0478576b;color:var(--accent-strong);background:var(--accent-soft)}.image-actions .output-copy-button:disabled{opacity:1;color:var(--muted-strong);background:var(--surface-muted);border-color:var(--line);box-shadow:none}.image-actions .output-copy-button:disabled:hover{color:var(--muted-strong);background:var(--surface-muted);border-color:var(--line)}.trash-button{color:var(--danger);background:#fff;border-color:#b4231847}.trash-button:not(:disabled):hover{color:#fff;background:var(--danger);border-color:var(--danger)}.trash-button:disabled:hover{color:var(--danger);background:#fff;border-color:#b4231847}.reference-chip-output{margin-top:.75rem;border-color:#163a5f38;background:linear-gradient(180deg,#fff,#e6f0f8eb),var(--surface)}.reference-chip-output button{color:var(--primary)}.history-body,.gallery-body{min-height:0}.history-body,.gallery-body{flex:1}label,label span{display:block}label span,.reference-label>span,.settings-group legend,.relay-controls label span{margin-bottom:.45rem;color:var(--primary);font-size:.76rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.settings-group{min-width:0;margin:1rem 0;padding:0;border:0}.settings-group legend{margin-bottom:.7rem;padding:0}textarea,input,select{width:100%;min-height:var(--control);border:1px solid var(--line-strong);border-radius:var(--radius-sm);color:var(--ink);background:var(--surface);box-shadow:var(--shadow-sm)}textarea::placeholder,input::placeholder{color:#8291a5}textarea:hover,input:hover,select:hover{border-color:#8fa0b3}textarea:focus,input:focus,select:focus{border-color:var(--focus);box-shadow:0 0 0 4px #2563eb24}textarea{min-height:15rem;padding:1rem;line-height:1.6;resize:vertical}input,select{padding:0 .85rem}select{appearance:none;padding-right:2.4rem;background-image:linear-gradient(45deg,transparent 50%,var(--muted-strong) 50%),linear-gradient(135deg,var(--muted-strong) 50%,transparent 50%);background-position:calc(100% - 1.15rem) 52%,calc(100% - .82rem) 52%;background-size:.38rem .38rem,.38rem .38rem;background-repeat:no-repeat}input[type=file]{position:absolute;width:1px;min-height:0;padding:0;border:0;opacity:0;pointer-events:none}.field-help,.hint{margin:.65rem 0 0;color:var(--muted-strong);font-size:.9rem;line-height:1.55}.batch-entry{display:grid;gap:.5rem;min-width:0;margin:.85rem 0 1rem}.batch-entry .field-help,.batch-entry small{margin:0;color:var(--muted);font-size:.84rem;font-weight:700;line-height:1.45}.reference-field{min-width:0;margin-top:1rem}.reference-field>*,.mask-field>*{min-width:0}.reference-label,.history-head,.gallery-head{display:flex;gap:1rem;align-items:end;justify-content:space-between}.reference-label small,.history-head-meta span,.gallery-head span{color:var(--muted);font-size:.9rem;font-weight:800}.gallery-head-meta{display:flex;gap:.65rem;align-items:center}.save-selected{min-height:2.4rem;padding:.45rem .8rem;border:1px solid rgb(4 120 87 / 28%);border-radius:var(--radius-sm);color:var(--accent-strong);font-size:.82rem;font-weight:850;background:var(--accent-soft);box-shadow:var(--shadow-sm)}.save-selected:hover{border-color:var(--accent);color:#fff;background:var(--accent)}.save-selected:disabled,.save-selected:disabled:hover{border-color:var(--line-strong);color:var(--muted);background:var(--surface-muted)}.reference-drop{position:relative;display:grid;min-height:6.5rem;padding:1rem;border:1px dashed var(--line-strong);border-radius:var(--radius);place-items:center;text-align:center;background:linear-gradient(180deg,#ffffffe5,#f4f7fae5),var(--surface);cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.reference-drop:hover,.reference-drop:focus-within{border-color:var(--focus);box-shadow:0 0 0 4px #2563eb1f}.reference-drop strong{color:var(--ink);font-weight:850}.reference-drop small{margin-top:.3rem;color:var(--muted)}.reference-list{display:grid;gap:.65rem;margin-top:.75rem}.reference-cache,.relay-message,.progress,.error-message{margin:0;padding:.75rem .85rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:750;line-height:1.45}.reference-cache,.relay-message{color:var(--accent-strong);background:var(--accent-soft);border:1px solid rgb(4 120 87 / 20%)}.reference-cache{margin-top:.75rem}.error-message{margin-top:.75rem;color:var(--danger);background:var(--danger-soft);border:1px solid rgb(180 35 24 / 22%)}.relay-key-state{color:var(--muted-strong);font-size:.84rem;line-height:1.4}.reference-chip{display:grid;grid-template-columns:3.5rem minmax(0,1fr) 2.75rem;gap:.75rem;align-items:center;min-width:0;padding:.55rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface)}.reference-chip img{display:block;width:3.5rem;aspect-ratio:1;border-radius:var(--radius-sm);object-fit:cover;background:var(--surface-strong)}.reference-chip div{min-width:0}.reference-chip strong,.reference-chip span{display:block}.reference-chip strong{overflow:hidden;color:var(--ink);font-size:.92rem;text-overflow:ellipsis;white-space:nowrap}.reference-chip span{color:var(--muted);font-size:.82rem}.reference-chip button,.reference-clear,.batch-button,.history-clear,.job-status-option,.relay-form button,.relay-controls [data-relay-delete],.job-copy{min-height:2.75rem;border:1px solid var(--line-strong);border-radius:var(--radius-sm);color:var(--ink);background:var(--surface);font-weight:800;transition:color .18s ease,background-color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.reference-chip button{width:2.75rem;padding:0;color:var(--danger);font-size:1.35rem;line-height:1}.reference-chip button:hover,.reference-clear:hover,.batch-button:hover,.history-clear:hover,.job-status-option:hover,.job-copy:hover{border-color:var(--primary);color:#fff;background:var(--primary)}.reference-chip button:hover{border-color:var(--danger);background:var(--danger)}.reference-clear{width:100%;margin-top:.75rem}.batch-button{width:100%;min-width:0;justify-content:center;padding:0 .9rem;color:var(--primary);background:var(--surface-muted);box-shadow:var(--shadow-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.batch-button:hover{box-shadow:var(--shadow-md)}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.generate-button{position:relative;width:100%;min-height:4rem;overflow:hidden;border:1px solid var(--primary-strong);border-radius:var(--radius);color:#fff;background:linear-gradient(135deg,var(--primary-strong),var(--primary));box-shadow:0 14px 30px #0d274438}.generate-button span:first-child{position:relative;z-index:1;font-weight:850;letter-spacing:0}.button-glow{position:absolute;inset:auto -15% -170%;height:210%;background:linear-gradient(90deg,transparent,rgb(255 255 255 / 18%),transparent),radial-gradient(circle,rgb(4 120 87 / 75%),transparent 62%);transition:transform .24s ease}.generate-button:hover .button-glow,.generate-button:focus-visible .button-glow{transform:translateY(-18%)}.generate-button:active,.reference-clear:active,.batch-button:active,.batch-close:active,.batch-cancel:active,.batch-confirm:active,.history-clear:active,.relay-form button:active,.relay-controls [data-relay-delete]:active,.download:active,.job-copy:active{transform:translateY(1px)}.generate-button:disabled,.reference-chip button:disabled,.reference-clear:disabled,.batch-button:disabled,.batch-close:disabled,.batch-cancel:disabled,.batch-confirm:disabled,.history-clear:disabled,.job-status-option:disabled,.download:disabled,.relay-form button:disabled,.relay-controls [data-relay-delete]:disabled{opacity:.55;transform:none}.relay-form button{flex:0 0 auto;min-width:7rem;padding:0 1rem;color:#fff;background:var(--ink);border-color:var(--ink);white-space:nowrap}.relay-form button:hover{background:var(--primary);border-color:var(--primary)}.relay-controls [data-relay-delete]{flex:0 0 auto;min-width:5.25rem;padding:0 .9rem;color:var(--danger);background:#fff;border-color:#b4231847;white-space:nowrap}.relay-controls [data-relay-delete]:not(:disabled):hover{color:#fff;background:var(--danger);border-color:var(--danger)}.relay-controls [data-relay-delete]:disabled:hover{color:var(--danger);background:#fff;border-color:#b4231847}.progress{margin:0 0 1rem;color:var(--warning);background:var(--warning-soft);border:1px solid rgb(180 83 9 / 22%)}.batch-modal{position:fixed;inset:0;z-index:80;display:grid;min-width:0;padding:clamp(.75rem,3vw,1.5rem);overflow-y:auto;overscroll-behavior:contain;place-items:center;background:#0f172a61}.batch-dialog{display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:1rem;width:min(42rem,100%);max-height:min(44rem,calc(100dvh - 2rem));min-width:0;overflow:hidden;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-lg)}.batch-head{display:grid;grid-template-columns:minmax(0,1fr) 2.5rem;gap:.85rem;align-items:start;min-width:0;padding:1rem 1rem 0}.batch-head h2,.batch-head p{min-width:0}.batch-head h2{font-size:1.05rem}.batch-head p{margin:.35rem 0 0;color:var(--muted-strong);font-size:.9rem;line-height:1.5;overflow-wrap:anywhere}.batch-close{display:grid;width:2.5rem;min-height:2.5rem;padding:0;border:1px solid var(--line);border-radius:var(--radius-sm);place-items:center;color:var(--muted-strong);background:var(--surface-muted);font-size:1.25rem;font-weight:800;line-height:1;transition:color .18s ease,background-color .18s ease,border-color .18s ease,transform .18s ease}.batch-close:hover{border-color:var(--primary);color:#fff;background:var(--primary)}.batch-dropzone,.batch-list,.batch-summary,.batch-error{min-width:0;margin-right:1rem;margin-left:1rem}.batch-dropzone{display:grid;gap:.35rem;min-height:8.5rem;padding:1rem;border:1px dashed var(--line-strong);border-radius:var(--radius);place-items:center;color:var(--muted-strong);text-align:center;background:linear-gradient(180deg,#fffffff0,#f4f7faeb),var(--surface);cursor:pointer;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.batch-dropzone:hover,.batch-dropzone:focus-within,.batch-dropzone.is-dragging,.batch-modal.is-dragging .batch-dropzone{border-color:var(--focus);background:linear-gradient(180deg,#fff,#e6f0f8d1),var(--surface);box-shadow:0 0 0 4px #2563eb1f}.batch-dropzone strong{color:var(--ink);font-weight:850;line-height:1.3}.batch-dropzone small{max-width:30rem;color:var(--muted);font-size:.86rem;line-height:1.45}.batch-list{display:grid;gap:.6rem;max-height:16rem;overflow-y:auto;padding-right:.15rem;scrollbar-gutter:stable}.batch-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.65rem;align-items:center;min-width:0;padding:.7rem .75rem;border:1px solid var(--line);border-left:4px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface-muted)}.batch-item strong,.batch-item span,.batch-item small{min-width:0;overflow-wrap:anywhere}.batch-item strong{display:block;color:var(--ink);font-size:.9rem;font-weight:850;line-height:1.35}.batch-item small{display:block;margin-top:.2rem;color:var(--muted);font-size:.8rem;line-height:1.4}.batch-item-status{min-width:5.75rem;padding:.32rem .55rem;border:1px solid var(--line);border-radius:999px;color:var(--muted-strong);background:var(--surface);font-size:.75rem;font-weight:850;line-height:1.2;text-align:center;white-space:nowrap}.batch-item.is-ready{border-left-color:var(--accent);background:linear-gradient(180deg,#fff,#dff7ed6b)}.batch-item.is-ready .batch-item-status,.batch-item.is-submitted .batch-item-status{border-color:#0478573d;color:var(--accent-strong);background:var(--accent-soft)}.batch-item.is-skipped{border-left-color:var(--warning);background:linear-gradient(180deg,#fff,#fff4de94)}.batch-item.is-skipped .batch-item-status{border-color:#b453093d;color:var(--warning);background:var(--warning-soft)}.batch-item.is-submitting{border-left-color:var(--focus);background:linear-gradient(180deg,#fff,#e6f0f8b8)}.batch-item.is-submitting .batch-item-status{border-color:#2563eb3d;color:var(--focus);background:#2563eb17}.batch-item.is-submitted{border-left-color:var(--accent)}.batch-item.is-failed{border-color:#b423183d;border-left-color:var(--danger);background:linear-gradient(180deg,#fff,#fff0ed9e)}.batch-item.is-failed .batch-item-status{border-color:#b423183d;color:var(--danger);background:var(--danger-soft)}.batch-summary,.batch-error{padding:.72rem .8rem;border-radius:var(--radius-sm);font-size:.88rem;font-weight:750;line-height:1.45;overflow-wrap:anywhere}.batch-summary{color:var(--accent-strong);background:var(--accent-soft);border:1px solid rgb(4 120 87 / 20%)}.batch-error{color:var(--danger);background:var(--danger-soft);border:1px solid rgb(180 35 24 / 22%)}.batch-actions{display:flex;gap:.65rem;align-items:center;justify-content:flex-end;min-width:0;padding:1rem;border-top:1px solid var(--line);background:var(--surface-muted)}.batch-cancel,.batch-confirm{min-width:7rem;min-height:2.75rem;padding:0 1rem;border:1px solid var(--line-strong);border-radius:var(--radius-sm);font-weight:850;transition:color .18s ease,background-color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.batch-cancel{color:var(--primary);background:var(--surface)}.batch-cancel:hover{border-color:var(--primary);color:var(--primary-strong);background:var(--primary-soft)}.batch-confirm{color:#fff;background:var(--primary);border-color:var(--primary);box-shadow:0 10px 22px #0d274429}.batch-confirm:hover{background:var(--primary-strong);border-color:var(--primary-strong)}.history-head,.gallery-head{margin-bottom:1rem}.job-status-filter{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem;margin-bottom:1rem}.job-status-option{min-width:0;min-height:2.5rem;padding:0 .65rem;color:var(--muted-strong);font-size:.84rem;white-space:nowrap}.job-status-option.is-active{border-color:#0478576b;color:var(--accent-strong);background:var(--accent-soft);box-shadow:0 0 0 1px #0478571a}.job-status-option.is-active:hover{color:var(--accent-strong);background:var(--accent-soft)}.history-head-meta{display:flex;gap:.65rem;align-items:center;justify-content:end}.history-clear{padding:0 .95rem}.history-empty,.empty{display:grid;place-items:center;border:1px dashed var(--line-strong);border-radius:var(--radius);color:var(--muted-strong);text-align:center;background:#ffffff94}.history-empty{min-height:14rem}.history-filter-empty{min-height:10rem;margin-bottom:.75rem;padding:1rem}.empty{min-height:24rem;padding:1rem}.history-empty p,.empty p{max-width:26rem;margin:0;line-height:1.65}.empty code{color:var(--primary);font-weight:800}.empty-mark{width:8rem;height:8rem;margin-bottom:1rem;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(135deg,transparent 48%,rgb(22 58 95 / 20%) 49% 51%,transparent 52%),linear-gradient(45deg,transparent 48%,rgb(4 120 87 / 18%) 49% 51%,transparent 52%),var(--surface);box-shadow:var(--shadow-sm)}.timeline{display:grid;gap:.75rem;min-width:0}.job-row{display:grid;gap:.6rem;min-width:0;padding:.9rem;border:1px solid var(--line);border-left:4px solid var(--line-strong);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm)}.job-running{border-left-color:var(--focus)}.job-succeeded,.job-partial{border-color:#0478573d;border-left-color:var(--accent);background:linear-gradient(180deg,#fff,#dff7ed6b)}.job-failed{border-color:#b423183d;border-left-color:var(--danger);background:linear-gradient(180deg,#fff,#fff0ed9e)}.job-row-head{display:flex;gap:.75rem;align-items:start;justify-content:space-between;min-width:0}.job-row-head div{display:grid;gap:.15rem;min-width:0}.job-row strong{color:var(--primary)}.job-row span,.job-row small{min-width:0;color:var(--muted);font-size:.8rem;font-weight:750;overflow-wrap:anywhere}.job-row p{min-width:0;margin:0;overflow-wrap:anywhere;color:var(--ink-soft);line-height:1.5}.job-prompt-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.65rem;align-items:start;min-width:0;padding:.65rem .75rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface-muted)}.job-prompt{display:-webkit-box;overflow:hidden;color:var(--muted-strong);line-height:1.5;overflow-wrap:anywhere;-webkit-box-orient:vertical;-webkit-line-clamp:2}.job-actions{display:flex;justify-content:flex-end;min-width:0}.job-copy,.job-retry{min-height:2.35rem;padding:0 .75rem;color:var(--primary);font-size:.8rem;background:#fff}.job-retry{color:#fff;background:var(--danger);border-color:var(--danger)}.job-failure-reason{display:block;overflow:visible;color:var(--danger);font-size:.86rem;font-weight:800;overflow-wrap:anywhere;white-space:pre-wrap;-webkit-line-clamp:unset}.gallery{--gallery-columns: 3;display:grid;grid-template-columns:repeat(var(--gallery-columns),minmax(0,1fr));gap:1rem;align-items:start}.gallery-column{display:grid;gap:1rem;align-content:start;min-width:0}.image-card{position:relative;width:100%;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-sm);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.image-card.is-selected{border-color:#163a5f70;box-shadow:0 0 0 2px #0d274429,var(--shadow-md)}.image-card:hover{border-color:#a7b6c7;box-shadow:var(--shadow-md);transform:translateY(-2px)}.image-frame{display:block;min-height:7rem;background:linear-gradient(45deg,rgb(15 23 42 / 5%) 25%,transparent 25% 75%,rgb(15 23 42 / 5%) 75%),linear-gradient(45deg,rgb(15 23 42 / 5%) 25%,transparent 25% 75%,rgb(15 23 42 / 5%) 75%),var(--surface-strong);background-position:0 0,.5rem .5rem,0 0;background-size:1rem 1rem,1rem 1rem,auto}.image-select-toggle{position:absolute;top:.5rem;left:.5rem;z-index:2;width:1.5rem;min-width:1.5rem;min-height:1.5rem;padding:0;border:1px solid var(--line-strong);border-radius:var(--radius-sm);color:var(--muted);font-size:.82rem;font-weight:900;background:#fffffff5;box-shadow:var(--shadow-sm)}.image-select-toggle:hover{border-color:var(--focus);color:var(--focus)}.image-select-toggle.is-selected{border-color:var(--primary-strong);color:#fff;background:linear-gradient(135deg,var(--primary-strong),var(--primary));box-shadow:0 8px 18px #0d27443d}.image-frame img{display:block;width:100%;height:auto}.image-meta{display:grid;gap:.35rem;padding:.85rem}.image-meta time{color:var(--ink);font-size:.9rem;font-weight:850;overflow-wrap:anywhere}.image-meta span{color:var(--muted);font-size:.86rem}.download{display:flex;min-height:2.75rem;align-items:center;justify-content:center;padding:.75rem .9rem;border-top:1px solid var(--line);color:var(--primary);font-weight:850;text-align:center;text-decoration:none;transition:color .18s ease,background-color .18s ease}.download:hover{color:#fff;background:var(--primary)}.download:disabled:hover{color:var(--primary);background:var(--surface)}.is-loading .generate-button{box-shadow:0 0 0 1px #2563eb1f,0 14px 30px #0d274438}@media(min-width:1180px){.history-panel,.gallery-panel{max-height:calc(100vh - 2rem)}.history-body,.gallery-body{overflow-y:auto;padding-right:.2rem;scrollbar-gutter:stable}}@media(max-width:1360px){.workspace{grid-template-areas:"control history gallery";grid-template-columns:minmax(18.5rem,.7fr) minmax(19rem,.8fr) minmax(0,1.52fr)}.history-panel,.gallery-panel{min-height:28rem}.mask-toolbar{align-items:stretch}.mask-toolbar button:first-of-type,.mask-toolbar button:last-of-type{min-width:0}}@media(max-width:1080px){.hero,.workspace{grid-template-columns:minmax(0,1fr)}.hero{align-items:stretch}.workspace{grid-template-areas:"control" "history" "gallery"}.control-panel{position:static}.history-panel,.gallery-panel{min-height:auto}h1{font-size:3.4rem}.relay-form button{flex:1 1 10rem}}@media(max-width:760px){.shell{width:min(100% - 1rem,1500px);padding-top:1rem}.grid,.image-actions{grid-template-columns:1fr}.relay-form{display:grid;grid-template-columns:1fr}.relay-form button,.relay-controls [data-relay-delete]{width:100%}.mode-grid{grid-template-columns:1fr}.mask-toolbar{flex-direction:column}.history-head,.gallery-head{align-items:start;flex-direction:column}.history-head-meta{width:100%;justify-content:space-between}.panel,.status-card{padding:1rem}.reference-label{align-items:start;flex-direction:column}.image-actions .download,.ghost-button,.mask-toolbar button{width:100%}.batch-modal{align-items:end;padding:.5rem}.batch-dialog{width:100%;max-height:calc(100dvh - 1rem)}.batch-list{max-height:14rem}.batch-actions{align-items:stretch;flex-direction:column-reverse}.batch-cancel,.batch-confirm{width:100%}}@media(max-width:620px){h1{font-size:2.55rem}.lede{font-size:1rem}.workspace{gap:1rem}.history-head-meta{align-items:stretch;flex-direction:column}.history-clear{width:100%}.job-row-head,.job-prompt-row{grid-template-columns:minmax(0,1fr)}.job-row-head{flex-direction:column}.job-copy{width:100%}.reference-chip{grid-template-columns:3.5rem minmax(0,1fr)}.reference-chip button{grid-column:1 / -1;width:100%}.mask-stage{min-height:14rem}.mode-card{padding:.85rem .9rem}.batch-head{grid-template-columns:minmax(0,1fr) 2.25rem;padding:.85rem .85rem 0}.batch-close{width:2.25rem;min-height:2.25rem}.batch-dropzone,.batch-list,.batch-summary,.batch-error{margin-right:.85rem;margin-left:.85rem}.batch-dropzone{min-height:7.25rem;padding:.85rem}.batch-item{grid-template-columns:minmax(0,1fr);align-items:start}.batch-item-status{width:100%}.batch-actions{padding:.85rem}}@media(min-width:1680px){.workspace{grid-template-areas:"control history gallery";grid-template-columns:minmax(19rem,.62fr) minmax(23rem,.78fr) minmax(0,2fr)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.image-card:hover,.generate-button:active,.reference-clear:active,.history-clear:active,.relay-form button:active,.relay-controls [data-relay-delete]:active,.download:active,.job-copy:active{transform:none}}
