/* 放量线（批量短视频生产线）· 作用域 .batch-* —— 全部走 tokens.css 设计令牌，与主 app 同体系，零 !important */

/* 三段切换 tab（pill，沿用 .chip 的体系：未选 surface/muted、选中 primary-soft/primary-text）*/
.batch-line-page .batch-tabs { display: flex; gap: var(--space-2); margin: var(--space-4) 0 var(--space-5); flex-wrap: wrap; }
.batch-tab { font: inherit; font-weight: 850; font-size: 12px; border: 1px solid var(--line); background: var(--surface); color: var(--muted); border-radius: 999px; min-height: 36px; padding: 0 var(--space-4); cursor: pointer; transition: background var(--motion-fast) var(--ease-out); }
.batch-tab.active { background: var(--primary-soft); color: var(--primary-text); border-color: transparent; }
.batch-tab.locked { opacity: .45; cursor: not-allowed; }

/* 配方 / 生产单 */
.batch-recipe-actions { display: flex; gap: var(--space-2); align-items: center; margin: var(--space-3) 0; flex-wrap: wrap; }
.batch-plan-head { display: flex; flex-direction: column; gap: var(--space-1); padding: var(--space-3) 0 var(--space-2); border-top: 1px solid var(--line); }
.batch-plan-head strong { font-size: 15px; color: var(--ink); }
.batch-shots { display: flex; flex-direction: column; }
.batch-shot { display: flex; gap: var(--space-3); padding: var(--space-3) 0; border-top: 1px dashed var(--line); }
.batch-shot:first-child { border-top: 0; }
.batch-shot-n { flex: 0 0 60px; font-weight: 850; font-size: 12px; color: var(--ink); }
.batch-shot-n em { display: block; color: var(--muted); font-weight: 400; font-style: normal; }
.batch-shot-b { flex: 1; font-size: 13px; color: var(--ink); }
.batch-empty { padding: var(--space-4) 0; }

/* 跑量 */
.batch-log { background: var(--ink); color: var(--paper); border-radius: var(--radius-md); padding: var(--space-3); font-size: 11px; max-height: 220px; overflow: auto; white-space: pre-wrap; margin: var(--space-3) 0; }
.batch-ok { color: var(--success); font-weight: 850; margin: var(--space-2) 0; }
.batch-fail { color: var(--danger); font-weight: 850; margin: var(--space-2) 0; }
.batch-video { width: 280px; max-width: 60vw; aspect-ratio: 9 / 16; border-radius: var(--radius-lg); background: var(--ink); display: block; margin: var(--space-3) 0; }

/* 抽检 · 快速过审 */
.batch-qc { display: flex; gap: var(--space-5); align-items: flex-start; flex-wrap: wrap; margin: var(--space-3) 0; }
.batch-video.qc { width: 240px; }
.batch-qc-side { flex: 1; min-width: 220px; }
.batch-qc-name { font-weight: 700; color: var(--ink); margin-bottom: var(--space-3); }
.batch-qc-actions { display: flex; gap: var(--space-2); margin-bottom: var(--space-4); }
.qc-fail { color: var(--danger); }
.batch-qc-strip { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.batch-qc-dot { min-width: 30px; height: 30px; border-radius: var(--radius-md); border: 1px solid var(--line); background: var(--surface); font-size: 12px; font-weight: 700; cursor: pointer; color: var(--muted); }
.batch-qc-dot.pass { background: var(--primary-soft); border-color: transparent; color: var(--primary-text); }
.batch-qc-dot.fail { background: color-mix(in oklch, var(--danger) 12%, var(--surface)); border-color: transparent; color: var(--danger); }
.batch-qc-dot.cur { outline: 2px solid color-mix(in oklch, var(--primary) 40%, transparent); outline-offset: 1px; }
.batch-gate { margin-top: var(--space-4); padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); font-weight: 700; background: var(--surface-2); border: 1px solid var(--line); color: var(--ink); }
.batch-gate.pass { background: var(--primary-soft); border-color: transparent; color: var(--primary-text); }
.batch-gate.fail { background: var(--accent-soft); border-color: transparent; color: var(--accent); }

/* composer 放量线开关 + 选项 + 配方内微调（native checkbox/range 用 accent-color 跟主题绿）*/
.batch-mode-row { margin-top: var(--space-3); border-top: 1px dashed var(--line); padding-top: var(--space-3); }
.batch-toggle { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 13px; color: var(--ink); cursor: pointer; }
.batch-toggle input[type="checkbox"] { accent-color: var(--primary); width: 16px; height: 16px; }
.batch-toggle b { color: var(--primary); font-weight: 850; }
.batch-toggle span { color: var(--muted); font-size: 12px; }
.batch-mode-opts { display: flex; gap: var(--space-5); flex-wrap: wrap; margin-top: var(--space-3); align-items: center; }
.batch-mode-opts .bmo, .batch-retune .bmo { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 12px; color: var(--muted); }
.batch-mode-opts input[type="range"], .batch-retune input[type="range"] { accent-color: var(--primary); width: 120px; }
.batch-mode-opts .batch-select, .batch-retune .batch-select { height: 36px; padding: 0 var(--space-3); }

/* 配方 · 生成设置（套路/手艺/时长 + 说明 + 操作）——简明分组 */
.bmo-k { font-weight: 850; color: var(--ink); font-size: 12px; }

/* 跑量 · 成本闸（批量规模 + 预算上限 + 预估 + 二次确认）*/
.batch-costgate { margin: var(--space-4) 0; display: flex; flex-direction: column; gap: var(--space-3); max-width: 560px; }
.batch-cg-row { display: flex; gap: var(--space-5); flex-wrap: wrap; align-items: center; }
.batch-cg-row .bmo { display: inline-flex; align-items: center; gap: var(--space-2); font-size: 13px; color: var(--ink); font-weight: 700; }
.batch-num { width: 92px; height: 34px; border: 1px solid var(--line); border-radius: var(--radius-md); padding: 0 var(--space-2); font: inherit; font-weight: 850; background: var(--surface); color: var(--ink); }
.batch-cg-est { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); background: var(--primary-soft); color: var(--primary-text); font-size: 14px; }
.batch-cg-est b { font-size: 18px; }
.batch-cg-est.over { background: var(--accent-soft); color: var(--accent); }
.batch-cg-warn { display: block; margin-top: var(--space-1); font-weight: 850; }
.batch-cg-note { font-size: 12px; margin: 0; }
.batch-cg-go { align-self: flex-start; }
.batch-cg-go[disabled] { opacity: .5; cursor: not-allowed; }
.batch-confirm-list { margin: var(--space-2) 0 0; padding-left: 1.1em; color: var(--ink); font-size: 13px; line-height: 1.7; }
.batch-confirm-list b { color: var(--primary); }

/* 跑量 · 进度 + 停止 + 批量成片网格 */
.batch-progress { margin: var(--space-3) 0; display: flex; flex-direction: column; gap: var(--space-2); }
.batch-progress-bar { height: 8px; border-radius: 999px; background: var(--surface-2); overflow: hidden; }
.batch-progress-bar span { display: block; height: 100%; background: var(--primary); border-radius: 999px; transition: width var(--motion-fast) var(--ease-out); }
.batch-progress-txt { display: flex; align-items: center; gap: var(--space-2); font-size: 13px; color: var(--ink); }
.batch-progress-txt b { color: var(--primary); }
.batch-stop { align-self: flex-start; color: var(--danger); border-color: color-mix(in oklch, var(--danger) 40%, var(--line)); }
.batch-done-grid { display: flex; gap: var(--space-3); flex-wrap: wrap; margin: var(--space-3) 0; }
.batch-done-cell { width: 132px; aspect-ratio: 9 / 16; border-radius: var(--radius-md); background: var(--ink); object-fit: cover; }
.batch-done-cell.big { width: 200px; max-width: 44vw; border-radius: var(--radius-lg); }

/* 生产单逐镜可编辑 + 回退 */
.batch-shots.editable .batch-shot { align-items: flex-start; }
.batch-shot-n output { display: block; color: var(--muted); font-weight: 400; font-size: 11px; }
.batch-shot-row { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-2); }
.chip.soft { background: var(--surface-2); color: var(--muted); }
.chip.warn { background: var(--accent-soft); color: var(--accent); }
.batch-dur-edit { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; color: var(--muted); }
.batch-num.sm { width: 54px; height: 28px; }
.batch-dur-auto { width: 24px; height: 24px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--surface); cursor: pointer; color: var(--primary); font-weight: 800; }
.batch-shot-ops { margin-left: auto; display: inline-flex; gap: 4px; }
.batch-shot-ops button { width: 28px; height: 28px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--surface); cursor: pointer; font-size: 13px; color: var(--ink); }
.batch-shot-ops button:hover:not([disabled]) { background: var(--primary-soft); }
.batch-shot-ops button[disabled] { opacity: .4; cursor: not-allowed; }
.batch-edit-cap { width: 100%; min-height: 44px; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: var(--space-2); font: inherit; font-size: 13px; color: var(--primary); font-weight: 600; background: var(--surface); resize: vertical; box-sizing: border-box; }
.batch-edit-cap:focus { outline: 2px solid color-mix(in oklch, var(--primary) 40%, transparent); outline-offset: 0; border-color: transparent; }
.batch-pr { margin-top: var(--space-2); }
.batch-pr summary { cursor: pointer; font-size: 11px; }
/* 画面提示词可编辑 + 插入线 + 排序 */
.batch-edit-prompt { width: 100%; box-sizing: border-box; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: var(--space-2); font: inherit; font-size: 12px; color: var(--muted); background: var(--surface); resize: vertical; margin-top: 4px; line-height: 1.5; }
.batch-edit-prompt:focus { outline: 2px solid color-mix(in oklch, var(--primary) 40%, transparent); border-color: transparent; color: var(--ink); }
.batch-ins { display: block; width: 100%; border: 1px dashed transparent; background: transparent; color: var(--muted); font: inherit; font-size: 12px; padding: 2px; cursor: pointer; border-radius: var(--radius-sm); opacity: .35; transition: opacity var(--motion-fast) var(--ease-out); }
.batch-shots.editable:hover .batch-ins { opacity: .7; }
.batch-ins:hover { opacity: 1; border-color: var(--primary); color: var(--primary); background: var(--primary-soft); }
.batch-pr .batch-shot-pr { margin-top: var(--space-1); }
/* 生产单标题行 + 角色块（角色来自角色库，带预览位） */
.batch-plan-title { flex-direction: row; align-items: baseline; gap: var(--space-2); flex-wrap: wrap; }
.batch-char { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) 0 var(--space-3); }
.batch-char-av { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; background: var(--surface-2); display: flex; align-items: center; justify-content: center; font-size: 22px; flex: 0 0 auto; border: 1px solid var(--line); }
.batch-char-av.ph { color: var(--muted); }
.batch-char-av img { width: 100%; height: 100%; object-fit: cover; }
.batch-char-meta { display: flex; flex-direction: column; gap: 2px; font-size: 13px; color: var(--ink); }
.batch-char-meta small { font-size: 11px; }
.batch-char-pick { margin-left: auto; flex: 0 0 auto; }

/* 配方·定方向：选题表 + 模板/角色 池 + 数量 */

/* 配方·简版：仿主流程 composer（一个选题框 + 一条工具栏），不堆解释文字 */
.batch-compose-spacer { flex: 1; min-width: 8px; }

/* plans 视图：N 条清单 + 展开当前条 */
/* 角色库挑选器 */
.batch-pickchar-av { width: 54px; height: 54px; border-radius: 50%; overflow: hidden; background: var(--surface-2); display: flex; align-items: center; justify-content: center; font-size: 20px; }
.batch-pickchar-av img { width: 100%; height: 100%; object-fit: cover; }

/* composer 放量线：上传提示行 + 模板下载（极简，不堆文字指引）*/
.batch-upload-hint { font-size: 12px; color: var(--muted); margin: 0 0 6px; }
.batch-tpl-dl { font: inherit; font-size: 12px; color: var(--primary); background: none; border: none; text-decoration: underline; cursor: pointer; padding: 0; }

/* N 条脚本网格 + 翻页 + 多选 */
.batch-cards-bar { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin: var(--space-3) 0; }
.batch-cards-bar button { font: inherit; font-size: 13px; padding: 5px 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--ink); cursor: pointer; }
.batch-cards-bar button:hover { border-color: var(--primary); }
.batch-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-2); }
.batch-card { position: relative; display: flex; flex-direction: column; gap: 4px; padding: var(--space-2); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); cursor: pointer; }
.batch-card:hover { border-color: var(--primary); }
.batch-card.cur { border-color: transparent; outline: 2px solid color-mix(in oklch, var(--primary) 45%, transparent); outline-offset: -1px; }
.batch-card.sel { background: var(--primary-soft); }
.batch-card-check { position: absolute; top: 4px; right: 4px; width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; font-size: 15px; color: var(--muted); cursor: pointer; line-height: 1; border-radius: 999px; transition: background var(--motion-fast) var(--ease-out), color var(--motion-fast) var(--ease-out); }
.batch-card:hover .batch-card-check { background: var(--surface-2); color: var(--primary); }
.batch-card.sel .batch-card-check { color: var(--primary); }
.batch-card-av { width: 100%; aspect-ratio: 16 / 10; border-radius: var(--radius-sm); overflow: hidden; background: var(--surface-2); display: flex; align-items: center; justify-content: center; font-size: 20px; }
.batch-card-av img { width: 100%; height: 100%; object-fit: cover; }
.batch-card b { font-size: 12px; color: var(--ink); }
.batch-card small { font-size: 11px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.batch-pager { display: flex; align-items: center; justify-content: center; gap: var(--space-2); margin: var(--space-3) 0; font-size: 13px; color: var(--ink); }
.batch-pager button { width: 30px; height: 30px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--surface); cursor: pointer; }
.batch-pager button[disabled] { opacity: .4; cursor: not-allowed; }

/* 品牌叠加（整批统一）+ 一帧成片预览 */
.batch-brand-panel { margin: var(--space-4) 0; border: 1px solid var(--line); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); background: var(--surface); }
.batch-brand-panel > summary { font-weight: 850; font-size: 13px; color: var(--ink); cursor: pointer; list-style: none; }
.batch-brand-panel > summary::-webkit-details-marker { display: none; }
.batch-brand-panel > summary::before { content: "▸ "; color: var(--muted); }
.batch-brand-panel[open] > summary::before { content: "▾ "; }
.batch-brand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: var(--space-2); }
.batch-pickchar { display: flex; flex-direction: column; gap: 4px; padding: var(--space-2); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); cursor: pointer; font: inherit; }
.batch-pickchar:hover { border-color: var(--primary); }
.batch-pickchar.on { background: var(--primary-soft); border-color: transparent; }
.batch-pickchar b { font-size: 12px; color: var(--ink); }

/* 素材库 · 类型预设视图（角色库/模板库/品牌库）——mat-* 前缀，走 tokens */
.mat-type-nav { display: flex; gap: var(--space-2); flex-wrap: wrap; margin: var(--space-3) 0; }
.mat-type-pill { font: inherit; font-weight: 700; font-size: 13px; border: 1px solid var(--line); background: var(--surface); color: var(--muted); border-radius: 999px; min-height: 34px; padding: 0 var(--space-4); cursor: pointer; }
.mat-type-pill.active { background: var(--primary-soft); color: var(--primary-text); border-color: transparent; }
.mat-type-hint { font-size: 12px; color: var(--muted); margin: 0 0 var(--space-3); }
.mat-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: var(--space-3); }
.mat-type-card { display: flex; flex-direction: column; gap: 4px; padding: var(--space-3); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); }
.mat-type-card.wide { grid-column: span 2; }
.mat-type-cover { width: 100%; aspect-ratio: 16 / 10; border-radius: var(--radius-sm); overflow: hidden; background: var(--surface-2); display: flex; align-items: center; justify-content: center; font-size: 26px; }
.mat-type-cover img { width: 100%; height: 100%; object-fit: cover; }
.mat-type-card b { font-size: 13px; color: var(--ink); }
.mat-type-card small { font-size: 11px; color: var(--muted); }
.mat-type-shots { font-size: 11px; color: var(--ink); line-height: 1.6; margin: var(--space-1) 0 0; }

/* 诚实角标：当前为本地示例引擎排稿（接通真模型后由 state.batchGenLive 置 true 隐藏）*/

/* 分镜编辑弹窗（点卡片弹出，不再内联） */
.batch-plan-editor { max-height: 68vh; overflow: auto; }

/* 换角色：复用素材库·角色库（本地封面），弹窗内就地切换；点头像=改这条 / 勾选=整批轮换 */
.batch-charpick { display: flex; flex-direction: column; gap: var(--space-3); }
.batch-charpick-head { display: flex; align-items: center; gap: var(--space-3); flex-wrap: wrap; }
.batch-charpick-back { font: inherit; font-size: 13px; padding: 5px 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--ink); cursor: pointer; }
.batch-charpick-back:hover { border-color: var(--primary); }
.batch-charpick-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(96px, 1fr)); gap: var(--space-2); max-height: 48vh; overflow: auto; }
.batch-charpick-cell { position: relative; }
.batch-charpick-chk { position: absolute; top: 5px; left: 5px; z-index: 1; width: 22px; height: 22px; border: 0; background: color-mix(in oklch, var(--surface) 82%, transparent); border-radius: 999px; font-size: 14px; color: var(--primary); cursor: pointer; line-height: 1; }
.batch-charpick-pic { display: flex; flex-direction: column; gap: 3px; width: 100%; padding: var(--space-1); border: 1px solid var(--line); border-radius: var(--radius-md); background: var(--surface); cursor: pointer; font: inherit; }
.batch-charpick-pic:hover { border-color: var(--primary); }
.batch-charpick-cell.cur .batch-charpick-pic { border-color: transparent; outline: 2px solid color-mix(in oklch, var(--primary) 45%, transparent); }
.batch-charpick-av { width: 100%; aspect-ratio: 1; border-radius: var(--radius-sm); overflow: hidden; background: var(--surface-2); }
.batch-charpick-av img { width: 100%; height: 100%; object-fit: cover; }
.batch-charpick-pic b { font-size: 12px; color: var(--ink); }
.batch-charpick-pic small { font-size: 10px; color: var(--muted); }
.batch-charpick-foot { display: flex; align-items: center; gap: var(--space-3); }

/* 品牌叠加编辑器：素材 + 位置(9宫格)/大小/时机 预设 + 一帧预览 */
.brand-edit { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-3) 0; border-top: 1px dashed var(--line); }
.brand-edit:first-of-type { border-top: 0; }
.brand-edit-asset { display: flex; align-items: center; gap: var(--space-2); }
.brand-edit-glyph { font-size: 20px; }
.brand-edit-name { flex: 1; display: flex; flex-direction: column; }
.brand-edit-name b { font-size: 13px; color: var(--ink); }
.brand-edit-pick { font: inherit; font-size: 12px; padding: 4px 12px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--ink); cursor: pointer; }
.brand-edit-pick:hover { border-color: var(--primary); }
.brand-edit-body { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: flex-start; justify-content: flex-start; }
.brand-edit-ctls { display: flex; flex-direction: column; gap: var(--space-2); flex: 0 1 360px; min-width: 240px; }
.brand-blur-on { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; color: var(--ink); cursor: pointer; }
.brand-blur-on input { accent-color: var(--primary); }
.brand-blur-range { accent-color: var(--primary); width: 90px; }
.brand-blur-range:disabled { opacity: .4; }
.brand-blur-val { font-size: 11px; color: var(--muted); min-width: 18px; }
.brand-prev-blur { position: absolute; width: 40px; height: 40px; border-radius: 8px; background: color-mix(in oklch, var(--ink) 12%, transparent); backdrop-filter: blur(var(--b, 0)); -webkit-backdrop-filter: blur(var(--b, 0)); }
.brand-prev-blur.off { display: none; }
.brand-prev-blur.sz-l { width: 52px; height: 52px; }
.brand-prev-blur.sz-s { width: 30px; height: 30px; }
.brand-hint { display: block; margin-top: var(--space-2); }
.brand-hint textarea { width: 100%; box-sizing: border-box; border: 1px solid var(--line); border-radius: var(--radius-sm); padding: var(--space-2); font: inherit; font-size: 12px; color: var(--ink); background: var(--surface); resize: vertical; line-height: 1.5; }
.brand-hint textarea:focus { outline: 2px solid color-mix(in oklch, var(--primary) 40%, transparent); border-color: transparent; }
.brand-ctl { display: flex; align-items: center; gap: var(--space-2); }
.brand-ctl > span { font-size: 12px; color: var(--muted); width: 36px; flex: 0 0 36px; }
.brand-posgrid { display: grid; grid-template-columns: repeat(3, 22px); grid-template-rows: repeat(3, 22px); gap: 3px; }
.brand-pos { width: 22px; height: 22px; border: 1px solid var(--line); border-radius: 4px; background: var(--surface); cursor: pointer; padding: 0; }
.brand-pos:hover { border-color: var(--primary); }
.brand-pos.on { background: var(--primary); border-color: transparent; }
.brand-pills { display: flex; gap: 4px; flex-wrap: wrap; }
.brand-pill { font: inherit; font-size: 12px; padding: 4px 10px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--muted); cursor: pointer; }
.brand-pill:hover { border-color: var(--primary); }
.brand-pill.on { background: var(--primary-soft); color: var(--primary-text); border-color: transparent; }
.brand-prev { position: relative; width: 80px; aspect-ratio: 9 / 16; border-radius: var(--radius-sm); background: linear-gradient(160deg, var(--surface-2), var(--surface)); border: 1px solid var(--line); flex: 0 0 auto; overflow: hidden; }
.brand-prev-ov { position: absolute; line-height: 1; }
.brand-prev-ov.sz-s { font-size: 11px; }
.brand-prev-ov.sz-m { font-size: 16px; }
.brand-prev-ov.sz-l { font-size: 22px; }
.brand-prev .pos-tl { top: 4px; left: 4px; }
.brand-prev .pos-tc { top: 4px; left: 50%; transform: translateX(-50%); }
.brand-prev .pos-tr { top: 4px; right: 4px; }
.brand-prev .pos-ml { top: 50%; left: 4px; transform: translateY(-50%); }
.brand-prev .pos-center { top: 50%; left: 50%; transform: translate(-50%, -50%); }
.brand-prev .pos-mr { top: 50%; right: 4px; transform: translateY(-50%); }
.brand-prev .pos-bl { bottom: 14px; left: 4px; }
.brand-prev .pos-bc { bottom: 14px; left: 50%; transform: translateX(-50%); }
.brand-prev .pos-br { bottom: 14px; right: 4px; }
.brand-prev-time { position: absolute; bottom: 2px; left: 0; right: 0; text-align: center; font-size: 8px; color: var(--muted); }

/* 成片叠加：删除单条 + 添加叠加素材 */
.brand-edit-del { width: 24px; height: 24px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); color: var(--muted); font-size: 15px; line-height: 1; cursor: pointer; flex: 0 0 auto; }
.brand-edit-del:hover { border-color: var(--danger); color: var(--danger); }
.brand-add { margin-top: var(--space-3); font: inherit; font-size: 13px; font-weight: 700; padding: 7px 16px; border: 1px dashed var(--line); border-radius: var(--radius-md); background: var(--surface); color: var(--primary); cursor: pointer; }
.brand-add:hover { border-color: var(--primary); border-style: solid; background: var(--primary-soft); }
