/* =========================================================================
   Guidelyze · Forja · forja.css
   Estilos do modal de geração + toaster persistente.
   Derivado de mockup/style.css mas stripped (sem demo-bar, sem state toggles).
   Estado dirigido por #forja-modal[data-state="idle|loading|result|error"]
   ========================================================================= */

/* ===== Botão "Gerar mídia" em cada card ===== */
.creative__forja-btn{
  margin:var(--space-2) var(--space-4) var(--space-3);
  font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:var(--track-wide);
  text-transform:uppercase;
  padding:8px 14px;border-radius:var(--radius-pill);
  background:transparent;color:var(--accent-deep);
  border:1.5px dashed var(--accent-soft);cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  transition:all var(--dur-fast);
}
.creative__forja-btn:hover{
  background:var(--accent);color:var(--paper);border-style:solid;border-color:var(--accent);
  box-shadow:0 3px 12px rgba(92,143,122,.28);
}
.creative__forja-btn::before{content:"✨";font-size:13px}

/* Terceiro botão por card: Salvar como post (snapshot copy + imagem -> biblioteca) */
.creative__save-btn{
  margin:0 var(--space-4) var(--space-3);
  font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:var(--track-wide);
  text-transform:uppercase;
  padding:8px 14px;border-radius:var(--radius-pill);
  background:transparent;color:var(--fg-soft);
  border:1.5px dashed var(--line);cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  transition:all var(--dur-fast);
}
.creative__save-btn:hover{
  background:var(--paper-deep);border-color:var(--fg-softer);color:var(--fg);
}
.creative__save-btn.is-saved{
  background:var(--accent);color:var(--paper);border-color:var(--accent);border-style:solid;
}

/* Link "Biblioteca (N)" no topbar */
.library-link{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:var(--track-wide);
  text-transform:uppercase;text-decoration:none;
  padding:8px 14px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--paper);
  border:1.5px solid var(--accent);
  transition:all var(--dur-fast);
  margin-left:var(--space-2);
}
.library-link:hover{
  background:var(--accent-deep);border-color:var(--accent-deep);
  box-shadow:0 3px 12px rgba(92,143,122,.28);
}
.library-link__count{
  font-family:var(--font-mono);font-size:11px;
  background:rgba(255,255,255,.22);padding:1px 6px;border-radius:8px;
}

/* Segundo botão por card: Trocar copy (gera variantes de texto) */
.creative__copy-btn{
  margin:0 var(--space-4) var(--space-3);
  font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:var(--track-wide);
  text-transform:uppercase;
  padding:8px 14px;border-radius:var(--radius-pill);
  background:transparent;color:#7A5A30;
  border:1.5px dashed #C9A87C;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  transition:all var(--dur-fast);
}
.creative__copy-btn:hover{
  background:#C9A87C;color:var(--paper);border-style:solid;border-color:#C9A87C;
  box-shadow:0 3px 12px rgba(201,168,124,.32);
}
.creative__copy-btn::before{content:"✏";font-size:13px}

/* =========================================================================
   COPY MODAL · #copy-modal (independente da forja de midia)
   ========================================================================= */
#copy-modal[hidden]{display:none}
.copy-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(28,28,26,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:var(--space-4);
}
.copy{
  width:min(820px, 96vw);max-height:90dvh;
  background:var(--paper);border-radius:var(--radius-lg);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-page);
  display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;
}
.copy__head{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-3) var(--space-5);
  background:var(--paper-warm);border-bottom:1px solid var(--line-soft);
}
.copy__head-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.copy__head-badge{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:#7A5A30;font-weight:700;
}
.copy__head-title{
  font-family:var(--font-display);font-weight:400;font-size:var(--text-lg);
  margin:0;line-height:var(--lead-snug);
}
.copy__close{
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:1px solid transparent;
  font-size:20px;color:var(--fg-soft);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);flex-shrink:0;
}
.copy__close:hover{background:var(--paper-deep);border-color:var(--line)}

.copy__body{
  display:flex;flex-direction:column;gap:var(--space-5);
  padding:var(--space-5) var(--space-6);overflow-y:auto;
}
.copy__body::-webkit-scrollbar{width:6px}
.copy__body::-webkit-scrollbar-thumb{background:var(--sand-soft);border-radius:3px}

.copy__eyebrow{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:#7A5A30;font-weight:700;margin:0 0 var(--space-2);
}

/* Bloco "Copy atual" — read-only */
.copy__current{
  background:var(--paper-warm);border:1px solid var(--line-soft);
  border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);
}
.copy__cur-hook{
  font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;
  margin:0 0 var(--space-2);line-height:var(--lead-snug);color:var(--fg);
}
.copy__cur-body{
  font-size:var(--text-sm);color:var(--fg-soft);margin:0 0 var(--space-2);
  line-height:var(--lead-normal);
}
.copy__cur-cta{
  display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:var(--track-wide);
  text-transform:uppercase;color:var(--accent-deep);
  background:rgba(92,143,122,.10);padding:5px 10px;border-radius:var(--radius-pill);margin:0;
}

/* Pickers (voz, tamanho) */
.copy__pickers{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}
@media (max-width:680px){.copy__pickers{grid-template-columns:1fr}}
.copy__picker-group{display:flex;flex-direction:column;gap:var(--space-2)}
.copy__picker-chips{display:flex;gap:var(--space-1);flex-wrap:wrap}
.copy__chip{
  font-family:var(--font-body);font-size:12px;font-weight:600;
  padding:7px 12px;border-radius:var(--radius-pill);
  background:var(--paper);border:1px solid var(--line-soft);color:var(--fg-soft);
  cursor:pointer;transition:all var(--dur-fast);
  display:inline-flex;flex-direction:column;align-items:flex-start;gap:2px;
}
.copy__chip strong{font-weight:700;font-size:13px;color:var(--fg)}
.copy__chip span{font-size:10px;color:var(--fg-softer);font-weight:400}
.copy__chip:hover{border-color:#C9A87C;color:#7A5A30}
.copy__chip.is-active{background:#C9A87C;border-color:#C9A87C;color:var(--paper)}
.copy__chip.is-active strong,.copy__chip.is-active span{color:var(--paper)}

/* Extra prompt */
.copy__extra{
  width:100%;min-height:60px;
  font-family:var(--font-body);font-size:14px;line-height:var(--lead-normal);
  padding:var(--space-3);
  border:1px solid var(--line-soft);border-radius:var(--radius-md);
  background:var(--paper);color:var(--fg);resize:vertical;
}
.copy__extra::placeholder{font-style:italic;color:var(--fg-softer);font-family:var(--font-display)}
.copy__extra:focus{outline:none;border-color:#C9A87C;box-shadow:0 0 0 3px rgba(201,168,124,.15)}

/* Estados — picker (idle) é o default visivel; outros viram visivel via [data-state] */
.copy__view[data-view="picker"]{display:block}
.copy__view[data-view="loading"],
.copy__view[data-view="result"],
.copy__view[data-view="error"]{display:none}

#copy-modal[data-state="loading"] .copy__view[data-view="picker"]{display:none}
#copy-modal[data-state="loading"] .copy__view[data-view="loading"]{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6) 0;
}

#copy-modal[data-state="result"] .copy__view[data-view="picker"]{display:none}
#copy-modal[data-state="result"] .copy__view[data-view="result"]{display:block}

#copy-modal[data-state="error"] .copy__view[data-view="picker"]{display:none}
#copy-modal[data-state="error"] .copy__view[data-view="error"]{display:block}

.copy__loading-text{
  font-family:var(--font-display);font-style:italic;font-size:14px;color:var(--fg-soft);text-align:center;margin:0;
}
.copy__loading-spinner{
  width:32px;height:32px;border:3px solid var(--paper-warm);
  border-top-color:#C9A87C;border-radius:50%;
  animation:copy-spin .9s linear infinite;
}
@keyframes copy-spin{to{transform:rotate(360deg)}}

/* Variantes geradas */
.copy__variants{display:flex;flex-direction:column;gap:var(--space-3)}
.copy-variant{
  background:var(--paper);border:1px solid var(--line-soft);
  border-left:3px solid #C9A87C;border-radius:var(--radius-md);
  padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);
}
.copy-variant.is-saved{opacity:.72;border-left-color:var(--alert-success)}
.copy-variant__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);margin-bottom:var(--space-1)}
.copy-variant__num{font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;color:#7A5A30;font-weight:700}
.copy-variant__voice{font-family:var(--font-mono);font-size:10px;color:var(--fg-softer)}
.copy-variant__hook{
  font-family:var(--font-display);font-size:var(--text-lg);font-weight:500;
  line-height:var(--lead-snug);margin:0;color:var(--fg);
}
.copy-variant__body{font-size:var(--text-sm);color:var(--fg-soft);margin:0;line-height:var(--lead-normal)}
.copy-variant__cta{
  display:inline-block;align-self:flex-start;
  font-size:var(--text-xs);font-weight:700;letter-spacing:var(--track-wide);
  text-transform:uppercase;color:var(--accent-deep);
  background:rgba(92,143,122,.10);padding:5px 10px;border-radius:var(--radius-pill);margin:0;
}
.copy-variant__tags{font-family:var(--font-mono);font-size:10px;color:var(--sage-deep);opacity:.78;margin:0}
.copy-variant__actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap}

.copy__result-meta{font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);text-align:center;margin:var(--space-2) 0 0}

/* Error */
.copy__error-card{
  max-width:380px;margin:0 auto;text-align:center;
  background:var(--paper-warm);border:1px solid #C9A87C;border-radius:var(--radius-md);
  padding:var(--space-5);
}
.copy__error-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:400;margin:0 0 var(--space-2)}
.copy__error-msg{font-size:14px;color:var(--fg-soft);margin:0 0 var(--space-2)}
.copy__error-code{font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);margin:0 0 var(--space-4)}

/* Biblioteca de copies salvas */
.copy__library{border-top:1px solid var(--line-soft);padding-top:var(--space-4)}
.copy__library-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}
.copy__library-count{font-family:var(--font-mono);font-size:11px;color:var(--fg-softer)}
.copy__library-list{display:flex;flex-direction:column;gap:6px}
.copy-lib-row{
  display:flex;align-items:center;gap:var(--space-3);
  padding:8px 10px;background:var(--paper-warm);border-radius:var(--radius-sm);
  border:1px solid var(--line-soft);
}
.copy-lib-row.is-in-use{border-color:var(--accent);background:rgba(92,143,122,.08)}
.copy-lib-row__main{flex:1;min-width:0}
.copy-lib-row__hook{
  font-family:var(--font-display);font-size:13px;font-weight:500;
  margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.copy-lib-row__meta{font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);margin:2px 0 0}
.copy-lib-row__actions{display:flex;gap:4px}
.copy-lib-icon{
  width:24px;height:24px;border-radius:50%;border:none;cursor:pointer;
  font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);
}
.copy-lib-icon--primary{background:var(--accent);color:var(--paper)}
.copy-lib-icon--primary:hover{background:var(--accent-deep)}
.copy-lib-icon--danger{background:rgba(255,255,255,.94);color:#9B4040}
.copy-lib-icon--danger:hover{background:#9B4040;color:var(--paper)}

/* Footer */
.copy__foot{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-3) var(--space-5);
  background:var(--paper-warm);border-top:1px solid var(--line-soft);
}
.copy__foot-hint{font-size:11px;color:var(--fg-softer);font-style:italic}
.copy__cta{
  background:#C9A87C;color:var(--paper);border:none;
  font-family:var(--font-display);font-size:16px;font-weight:500;
  padding:12px 28px;border-radius:var(--radius-pill);cursor:pointer;
  transition:all var(--dur-fast);min-width:140px;
  box-shadow:0 3px 14px rgba(201,168,124,.32);
}
.copy__cta:hover{background:#7A5A30;box-shadow:0 5px 20px rgba(122,90,48,.4)}

/* =========================================================================
   MODAL · #forja-modal
   ========================================================================= */
#forja-modal[hidden]{display:none}

.forja-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(28,28,26,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:var(--space-4);
}

.forja{
  width:min(1280px, 96vw);height:min(860px, 92dvh);
  background:var(--paper);border-radius:var(--radius-lg);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-page);
  display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;
  position:relative;
}

/* Header */
.forja__head{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-3) var(--space-5);
  background:var(--paper-warm);border-bottom:1px solid var(--line-soft);
}
.forja__head-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.forja__head-badge{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:var(--accent-deep);font-weight:700;
}
.forja__head-title{
  font-family:var(--font-display);font-weight:400;font-size:var(--text-lg);
  margin:0;line-height:var(--lead-snug);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.forja__head-title em{color:var(--fg-soft);font-style:italic;font-weight:400}
.forja__close{
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:1px solid transparent;
  font-size:20px;color:var(--fg-soft);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);flex-shrink:0;
}
.forja__close:hover{background:var(--paper-deep);border-color:var(--line)}

/* Body: split desktop / column mobile */
.forja__body{
  display:grid;grid-template-columns:380px 1px 1fr;
  min-height:0;overflow:hidden;
}
.forja__divisor{
  background:linear-gradient(180deg, transparent, var(--sand) 12%, var(--sand) 88%, transparent);
}

/* Galeria */
.forja__gallery{
  display:flex;flex-direction:column;background:var(--paper-warm);
  min-width:0;overflow:hidden;
}
.forja__gallery-head{
  padding:var(--space-4) var(--space-4) var(--space-2);
  display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-2);
}
.forja__gallery-eyebrow{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:var(--accent-deep);font-weight:700;margin:0;
}
.forja__gallery-count{font-size:11px;color:var(--fg-softer);font-family:var(--font-mono)}

.forja__gallery-grid{
  list-style:none;margin:0;padding:0 var(--space-4) var(--space-3);
  display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);
  overflow-y:auto;flex:1;
}
.forja__gallery-grid::-webkit-scrollbar{width:4px}
.forja__gallery-grid::-webkit-scrollbar-thumb{background:var(--sand-soft);border-radius:2px}

.gallery__item{
  position:relative;cursor:pointer;
  border-radius:8px;overflow:hidden;border:2px solid transparent;
  transition:transform var(--dur-fast),border-color var(--dur-fast),box-shadow var(--dur-fast);
}
.gallery__item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lift)}
.gallery__item.is-in-use{border-color:var(--accent)}
.gallery__item.is-ref{border-color:var(--accent);box-shadow:0 0 0 3px rgba(92,143,122,.22)}

.gallery__visual{
  position:relative;
  background:linear-gradient(135deg,#EFE6CE,#E3D8C8);
  display:flex;align-items:center;justify-content:center;color:var(--fg-softer);
  overflow:hidden;
}
.gallery__visual[data-ar="9/16"],.gallery__visual[data-ar="9:16"]{aspect-ratio:9/16}
.gallery__visual[data-ar="1/1"],.gallery__visual[data-ar="1:1"]{aspect-ratio:1/1}
.gallery__visual[data-ar="4/5"],.gallery__visual[data-ar="4:5"]{aspect-ratio:4/5}
.gallery__visual[data-ar="4/3"],.gallery__visual[data-ar="4:3"]{aspect-ratio:4/3}
.gallery__visual img,.gallery__visual video{width:100%;height:100%;object-fit:cover;display:block}
.gallery__hint{
  font-family:var(--font-mono);font-size:10px;
  background:rgba(255,255,255,.78);color:var(--fg-soft);
  padding:2px 6px;border-radius:var(--radius-pill);
}
.gallery__used{
  position:absolute;top:6px;left:6px;
  font-size:9px;letter-spacing:var(--track-wide);text-transform:uppercase;font-weight:700;
  background:var(--accent);color:var(--paper);padding:2px 6px;border-radius:4px;
}
.gallery__ref-badge{
  position:absolute;top:6px;left:6px;
  font-size:9px;letter-spacing:var(--track-wide);text-transform:uppercase;font-weight:700;
  background:var(--accent-deep);color:var(--paper);padding:2px 6px;border-radius:4px;
}

/* 3 ações em ícones flutuantes no top-right do thumb — sempre visíveis,
   ganham contraste no hover/focus. Resolve dois problemas do overlay anterior:
   ações sumiam em touch (sem hover) e cobriam o conteúdo do thumb. */
.gallery__item-actions{
  position:absolute;top:6px;right:6px;
  display:flex;gap:4px;z-index:2;
  opacity:.72;transition:opacity var(--dur-fast);
}
.gallery__item:hover .gallery__item-actions,
.gallery__item:focus-within .gallery__item-actions{opacity:1}
.gallery__action-icon{
  width:24px;height:24px;border-radius:50%;
  background:rgba(255,255,255,.94);color:var(--ink);
  border:none;cursor:pointer;
  font-family:var(--font-body);font-size:14px;font-weight:700;line-height:1;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 1px 4px rgba(0,0,0,.25);
  transition:transform var(--dur-fast),background var(--dur-fast),color var(--dur-fast);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.gallery__action-icon:hover{transform:scale(1.12)}
.gallery__action-icon--primary{background:var(--accent);color:var(--paper)}
.gallery__action-icon--primary:hover{background:var(--accent-deep)}
.gallery__action-icon--ref{background:var(--paper-warm);color:var(--fg)}
.gallery__action-icon--ref:hover{background:var(--paper-deep)}
.gallery__action-icon--danger{color:#9B4040}
.gallery__action-icon--danger:hover{background:#9B4040;color:var(--paper)}

/* Em thumb pequeno reposiciona "em uso" pra não colidir com os 3 ícones */
.gallery__item-actions ~ .gallery__used,
.gallery__visual:has(.gallery__item-actions) .gallery__used{
  top:auto;bottom:6px;
}

.gallery__caption{
  font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);
  margin:4px 0 0;text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}

.forja__gallery-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:var(--space-6);text-align:center;gap:var(--space-3);
}
.forja__gallery-empty[hidden]{display:none}
.forja__gallery-empty-frame{
  font-size:48px;color:var(--accent-soft);
  border:2px dashed var(--accent-soft);
  width:80px;height:120px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
}
.forja__gallery-empty-text{
  font-family:var(--font-display);font-size:13px;font-style:italic;
  color:var(--fg-soft);margin:0;line-height:var(--lead-snug);max-width:200px;
}

/* Forja (painel direito) */
.forja__panel{display:flex;flex-direction:column;min-width:0;overflow:hidden;position:relative}
.forja__scroll{
  flex:1;overflow-y:auto;
  padding:var(--space-5) var(--space-6);
  display:flex;flex-direction:column;gap:var(--space-5);
}
.forja__scroll::-webkit-scrollbar{width:6px}
.forja__scroll::-webkit-scrollbar-thumb{background:var(--sand-soft);border-radius:3px}

.forja__eyebrow{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:var(--accent-deep);font-weight:700;margin:0 0 var(--space-2);
}

/* Textarea hero */
.forja__textarea-wrap{position:relative}
.forja__textarea{
  width:100%;min-height:120px;
  font-family:var(--font-body);font-size:15px;line-height:var(--lead-normal);
  padding:var(--space-3) var(--space-4);
  border:1px solid var(--line-soft);border-radius:var(--radius-md);
  background:var(--paper);color:var(--fg);resize:vertical;
}
.forja__textarea::placeholder{
  font-family:var(--font-display);font-style:italic;color:var(--fg-softer);font-size:14px;
}
.forja__textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(92,143,122,.12)}
.forja__counter{
  position:absolute;bottom:8px;right:12px;
  font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);
}

/* Chips */
.forja__chips-wrap{position:relative}
.forja__chips{
  display:flex;gap:var(--space-2);overflow-x:auto;
  padding-bottom:6px;scroll-snap-type:x mandatory;
}
.forja__chips::-webkit-scrollbar{height:4px}
.forja__chips::-webkit-scrollbar-thumb{background:var(--sand-soft);border-radius:2px}
.forja__chips-wrap::after{
  content:"";position:absolute;top:0;right:0;bottom:6px;width:40px;
  background:linear-gradient(to right, transparent, var(--paper));pointer-events:none;
}
.forja__chips .chip{
  flex-shrink:0;scroll-snap-align:start;max-width:280px;
  font-size:12px;line-height:var(--lead-snug);
  padding:10px 14px;border-radius:var(--radius-pill);
  background:var(--paper-warm);border:1px solid var(--line-soft);color:var(--fg-soft);
  text-align:left;cursor:pointer;transition:all var(--dur-fast);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-family:inherit;text-transform:none;letter-spacing:0;font-weight:400;
}
.forja__chips .chip:hover{border-color:var(--accent);background:var(--paper);color:var(--fg);transform:translateY(-1px)}
.forja__chips .chip[aria-pressed="true"]{background:var(--accent);color:var(--paper);border-color:var(--accent)}

/* Referência */
.forja__ref{
  display:flex;align-items:center;gap:var(--space-3);
  padding:var(--space-3);background:var(--paper-warm);
  border-radius:var(--radius-md);border:1px solid var(--line-soft);
}
.ref__drop{
  flex-shrink:0;width:80px;height:80px;
  border:1.5px dashed var(--line);border-radius:var(--radius-sm);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  text-align:center;color:var(--fg-softer);cursor:pointer;
  background:transparent;transition:all var(--dur-fast);
}
.ref__drop:hover,.ref__drop.is-dragover{border-color:var(--accent);background:var(--paper);color:var(--accent-deep)}
.ref__icon{font-size:18px}
.ref__hint{font-size:10px;line-height:1.2;font-weight:600}
.ref__or{font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);letter-spacing:var(--track-wide)}
.ref__galleryhint{font-size:12px;color:var(--fg-soft);font-style:italic;line-height:var(--lead-snug)}

.ref__chip{
  display:flex;align-items:center;gap:var(--space-2);
  padding:8px 12px;border-radius:var(--radius-pill);
  background:rgba(92,143,122,.10);border:1px solid var(--accent);
}
.ref__chip-label{font-size:12px;color:var(--accent-deep);font-weight:600}
.ref__chip-remove{
  background:transparent;border:none;color:var(--fg-soft);
  font-size:16px;cursor:pointer;padding:0 4px;
}

/* Estilo de marca */
/* IA helpers acima da textarea */
.forja__ia-helpers{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-2)}
.forja__suggest-btn,.forja__enhance-btn{
  font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:var(--track-wide);
  padding:7px 14px;border-radius:var(--radius-pill);
  background:var(--paper);border:1.5px dashed var(--accent-soft);color:var(--accent-deep);
  cursor:pointer;transition:all var(--dur-fast);
  display:inline-flex;align-items:center;gap:6px;
}
.forja__suggest-btn:hover,.forja__enhance-btn:hover{
  background:var(--accent);color:var(--paper);border-color:var(--accent);border-style:solid;
}
.forja__suggest-btn:disabled,.forja__enhance-btn:disabled{opacity:.6;cursor:wait}
.forja__helper-status{font-size:11px;color:var(--alert-warn);font-style:italic;margin:6px 0 0}

/* Texto na arte — secao opt-in com toggle + input + 6 estilos tipograficos */
.forja__text-section{
  background:var(--paper-warm);border:1px dashed var(--line);
  border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);
}
.forja__text-label{
  display:flex;align-items:center;gap:var(--space-2);cursor:pointer;
  font-size:11px;color:var(--fg-soft);
}
.forja__text-toggle{
  width:18px;height:18px;cursor:pointer;accent-color:var(--accent);
}
.forja__text-eyebrow{
  font-size:11px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:var(--accent-deep);font-weight:700;
}
.forja__text-hint{font-size:10px;color:var(--fg-softer);font-style:italic;margin-left:auto}
.forja__text-block{margin-top:var(--space-3)}
.forja__text-block[hidden]{display:none}
.forja__text-input{
  width:100%;font-family:var(--font-display);font-style:italic;font-size:14px;
  padding:10px var(--space-3);
  border:1px solid var(--line-soft);border-radius:var(--radius-md);
  background:var(--paper);color:var(--fg);
}
.forja__text-input::placeholder{color:var(--fg-softer)}
.forja__text-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(92,143,122,.12)}

.forja__typo-styles{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:6px}
@media (max-width:880px){.forja__typo-styles{grid-template-columns:1fr 1fr}}
.typo-card{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  padding:8px 10px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  cursor:pointer;transition:all var(--dur-fast);text-align:left;position:relative;
}
.typo-card:hover{border-color:var(--accent-soft)}
.typo-card.is-active{border-color:var(--accent);background:var(--paper-deep)}
.typo-card.is-active::after{content:"✓";position:absolute;top:4px;right:7px;color:var(--accent);font-weight:700;font-size:11px}
.typo-card__name{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--fg)}
.typo-card__desc{font-size:10px;color:var(--fg-softer);line-height:1.3}

/* Abordagem visual (9 cards: Variável + 8 abordagens) — eixo ortogonal ao vibe */
.forja__approaches{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
@media (max-width:1100px){.forja__approaches{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.forja__approaches{grid-template-columns:repeat(2,1fr)}}
.approach-card{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  padding:8px 10px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  cursor:pointer;transition:all var(--dur-fast);text-align:left;position:relative;
  min-height:62px;
}
.approach-card:hover{border-color:var(--accent-soft);background:var(--paper-warm)}
.approach-card.is-active{border-color:var(--accent);background:var(--paper-deep)}
.approach-card.is-active::after{content:"✓";position:absolute;top:4px;right:7px;color:var(--accent);font-weight:700;font-size:11px}
.approach-card--featured{
  border-color:var(--accent);background:linear-gradient(135deg, var(--paper-warm), var(--paper-deep));
  position:relative;
}
.approach-card--featured::before{
  content:"DEFAULT";position:absolute;top:-7px;left:8px;
  font-family:var(--font-mono);font-size:8px;letter-spacing:var(--track-widest);
  background:var(--accent);color:var(--paper);padding:2px 6px;border-radius:3px;
}
.approach-card__ico{font-size:16px;margin-bottom:1px}
.approach-card__name{font-family:var(--font-display);font-size:13px;font-weight:500;color:var(--fg)}
.approach-card__desc{font-size:10px;color:var(--fg-softer);line-height:1.3}

/* Vibes/atmosferas (6 radio-cards) — substitui as 3 brand-styles */
.forja__vibes{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}
@media (max-width:880px){.forja__vibes{grid-template-columns:1fr 1fr}}
.vibe-card{
  display:flex;flex-direction:column;align-items:flex-start;gap:4px;
  padding:var(--space-3);
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-md);
  cursor:pointer;transition:all var(--dur-fast);text-align:left;position:relative;
}
.vibe-card:hover{border-color:var(--accent-soft)}
.vibe-card.is-active{border-color:var(--accent);background:var(--paper-deep)}
.vibe-card.is-active::after{content:"✓";position:absolute;top:8px;right:10px;color:var(--accent);font-weight:700;font-size:14px}
.vibe-card__name{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--fg)}
.vibe-card__desc{font-size:11px;color:var(--fg-softer);line-height:var(--lead-snug)}

/* Formato da arte (5 chips inline: Auto/Infográfico/Curiosidade/Editorial/Capa) */
.forja__formats{display:flex;flex-wrap:wrap;gap:var(--space-2)}
.format-chip{
  display:flex;flex-direction:column;align-items:flex-start;gap:2px;
  padding:6px 10px;
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  background:var(--paper);cursor:pointer;transition:all var(--dur-fast);
  text-align:left;position:relative;min-width:80px;
}
.format-chip:hover{border-color:var(--accent-soft);background:var(--paper-warm)}
.format-chip.is-active{border-color:var(--accent);background:var(--paper-deep)}
.format-chip.is-active::after{content:"✓";position:absolute;top:4px;right:6px;color:var(--accent);font-weight:700;font-size:10px}
.format-chip__name{font-size:12px;font-weight:600;color:var(--fg)}
.format-chip__desc{font-size:10px;color:var(--fg-softer);line-height:1.2}

/* (legacy .forja__styles{display:grid...} removido — colidia com .forja__styles
   novo dos chips de estilo maduro. style-card já não existe no HTML.) */
.style-card{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  padding:var(--space-3);
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-md);
  cursor:pointer;transition:all var(--dur-fast);text-align:left;position:relative;
}
.style-card:hover{border-color:var(--accent-soft)}
.style-card.is-active{border-color:var(--accent);background:var(--paper-deep)}
.style-card.is-active::after{content:"✓";position:absolute;top:8px;right:10px;color:var(--accent);font-weight:700;font-size:14px}
.style-card__swatch{
  width:28px;height:28px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:14px;font-weight:600;
}
.style-card__swatch--livro{background:linear-gradient(135deg,#FAF6EC,#A8C4B5);color:#3D5A45}
.style-card__swatch--app{background:linear-gradient(135deg,#1C1C1A,#3D5A45);color:#A8C4B5}
.style-card__swatch--future{background:linear-gradient(135deg,#B8A8E3,#7AC4D4,#E3B8C9);color:#FAF6EC}
.style-card__name{font-family:var(--font-display);font-size:14px;font-weight:500;color:var(--fg)}
.style-card__sub{font-size:11px;color:var(--fg-softer)}

/* Parâmetros */
.forja__params{display:flex;gap:var(--space-2);flex-wrap:wrap}
.param-chip{
  font-size:12px;font-weight:600;
  padding:7px 12px;border-radius:var(--radius-pill);
  background:var(--paper);border:1px solid var(--line-soft);color:var(--fg-soft);
  cursor:pointer;transition:all var(--dur-fast);
  display:inline-flex;align-items:center;gap:6px;
}
.param-chip:hover{border-color:var(--accent);color:var(--accent-deep)}
.param-chip.is-active{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.param-chip.is-disabled{opacity:.4;cursor:not-allowed}

/* Model picker popover */
.forja__model-chip{min-width:160px;text-align:left}
.forja__model-pop{
  position:absolute;top:calc(100% + 6px);left:0;z-index:10;
  min-width:320px;max-width:480px;max-height:340px;overflow-y:auto;
  background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius-md);box-shadow:var(--shadow-lift);
  padding:var(--space-2);
}
.forja__model-pop[hidden]{display:none}
.forja__model-head{
  font-size:10px;letter-spacing:var(--track-widest);text-transform:uppercase;
  color:var(--fg-softer);font-weight:600;margin:0 0 var(--space-2);
  padding:0 var(--space-2);
}
.forja__model-loading{
  font-family:var(--font-display);font-style:italic;font-size:13px;
  color:var(--fg-soft);text-align:center;margin:var(--space-3) 0;
}
.forja__model-row{
  display:grid;grid-template-columns:1fr auto;gap:var(--space-1);
  width:100%;padding:8px var(--space-3);
  background:transparent;border:none;border-radius:var(--radius-sm);
  cursor:pointer;text-align:left;
  transition:background var(--dur-fast);
}
.forja__model-row:hover{background:var(--paper-warm)}
.forja__model-row.is-active{background:rgba(92,143,122,.12);outline:1px solid var(--accent-soft)}
.forja__model-row.is-active::before{content:"✓";color:var(--accent);font-weight:700;margin-right:6px;grid-column:1;grid-row:1}
.forja__model-name{
  font-family:var(--font-body);font-size:13px;font-weight:600;color:var(--fg);
  grid-column:1;
}
.forja__model-slug{
  font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);
  grid-column:1;grid-row:2;
}
.forja__model-price{
  font-family:var(--font-mono);font-size:10px;color:var(--accent-deep);
  grid-column:2;grid-row:1/3;align-self:center;white-space:nowrap;
}

/* Estados loading / result / error */
.forja__view{display:none;padding:var(--space-5) var(--space-6);flex:1;overflow-y:auto}
#forja-modal[data-state="loading"] .forja__scroll{display:none}
#forja-modal[data-state="loading"] .forja__view[data-view="loading"]{display:flex;flex-direction:column;gap:var(--space-4);align-items:center;justify-content:center}
#forja-modal[data-state="result"] .forja__scroll{display:none}
#forja-modal[data-state="result"] .forja__view[data-view="result"]{display:flex;flex-direction:column;gap:var(--space-3)}
#forja-modal[data-state="error"] .forja__scroll{display:none}
#forja-modal[data-state="error"] .forja__view[data-view="error"]{display:flex;flex-direction:column;gap:var(--space-4);align-items:center;justify-content:center}

.forja__loading-skeleton{
  width:240px;max-width:60%;aspect-ratio:1/1;
  background:linear-gradient(135deg,#EFE6CE,#E3D8C8);
  border-radius:var(--radius-md);
  position:relative;overflow:hidden;border:1px solid var(--line-soft);
}
.forja__loading-skeleton::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(90deg, transparent, rgba(168,196,181,.4), transparent);
  animation:forja-shimmer 1.6s linear infinite;
}
@keyframes forja-shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}
.forja__loading-text{
  font-family:var(--font-display);font-style:italic;font-size:14px;
  color:var(--fg-soft);text-align:center;max-width:340px;margin:0;
}

.forja__result-prompt{
  font-family:var(--font-display);font-style:italic;font-size:13px;
  color:var(--fg-soft);background:var(--paper-warm);
  padding:8px 14px;border-radius:var(--radius-pill);
  border:1px solid var(--line-soft);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin:0;
}
.forja__result-media{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:var(--space-3);max-width:600px;margin:0 auto;
}
.result__img,.result__video{
  width:100%;height:auto;border-radius:var(--radius-md);
  border:1px solid var(--line-soft);display:block;
}
.forja__result-meta{
  font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);
  margin:0;text-align:center;
}
.forja__result-actions{display:flex;gap:var(--space-2);flex-wrap:wrap;justify-content:center}

.forja__error-card{
  max-width:380px;text-align:center;
  background:var(--paper-warm);border:1px solid #C9A87C;border-radius:var(--radius-md);
  padding:var(--space-5);
}
.forja__error-icon{font-size:32px;color:#C9A87C;display:block;margin-bottom:var(--space-2)}
.forja__error-title{font-family:var(--font-display);font-weight:400;font-size:var(--text-xl);margin:0 0 var(--space-2)}
.forja__error-msg{font-size:14px;color:var(--fg-soft);margin:0 0 var(--space-2)}
.forja__error-code{font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);margin:0 0 var(--space-4)}

/* Botões */
.fb{
  font-family:var(--font-body);font-size:13px;font-weight:600;
  padding:9px 16px;border-radius:var(--radius-pill);
  cursor:pointer;transition:all var(--dur-fast);border:1px solid transparent;
}
.fb--primary{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.fb--primary:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.fb--ghost{background:transparent;color:var(--accent-deep);border-color:var(--accent-soft)}
.fb--ghost:hover{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.fb--text{background:transparent;color:var(--fg-softer);border:none;text-decoration:underline}
.fb--text:hover{color:var(--fg)}

/* Footer */
.forja__foot{
  display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);
  padding:var(--space-3) var(--space-5);
  background:var(--paper-warm);border-top:1px solid var(--line-soft);
}
#forja-modal[data-state="result"] .forja__foot,
#forja-modal[data-state="error"] .forja__foot{display:none}

.forja__cost{display:flex;flex-direction:column;gap:2px;min-width:0}
.forja__cost-estimate{font-size:13px;color:var(--fg-soft)}
.forja__cost-estimate strong{font-family:var(--font-display);font-size:16px;color:var(--fg)}
.forja__cost-cumulative{font-family:var(--font-mono);font-size:10px;color:var(--fg-softer)}

.forja__cta{
  background:var(--accent);color:var(--paper);border:none;
  font-family:var(--font-display);font-size:16px;font-weight:500;
  padding:12px 28px;border-radius:var(--radius-pill);cursor:pointer;
  transition:all var(--dur-fast);min-width:140px;
  box-shadow:0 3px 14px rgba(92,143,122,.32);
}
.forja__cta:hover{background:var(--accent-deep);box-shadow:0 5px 20px rgba(60,90,69,.4)}

/* Footer durante loading */
#forja-modal[data-state="loading"] .forja__foot .forja__cost{display:none}
#forja-modal[data-state="loading"] .forja__foot .forja__cta{display:none}
#forja-modal:not([data-state="loading"]) .forja__cancel,
#forja-modal:not([data-state="loading"]) .forja__minimize{display:none}
.forja__cancel{
  background:transparent;color:var(--fg-soft);border:1px solid var(--line);
  font-size:13px;font-weight:600;padding:9px 16px;border-radius:var(--radius-pill);cursor:pointer;
}
.forja__minimize{
  background:var(--accent);color:var(--paper);border:none;
  font-size:13px;font-weight:600;padding:9px 16px;border-radius:var(--radius-pill);cursor:pointer;
}

/* =========================================================================
   MOBILE (<760px) — bottom-sheet
   ========================================================================= */
@media (max-width:760px){
  .forja-overlay{align-items:flex-end;padding:0}
  .forja{
    width:100%;max-width:100%;height:92dvh;
    border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  }
  .forja::before{
    content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);
    width:36px;height:4px;border-radius:2px;background:var(--line);z-index:2;
  }
  .forja__head{padding-top:var(--space-4)}
  .forja__body{grid-template-columns:1fr;grid-template-rows:1fr;overflow-y:auto}
  .forja__divisor{display:none}
  .forja__gallery{order:2;background:var(--paper);border-top:1px solid var(--line-soft)}
  .forja__panel{order:1}
  .forja__gallery-grid{
    display:flex;overflow-x:auto;overflow-y:hidden;
    padding:0 var(--space-4) var(--space-3);gap:var(--space-2);
    scroll-snap-type:x mandatory;
  }
  .gallery__item{width:140px;flex-shrink:0;scroll-snap-align:start}
  .style-card{padding:var(--space-2);gap:4px}
  .style-card__sub{display:none}
  .forja__foot{padding:var(--space-3) var(--space-4)}
  .forja__cta{padding:10px 20px;font-size:14px}
}

/* =========================================================================
   TOASTER · #forja-toaster-root (vive fora do modal)
   ========================================================================= */
.forja-toaster{
  position:fixed;bottom:var(--space-4);left:var(--space-4);
  z-index:900;display:flex;flex-direction:column;gap:var(--space-2);
  max-width:340px;pointer-events:none;
}
.forja-toast{
  pointer-events:auto;
  display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-3);align-items:center;
  background:var(--paper);border:1px solid var(--line-soft);
  border-radius:var(--radius-md);padding:var(--space-3);
  box-shadow:var(--shadow-lift);
  border-left:3px solid var(--accent);
  font-family:var(--font-body);
  animation:forja-toast-in .3s var(--ease-out);
}
@keyframes forja-toast-in{from{transform:translateX(-110%);opacity:0}to{transform:none;opacity:1}}

.forja-toast[data-status="completed"]{border-left-color:var(--alert-success);background:linear-gradient(135deg,var(--paper),rgba(168,196,181,.18))}
.forja-toast[data-status="failed"],.forja-toast[data-status="canceled"]{border-left-color:#C9A87C;opacity:.85}

.forja-toast__icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--accent-soft);color:var(--accent-deep);
  display:flex;align-items:center;justify-content:center;font-size:14px;
}
.forja-toast[data-status="completed"] .forja-toast__icon{background:var(--alert-success);color:var(--paper)}
.forja-toast__body{min-width:0}
.forja-toast__title{
  font-family:var(--font-display);font-size:14px;font-weight:500;
  margin:0;line-height:1.3;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.forja-toast__meta{
  font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);
  margin:2px 0 0;
}
.forja-toast__actions{display:flex;gap:4px}
.forja-toast__open,.forja-toast__cancel{
  width:28px;height:28px;border-radius:50%;
  background:transparent;border:1px solid transparent;cursor:pointer;
  font-size:14px;color:var(--fg-soft);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);
}
.forja-toast__open:hover{background:var(--accent);color:var(--paper)}
.forja-toast__cancel:hover{background:var(--bg-alt);color:var(--alert-error)}

/* Paletas (15 chips: 3 modos × 5 variações + chip "Nenhuma") */
.forja__palettes{
  display:grid;grid-template-columns:repeat(4,1fr);gap:6px;
}
@media (max-width:1100px){.forja__palettes{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.forja__palettes{grid-template-columns:repeat(2,1fr)}}
.forja__palettes .palette-group-label{
  grid-column:1/-1;
  font-family:var(--font-mono);font-size:9px;letter-spacing:var(--track-widest);
  text-transform:uppercase;font-weight:700;color:var(--fg-softer);
  padding:6px 0 2px;
  border-top:1px dashed var(--line-soft);
}
.forja__palettes .palette-group-label:first-child{border-top:0;padding-top:0}
.palette-chip{
  display:flex;flex-direction:column;align-items:flex-start;gap:4px;
  padding:6px 8px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  cursor:pointer;transition:all var(--dur-fast);text-align:left;position:relative;
  min-height:48px;
}
.palette-chip:hover{border-color:var(--accent-soft);background:var(--paper-warm)}
.palette-chip.is-active{border-color:var(--accent);background:var(--paper-deep)}
.palette-chip.is-active::after{
  content:"✓";position:absolute;top:3px;right:6px;color:var(--accent);
  font-weight:700;font-size:11px;
}
.palette-chip__swatch{
  display:grid;grid-template-columns:repeat(5,1fr);gap:0;
  width:100%;height:14px;border-radius:2px;overflow:hidden;
  box-shadow:0 0 0 1px rgba(0,0,0,0.08);
}
.palette-chip__swatch span{display:block;height:100%}
.palette-chip__swatch--none{
  display:flex;align-items:center;justify-content:center;
  background:var(--paper-warm);color:var(--fg-softer);font-family:var(--font-mono);
  font-size:11px;
}
.palette-chip__name{
  font-family:var(--font-display);font-size:11px;font-weight:500;color:var(--fg);
  line-height:1.2;
}

/* Linha do input "frase na arte" com botão aleatória à direita */
.forja__text-input-row{
  display:flex;gap:6px;align-items:stretch;
}
.forja__text-input-row .forja__text-input{flex:1}
.forja__text-random-btn{
  white-space:nowrap;
  padding:6px 12px;
  background:var(--paper-warm);border:1.5px solid var(--line-soft);
  border-radius:var(--radius-sm);
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.02em;
  color:var(--fg);cursor:pointer;transition:all var(--dur-fast);
}
.forja__text-random-btn:hover:not(:disabled){
  border-color:var(--accent);background:var(--paper-deep);
}
.forja__text-random-btn:disabled{opacity:.55;cursor:wait}

/* Linha de estilos maduros (chips + input do TEMA) acima da textarea de prompt */
.forja__styles-row{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  margin:8px 0 6px;
  padding:8px 10px;
  background:var(--paper-warm);
  border:1px dashed var(--line-soft);
  border-radius:var(--radius-sm);
}
.forja__styles-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--fg-softer);font-weight:700;
}
.forja__styles{display:flex;gap:6px;flex-wrap:wrap}
.forja__style-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 10px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:999px;
  cursor:pointer;transition:all var(--dur-fast);
  font-size:11px;font-weight:600;color:var(--fg);
}
.forja__style-chip:hover{border-color:var(--accent);background:var(--paper-deep)}
.forja__style-chip.is-active{
  border-color:var(--accent);background:var(--accent);color:var(--paper);
}
.forja__style-chip__ico{font-size:13px;line-height:1}
.forja__style-tema{
  flex:1;min-width:140px;
  padding:5px 10px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  font-family:var(--font-mono);font-size:12px;color:var(--fg);
  transition:border-color var(--dur-fast);
}
.forja__style-tema:focus{border-color:var(--accent);outline:none}

/* Checkbox "Gerar legenda longa" no footer */
.forja__caption-toggle{
  display:inline-flex;align-items:center;gap:6px;
  margin-left:12px;
  font-size:11px;color:var(--fg-soft);cursor:pointer;
  user-select:none;
}
.forja__caption-toggle input{cursor:pointer;margin:0}
.forja__caption-toggle:hover{color:var(--fg)}

/* Bloco da legenda renderizado no result */
.forja__caption-block{
  margin-top:var(--space-4);
  padding:var(--space-3);
  background:var(--paper-warm);
  border:1.5px solid var(--line-soft);
  border-radius:var(--radius-md);
}
.forja__caption-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  margin-bottom:8px;
}
.forja__caption-eyebrow{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;
  text-transform:uppercase;font-weight:700;color:var(--fg-softer);
}
.forja__caption-status{
  flex:1;text-align:center;
  font-size:10px;color:var(--fg-softer);
}
.forja__caption-copy{
  padding:4px 10px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--fg);
  cursor:pointer;transition:all var(--dur-fast);
}
.forja__caption-copy:hover{border-color:var(--accent);background:var(--paper-deep)}
.forja__caption-text{
  font-family:var(--font-display, Fraunces, serif);font-size:13px;line-height:1.55;
  color:var(--fg);
  white-space:pre-wrap;word-wrap:break-word;
  margin:0;padding:8px;
  background:var(--paper);
  border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);
  max-height:340px;overflow-y:auto;
}

/* Botão 📝 nos items da galeria (só aparece se item.caption existe) */
.gallery__action-icon--caption{
  background:rgba(192, 168, 124, .92) !important;
  color:#3a2d18 !important;
}
.gallery__action-icon--caption:hover{
  background:#c9a87c !important;
  transform:scale(1.08);
}

/* Modal viewer da legenda */
#caption-viewer[hidden]{display:none}
#caption-viewer{
  position:fixed;inset:0;z-index:1500;
  display:flex;align-items:center;justify-content:center;
}
.caption-viewer__backdrop{
  position:absolute;inset:0;
  background:rgba(28,28,26,.55);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  cursor:pointer;
}
.caption-viewer__shell{
  position:relative;z-index:1;
  width:min(640px, 92vw);max-height:80dvh;
  background:var(--paper);
  border:1px solid var(--line-soft);border-radius:var(--radius-lg);
  box-shadow:var(--shadow-page);
  display:flex;flex-direction:column;overflow:hidden;
}
.caption-viewer__head{
  display:flex;align-items:center;gap:var(--space-2);
  padding:var(--space-3) var(--space-4);
  background:var(--paper-warm);
  border-bottom:1px solid var(--line-soft);
}
.caption-viewer__head h3{
  margin:0;font-family:var(--font-display);font-size:var(--text-md);font-weight:500;
  flex-shrink:0;
}
.caption-viewer__head-meta{
  flex:1;
  font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.caption-viewer__copy{
  padding:5px 12px;
  background:var(--paper);border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  font-family:var(--font-mono);font-size:11px;font-weight:600;color:var(--fg);
  cursor:pointer;transition:all var(--dur-fast);
}
.caption-viewer__copy:hover{border-color:var(--accent);background:var(--paper-deep)}
.caption-viewer__close{
  width:32px;height:32px;border-radius:50%;
  background:transparent;border:1px solid transparent;
  font-size:20px;color:var(--fg-soft);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);
}
.caption-viewer__close:hover{background:var(--paper-deep);border-color:var(--line)}
.caption-viewer__text{
  margin:0;padding:var(--space-4) var(--space-5);
  font-family:var(--font-display, Fraunces, serif);font-size:14px;line-height:1.65;
  color:var(--fg);
  white-space:pre-wrap;word-wrap:break-word;
  overflow-y:auto;
  background:var(--paper);
}

/* =========================================================================
   CARROSSEL · #carousel-modal
   ========================================================================= */
#carousel-modal[hidden]{display:none}
.carousel-overlay{
  position:fixed;inset:0;z-index:1100;
  background:rgba(28,28,26,.62);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:var(--space-3);
}
.carousel{
  width:min(1180px, 98vw);max-height:94dvh;
  background:var(--paper);border-radius:var(--radius-lg);
  border:1px solid var(--line-soft);box-shadow:var(--shadow-page);
  display:grid;grid-template-rows:auto 1fr auto;overflow:hidden;
}
.carousel__head{
  display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);
  padding:var(--space-4) var(--space-5);
  border-bottom:1px solid var(--line-soft);
  background:var(--paper-warm);
}
.carousel__eyebrow{
  font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;
  color:#8A6FB0;font-weight:700;text-transform:uppercase;margin:0;
}
.carousel__title{
  font-family:var(--font-display);font-weight:500;font-size:var(--text-xl);
  margin:2px 0;line-height:1.1;
}
.carousel__card-info{font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);margin:0}
.carousel__close{
  width:36px;height:36px;border-radius:50%;border:1px solid transparent;
  background:transparent;font-size:24px;color:var(--fg-soft);cursor:pointer;
  transition:all var(--dur-fast);
}
.carousel__close:hover{background:var(--paper-deep);border-color:var(--line)}

.carousel__body{
  overflow-y:auto;padding:var(--space-4) var(--space-5);
  display:flex;flex-direction:column;gap:var(--space-5);
}

.carousel__label{
  display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;
  text-transform:uppercase;font-weight:700;color:var(--fg-softer);
  margin-bottom:6px;
}

.carousel__config{
  display:flex;flex-direction:column;gap:var(--space-3);
  padding:var(--space-3);background:var(--paper-warm);
  border-radius:var(--radius-md);border:1px dashed var(--line-soft);
}
.carousel__row{display:flex;gap:var(--space-4);align-items:flex-start;flex-wrap:wrap}
.carousel__row--full{display:block; padding: 10px 0 0 0;}
.carousel__row label{flex:1;min-width:200px}

.carousel__n-wrap{display:flex;align-items:center;gap:10px}
.carousel__n-input{flex:1;accent-color:#8A6FB0}
.carousel__n-display{
  font-family:var(--font-mono);font-size:14px;font-weight:700;
  background:#8A6FB0;color:var(--paper);
  padding:3px 10px;border-radius:var(--radius-pill);
}

.carousel__aspects,.carousel__styles,.carousel__palettes{
  display:flex;gap:6px;flex-wrap:wrap;
}
.carousel__chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:var(--radius-pill);
  background:var(--paper);border:1.5px solid var(--line-soft);
  font-family:var(--font-mono);font-size:11px;color:var(--fg);
  cursor:pointer;transition:all var(--dur-fast);
}
.carousel__chip:hover{border-color:#8A6FB0;background:var(--paper-deep)}
.carousel__chip.is-active{background:#8A6FB0;color:var(--paper);border-color:#8A6FB0}
.carousel__chip--palette .carousel__chip-swatches{
  display:inline-grid;grid-template-columns:repeat(5,1fr);gap:0;
  width:36px;height:10px;border-radius:2px;overflow:hidden;
  box-shadow:0 0 0 1px rgba(0,0,0,.1);
}
.carousel__chip--palette .carousel__chip-swatches span{display:block}

.carousel__tema{
  width:100%;padding:8px 12px;
  font-family:var(--font-body);font-size:13px;color:var(--fg);
  background:var(--paper);border:1.5px solid var(--line-soft);
  border-radius:var(--radius-sm);
}

.carousel__script-section,.carousel__slides-section{
  display:flex;flex-direction:column;gap:8px;
}
.carousel__script-head,.carousel__slides-head{
  display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);
}
.carousel__gen-script,.carousel__gen-images,.carousel__save-all{
  padding:8px 14px;
  font-family:var(--font-body);font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  background:#8A6FB0;color:var(--paper);border:none;border-radius:var(--radius-pill);
  cursor:pointer;transition:all var(--dur-fast);
}
.carousel__gen-script:hover,.carousel__gen-images:hover,.carousel__save-all:hover{
  background:#6E5395;box-shadow:0 3px 12px rgba(138,111,176,.32);
}
.carousel__gen-script:disabled,.carousel__gen-images:disabled,.carousel__save-all:disabled{
  opacity:.6;cursor:wait;
}
.carousel__script{
  width:100%;padding:10px 12px;
  font-family:var(--font-display, Fraunces, serif);font-size:13px;line-height:1.55;
  color:var(--fg);background:var(--paper);
  border:1.5px solid var(--line-soft);border-radius:var(--radius-sm);
  resize:vertical;
}
.carousel__cost-script,.carousel__cost-imgs{
  margin:4px 0 0;font-family:var(--font-mono);font-size:11px;color:var(--fg-softer);
}

.carousel__slides{
  display:grid;grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:var(--space-3);
}
.carousel__empty{
  grid-column:1/-1;text-align:center;color:var(--fg-softer);
  padding:var(--space-6);font-style:italic;
  border:1px dashed var(--line-soft);border-radius:var(--radius-md);
}
.carousel-slide{
  background:var(--paper);border:1.5px solid var(--line-soft);
  border-left:3px solid #8A6FB0;
  border-radius:var(--radius-md);padding:var(--space-3);
  display:flex;flex-direction:column;gap:8px;
}
.carousel-slide[data-role="hook"]{border-left-color:#C9A87C;background:rgba(201,168,124,.04)}
.carousel-slide[data-role="cta"] {border-left-color:var(--accent)}
.carousel-slide__head{display:flex;align-items:center;gap:6px}
.carousel-slide__num{
  font-family:var(--font-mono);font-size:11px;font-weight:700;
  background:var(--paper-deep);padding:2px 8px;border-radius:var(--radius-pill);
}
.carousel-slide__role{
  font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);
  text-transform:uppercase;letter-spacing:.05em;flex:1;
}
.carousel-slide__regen{
  width:24px;height:24px;border-radius:50%;
  background:transparent;border:1px solid var(--line);color:var(--fg-soft);
  cursor:pointer;font-size:13px;
}
.carousel-slide__regen:hover{background:#8A6FB0;color:var(--paper);border-color:#8A6FB0}
.carousel-slide__visual{
  position:relative;
  background:linear-gradient(135deg,#EFE6CE,#E3D8C8);
  border-radius:var(--radius-sm);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  color:var(--fg-softer);
}
.carousel-slide__visual[data-ar="1/1"] {aspect-ratio:1/1}
.carousel-slide__visual[data-ar="4/5"] {aspect-ratio:4/5}
.carousel-slide__visual[data-ar="9/16"]{aspect-ratio:9/16}
.carousel-slide__visual img{width:100%;height:100%;object-fit:cover;display:block}
.carousel-slide__visual-hint{
  position:absolute;bottom:6px;right:8px;
  font-family:var(--font-mono);font-size:9px;
  background:rgba(255,255,255,.8);padding:2px 6px;border-radius:var(--radius-pill);
}
.carousel-slide__prompt{
  width:100%;padding:6px 8px;
  font-family:var(--font-mono);font-size:10.5px;line-height:1.4;
  background:var(--paper-warm);border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);resize:vertical;color:var(--fg);
}
.carousel-slide__caption{
  width:100%;padding:6px 8px;
  font-family:var(--font-body);font-size:11px;color:var(--fg);
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
}
.carousel-slide__status{
  margin:0;font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);
  min-height:14px;
}

.carousel__foot{
  display:flex;justify-content:flex-end;
  padding:var(--space-4) var(--space-5);
  background:var(--paper-warm);
  border-top:1px solid var(--line-soft);
}

/* Botão 💾 individual no slide do carrossel (ao lado do ↻) */
.carousel-slide__save-one{
  width:24px;height:24px;border-radius:50%;
  background:transparent;border:1px solid var(--line);color:var(--fg-soft);
  cursor:pointer;font-size:11px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);
}
.carousel-slide__save-one:hover{
  background:var(--accent);color:var(--paper);border-color:var(--accent);
}

/* Headline + body text editáveis (texto-na-arte) */
.carousel-slide__headline{
  width:100%;padding:6px 8px;
  font-family:var(--font-display);font-weight:600;font-size:12px;color:var(--fg);
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
}
.carousel-slide__body-text{
  width:100%;padding:6px 8px;resize:vertical;
  font-family:var(--font-body);font-size:11px;color:var(--fg-soft);line-height:1.4;
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
  min-height:36px;
}

/* Upload de imagem de referência por slide (🖼 file input) */
.carousel-slide__ref-label{
  width:24px;height:24px;border-radius:50%;
  background:transparent;border:1px dashed var(--line);color:var(--fg-soft);
  cursor:pointer;font-size:11px;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);
}
.carousel-slide__ref-label:hover{border-color:var(--accent);color:var(--accent)}
.carousel-slide__ref-label.has-ref{
  background:rgba(92,143,122,.18);border-color:var(--accent);color:var(--accent-deep);border-style:solid;
}

/* Assinatura visual travada — mostra abaixo do script */
.carousel__visual-signature{
  margin:6px 0 0;padding:8px 12px;
  font-family:var(--font-mono);font-size:10px;line-height:1.5;color:var(--fg-soft);
  background:rgba(92,143,122,.06);border:1px dashed rgba(92,143,122,.4);border-radius:var(--radius-sm);
  min-height:14px;
}
.carousel__visual-signature:empty{display:none}

/* Structures chips — mesmo padrão dos scripts */
.carousel__structures{display:flex;flex-wrap:wrap;gap:6px}

/* =========================================================================
   CARROSSEL COESO (storyboard)
   ========================================================================= */
.creative__coeso-btn{
  background:linear-gradient(135deg, #4A5D75 0%, #2C3E5A 100%);color:#fff;border:none;
}
.creative__coeso-btn:hover{filter:brightness(1.1)}

.coeso__anchor-row{
  display:flex;align-items:flex-start;gap:10px;
  padding:10px 12px;background:rgba(74,93,117,.08);
  border:1px dashed rgba(74,93,117,.4);border-radius:var(--radius-sm);
  font-size:11px;line-height:1.5;color:var(--fg-soft);
}
.coeso__anchor-row input[type="checkbox"]{margin-top:3px;width:14px;height:14px;cursor:pointer}
.coeso__anchor-row strong{color:#2C3E5A}
.coeso__anchor-row code{font-family:var(--font-mono);font-size:10px;background:rgba(0,0,0,.06);padding:1px 4px;border-radius:3px}

/* Linha de chips multi-opção (CTA produto, modo de prints) */
.carousel__chips-row{
  display:flex;flex-wrap:wrap;gap:6px;
}

/* Hint abaixo do chip de prints — explica auto-detect */
.coeso__prints-hint{
  margin:8px 0 0;padding:8px 12px;
  font-family:var(--font-body);font-size:11px;line-height:1.5;color:var(--fg-soft);
  background:rgba(74,93,117,.04);border:1px dashed rgba(74,93,117,.30);border-radius:var(--radius-sm);
}
.coeso__prints-hint code{
  font-family:var(--font-mono);font-size:10px;
  background:rgba(0,0,0,.06);padding:1px 5px;border-radius:3px;color:#2C3E5A;
}

.coeso__master-scene{
  width:100%;padding:8px 10px;resize:vertical;
  font-family:var(--font-body);font-size:12px;color:var(--fg);line-height:1.5;
  background:rgba(74,93,117,.04);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
  min-height:60px;
}

.coeso__visual-signature{
  margin:6px 0 0;padding:8px 12px;
  font-family:var(--font-mono);font-size:10px;line-height:1.5;color:var(--fg-soft);
  background:rgba(92,143,122,.06);border:1px dashed rgba(92,143,122,.4);border-radius:var(--radius-sm);
  min-height:14px;
}
.coeso__visual-signature:empty{display:none}

/* Shot badge no header de cada slide */
.coeso-slide__shot{
  font-family:var(--font-mono);font-size:10px;font-weight:600;
  padding:2px 8px;border-radius:var(--radius-pill);
  background:rgba(74,93,117,.15);color:#2C3E5A;
  letter-spacing:.04em;
}
.coeso-slide[data-shot="hero_wide"] .coeso-slide__shot,
.coeso-slide[data-shot="eco_cta"] .coeso-slide__shot{
  background:rgba(176,122,111,.18);color:#7A4A40; /* terra: enquadramentos âncora */
}
.coeso-slide[data-shot="data_hero"] .coeso-slide__shot{
  background:rgba(201,168,124,.22);color:#7A5A30; /* sand: dado */
}

.coeso-slide__anchor-badge{
  font-family:var(--font-mono);font-size:9px;font-weight:700;
  padding:2px 6px;border-radius:var(--radius-pill);
  background:#2C3E5A;color:#fff;letter-spacing:.06em;
}

.coeso-slide__texto-arte{
  width:100%;padding:6px 8px;
  font-family:var(--font-display);font-weight:500;font-size:12px;color:var(--fg);
  background:rgba(176,122,111,.06);border:1px solid rgba(176,122,111,.3);border-radius:var(--radius-sm);
}

.coeso-slide__delta{
  font-family:var(--font-body);font-size:11px;color:var(--fg-soft);font-style:italic;
}

/* Textarea editável do prompt FINAL — preserva look "code-block" do <pre> antigo */
.coeso-slide__final-prompt{
  display:block;width:100%;margin:6px 0 0;padding:10px;
  min-height:200px;max-height:480px;resize:vertical;
  font-family:var(--font-mono);font-size:11px;line-height:1.5;
  background:#1a1a1a;color:#c9b8a8;
  border:1px solid #333;border-radius:var(--radius-sm);
  white-space:pre-wrap;word-break:break-word;
}
.coeso-slide__final-prompt:focus{
  outline:none;border-color:#8A6FB0;
  box-shadow:0 0 0 2px rgba(138,111,176,.25);
}

.coeso-slide__final-actions{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  margin:4px 0 0;
}
.coeso-slide__reset-final{
  padding:4px 10px;border-radius:var(--radius-pill);
  background:rgba(138,111,176,.18);border:1px solid rgba(138,111,176,.45);
  color:#5C4480;font-family:var(--font-mono);font-size:10px;font-weight:700;
  cursor:pointer;transition:all var(--dur-fast);letter-spacing:.04em;
}
.coeso-slide__reset-final:hover{background:rgba(138,111,176,.32)}
.coeso-slide__final-status{
  font-family:var(--font-mono);font-size:10px;color:var(--fg-softer);font-style:italic;
}

/* ===========================================================================
   AMPLIAR EDIÇÃO POR SLIDE — labels explicativos + textareas grandes
   ========================================================================== */
.coeso-slide__expand{
  margin-left:auto; padding:3px 9px; border-radius:var(--radius-pill);
  background:rgba(74,93,117,.10); color:#2C3E5A; border:1px solid rgba(74,93,117,.30);
  font-family:var(--font-mono); font-size:10px; font-weight:600;
  cursor:pointer; transition:all var(--dur-fast); letter-spacing:.04em;
}
.coeso-slide__expand:hover{background:rgba(74,93,117,.22)}

/* Labels explicativos: invisíveis por default, aparecem em modo expandido */
.coeso-slide__field-label{
  display:none;
  margin:6px 0 2px;
  font-family:var(--font-body); font-size:10px; line-height:1.5; color:var(--fg-soft);
}
.coeso-slide__field-label strong{
  font-family:var(--font-mono); font-size:11px; font-weight:700; color:#2C3E5A;
  letter-spacing:.04em; margin-right:6px;
}

/* Quando .is-expanded: labels aparecem + textareas crescem + final-prompt expande */
.coeso-slide.is-expanded{
  border:2px solid #2C3E5A; padding:4px; border-radius:var(--radius-md);
  background:rgba(74,93,117,.03);
}
.coeso-slide.is-expanded .coeso-slide__field-label{display:block}
.coeso-slide.is-expanded .coeso-slide__delta{
  min-height:140px; rows:8;
  font-size:12px; line-height:1.5;
}
.coeso-slide.is-expanded .coeso-slide__final-prompt{
  max-height:400px; font-size:11px; line-height:1.6;
}
.coeso-slide.is-expanded textarea,
.coeso-slide.is-expanded input[type="text"]{
  font-size:12px; padding:8px 10px;
}

/* ===========================================================================
   RELATÓRIO DE CUSTOS no fim do modal
   ========================================================================== */
.carousel__cost-section{
  margin-top:16px; padding:14px 18px;
  background:rgba(92,143,122,.05); border:1px dashed rgba(92,143,122,.30);
  border-radius:var(--radius-md);
}
.coeso__cost-report{
  display:flex; flex-direction:column; gap:6px;
  font-family:var(--font-mono); font-size:11px;
}
.coeso-cost-row{
  display:flex; justify-content:space-between; align-items:baseline; gap:12px;
  padding:6px 10px;
  background:var(--paper); border-radius:var(--radius-sm);
  border:1px solid var(--line-soft);
}
.coeso-cost-row__label{color:var(--fg-soft); letter-spacing:.02em}
.coeso-cost-row__val{font-weight:700; color:var(--fg); white-space:nowrap}
.coeso-cost-row__val em{
  font-style:italic; font-weight:400; color:var(--fg-softer); margin-left:8px; font-size:10px;
}
.coeso-cost-row--total{
  background:rgba(92,143,122,.15); border-color:rgba(92,143,122,.50);
  margin-top:4px;
}
.coeso-cost-row--total .coeso-cost-row__label{color:var(--accent-deep); font-weight:700}
.coeso-cost-row--total .coeso-cost-row__val{color:var(--accent-deep); font-size:14px}

/* Override por slide — <details> colapsado dentro do .carousel-slide */
.carousel-slide__advanced{
  margin:6px 0;font-family:var(--font-body);font-size:11px;
  border:1px dashed var(--line-soft);border-radius:var(--radius-sm);
  background:rgba(92,143,122,.04);
}
.carousel-slide__advanced summary{
  cursor:pointer;padding:6px 10px;
  font-family:var(--font-mono);font-size:11px;color:var(--fg-soft);
  list-style:none;
  display:flex;align-items:center;gap:6px;
}
.carousel-slide__advanced summary::-webkit-details-marker{display:none}
.carousel-slide__advanced summary::before{
  content:'▸';display:inline-block;transition:transform var(--dur-fast);font-size:9px;
}
.carousel-slide__advanced[open] summary::before{transform:rotate(90deg)}
.carousel-slide__advanced summary:hover{color:var(--accent-deep)}
.carousel-slide__overrides{
  padding:8px 10px 10px;display:grid;gap:6px;
}
.carousel-slide__overrides label{
  display:flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:10px;color:var(--fg-soft);
}
.carousel-slide__overrides label > span{
  flex:0 0 70px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;
}
.carousel-slide__overrides select{
  flex:1;padding:4px 6px;
  font-family:var(--font-body);font-size:11px;color:var(--fg);
  background:var(--paper);border:1px solid var(--line-soft);border-radius:var(--radius-sm);
}
.carousel-slide__advanced-hint{
  margin:4px 0 0;font-size:10px;line-height:1.4;color:var(--fg-softer);
  font-style:italic;
}
.carousel-slide__advanced-hint strong{color:var(--accent-deep);font-style:normal}

/* Models — strong + light secondary */
.carousel__models .carousel__chip strong{font-weight:600}
.carousel__models .carousel__chip{font-family:var(--font-body);font-size:11px}

/* Footer com 2 botões */
.carousel__foot{
  justify-content:space-between !important;
  gap:12px;flex-wrap:wrap;
}
.carousel__use-visual{
  padding:8px 14px;
  font-family:var(--font-body);font-size:11px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  background:var(--accent);color:var(--paper);border:none;border-radius:var(--radius-pill);
  cursor:pointer;transition:all var(--dur-fast);
}
.carousel__use-visual:hover{background:var(--accent-deep);box-shadow:0 3px 12px rgba(92,143,122,.32)}
.carousel__use-visual:disabled{opacity:.6;cursor:wait}

/* Slider inline no .creative__visual (substitui imagem única quando há carrossel) */
.creative__visual.is-carousel{
  padding:0;background:#1c1c1a;overflow:hidden;
  display:block;
}
.creative__slider-track{
  display:flex;width:100%;height:100%;
  overflow-x:auto;scroll-snap-type:x mandatory;
  scrollbar-width:none;
}
.creative__slider-track::-webkit-scrollbar{display:none}
.creative__slider-slide{
  flex:0 0 100%;width:100%;height:100%;object-fit:cover;
  scroll-snap-align:start;display:block;
}
/* Setas ◀ ▶ overlay + contador #/N (substituiu os dots) */
.creative__slider-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:rgba(0,0,0,.55);color:#fff;
  border:none;cursor:pointer;
  font-size:14px;font-weight:600;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--dur-fast);z-index:2;
}
.creative__slider-arrow:hover{background:rgba(0,0,0,.78);transform:translateY(-50%) scale(1.08)}
.creative__slider-arrow--prev{left:8px}
.creative__slider-arrow--next{right:8px}
.creative__slider-arrow.is-disabled{opacity:.25;cursor:default;pointer-events:none}

.creative__slider-counter{
  position:absolute;top:10px;right:10px;
  font-family:var(--font-mono);font-size:11px;font-weight:700;
  background:rgba(0,0,0,.7);color:#fff;
  padding:4px 10px;border-radius:var(--radius-pill);
  z-index:2;letter-spacing:.04em;
}

/* Botão "✏ Editar carrossel" — aparece no canto superior esquerdo do slider */
.creative__slider-edit{
  position:absolute;top:10px;left:10px;z-index:3;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  background:rgba(255,255,255,.92);color:var(--fg);
  padding:4px 10px;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-pill);
  cursor:pointer;opacity:0;transition:opacity var(--dur-fast);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.creative__visual:hover .creative__slider-edit{opacity:1}
.creative__slider-edit:hover{background:var(--accent);color:var(--paper)}
.biblio-card__slider-edit{
  position:absolute;top:10px;left:10px;z-index:3;
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  background:rgba(255,255,255,.92);color:var(--fg);
  padding:4px 10px;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-pill);
  cursor:pointer;opacity:0;transition:opacity var(--dur-fast);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.biblio-card__visual:hover .biblio-card__slider-edit{opacity:1}
.biblio-card__slider-edit:hover{background:var(--accent);color:var(--paper)}

/* =========================================================================
   FORJA RÁPIDA — botão do card + modal compacto (idle/loading/result)
   ========================================================================= */
.creative__frapida-btn{
  font-family:var(--font-mono);font-size:11px;font-weight:600;
  padding:6px 12px;border-radius:var(--radius-pill);
  background:linear-gradient(135deg,#C9A24B 0%,#B07A6F 100%);color:#fff;border:none;
  cursor:pointer;transition:filter var(--dur-fast),transform var(--dur-fast);
  letter-spacing:.02em;
}
.creative__frapida-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}

/* O modal reaproveita .carousel / .carousel-overlay / .carousel__* do CSS acima.
   Aqui só os estados via [data-state] e o bloco de resultado. */
#frapida-modal .frapida{max-width:760px}

/* Alterna config / loading / result conforme data-state */
#frapida-modal .frapida__loading,
#frapida-modal .frapida__result-section{display:none}
#frapida-modal[data-state="idle"]    .frapida__config{display:block}
#frapida-modal[data-state="idle"]    .frapida__gen{display:inline-flex}
#frapida-modal[data-state="loading"] .frapida__config,
#frapida-modal[data-state="loading"] .frapida__gen{display:none}
#frapida-modal[data-state="loading"] .frapida__loading{display:block}
#frapida-modal[data-state="result"]  .frapida__config,
#frapida-modal[data-state="result"]  .frapida__gen{display:none}
#frapida-modal[data-state="result"]  .frapida__result-section{display:block}

.frapida__foot{justify-content:flex-end}
.frapida__gen{
  padding:9px 18px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--paper);border:none;
  font-family:var(--font-mono);font-size:12px;font-weight:700;cursor:pointer;
  letter-spacing:.04em;transition:filter var(--dur-fast);
}
.frapida__gen:hover{filter:brightness(1.08)}

/* Loading skeleton */
.frapida__skeleton{
  width:100%;aspect-ratio:1/1;max-height:380px;border-radius:var(--radius-md);
  background:linear-gradient(100deg,#EFE6CE 30%,#F6F0E0 50%,#EFE6CE 70%);
  background-size:200% 100%;animation:frapidaShimmer 1.3s linear infinite;
}
@keyframes frapidaShimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.frapida__status{
  margin:10px 0 0;text-align:center;
  font-family:var(--font-mono);font-size:11px;color:var(--fg-soft);
}

/* Result */
.frapida__result-visual{
  display:flex;align-items:center;justify-content:center;
  background:#1a1a1a;border-radius:var(--radius-md);overflow:hidden;
  max-height:520px;
}
.frapida__result-img{max-width:100%;max-height:520px;object-fit:contain;display:block}
.frapida__cost{
  margin:8px 0 0;text-align:center;
  font-family:var(--font-mono);font-size:11px;color:var(--accent-deep);
}
.frapida__result-actions{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:12px;
}
.frapida__result-actions button{
  padding:8px 14px;border-radius:var(--radius-pill);
  font-family:var(--font-mono);font-size:11px;font-weight:600;cursor:pointer;
  border:1px solid var(--line);background:var(--paper);color:var(--fg);
  transition:all var(--dur-fast);
}
.frapida__use{background:var(--accent)!important;color:var(--paper)!important;border-color:var(--accent)!important}
.frapida__result-actions button:hover{filter:brightness(1.05);transform:translateY(-1px)}
.frapida__discard{color:var(--fg-softer)}

/* ── Fix: frapida modal mais largo (alinha com o GERAR MÍDIA) ── */
#frapida-modal .frapida{max-width:960px}
#frapida-modal .carousel__body{gap:0}
#frapida-modal .carousel__row--full + .carousel__row--full{margin-top:2px;padding:20px 0 0 0}

/* ── Info-dot: bolinha ⓘ com tooltip CSS — reutilizável em qualquer modal ── */
.info-dot{
  display:inline-flex;align-items:center;justify-content:center;
  width:13px;height:13px;border-radius:50%;
  background:var(--paper-deep);border:1px solid var(--line-soft);
  color:var(--fg-softer);font-size:8px;font-family:var(--font-mono);font-weight:700;
  cursor:default;position:relative;vertical-align:middle;
  margin-left:5px;flex-shrink:0;user-select:none;
  transition:border-color var(--dur-fast),color var(--dur-fast);
}
.info-dot::before{content:'i'}
.info-dot:hover,.info-dot:focus{border-color:var(--accent);color:var(--accent);outline:none}
#info-dot-tooltip{
  position:fixed;z-index:99999;pointer-events:none;
  background:var(--fg);color:var(--paper);
  font-size:11px;line-height:1.45;padding:8px 11px;border-radius:var(--radius-md);
  width:240px;opacity:0;transition:opacity .12s;
  text-align:left;font-family:var(--font-body);font-weight:400;
  text-transform:none;letter-spacing:0;
}
#info-dot-tooltip.is-visible{opacity:1}
#info-dot-tooltip::after{
  content:'';position:absolute;top:100%;left:10px;
  border:5px solid transparent;border-top-color:var(--fg);
}
