/* ════════════════════════════════════════════════════════════════
   ADVANCED TOOLS MODULES III — Similar Ideas · Transform Tools
   Continuación con prefijo .atpm- (mismo namespace que módulos I-II).
   ════════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────── */
/* ── 6) SIMILAR IDEAS ─────────────────────────────────────────── */
/* ────────────────────────────────────────────────────────────── */

/* Cabecera con celda activa */
.atpm-context-header{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:11px 12px;
  background:linear-gradient(135deg, rgba(232,184,75,.06) 0%, transparent 100%);
  border:1px solid var(--border2);
  border-left:3px solid var(--gold);
  border-radius:5px;
}
.atpm-context-icon{
  width:30px;height:30px;
  border-radius:5px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  font-size:14px;
  background:rgba(232,184,75,.12);
  border:1px solid rgba(232,184,75,.35);
  color:var(--gold2);
}
.atpm-context-main{
  flex:1;
  min-width:0;
}
.atpm-context-title{
  font-family:var(--ff-cinzel);
  font-size:11px;
  letter-spacing:1.4px;
  color:var(--text);
  text-transform:uppercase;
  margin-bottom:2px;
  line-height:1.2;
}
.atpm-context-current{
  font-family:var(--ff-crimson);
  font-size:12px;
  color:var(--text2);
  line-height:1.35;
  font-style:italic;
}
.atpm-context-empty{
  color:var(--text3);
  font-style:italic;
}

/* Source badges (de dónde viene cada idea) */
.atpm-source-badges{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  margin-top:-4px;
}
.atpm-source-badge{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:4px 8px;
  border-radius:10px;
  font-family:var(--ff-cinzel);
  font-size:8px;
  letter-spacing:1.3px;
  text-transform:uppercase;
  border:1px solid var(--border2);
  background:var(--bg3);
  color:var(--text3);
}
.atpm-source-badge.atpm-on{
  color:var(--gold2);
  border-color:rgba(232,184,75,.5);
  background:rgba(232,184,75,.08);
}
.atpm-source-badge-dot{
  width:6px;height:6px;border-radius:50%;
  background:currentColor;
  opacity:.85;
}

/* Lista de ideas */
.atpm-ideas-list{
  display:flex;
  flex-direction:column;
  gap:6px;
  max-height:380px;
  overflow-y:auto;
  padding-right:2px;
}
.atpm-idea-card{
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:6px;
  padding:9px 10px;
  display:flex;
  align-items:flex-start;
  gap:9px;
  transition:.15s;
  position:relative;
  overflow:hidden;
}
.atpm-idea-card::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  background:var(--gold);
  opacity:0;
  transition:opacity .15s;
}
.atpm-idea-card:hover{
  background:var(--bg4);
  border-color:rgba(232,184,75,.4);
}
.atpm-idea-card:hover::before{ opacity:.4 }

.atpm-idea-label{
  flex-shrink:0;
  width:auto;
  min-width:54px;
  text-align:center;
  padding:3px 6px;
  border-radius:3px;
  font-family:var(--ff-cinzel);
  font-size:8px;
  letter-spacing:1.3px;
  text-transform:uppercase;
  background:var(--bg);
  border:1px solid var(--border2);
  color:var(--text3);
  align-self:center;
}
.atpm-idea-label.atpm-l-ai      { color:#a04ae8; border-color:rgba(160,74,232,.4); background:rgba(160,74,232,.06) }
.atpm-idea-label.atpm-l-similar { color:#4ad0d8; border-color:rgba(74,208,216,.4); background:rgba(74,208,216,.06) }
.atpm-idea-label.atpm-l-combinatorial { color:#d878a0; border-color:rgba(216,120,160,.45); background:rgba(216,120,160,.08); font-weight:600 }
/* ✦ Variación combinatoria que usó vocabulario del corpus del usuario.
   El color dorado (gold) distingue el aporte personal sin gritar. */
.atpm-idea-label.atpm-l-combinatorial-personal {
  color:var(--gold, #e8b84b);
  border-color:rgba(232,184,75,.55);
  background:rgba(232,184,75,.10);
  font-weight:600;
}
.atpm-idea-label.atpm-l-genre   { color:#e88a4a; border-color:rgba(232,138,74,.4); background:rgba(232,138,74,.06) }
.atpm-idea-label.atpm-l-shape   { color:#4ac870; border-color:rgba(74,200,112,.4); background:rgba(74,200,112,.06) }
.atpm-idea-label.atpm-l-default { color:var(--gold2); border-color:rgba(232,184,75,.4); background:rgba(232,184,75,.06) }

/* Card con barra lateral dorada cuando contiene un aporte personal. */
.atpm-idea-card.atpm-idea-personal::before{
  opacity:0.7;
  background:var(--gold, #e8b84b);
}
.atpm-idea-card.atpm-idea-personal:hover::before{ opacity:1 }

.atpm-idea-text{
  flex:1;
  min-width:0;
  font-family:var(--ff-crimson);
  font-size:12px;
  color:var(--text);
  line-height:1.4;
  word-wrap:break-word;
}
.atpm-idea-apply{
  flex-shrink:0;
  width:30px;height:30px;
  border-radius:4px;
  border:1px solid var(--border2);
  background:transparent;
  color:var(--gold2);
  font-size:14px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.15s;
  align-self:center;
}
.atpm-idea-apply:hover{
  background:rgba(232,184,75,.12);
  border-color:var(--gold);
  transform:scale(1.05);
}
.atpm-idea-apply:active{ transform:scale(.95) }

/* Estado: cargando ideas IA */
.atpm-ai-loading{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px;
  font-family:var(--ff-mono);
  font-size:10px;
  color:var(--gold2);
  background:var(--bg3);
  border:1px dashed rgba(232,184,75,.4);
  border-radius:5px;
}
.atpm-spinner{
  width:14px;height:14px;
  border:2px solid rgba(232,184,75,.25);
  border-top-color:var(--gold2);
  border-radius:50%;
  animation:atpmSpin .8s linear infinite;
}
@keyframes atpmSpin{ to { transform:rotate(360deg) } }

.atpm-ai-fail{
  font-family:var(--ff-crimson);
  font-size:11px;
  color:var(--crimson);
  padding:9px 12px;
  background:rgba(232,74,96,.06);
  border:1px solid rgba(232,74,96,.3);
  border-radius:5px;
  line-height:1.35;
}

/* ────────────────────────────────────────────────────────────── */
/* ── 7) TRANSFORM TOOLS ───────────────────────────────────────── */
/* ────────────────────────────────────────────────────────────── */

.atpm-transform-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:7px;
}
.atpm-transform-card{
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:6px;
  padding:11px 8px 10px;
  cursor:pointer;
  transition:.15s;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  min-height:78px;
  position:relative;
}
.atpm-transform-card:hover{
  background:var(--bg4);
  border-color:var(--gold);
  transform:translateY(-1px);
}
.atpm-transform-card:active{ transform:translateY(0) }
.atpm-transform-card[disabled],
.atpm-transform-card.atpm-disabled{
  opacity:.4;
  cursor:not-allowed;
  pointer-events:none;
}
.atpm-transform-card.atpm-busy{
  pointer-events:none;
}
.atpm-transform-card.atpm-busy::after{
  content:'';
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.4);
  border-radius:6px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.atpm-transform-icon{
  font-size:20px;
  line-height:1;
  color:var(--gold2);
  margin-bottom:1px;
}
.atpm-transform-name{
  font-family:var(--ff-cinzel);
  font-size:10px;
  letter-spacing:1.4px;
  color:var(--text);
  text-transform:uppercase;
  line-height:1.2;
}
.atpm-transform-desc{
  font-family:var(--ff-crimson);
  font-size:10px;
  color:var(--text3);
  line-height:1.2;
  font-style:italic;
  max-width:120px;
}

/* Preview area: muestra el resultado antes de aplicar */
.atpm-preview-row{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:10px;
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:6px;
  margin-top:2px;
}
.atpm-preview-title{
  font-family:var(--ff-cinzel);
  font-size:9px;
  letter-spacing:1.4px;
  color:var(--text3);
  text-transform:uppercase;
}
.atpm-preview-before,
.atpm-preview-after{
  font-family:var(--ff-crimson);
  font-size:12px;
  line-height:1.35;
  padding:6px 8px;
  border-radius:4px;
}
.atpm-preview-before{
  color:var(--text3);
  background:var(--bg);
  border:1px solid var(--border2);
  text-decoration:line-through;
  text-decoration-color:rgba(232,74,96,.4);
  text-decoration-thickness:1px;
}
.atpm-preview-arrow{
  font-family:var(--ff-cinzel);
  font-size:11px;
  color:var(--gold2);
  text-align:center;
  letter-spacing:1.5px;
}
.atpm-preview-after{
  color:var(--text);
  background:rgba(232,184,75,.08);
  border:1px solid rgba(232,184,75,.4);
}
.atpm-preview-actions{
  display:flex;
  gap:6px;
}
.atpm-preview-actions .atpm-action-btn{
  flex:1;
}
