/* 
  src/css/modules.css
  Sovereign storage for module-specific animations, keyframes, and custom layouts.
  Extracted from JS inline templates to adhere to [S-SOT] and [ROOT-CLEAN] Rules.
*/

/* =========================================================================
   MÓDULOS 19 Y 20 — VISION Y LEADERBOARD
   ========================================================================= */
.m19-role-card { 
  background: var(--glass-bg); 
  backdrop-filter: var(--blur-std);
  border: 1px solid var(--glass-border); 
  border-radius: 16px; 
  padding: 24px; 
  margin-bottom: 20px; 
  position: relative; 
  overflow: hidden; 
  transition: var(--trans-premium); 
}
.m19-role-card:hover { 
  transform: translateY(-5px); 
  border-color: var(--primary-light); 
  background: hsla(239, 84%, 67%, 0.05); 
  box-shadow: var(--shadow-lux);
}
.m19-role-title { font-size: 1.1rem; font-weight: 700; color: #60a5fa; margin-bottom: 5px; display: flex; align-items: center; gap: 8px; }
.m19-role-desc { font-size: 0.85rem; color: #cbd5e1; line-height: 1.5; margin-bottom: 10px; }
.m19-role-skill { display: inline-block; background: rgba(255,255,255,0.1); padding: 4px 8px; border-radius: 6px; font-size: 0.75rem; color: #94a3b8; margin-right: 5px; margin-bottom: 5px; }
.m19-salary { position: absolute; top: 20px; right: 20px; font-family: monospace; color: #10b981; font-weight: 700; background: rgba(16,185,129,0.1); padding: 4px 8px; border-radius: 6px; }

.m20-glory-box { background: url('data:image/svg+xml;utf8,<svg width="100%" height="100%" xmlns="http://www.w3.org/2000/svg"><defs><pattern id="dots" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="2" cy="2" r="1" fill="rgba(255,255,255,0.05)"/></pattern></defs><rect width="100%" height="100%" fill="url(%23dots)"/></svg>') #050a0e; border: 2px solid #eab308; border-radius: 20px; padding: 40px; text-align: center; position: relative; overflow: hidden; box-shadow: 0 0 40px rgba(234,179,8,0.1); }
.m20-glory-box::before { content:''; position:absolute; top:-50%; left:-50%; width:200%; height:200%; background:radial-gradient(circle, rgba(234,179,8,0.15) 0%, transparent 50%); animation: m20rotate 20s linear infinite; pointer-events:none; }
@keyframes m20rotate { 100% { transform: rotate(360deg); } }
.m20-stat { display: inline-block; padding: 15px 30px; background: rgba(0,0,0,0.5); border: 1px solid #333; border-radius: 12px; margin: 10px; backdrop-filter: blur(10px); }
.m20-stat-num { font-size: 2.5rem; font-weight: 800; color: #fde047; text-shadow: 0 0 10px rgba(234,179,8,0.5); font-family: monospace; }
.m20-stat-label { font-size: 0.8rem; color: #cbd5e1; text-transform: uppercase; letter-spacing: 1px; margin-top: 5px; }
.m20-leaderboard { margin-top: 30px; text-align: left; background: rgba(0,0,0,0.5); border-radius: 12px; padding: 20px; }
.m20-lb-row { display: flex; align-items: center; padding: 15px; border-bottom: 1px solid #333; transition: all 0.2s; }
.m20-lb-row:hover { background: rgba(255,255,255,0.02); }
.m20-lb-row:last-child { border: none; }
.m20-lb-rank { font-size: 1.5rem; font-weight: 800; width: 50px; text-align: center; }
.m20-lb-avatar { width: 40px; height: 40px; background: #333; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; margin-right: 15px; }
.m20-lb-info { flex: 1; }
.m20-lb-name { font-weight: 700; color: #fff; font-size: 1rem; }
.m20-lb-title { font-size: 0.75rem; color: #94a3b8; }
.m20-lb-score { font-family: monospace; font-size: 1.2rem; color: #10b981; font-weight: 700; }

.rank-1 .m20-lb-rank { color: #eab308; } .rank-1 .m20-lb-avatar { background: rgba(234,179,8,0.2); border: 1px solid #eab308; }
.rank-2 .m20-lb-rank { color: #94a3b8; } .rank-2 .m20-lb-avatar { background: rgba(148,163,184,0.2); border: 1px solid #94a3b8; }
.rank-3 .m20-lb-rank { color: #b45309; } .rank-3 .m20-lb-avatar { background: rgba(180,83,9,0.2); border: 1px solid #b45309; }

/* =========================================================================
   MÓDULOS 16 A 18 — IA PARA CÓDIGO, OLLAMA Y ROI
   ========================================================================= */
.m16-code-window { 
  background: #010409; 
  border: 1px solid var(--glass-border); 
  border-radius: 16px; 
  overflow: hidden; 
  margin-top: 24px; 
  font-family: 'JetBrains Mono', monospace; 
  box-shadow: var(--shadow-lux);
}
.m16-code-header { 
  background: hsla(222, 47%, 10%, 0.8); 
  padding: 12px 20px; 
  display: flex; 
  gap: 10px; 
  border-bottom: 1px solid var(--glass-border); 
}
.m16-dot { width: 12px; height: 12px; border-radius: 50%; }
.m16-dot.r { background: #ef4444; } .m16-dot.y { background: #f59e0b; } .m16-dot.g { background: #10b981; }
.m16-code-body { padding: 20px; font-size: 0.85rem; color: #a5b4fc; line-height: 1.6; position: relative; }
.m16-cursor { display: inline-block; width: 8px; height: 15px; background: #60a5fa; animation: m16blink 1s step-end infinite; vertical-align: middle; margin-left: 2px; }
@keyframes m16blink { 0%, 100% {opacity:1;} 50% {opacity:0;} }
.m16-excel-grid { display: grid; grid-template-columns: 40px auto auto auto; gap: 1px; background: #333; border: 1px solid #333; margin-top: 15px; border-radius: 8px; overflow: hidden; }
.m16-cel, .m16-th { background: #0d1117; padding: 10px; font-size: 0.8rem; }
.m16-th { background: #1a1a2e; text-align: center; font-weight: 700; color: #cbd5e1; }
.m16-cel.hl { background: rgba(16,185,129,0.1); border: 1px solid #10b981; }
.m16-lab-card { background: rgba(255, 255, 255, 0.02); padding: 20px; border-radius: 12px; margin-top: 20px; border: 1px solid #10b981; }
.m16-lab-group { display: flex; gap: 10px; flex-wrap: wrap; align-items: stretch; }
.m16-lab-select { flex: 1; min-width: 200px; padding: 12px; background: #050a0e; border: 1px solid #333; border-radius: 8px; color: #fff; font-size: 0.85rem; outline: none; transition: border-color 0.2s; }
.m16-lab-select:focus { border-color: #10b981; }
.m16-lab-btn { background: #10b981 !important; color: #000 !important; font-weight: 700 !important; white-space: nowrap; flex-shrink: 0; }

.m17-terminal { 
  background: #010409; 
  color: var(--success); 
  font-family: 'JetBrains Mono', monospace; 
  border-radius: 16px; 
  padding: 24px; 
  border: 1px solid var(--glass-border); 
  margin-top: 20px; 
  min-height: 150px; 
  position:relative;
  box-shadow: inset 0 0 20px rgba(0,0,0,0.5);
}
.m17-lock { font-size: 3rem; text-align: center; color: #10b981; text-shadow: 0 0 20px rgba(16,185,129,0.5); }
.m17-arch { display: flex; align-items: center; justify-content: center; gap: 20px; margin: 30px 0; }
.m17-box { padding: 15px; border-radius: 12px; border: 2px solid; text-align: center; width: 150px; }
.m17-arrow { font-size: 1.5rem; color: #64748b; }

.m18-royalty-card { 
  padding: 30px; 
  border-radius: 20px; 
  position: relative; 
  overflow: hidden; 
  background: var(--glass-bg); 
  backdrop-filter: var(--blur-std);
  border: 1px solid rgba(139,92,246,0.2); 
  box-shadow: var(--shadow-lux);
}
.m18-royalty-card::before { 
  content:''; 
  position:absolute; 
  top:0; 
  left:0; 
  width:100%; 
  height:4px; 
  background: linear-gradient(90deg, #8b5cf6, #d946ef); 
}
.m18-result-box { transition: all 0.25s ease; }
.m18-result-box.is-poor { background: rgba(239,68,68,0.08) !important; border-color: rgba(239,68,68,0.45) !important; }
.m18-result-box.is-fair { background: rgba(245,158,11,0.08) !important; border-color: rgba(245,158,11,0.45) !important; }
.m18-result-box.is-strong { background: rgba(16,185,129,0.08) !important; border-color: rgba(16,185,129,0.45) !important; }
.m18-result-box.is-excellent { background: rgba(59,130,246,0.1) !important; border-color: rgba(59,130,246,0.45) !important; }
.m18-verdict-badge { display: inline-flex; align-items: center; padding: 6px 12px; border-radius: 999px; font-size: 0.75rem; font-weight: 800; letter-spacing: 0.3px; text-transform: uppercase; margin-bottom: 10px; border: 1px solid transparent; }
.m18-verdict-badge.is-poor { background: rgba(239,68,68,0.15); color: #fca5a5; border-color: rgba(239,68,68,0.35); }
.m18-verdict-badge.is-fair { background: rgba(245,158,11,0.15); color: #fcd34d; border-color: rgba(245,158,11,0.35); }
.m18-verdict-badge.is-strong { background: rgba(16,185,129,0.15); color: #86efac; border-color: rgba(16,185,129,0.35); }
.m18-verdict-badge.is-excellent { background: rgba(59,130,246,0.15); color: #93c5fd; border-color: rgba(59,130,246,0.35); }
.m18-summary-note { margin-top: 14px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.08); }
@media (max-width: 900px) {
  .m18-roi-grid-2,
  .m18-roi-grid-4,
  .m18-roi-grid-verdict { grid-template-columns: 1fr !important; }
}

/* =========================================================================
   MÓDULOS 11 A 12 — ANÁLISIS DE DATOS Y GESTIÓN DE PROYECTOS
   ========================================================================= */
.m11-drop-zone { border: 2px dashed rgba(16,185,129,0.5); border-radius: 12px; padding: 30px; text-align: center; background: rgba(16,185,129,0.02); transition: all 0.3s; cursor: default; margin-top:15px; }
.m11-drop-zone.active { border-color: #10b981; background: rgba(16,185,129,0.1); transform: scale(1.02); }
.m11-pdf-icon { font-size: 3rem; margin-bottom: 15px; color: #10b981; }
.m11-tool-card { background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 14px; padding: 20px; transition: all 0.25s; }
.m11-tool-card:hover { border-color: var(--primary); transform: translateY(-3px); }
.m11-chat-bubble { background: rgba(255,255,255,0.05); border-radius: 12px; padding: 15px; margin-bottom: 10px; font-size: 0.85rem; }
.m11-chat-bubble.ai { background: rgba(37,99,235,0.1); border-left: 3px solid #2563eb; }

.m12-wbs-card { background: rgba(255,255,255,0.02); border: 1px solid #333; border-left: 4px solid #f59e0b; border-radius: 8px; padding: 12px 16px; margin: 8px 0; font-size: 0.85rem; }
.m12-wbs-title { font-weight: 700; color: #fcd34d; margin-bottom: 4px; }
.m12-subtask { margin-left: 20px; border-left: 1px solid #444; padding-left: 12px; margin-top: 6px; color: #cbd5e1; }
.m12-matrix { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 20px; }
.m12-quadrant { border-radius: 12px; padding: 15px; min-height: 120px; transition: all 0.2s; }
.m12-q1 { background: rgba(239,68,68,0.1); border: 1px solid #ef4444; }
.m12-q2 { background: rgba(16,185,129,0.1); border: 1px solid #10b981; }
.m12-q3 { background: rgba(245,158,11,0.1); border: 1px solid #f59e0b; }
.m12-q4 { background: rgba(100,116,139,0.1); border: 1px solid #64748b; }

.m12-helper-row { display:flex; flex-wrap:wrap; gap:10px; margin-bottom:14px; }
.m12-example-chip { border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); color: #cbd5e1; border-radius: 999px; padding: 8px 12px; font-size: 0.76rem; cursor: pointer; transition: all 0.2s ease; }
.m12-example-chip:hover { background: rgba(99,102,241,0.14); border-color: rgba(99,102,241,0.28); color: #fff; }
.m12-toolbar { display:flex; justify-content:space-between; align-items:center; gap:14px; margin-bottom: 18px; flex-wrap:wrap; }
.m12-input-tip { color:#94a3b8; font-size:0.78rem; }
.m12-summary { display:flex; flex-wrap:wrap; gap:8px; }
.m12-summary-chip { padding: 6px 10px; border-radius: 999px; font-size: 0.74rem; font-weight: 700; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.04); }
.m12-summary-chip.danger { color:#fca5a5; }
.m12-summary-chip.success { color:#86efac; }
.m12-summary-chip.warning { color:#fcd34d; }
.m12-summary-chip.neutral { color:#a5b4fc; }
.m12-matrix-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 20px; perspective: 1000px; }
.m12-quadrant-lux { background: rgba(15, 23, 42, 0.6); backdrop-filter: blur(20px); border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 20px; padding: 20px; min-height: 220px; transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275); position: relative; overflow: hidden; }
.m12-quadrant-lux:hover { transform: translateY(-5px) scale(1.02); border-color: rgba(255,255,255,0.2); }

.m12-q1-lux { border-top: 4px solid #ef4444; }
.m12-q1-lux:hover { box-shadow: 0 10px 30px rgba(239, 68, 68, 0.2); }
.m12-q2-lux { border-top: 4px solid #10b981; }
.m12-q2-lux:hover { box-shadow: 0 10px 30px rgba(16, 185, 129, 0.2); }
.m12-q3-lux { border-top: 4px solid #f59e0b; }
.m12-q3-lux:hover { box-shadow: 0 10px 30px rgba(245, 158, 11, 0.2); }
.m12-q4-lux { border-top: 4px solid #6366f1; }
.m12-q4-lux:hover { box-shadow: 0 10px 30px rgba(99, 102, 241, 0.2); }

.m12-task-pill { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 12px; margin-bottom: 10px; font-size: 0.8rem; display: block; animation: m12SlideInRight 0.3s ease-out forwards; }
.m12-task-main { display:flex; flex-direction:column; gap:8px; }
.m12-task-topline { display:flex; align-items:flex-start; gap:8px; }
.m12-task-text { flex: 1; color: #e2e8f0; line-height:1.45; }
.m12-task-meta { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.m12-task-badge { display:inline-flex; align-items:center; padding: 4px 8px; border-radius: 999px; background: rgba(255,255,255,0.06); color:#cbd5e1; font-size:0.68rem; font-weight:800; text-transform:uppercase; letter-spacing:0.4px; }
.m12-task-reason { color:#94a3b8; font-size:0.72rem; line-height:1.4; }
.m12-task-action { color:#e2e8f0; font-size:0.74rem; line-height:1.45; }
.m12-task-remove { background: none; border: none; color: #ef4444; cursor: pointer; font-size: 1.1rem; opacity: 0.4; transition: 0.2s; }
.m12-task-remove:hover { opacity: 1; transform: scale(1.2); }
.m12-empty-state { color:#64748b; font-size:0.8rem; border: 1px dashed rgba(255,255,255,0.08); border-radius: 12px; padding: 14px; margin-top: 8px; }

@keyframes m12SlideInRight { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }

.q-icon { font-size: 1.2rem; margin-bottom: 10px; display: block; }

/* ── Matriz: cabeceras de paso ── */
.m12-step-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}
.m12-step-num {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  color: #000;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
.m12-step-label {
  font-weight: 700;
  font-size: 0.95rem;
  color: #e2e8f0;
}

/* ── Matriz: leyenda de cuadrantes ── */
.m12-legend-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 8px;
}
.m12-legend-card {
  border-radius: 14px;
  padding: 14px 12px;
  text-align: center;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  transition: transform 0.2s;
}
.m12-legend-card:hover { transform: translateY(-3px); }
.m12-leg-icon { font-size: 1.5rem; margin-bottom: 6px; }
.m12-leg-title { font-weight: 800; font-size: 0.75rem; letter-spacing: 0.04em; margin-bottom: 3px; }
.m12-leg-sub { font-size: 0.65rem; color: #94a3b8; margin-bottom: 6px; font-weight: 700; }
.m12-leg-desc { font-size: 0.65rem; color: #64748b; line-height: 1.4; }
.m12-leg-q1 { border-top: 3px solid #ef4444; }
.m12-leg-q2 { border-top: 3px solid #10b981; }
.m12-leg-q3 { border-top: 3px solid #f59e0b; }
.m12-leg-q4 { border-top: 3px solid #6366f1; }

/* ── Matriz: barra de acciones post-resultados ── */
.m12-actions-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
}
.m12-action-btn { display: inline-flex; align-items: center; gap: 6px; }
.m12-action-hint { font-size: 0.65rem; opacity: 0.6; font-weight: 400; }

@media (max-width: 900px) {
  .m12-matrix-grid { grid-template-columns: 1fr; }
  .m12-legend-grid { grid-template-columns: repeat(2, 1fr); }
  .m12-actions-bar { flex-direction: column; }
}

/* =========================================================================
   MÓDULOS 6 A 7 — IA PARA IMÁGENES Y PRESENTACIONES
   ========================================================================= */
.m6-prompt-studio { background: linear-gradient(135deg, rgba(16,185,129,0.05), rgba(0,0,0,0.2)); border: 1px solid #10b981; border-radius: 16px; padding: 24px; margin: 20px 0; }
.m6-style-pill { display: inline-block; padding: 6px 14px; border-radius: 20px; border: 1px solid #10b981; color: #10b981; font-size: 0.75rem; cursor: pointer; margin: 4px; transition: all 0.2s; }
.m6-style-pill:hover, .m6-style-pill.active { background: #10b981; color: #000; font-weight: 700; }
.m6-output-box { background: #050a0e; border: 1px dashed #10b981; border-radius: 12px; padding: 20px; min-height: 80px; margin-top: 15px; font-style: italic; font-size: 0.9rem; color: #a7f3d0; line-height: 1.6; }
.m6-tool-badge { display: inline-flex; align-items: center; gap: 8px; padding: 10px 16px; background: rgba(255,255,255,0.03); border: 1px solid var(--border); border-radius: 12px; font-size: 0.8rem; cursor: pointer; transition: all 0.25s; text-decoration: none; color: inherit; }
.m6-tool-badge:hover { border-color: #10b981; background: rgba(16,185,129,0.08); transform: translateY(-2px); }
.m6-quiz-opt { padding: 12px 18px; background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 10px; cursor: pointer; font-size: 0.85rem; margin: 6px 0; transition: all 0.2s; }
.m6-quiz-opt:hover { border-color: var(--primary); }
.m6-quiz-opt.correct { border-color: #10b981; background: rgba(16,185,129,0.1); color: #10b981; }
.m6-quiz-opt.wrong { border-color: #ef4444; background: rgba(239,68,68,0.08); color: #ef4444; }

.m7-slide-preview { background:#1a1a2e;border:1px solid #2563eb;border-radius:12px;padding:20px;margin:10px 0;position:relative;min-height:120px; }
.m7-slide-num { position:absolute;top:10px;right:15px;font-size:0.7rem;opacity:0.5; }
.m7-slide-title { font-size:1.1rem;font-weight:700;color:#60a5fa;margin-bottom:8px; }
.m7-slide-body { font-size:0.8rem;opacity:0.8;line-height:1.5; }
.m7-tool-row { display:flex;align-items:center;gap:15px;padding:16px;border:1px solid var(--border);border-radius:12px;margin:10px 0;transition:all 0.2s;cursor:pointer; }
.m7-tool-row:hover { border-color:var(--primary);background:rgba(var(--primary-rgb),0.04); }
.m7-badge-free { background:rgba(16,185,129,0.15);color:#10b981;padding:3px 10px;border-radius:20px;font-size:0.7rem;font-weight:700; }

/* =========================================================================
   MÓDULO FINAL — OPERACIÓN CENTAURO
   ========================================================================= */
.centauro-step { display: none; animation: fadeIn 0.5s forwards; }
.centauro-step.active { display: block; }
.centauro-hero {
  text-align: left;
  padding: 40px !important;
  background: 
    radial-gradient(circle at 0% 0%, hsla(243, 75%, 59%, 0.15) 0%, transparent 50%),
    radial-gradient(circle at 100% 0%, hsla(2, 87%, 67%, 0.15) 0%, transparent 50%),
    linear-gradient(135deg, hsla(222, 47%, 4%, 0.95), hsla(222, 47%, 10%, 0.9)) !important;
  border: 1px solid hsla(0, 0%, 100%, 0.1) !important;
  border-radius: 24px !important;
  box-shadow: var(--shadow-lux);
}
.centauro-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, rgba(255,255,255,0.06), transparent 32%, transparent 70%, rgba(255,255,255,0.03));
  pointer-events: none;
}
.centauro-hero-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.centauro-badge {
  background: linear-gradient(135deg, #ef4444, #fb7185) !important;
  box-shadow: 0 12px 28px rgba(239, 68, 68, 0.24) !important;
}
.centauro-status-pill,
.centauro-risk-badge,
.centauro-phase-chip,
.centauro-brief-label,
.centauro-kicker,
.centauro-hero-label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
  font-weight: 800;
}
.centauro-status-pill {
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: #fca5a5;
}
.centauro-hero-title {
  color: #fca5a5 !important;
  margin-bottom: 10px;
}
.centauro-hero-copy {
  max-width: 760px;
  font-size: 1.02rem;
  line-height: 1.75;
  color: #dbe4ff;
}
.centauro-hero-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.centauro-hero-card,
.centauro-panel,
.centauro-brief {
  position: relative;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 20px;
  backdrop-filter: blur(18px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.26);
}
.centauro-hero-card {
  padding: 22px;
}
.centauro-hero-card strong {
  display: block;
  margin: 10px 0 8px;
  color: #f8fafc;
  font-size: 1.03rem;
}
.centauro-hero-card p {
  margin: 0;
  color: #b8c2dd;
  font-size: 0.9rem;
  line-height: 1.6;
}
.centauro-hero-label {
  color: #f59e0b;
}
.centauro-command-bar {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(260px, 0.9fr);
  gap: 18px;
  margin-bottom: 28px;
}
.centauro-phase-track {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.centauro-phase-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  color: #8fa0c7;
}
.centauro-phase-chip span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: rgba(255,255,255,0.08);
  color: #fff;
}
.centauro-phase-chip.is-active {
  background: linear-gradient(135deg, hsla(239, 84%, 67%, 0.3), hsla(0, 84%, 60%, 0.2));
  color: #fff;
  border-color: hsla(239, 84%, 67%, 0.4);
  box-shadow: 0 0 25px hsla(239, 84%, 67%, 0.25);
  transform: scale(1.05);
}
.centauro-phase-chip.is-complete {
  color: #bbf7d0;
  border-color: rgba(16,185,129,0.26);
  background: rgba(16,185,129,0.12);
}
.centauro-phase-chip.is-complete span {
  background: rgba(16,185,129,0.22);
}
.centauro-phase-chip-final {
  color: #fbbf24;
}
.centauro-brief {
  padding: 18px 20px;
}
.centauro-brief-label {
  display: block;
  color: #f59e0b;
  margin-bottom: 8px;
}
.centauro-brief strong {
  display: block;
  color: #fff;
  font-size: 1rem;
  margin-bottom: 6px;
}
.centauro-brief p {
  margin: 0;
  color: #b8c2dd;
  font-size: 0.86rem;
  line-height: 1.55;
}
.centauro-card {
  border-color: rgba(129,140,248,0.14);
}
.centauro-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 8px;
}
.centauro-kicker {
  display: inline-block;
  color: #f59e0b;
  margin-bottom: 8px;
}
.centauro-risk-badge {
  flex-shrink: 0;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(248,113,113,0.08);
  border: 1px solid rgba(248,113,113,0.18);
  color: #fda4af;
}
.centauro-situation {
  margin-bottom: 18px !important;
}
.centauro-rubric {
  margin-bottom: 18px !important;
  background: linear-gradient(135deg, rgba(99,102,241,0.08), rgba(16,185,129,0.05));
  border: 1px solid rgba(129,140,248,0.14);
}
.centauro-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(220px, 0.8fr);
  gap: 18px;
  align-items: start;
}
.centauro-panel {
  padding: 22px;
}
.centauro-panel-main {
  background: linear-gradient(180deg, rgba(3,7,18,0.52), rgba(15,23,42,0.55));
}
.centauro-panel-side {
  background: linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.02));
}
.centauro-panel-label {
  display: block;
  margin-bottom: 12px;
  color: #86efac;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.74rem;
  font-weight: 800;
}
.centauro-side-title {
  font-size: 0.92rem;
  color: #fff;
  font-weight: 700;
  margin-bottom: 12px;
}
.centauro-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}
.centauro-checklist li {
  position: relative;
  padding-left: 22px;
  color: #cbd5e1;
  font-size: 0.85rem;
  line-height: 1.55;
}
.centauro-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.58rem;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #10b981, #22d3ee);
  box-shadow: 0 0 12px rgba(34,211,238,0.25);
}
.centauro-input,
.centauro-action,
.centauro-next,
.centauro-complete,
.centauro-reflection {
  width: 100%;
}
.centauro-input {
  margin: 10px 0 14px;
}
.centauro-output {
  margin-top: 16px;
}
.centauro-placeholder {
  min-height: 210px;
  border-radius: 16px;
  border: 1px dashed rgba(129,140,248,0.24);
  display: grid;
  place-items: center;
  text-align: center;
  background: linear-gradient(135deg, rgba(15,23,42,0.7), rgba(30,41,59,0.55));
  color: #b8c2dd;
  padding: 24px;
}
.centauro-placeholder span {
  display: block;
  font-size: 2rem;
  margin-bottom: 12px;
}
.centauro-placeholder p {
  margin: 0;
  max-width: 320px;
  line-height: 1.6;
}
.centauro-visual-preview {
  min-height: 210px;
}
.centauro-nav { margin-top: 25px; display: none; }
.centauro-next {
  margin-top: 4px;
}
.centauro-terminal,
#local-ai-log {
  background: linear-gradient(180deg, rgba(0,0,0,0.96), rgba(5,10,20,0.96));
  color: #a5f3fc;
  font-family: monospace;
  padding: 18px;
  border-radius: 16px;
  min-height: 160px;
  overflow-y: auto;
  font-size: 0.82rem;
  border: 1px solid rgba(34,211,238,0.4);
  box-shadow: inset 0 0 24px rgba(34,211,238,0.08);
}
.centauro-finish-box {
  margin-bottom: 20px;
  border-color: #10b981 !important;
  background: linear-gradient(135deg, rgba(16,185,129,0.1), rgba(15,23,42,0.42));
}
.centauro-reflection {
  min-height: 140px;
}
.centauro-complete {
  margin-top: 15px;
}
@media (max-width: 1100px) {
  .centauro-hero-grid,
  .centauro-phase-track {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .centauro-command-bar,
  .centauro-layout {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 720px) {
  .centauro-hero {
    padding: 24px !important;
  }
  .centauro-hero-grid,
  .centauro-phase-track {
    grid-template-columns: 1fr;
  }
  .centauro-card-header {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* =========================================================================
   MÓDULO TEAMS Y MEET
   ========================================================================= */
.m-tm-card { background: var(--bg-glass-strong); border: 1px solid rgba(70,78,184,0.3); border-radius: 20px; padding: 24px; position: relative; overflow: hidden; margin-bottom: 24px; backdrop-filter: blur(20px); }
.m-tm-hero { background: linear-gradient(135deg, rgba(70,78,184,0.15), rgba(255,255,255,0.05)); border: 1px solid rgba(70,78,184,0.3); border-radius: 16px; padding: 24px; margin-bottom: 24px; backdrop-filter: blur(16px); }
.m-tm-chip-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.m-tm-chip { padding:7px 14px; border-radius:999px; background:rgba(70,78,184,0.1); border:1px solid rgba(70,78,184,0.25); color:#c7d2fe; font-size:0.75rem; font-weight:700; }
.m-tm-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.m-tm-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.m-tm-panel { background:rgba(255,255,255,0.03); border:1px solid rgba(70,78,184,0.2); border-radius:16px; padding:20px; }
.m-tm-panel h4 { margin:0 0 10px; color:#fff; font-family: 'Space Grotesk', sans-serif; }
.m-tm-note { font-size:0.85rem; color:#cbd5e1; line-height:1.8; }
.m-tm-step { position:relative; padding:18px 18px 18px 56px; border-radius:14px; border:1px solid rgba(70,78,184,0.2); background:rgba(255,255,255,0.02); }
.m-tm-step-badge { position:absolute; left:16px; top:18px; width:28px; height:28px; border-radius:50%; background:#464eb8; color:#fff; font-weight:800; display:flex; align-items:center; justify-content:center; font-size:0.8rem; box-shadow: 0 0 10px rgba(70,78,184,0.5); }
.m-tm-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; height: 400px; }
.m-tm-call { background: #0a0a0f; border-radius: 12px; display: flex; flex-direction: column; overflow: hidden; position: relative; border: 1px solid rgba(255,255,255,0.05);}
.m-tm-video-grid { flex: 1; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding: 8px;}
.m-tm-person { background: #1a1a24; border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; overflow: hidden; border: 1px solid rgba(255,255,255,0.03); transition: 0.3s ease;}
.m-tm-person.active { border: 2px solid #a972ff; box-shadow: inset 0 0 20px rgba(169,114,255,0.15); }
.m-tm-avatar { width: 56px; height: 56px; border-radius: 50%; background: #333; display: flex; align-items: center; justify-content: center; font-size: 1.6rem; color: #fff; box-shadow: 0 4px 15px rgba(0,0,0,0.3);}
.m-tm-pname { position: absolute; bottom: 8px; left: 8px; background: rgba(0,0,0,0.7); color: #fff; padding: 3px 10px; border-radius: 6px; font-size: 0.72rem; backdrop-filter: blur(4px);}
.m-tm-subtitles { position: absolute; bottom: 70px; left: 20px; right: 20px; text-align: center; font-size: 0.9rem; color: #fff; text-shadow: 0 2px 4px rgba(0,0,0,0.8); background: rgba(0,0,0,0.6); padding: 8px 16px; border-radius: 8px; opacity: 0; transition: opacity 0.3s; pointer-events: none; z-index: 5; border: 1px solid rgba(255,255,255,0.1);}
.m-tm-subtitles.active { opacity: 1; }
.m-tm-controls { height: 60px; background: #16161c; display: flex; justify-content: center; align-items: center; gap: 18px; border-top: 1px solid rgba(255,255,255,0.05);}
.m-tm-ctrl-btn { width: 40px; height: 40px; border-radius: 50%; background: #2d2d35; display: flex; align-items: center; justify-content: center; color: #fff; cursor: pointer; transition: 0.3s; border: 1px solid rgba(255,255,255,0.05);}
.m-tm-ctrl-btn:hover { background: #3d3d45; transform: translateY(-2px); }
.m-tm-ctrl-btn.danger { background: #c5221f; border-color: rgba(255,255,255,0.1); }
.m-tm-ctrl-btn.copilot { background: linear-gradient(135deg, #a972ff, #0854c7); border: 1px solid rgba(255,255,255,0.2); box-shadow: 0 4px 12px rgba(169,114,255,0.3);}
.m-tm-ctrl-btn.copilot.active { animation: glow-copilot 2s infinite; }
@keyframes glow-copilot { 0% { box-shadow: 0 0 0 0 rgba(169,114,255,0.6); } 70% { box-shadow: 0 0 0 10px rgba(169,114,255,0); } 100% { box-shadow: 0 0 0 0 rgba(169,114,255,0); } }
.m-tm-copilot { background: var(--bg-glass-strong); border-radius: 12px; display: flex; flex-direction: column; border: 1px solid rgba(255,255,255,0.1); backdrop-filter: blur(25px); overflow: hidden; }
.m-tm-cp-header { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,0.05); display: flex; align-items: center; gap: 10px; font-weight: 700; color: #fff; font-size: 0.9rem; background: rgba(169,114,255,0.05);}
.m-tm-cp-logo { font-size: 1.2rem; }
.m-tm-cp-body { flex: 1; padding: 12px; overflow-y: auto; font-size: 0.8rem; color: #ccc; display: flex; flex-direction: column; gap: 12px; scroll-behavior: smooth;}
.m-tm-cp-prompt { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding: 12px; border-top: 1px solid rgba(255,255,255,0.05); background: rgba(0,0,0,0.15);}
.m-tm-p-btn { background: #333; color: #fff; border: 1px solid #444; border-radius: 4px; padding: 6px; font-size: 0.7rem; cursor: pointer; transition: 0.2s;}
.m-tm-p-btn:hover { background: #444; border-color: #a972ff; }
.m-tm-msg { padding: 8px; border-radius: 6px; background: #222; }
.m-tm-msg-title { color: #a972ff; font-weight: 700; margin-bottom: 5px; display:flex; align-items:center; gap:5px;}
.m-tm-pulse { width: 8px; height: 8px; background: #a972ff; border-radius: 50%; display: inline-block; animation: pulse 1.5s infinite;}
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(169,114,255,0.7); } 70% { box-shadow: 0 0 0 5px rgba(169,114,255,0); } 100% { box-shadow: 0 0 0 0 rgba(169,114,255,0); } }
.m-tm-gem-shell { background: linear-gradient(180deg, rgba(5, 10, 24, 0.96), rgba(11, 18, 34, 0.92)); border: 1px solid rgba(52, 211, 153, 0.18); border-radius: 24px; padding: 28px; box-shadow: inset 0 1px 0 rgba(255,255,255,0.04), 0 20px 50px rgba(0,0,0,0.28); position: relative; overflow: hidden; }
.m-tm-gem-shell::before { content: ""; position: absolute; inset: -20% auto auto 65%; width: 220px; height: 220px; border-radius: 999px; background: radial-gradient(circle, rgba(52,211,153,0.18), rgba(52,211,153,0)); pointer-events: none; }
.m-tm-gem-header { display:flex; justify-content:space-between; align-items:flex-start; gap:20px; flex-wrap:wrap; margin-bottom:8px; position:relative; z-index:1; }
.m-tm-gem-kicker { font-size:0.72rem; text-transform:uppercase; letter-spacing:0.12em; color:#86efac; font-weight:800; margin-bottom:8px; }
.m-tm-gem-title { margin:0 0 8px; color:#ecfdf5; font-size:1.45rem; font-family:'Space Grotesk', sans-serif; }
.m-tm-gem-lead { margin:0; max-width:760px; color:#cbd5e1; font-size:0.92rem; line-height:1.75; }
.m-tm-gem-badges { display:flex; flex-wrap:wrap; gap:10px; }
.m-tm-gem-badge { padding:8px 12px; border-radius:999px; background:rgba(52,211,153,0.08); border:1px solid rgba(52,211,153,0.2); color:#bbf7d0; font-size:0.72rem; font-weight:800; }
.m-tm-gem-mini { background:rgba(255,255,255,0.03); border:1px solid rgba(148,163,184,0.14); border-radius:18px; padding:18px; position:relative; z-index:1; }
.m-tm-gem-mini-label { display:block; font-size:0.72rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#86efac; margin-bottom:10px; }
.m-tm-gem-mini p { margin:0; color:#dbe4f0; font-size:0.82rem; line-height:1.75; }
.m-tm-gem-prompt-box { margin-top:20px; background:rgba(15,23,42,0.8); border:1px solid rgba(52,211,153,0.16); border-radius:18px; padding:18px; position:relative; z-index:1; }
.m-tm-gem-prompt-top { display:flex; justify-content:space-between; align-items:center; gap:12px; margin-bottom:14px; flex-wrap:wrap; }
.m-tm-gem-prompt-label { color:#ecfdf5; font-size:0.82rem; font-weight:800; }
.m-tm-gem-prompt-text { color:#d1fae5; font-family:'Space Grotesk', monospace; font-size:0.78rem; line-height:1.8; white-space:pre-wrap; max-height:420px; overflow:auto; padding-right:6px; }
.m-tm-gem-actions { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:12px; margin-top:18px; position:relative; z-index:1; }
.m-tm-gem-tip { margin-top:18px; padding:14px 16px; border-radius:14px; background:rgba(52,211,153,0.08); border:1px solid rgba(52,211,153,0.14); color:#d1fae5; font-size:0.82rem; line-height:1.7; position:relative; z-index:1; }
@media (max-width:900px){ .m-tm-gem-actions { grid-template-columns:1fr; } }
@media (max-width:900px){ .m-tm-grid-2,.m-tm-grid-3 { grid-template-columns:1fr; } }

/* =========================================================================
   MÓDULO POWER AUTOMATE
   ========================================================================= */
.m-pa-hero { background: var(--bg-glass-strong); border: 1px solid rgba(8, 84, 199, 0.4); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 24px; backdrop-filter: blur(20px); box-shadow: 0 8px 32px rgba(0,0,0,0.3); }
.m-pa-chip-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.m-pa-chip { padding:6px 14px; border-radius:999px; background:rgba(8,84,199,0.15); border:1px solid rgba(8,84,199,0.3); color: var(--primary-light); font-size:0.75rem; font-weight:700; }
.m-pa-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.m-pa-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.m-pa-panel-card { background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(8, 84, 199, 0.2); border-radius: var(--radius-md); padding: 20px; }
.m-pa-note { font-size:0.85rem; color: var(--text-secondary); line-height:1.7; }
.m-pa-step { position:relative; padding:16px 16px 16px 56px; border-radius: var(--radius-md); border: 1px solid rgba(8, 84, 199, 0.2); background: rgba(255, 255, 255, 0.02); }
.m-pa-step-badge { position:absolute; left:16px; top:16px; width:28px; height:28px; border-radius:50%; background: var(--primary); color:#fff; font-weight:800; display:flex; align-items:center; justify-content:center; font-size:0.8rem; box-shadow: 0 0 10px var(--primary-glow); }
.m-pa-codebox { background: rgba(0, 0, 0, 0.3); border: 1px solid var(--border); border-radius: var(--radius-md); padding: 16px; font-size:0.8rem; color: var(--primary-light); line-height:1.6; white-space:pre-wrap; font-family: 'Space Grotesk', monospace; }
.m-pa-flow-container { background: rgba(0, 0, 0, 0.2); border: 1px dashed var(--border); border-radius: var(--radius-lg); padding: 40px; margin-top: 20px; display: flex; flex-direction: column; align-items: center; min-height: 300px; position: relative; backdrop-filter: blur(10px); }
.m-pa-node { background: var(--bg-glass-strong); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--radius-md); padding: 18px; width: 300px; box-shadow: var(--shadow-md); display: flex; align-items: center; gap: 15px; z-index: 2; position: relative; margin-bottom: 35px; cursor:pointer; transition: all 0.3s ease; }
.m-pa-node:hover { border-color: var(--primary); transform: translateY(-3px); box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3); background: rgba(255, 255, 255, 0.08); }
.m-pa-node-icon { width: 44px; height: 44px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: #fff; box-shadow: 0 4px 10px rgba(0,0,0,0.2); }
.m-pa-node-icon.outlook { background: #0f62fe; }
.m-pa-node-icon.ai { background: linear-gradient(135deg, #a972ff, #0854c7); }
.m-pa-node-icon.excel { background: #107c41; }
.m-pa-node-icon.teams { background: #464eb8; }
.m-pa-node-icon.add { background: rgba(255, 255, 255, 0.05); border: 2px dashed rgba(255, 255, 255, 0.2); color: rgba(255, 255, 255, 0.4); }
.m-pa-node-content { flex: 1; }
.m-pa-node-title { font-weight: 700; color: #fff; font-size: 1rem; margin-bottom: 2px; }
.m-pa-node-desc { font-size: 0.8rem; color: var(--text-secondary); }
.m-pa-connector { position: absolute; width: 2px; height: 35px; background: rgba(255, 255, 255, 0.1); left: 50%; transform: translateX(-50%); top: 100%; z-index: 1;}
.m-pa-panel { position: absolute; right: 0; top: 0; bottom: 0; width: 320px; background: var(--bg-glass-strong); backdrop-filter: blur(25px); border-left: 1px solid var(--border); box-shadow: -10px 0 30px rgba(0,0,0,0.3); padding: 24px; transform: translateX(100%); transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1); z-index: 100; display:flex; flex-direction:column; }
.m-pa-panel.open { transform: translateX(0); }
.m-pa-option { padding: 14px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--radius-md); margin-bottom: 12px; cursor: pointer; display: flex; align-items: center; gap: 12px; transition: all 0.2s ease; background: rgba(255, 255, 255, 0.03); }
.m-pa-option:hover { background: rgba(255, 255, 255, 0.08); border-color: var(--primary); transform: translateX(5px); }
.m-pa-play-btn { background: var(--primary); color: #fff; border: none; padding: 14px 28px; border-radius: var(--radius-md); font-weight: 800; cursor: pointer; display: flex; align-items: center; gap: 12px; transition: all 0.3s ease; margin: 25px auto 0; box-shadow: 0 4px 15px var(--primary-glow); }
.m-pa-play-btn:hover { background: var(--primary-light); transform: scale(1.05) translateY(-2px); box-shadow: 0 6px 20px var(--primary-glow); }
.m-pa-run-overlay { position:absolute; inset:0; background: rgba(10, 15, 30, 0.85); z-index: 110; display:none; flex-direction:column; align-items:center; justify-content:center; backdrop-filter: blur(20px); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-lg); }
.m-pa-run-overlay.active { display:flex; }
.m-pa-spinner { width:50px; height:50px; border:4px solid rgba(255, 255, 255, 0.1); border-top-color: var(--primary); border-radius:50%; animation: spin-pa 1s linear infinite; margin-bottom:20px; box-shadow: 0 0 15px var(--primary-glow); }
@keyframes spin-pa { to { transform: rotate(360deg); } }
@media (max-width:900px){ .m-pa-grid-2,.m-pa-grid-3 { grid-template-columns:1fr; } }

/* =========================================================================
   MÓDULO NOTION AI
   ========================================================================= */
:root { --notion-bg: rgba(255, 255, 255, 0.03); --notion-text: #e2e8f0; --notion-accent: #a972ff; --notion-glass: rgba(15, 23, 42, 0.8); --notion-border: rgba(255, 255, 255, 0.1); --font-premium: 'Outfit', sans-serif; --font-mono: 'Space Grotesk', monospace; }
.m-notion-container { perspective: 1000px; margin-bottom: 30px; color: var(--notion-text); font-family: var(--font-premium); }
.m-notion-card { background: var(--notion-glass); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid var(--notion-border); border-radius: 16px; padding: 24px; box-shadow: 0 8px 32px rgba(0,0,0,0.3); }
.m-notion-hero { background: linear-gradient(135deg, rgba(169,114,255,0.08), rgba(255,255,255,0.02)); border: 1px solid rgba(169,114,255,0.2); border-radius: 16px; padding: 24px; margin-bottom: 24px; backdrop-filter: blur(20px) saturate(160%); box-shadow: 0 10px 30px rgba(0,0,0,0.35), inset 0 1px 1px rgba(255,255,255,0.05); }
.m-notion-chip-row { display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }
.m-notion-chip { padding:7px 12px; border-radius:999px; background:rgba(255,255,255,0.05); border:1px solid rgba(169,114,255,0.14); color:#e9d5ff; font-size:0.72rem; font-weight:700; }
.m-notion-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.m-notion-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.m-notion-panel { background:rgba(255,255,255,0.015); border: 1px solid rgba(255,255,255,0.08); border-radius: 16px; padding: 20px; box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
.m-notion-panel h4 { margin:0 0 10px; color:#fff; font-family: 'Space Grotesk'; }
.m-notion-note { font-size:0.85rem; color:#cbd5e1; line-height:1.7; }
.m-notion-step { position:relative; padding:18px 18px 18px 56px; border-radius:12px; border:1px solid rgba(169,114,255,0.16); background:rgba(255,255,255,0.02); }
.m-notion-step-badge { position:absolute; left:16px; top:18px; width:26px; height:26px; border-radius:50%; background:#a972ff; color:#fff; font-weight:800; display:flex; align-items:center; justify-content:center; font-size:0.75rem; box-shadow: 0 0 10px rgba(169,114,255,0.4); }
.m-notion-editor { border: 1px solid var(--notion-border); border-radius: 12px; padding: 24px; min-height: 250px; position: relative; background: rgba(0, 0, 0, 0.4); cursor: text; box-shadow: inset 0 2px 10px rgba(0,0,0,0.5); }
.m-notion-block { min-height: 1.5em; outline: none; }
.m-notion-block:empty::before { content: attr(data-placeholder); color: #9ca3af; }
.m-notion-scenarios { display: flex; gap: 12px; margin: 20px 0; }
.scenario-chip { padding: 8px 16px; border-radius: 20px; background: rgba(255, 255, 255, 0.05); font-size: 0.85rem; cursor: pointer; border: 1px solid rgba(255, 255, 255, 0.1); transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1); color: var(--notion-text); }
.scenario-chip:hover { background: rgba(255, 255, 255, 0.08); border-color: var(--notion-accent); }
.scenario-chip.active { background: rgba(169, 114, 255, 0.15); color: #fff; border-color: var(--notion-accent); font-weight: 700; box-shadow: 0 0 15px rgba(169, 114, 255, 0.2); }
.m-notion-menu { position: absolute; background: rgba(15, 23, 42, 0.95); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); border: 1px solid var(--notion-border); border-radius: 12px; box-shadow: 0 15px 35px rgba(0,0,0,0.5); width: 260px; z-index: 100; display: none; padding: 10px; }
.m-notion-menu.active { display: block; animation: popIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1); }
@keyframes popIn { from { opacity: 0; transform: scale(0.95); } to { opacity: 1; transform: scale(1); } }
.m-notion-menu-item { padding: 10px 14px; border-radius: 8px; display: flex; align-items: center; gap: 12px; cursor: pointer; font-size: 0.9rem; transition: 0.2s ease; color: var(--notion-text); }
.m-notion-menu-item:hover { background: rgba(169, 114, 255, 0.1); color: #fff; }
.m-notion-menu-item .icon { font-size: 1.1rem; }
.m-notion-result-ai { background: rgba(169, 114, 255, 0.05); border-left: 4px solid var(--notion-accent); padding: 20px; margin-top: 15px; border-radius: 0 12px 12px 0; backdrop-filter: blur(10px); }
.m-notion-result-ai h4 { margin-top: 0; color: var(--notion-accent); font-family: var(--font-mono); }
.m-notion-table { width: 100%; border-collapse: collapse; }
.m-notion-table th, .m-notion-table td { padding: 12px; text-align: left; border-bottom: 1px solid #e2e8f0; }
.m-notion-tag { padding: 2px 8px; border-radius: 4px; font-size: 0.75rem; font-weight: 700; }
.m-notion-loading { display: none; align-items: center; gap: 10px; font-size: 0.85rem; color: #4b5563; }
.m-notion-loading.active { display: flex; }
.m-notion-spinner { width: 16px; height: 16px; border: 2px solid #e5e7eb; border-top-color: #a972ff; border-radius: 50%; animation: spin-notion 0.8s linear infinite; }
@keyframes spin-notion { to { transform: rotate(360deg); } }
@media (max-width:900px){ .m-notion-grid-2,.m-notion-grid-3 { grid-template-columns:1fr; } }

/* =========================================================================
   MÓDULO NOTEBOOKLM
   ========================================================================= */
.m-nlm-card { background: rgba(13, 17, 23, 0.75); backdrop-filter: blur(20px) saturate(160%); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 16px; padding: 24px; position: relative; overflow: hidden; margin-bottom: 24px; box-shadow: 0 15px 40px rgba(0,0,0,0.45), inset 0 1px 1px rgba(255,255,255,0.05); }
.m-nlm-header-bg { position: absolute; top:0; left:0; width:100%; height:100px; background: linear-gradient(180deg, rgba(251,191,36,0.1) 0%, transparent 100%); pointer-events:none; }
.m-nlm-hero { background: linear-gradient(135deg, rgba(251,191,36,0.08), rgba(255,255,255,0.02)); border: 1px solid rgba(251,191,36,0.2); border-radius: 16px; padding: 24px; margin-bottom: 24px; backdrop-filter: blur(20px) saturate(140%); box-shadow: 0 12px 30px rgba(0,0,0,0.3); }
.m-nlm-chip-row { display:flex; gap:12px; flex-wrap:wrap; margin-top:15px; }
.m-nlm-chip { padding:8px 14px; border-radius:999px; background:rgba(255,255,255,0.05); border:1px solid rgba(251,191,36,0.15); color:#fef3c7; font-size:0.75rem; font-weight:700; cursor: default; }
.m-nlm-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.m-nlm-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.m-nlm-panel { background:rgba(255,255,255,0.015); border: 1px solid rgba(255,255,255,0.08); border-radius:16px; padding: 20px; box-shadow: 0 8px 24px rgba(0,0,0,0.25); }
.m-nlm-panel h4 { margin:0 0 10px; color:#fff; font-family: 'Space Grotesk'; }
.m-nlm-note { font-size:0.85rem; color:#cbd5e1; line-height:1.7; }
.m-nlm-step { position:relative; padding:18px 18px 18px 56px; border-radius:12px; border:1px solid rgba(251,191,36,0.18); background:rgba(255,255,255,0.02); }
.m-nlm-step-badge { position:absolute; left:16px; top:18px; width:26px; height:26px; border-radius:50%; background:#f59e0b; color:#000; font-weight:800; display:flex; align-items:center; justify-content:center; font-size:0.8rem; box-shadow: 0 0 10px rgba(245,158,11,0.4); }
.m-nlm-layout { display: flex; gap: 20px; margin-top: 15px; flex-wrap: wrap; }
.m-nlm-sources { flex: 1; min-width: 250px; background: rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 20px; box-shadow: inset 0 2px 10px rgba(0,0,0,0.4); }
.m-nlm-title { font-weight: 700; color: #fff; margin-bottom: 15px; display: flex; align-items: center; justify-content: space-between; font-family: 'Space Grotesk'; }
.m-nlm-source-item { display: flex; align-items: center; gap: 12px; background: rgba(255,255,255,0.04); padding: 12px; border-radius: 10px; border: 1px solid rgba(255,255,255,0.08); margin-bottom: 12px; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); cursor: pointer;}
.m-nlm-source-item:hover { border-color: #fbbf24; background: rgba(251,191,36,0.1); transform: translateX(5px); }
.m-nlm-source-icon { font-size: 1.6rem; }
.m-nlm-source-text { font-size: 0.85rem; color: #cbd5e1; font-weight: 600; flex: 1; }
.m-nlm-upload-btn { display: flex; align-items: center; justify-content: center; gap: 10px; width: 100%; border: 2px dashed rgba(255,255,255,0.15); background: transparent; color: #94a3b8; padding: 14px; border-radius: 10px; cursor: pointer;}
@keyframes spin { 100% { transform: rotate(360deg); } }
.m-nlm-upload-btn:hover { border-color: #fbbf24; color: #fbbf24; background: rgba(251,191,36,0.08); }
.m-nlm-chat { flex: 2; min-width: 300px; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; padding: 24px; box-shadow: 0 10px 40px rgba(0,0,0,0.4); display: flex; flex-direction: column; backdrop-filter: blur(10px); }
.m-nlm-audio-card { background: #1e293b; border-radius: 12px; padding: 20px; color: #fff; text-align: center; margin-bottom: 20px; position:relative; overflow:hidden;}
.m-nlm-audio-wave { position:absolute; bottom:0; left:0; width:100%; height:30%; background: url('data:image/svg+xml;utf8,<svg viewBox="0 0 100 20" xmlns="http://www.w3.org/2000/svg"><path d="M0 10 Q 25 20 50 10 T 100 10 L 100 20 L 0 20 Z" fill="rgba(251,191,36,0.3)"/></svg>') repeat-x; background-size: 50% 100%; animation: wave 3s linear infinite; display:none;}
@keyframes wave { 0% {background-position: 0 0;} 100% {background-position: 100% 0;} }
.m-nlm-play-btn { width: 50px; height: 50px; border-radius: 50%; background: #fbbf24; display: flex; align-items: center; justify-content: center; margin: 0 auto 15px; cursor: pointer; font-size: 1.5rem; color: #000; border: none; box-shadow: 0 4px 10px rgba(251,191,36,0.4); transition: transform 0.2s; z-index:2; position:relative;}
.m-nlm-play-btn:hover { transform: scale(1.1); }
.m-nlm-audio-title { font-weight: 700; font-size: 1.1rem; margin-bottom: 5px; z-index:2; position:relative;}
.m-nlm-audio-sub { color: #94a3b8; font-size: 0.8rem; z-index:2; position:relative;}
.m-nlm-chat-box { flex: 1; padding: 15px; overflow-y: auto; display: flex; flex-direction: column; gap: 15px; font-size: 0.95rem; min-height: 200px; }
.m-nlm-msg { padding: 14px 18px; border-radius: 12px; max-width: 85%; line-height: 1.6; position:relative; box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.m-nlm-msg.user { background: rgba(59, 130, 246, 0.15); align-self: flex-end; color: #fff; border: 1px solid rgba(59, 130, 246, 0.3); border-bottom-right-radius: 0; }
.m-nlm-msg.ai { background: rgba(251, 191, 36, 0.08); border: 1px solid rgba(251, 191, 36, 0.25); align-self: flex-start; color: #fef3c7; border-bottom-left-radius: 0; }
.m-nlm-citation { display:inline-block; background: #fbbf24; color: #000; font-size: 0.7rem; padding: 2px 8px; border-radius: 12px; margin-left: 8px; font-weight: 800; cursor:pointer;}
.m-nlm-input-area { display: flex; gap: 10px; margin-top: 15px; border-top: 1px solid #e2e8f0; padding-top: 15px;}
.m-nlm-input { flex: 1; border: 1px solid #cbd5e1; border-radius: 20px; padding: 10px 15px; outline: none; transition: 0.2s; }
.m-nlm-input:focus { border-color: #fbbf24; }
@media (max-width:900px){ .m-nlm-grid-2,.m-nlm-grid-3 { grid-template-columns:1fr; } }

/* =========================================================================
   MÓDULO MULTIMEDIA
   ========================================================================= */
.m-mm-hero { background: linear-gradient(135deg, rgba(236,72,153,0.12), rgba(139,92,246,0.08)); border: 1px solid rgba(236,72,153,0.24); border-radius: 18px; padding: 22px; margin-bottom: 22px; }
.m-mm-chip-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.m-mm-chip { background: rgba(255,255,255,0.04); border:1px solid rgba(236,72,153,0.22); color:#fbcfe8; border-radius:999px; padding:8px 12px; font-size:0.75rem; font-weight:700; }
.m-mm-grid-2 { display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:16px; }
.m-mm-grid-3 { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; }
.m-mm-panel { background: rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07); border-radius:14px; padding:18px; }
.m-mm-kicker { font-size:0.72rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:#f9a8d4; margin-bottom:8px; }
.m-mm-note { background: rgba(236,72,153,0.08); border-left:3px solid #ec4899; border-radius:10px; padding:12px 14px; color:#fbcfe8; font-size:0.8rem; line-height:1.7; }
.m-mm-step { display:flex; gap:12px; align-items:flex-start; padding:12px 0; border-top:1px solid rgba(255,255,255,0.05); }
.m-mm-step:first-child { border-top:none; padding-top:0; }
.m-mm-step-badge { width:28px; height:28px; border-radius:999px; background:rgba(236,72,153,0.18); border:1px solid rgba(236,72,153,0.35); color:#f9a8d4; display:flex; align-items:center; justify-content:center; font-size:0.78rem; font-weight:800; flex-shrink:0; }
.m-mm-card { background: #111827; border: 1px solid #374151; border-radius: 12px; padding: 25px; position: relative; overflow: hidden; margin-bottom: 20px;}
.m-mm-master-shell {
  background:
    radial-gradient(circle at top right, rgba(236,72,153,0.12), transparent 28%),
    radial-gradient(circle at bottom left, rgba(139,92,246,0.12), transparent 24%),
    linear-gradient(180deg, rgba(3,7,18,0.94), rgba(15,23,42,0.88));
  border: 1px solid rgba(244,114,182,0.14);
}
.m-mm-master-intro {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:12px;
}
.m-mm-master-tip {
  max-width: 340px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: #fce7f3;
  font-size: 0.78rem;
  line-height: 1.55;
}
.m-mm-master-copy {
  max-width: 760px;
  color:#cbd5e1;
  font-size:0.92rem;
  line-height:1.7;
}
.m-mm-master-grid { align-items: stretch; }
.m-mm-master-card {
  display:flex;
  flex-direction:column;
  min-height:100%;
  padding: 22px;
  border-color: rgba(148,163,184,0.22);
  background:
    linear-gradient(180deg, rgba(17,24,39,0.96), rgba(15,23,42,0.98)),
    linear-gradient(135deg, rgba(236,72,153,0.05), rgba(139,92,246,0.04));
  box-shadow: 0 18px 40px rgba(0,0,0,0.22);
}
.m-mm-master-card::before {
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(135deg, rgba(255,255,255,0.05), transparent 24%, transparent 76%, rgba(255,255,255,0.03));
  pointer-events:none;
}
.m-mm-master-top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:14px;
}
.m-mm-master-badge,
.m-mm-master-format {
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  font-size:0.68rem;
  font-weight:800;
  letter-spacing:0.05em;
  text-transform:uppercase;
}
.m-mm-master-badge {
  padding:8px 12px;
  background: rgba(236,72,153,0.12);
  border:1px solid rgba(236,72,153,0.26);
  color:#f9a8d4;
}
.m-mm-master-format {
  padding:7px 10px;
  background: rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  color:#cbd5e1;
}
.m-mm-master-title {
  margin:0 0 8px;
  color:#fff;
  font-size:1.45rem;
  line-height:1.18;
}
.m-mm-master-desc {
  margin:0 0 16px;
  color:#cbd5e1;
  font-size:0.82rem;
  line-height:1.65;
}
.m-mm-master-prompt {
  position:relative;
  flex:1;
  margin-bottom:16px;
  padding:18px;
  border-radius:16px;
  background: linear-gradient(180deg, rgba(30,41,59,0.78), rgba(15,23,42,0.94));
  border:1px solid rgba(192,132,252,0.16);
  color:#f5d0fe;
  font-size:0.84rem;
  line-height:1.85;
}
.m-mm-master-prompt::before {
  content:"Prompt base";
  display:block;
  margin-bottom:10px;
  color:#f9a8d4;
  font-size:0.68rem;
  font-weight:800;
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.m-mm-master-btn {
  width:100%;
  margin-top:auto;
  border-radius:12px;
  padding:14px 18px;
  box-shadow: 0 16px 30px rgba(139,92,246,0.2);
}
.m-mm-header-bg { position: absolute; top:0; left:0; width:100%; height:80px; background: linear-gradient(180deg, rgba(236,72,153,0.1) 0%, transparent 100%); pointer-events:none; }
.m-mm-prompt-builder { background: #1f2937; border: 1px solid #4b5563; border-radius: 8px; padding: 20px; display: grid; gap: 15px;}
.m-mm-label { font-size: 0.8rem; color: #9ca3af; font-weight: 700; text-transform: uppercase; margin-bottom: 5px;}
.m-mm-select { width: 100%; background: #374151; border: 1px solid #4b5563; color: #fff; padding: 10px; border-radius: 6px; outline: none; transition: 0.2s;}
.m-mm-select:focus { border-color: #ec4899; }
.m-mm-final-prompt { background: #000; padding: 15px; border-radius: 6px; font-family: monospace; color: #a78bfa; font-size: 0.85rem; border: 1px dashed #6b7280; min-height: 50px;}
.m-mm-canvas { width: 100%; height: 300px; background: #030712; border-radius: 8px; margin-top: 20px; border: 1px solid #374151; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; overflow:hidden;}
.m-mm-loader { display: none; flex-direction: column; align-items: center; gap: 10px;}
.m-mm-loader.active { display: flex; }
.m-mm-pbar { width: 200px; height: 6px; background: #374151; border-radius: 3px; overflow: hidden;}
.m-mm-pfill { width: 0%; height: 100%; background: linear-gradient(90deg, #ec4899, #8b5cf6); transition: width 0.1s linear;}
.m-mm-result-img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; opacity: 0; transition: opacity 0.5s;}
.m-mm-result-img.active { opacity: 1; }
.m-mm-gen-btn { background: linear-gradient(90deg, #ec4899, #8b5cf6); color: #fff; border: none; padding: 12px 24px; border-radius: 6px; cursor: pointer; font-weight: 700; transition: transform 0.2s; align-self: center; display: inline-block; margin-top: 15px;}
.m-mm-gen-btn:hover { transform: scale(1.05); }
@media (max-width: 900px) {
  .m-mm-grid-3,
  .m-mm-grid-2 { grid-template-columns:1fr; }
  .m-mm-master-intro { flex-direction:column; }
  .m-mm-master-tip { max-width:none; width:100%; }
}

/* ═══ Multimedia Pro: Tool Chooser (Decisor) ═══ */
.m-mm-quiz-step {
  display: none;
  animation: fadeIn 0.4s ease-out;
}

.m-mm-quiz-step.active {
  display: block;
}

.m-mm-chooser-title {
  font-size: 1.25rem;
  font-weight: 800;
  color: #f9a8d4;
  margin-bottom: 20px;
  font-family: 'Space Grotesk', sans-serif;
  letter-spacing: -0.02em;
}

.m-mm-options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 20px;
}

.m-mm-option-btn {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 18px 22px;
  color: #f8fafc;
  font-size: 0.95rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  gap: 12px;
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}

.m-mm-option-btn:hover {
  background: rgba(236, 72, 153, 0.08);
  border-color: rgba(236, 72, 153, 0.3);
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 10px 30px -10px rgba(236, 72, 153, 0.2);
}

.m-mm-option-btn::after {
  content: "→";
  margin-left: auto;
  opacity: 0;
  transform: translateX(-10px);
  transition: all 0.3s ease;
  color: #f9a8d4;
  font-weight: 800;
}

.m-mm-option-btn:hover::after {
  opacity: 1;
  transform: translateX(0);
}

.m-mm-result-container {
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.08), rgba(59, 130, 246, 0.08));
  border: 1px solid rgba(16, 185, 129, 0.2);
  border-radius: 20px;
  padding: 30px;
  text-align: center;
  backdrop-filter: blur(20px);
  box-shadow: 0 20px 50px -12px rgba(0, 0, 0, 0.4);
  animation: scaleUp 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@keyframes scaleUp {
  from { opacity: 0; transform: scale(0.95); }
  to { opacity: 1; transform: scale(1); }
}

.m-mm-result-badge {
  display: inline-block;
  padding: 6px 16px;
  background: rgba(16, 185, 129, 0.15);
  border: 1px solid rgba(16, 185, 129, 0.3);
  color: #10b981;
  border-radius: 50px;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 20px;
}

#chooser-result {
  font-size: 1.8rem;
  font-weight: 900;
  color: #fff;
  margin-bottom: 12px;
  font-family: 'Space Grotesk', sans-serif;
  text-shadow: 0 0 20px rgba(255, 255, 255, 0.2);
}

#chooser-details {
  font-size: 0.95rem;
  color: #cbd5e1;
  line-height: 1.7;
  max-width: 600px;
  margin: 0 auto;
}

.m-mm-chooser-flow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 20px;
  margin-top: 30px;
}

.m-mm-flow-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 20px;
  transition: all 0.3s ease;
}

.m-mm-flow-card:hover {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.1);
}

.m-mm-flow-label {
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

/* =========================================================================
   EVALUACIÓN DE CALIDAD - MÓDULO MULTIMEDIA PRO
   ========================================================================= */
.quality-criteria {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 15px;
}

.quality-criterion {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 10px;
}

.quality-icon {
  font-size: 1.2rem;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(236, 72, 153, 0.1);
  border-radius: 8px;
  color: #f9a8d4;
}

.quality-body {
  flex: 1;
}

.quality-name {
  margin: 0 0 4px;
  font-weight: 700;
  color: #fff;
  font-size: 0.9rem;
}

.quality-desc {
  margin: 0;
  font-size: 0.75rem;
  color: #cbd5e1;
  line-height: 1.4;
}

.quality-slider {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 180px;
}

.quality-range {
  flex: 1;
  height: 6px;
  -webkit-appearance: none;
  appearance: none;
  background: linear-gradient(90deg, #ef4444, #f59e0b, #10b981);
  border-radius: 3px;
  outline: none;
}

.quality-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #ec4899;
  cursor: pointer;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}

.quality-range::-moz-range-thumb {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #ec4899;
  cursor: pointer;
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.5);
}

.quality-value {
  font-size: 0.85rem;
  font-weight: 700;
  color: #fff;
  min-width: 40px;
  text-align: center;
}

.quality-result {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.quality-score {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-radius: 12px;
}

.quality-score-circle {
  position: relative;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: conic-gradient(#10b981 0% 50%, rgba(255, 255, 255, 0.1) 50% 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.quality-score-circle::before {
  content: '';
  position: absolute;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  background: #111827;
}

.quality-score-value {
  position: relative;
  z-index: 1;
  font-size: 1.8rem;
  font-weight: 800;
  color: #10b981;
}

.quality-score-label {
  position: relative;
  z-index: 1;
  font-size: 0.9rem;
  color: #cbd5e1;
  margin-left: 2px;
}

.quality-score-text {
  flex: 1;
}

.quality-score-title {
  margin: 0 0 5px;
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
}

.quality-score-desc {
  margin: 0;
  font-size: 0.85rem;
  color: #cbd5e1;
}

.quality-breakdown {
  padding: 15px;
  background: rgba(255, 255, 255, 0.02);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.05);
}

.quality-bars {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}

.quality-bar {
  display: flex;
  align-items: center;
  gap: 10px;
}

.quality-bar-label {
  font-size: 0.8rem;
  color: #cbd5e1;
  min-width: 80px;
}

.quality-bar-container {
  flex: 1;
  height: 8px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 4px;
  overflow: hidden;
}

.quality-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.5s ease;
}

.quality-bar-value {
  font-size: 0.8rem;
  font-weight: 700;
  color: #fff;
  min-width: 40px;
  text-align: right;
}

.quality-feedback {
  padding: 15px;
  background: rgba(236, 72, 153, 0.05);
  border-radius: 10px;
  border-left: 4px solid #ec4899;
}

.quality-feedback-text {
  font-size: 0.8rem;
  color: #cbd5e1;
  line-height: 1.6;
}

.quality-feedback-text p {
  margin: 8px 0;
}

.quality-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.quality-tips ul {
  margin: 0;
  padding-left: 20px;
}

.quality-tips li {
  margin-bottom: 6px;
  font-size: 0.85rem;
  color: #cbd5e1;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .quality-criterion {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .quality-slider {
    width: 100%;
    min-width: auto;
  }
  
  .quality-score {
    flex-direction: column;
    text-align: center;
  }
  
  .quality-actions {
    flex-direction: column;
  }
  
  .quality-actions .gl-btn {
    width: 100%;
    margin-left: 0 !important;
    margin-bottom: 10px;
  }
}

/* =========================================================================
   MÓDULO DEEPSEEK
   ========================================================================= */
.m-ds-titan-shell { 
  background: #010409; 
  border: 1px solid rgba(99,102,241,0.25); 
  border-radius: 16px; 
  overflow: hidden; 
  box-shadow: var(--shadow-lux); 
}
.m-ds-t-header { background: rgba(99,102,241,0.1); padding: 10px 15px; border-bottom: 1px solid rgba(99,102,241,0.2); }
.m-ds-t-body { padding: 20px; height: 280px; overflow-y: auto; font-family: 'JetBrains Mono', 'Fira Code', monospace; line-height: 1.6; }
.m-ds-thought-line { font-size: 0.82rem; margin-bottom: 8px; animation: scanIn 0.4s ease-out forwards; opacity: 0; transform: translateX(-10px); }
@keyframes scanIn { to { opacity: 1; transform: translateX(0); } }
.ds-status-idle { color: #64748b; font-size: 0.65rem; padding: 2px 8px; border: 1px solid #334155; border-radius: 10px; }
.ds-status-busy { color: #facc15; font-size: 0.65rem; padding: 2px 8px; border: 1px solid #facc15; border-radius: 10px; animation: pulseGlow 1.5s infinite; }
@keyframes pulseGlow { 0% { opacity: 0.6; box-shadow: 0 0 0px #facc15; } 50% { opacity: 1; box-shadow: 0 0 10px #facc15; } 100% { opacity: 0.6; box-shadow: 0 0 0px #facc15; } }
.m-ds-controls { display: grid; grid-template-columns: 1fr 220px; gap: 15px; margin-top: 20px; align-items: end; }
.ds-premium-select { background: rgba(255,255,255,0.05); border: 1px solid #333; color: #fff; padding: 12px; border-radius: 10px; width: 100%; outline: none; appearance: none; cursor: pointer; }
.ds-premium-select:focus { border-color: #6366f1; }
.ds-btn-glow-titan { background: linear-gradient(135deg, #6366f1, #4f46e5); color: #fff; border: none; padding: 12px 20px; border-radius: 10px; font-weight: 800; font-size: 0.85rem; cursor: pointer; transition: all 0.3s; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; gap: 10px; }
.ds-btn-glow-titan:hover { transform: translateY(-2px); box-shadow: 0 0 20px rgba(99,102,241,0.6); }
.ds-btn-glow-titan:active { transform: translateY(0); }
.ds-btn-glow-titan:disabled { opacity: 0.5; filter: grayscale(1); cursor: not-allowed; }

/* =========================================================================
   MÓDULO GEMINI PRODUCTIVITY
   ========================================================================= */
:root { --gm-primary:#8e2de2; --gm-secondary:#4a00e0; --gm-accent:#b388ff; --gm-card:#0b0b15; --gm-border:#221b39; --gm-soft:#94a3b8; }
.m-gm-container { color:#f1f5f9; font-family:'Inter',sans-serif; }
.m-gm-card { background:var(--gm-card); border:1px solid var(--gm-border); border-radius:16px; padding:22px; margin-bottom:18px; }
.gm-btn-glow { background:linear-gradient(135deg,#8e2de2 0%,#4a00e0 100%); color:#fff; border:none; padding:12px 22px; border-radius:8px; font-weight:700; cursor:pointer; }
.m-gm-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.m-gm-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.m-gm-note { font-size:0.79rem; color:var(--gm-soft); line-height:1.7; }
.m-gm-copy { background:rgba(142,45,226,0.12); border:1px solid rgba(179,136,255,0.28); color:var(--gm-accent); padding:5px 12px; border-radius:6px; font-size:0.72rem; font-weight:700; cursor:pointer; }
.m-gm-meter { height:10px; background:#111; border-radius:5px; overflow:hidden; margin-top:15px; border:1px solid #333; }
.m-gm-meter-fill { height:100%; width:0%; background:linear-gradient(90deg,#8e2de2,#4a00e0); transition:width 1s ease; }
.m-gm-hero { background:radial-gradient(circle at top left,rgba(179,136,255,0.18),transparent 45%),linear-gradient(135deg,rgba(142,45,226,0.12),rgba(10,10,20,0.95)); border:1px solid rgba(179,136,255,0.22); border-radius:20px; padding:22px; margin-bottom:18px; }
.m-gm-chip-row { display:flex; flex-wrap:wrap; gap:10px; margin-top:14px; }
.m-gm-chip { padding:8px 12px; border-radius:999px; background:rgba(255,255,255,0.04); border:1px solid rgba(179,136,255,0.16); color:#ddd6fe; font-size:0.74rem; font-weight:700; }
.m-gm-step { position:relative; padding:18px 18px 18px 58px; border-radius:14px; border:1px solid rgba(179,136,255,0.16); background:rgba(255,255,255,0.02); }
.m-gm-step-badge { position:absolute; left:16px; top:16px; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.74rem; font-weight:800; color:#fff; background:linear-gradient(135deg,#8e2de2,#4a00e0); }
.m-gm-matrix { display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr; gap:1px; background:rgba(179,136,255,0.18); border-radius:16px; overflow:hidden; margin-top:18px; }
.m-gm-matrix > div { background:#0a0a14; padding:14px; font-size:0.77rem; line-height:1.6; color:var(--gm-soft); }
.m-gm-matrix .is-head { background:rgba(142,45,226,0.15); color:#ede9fe; font-weight:800; }
.m-gm-route { border-radius:16px; padding:18px; border:1px solid rgba(179,136,255,0.16); background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.01)); }
.m-gm-route h4 { margin:0 0 8px; color:#fff; }
.m-gm-route-line { font-size:0.78rem; color:#cbd5e1; line-height:1.8; }
.m-gm-highlight { color:#f5d0fe; font-weight:800; }
.m-gm-surface { border-radius:16px; padding:16px; border:1px solid rgba(179,136,255,0.14); background:rgba(255,255,255,0.02); min-height:140px; }
.m-gm-surface-icon { font-size:1.4rem; margin-bottom:10px; }
.m-gm-mini { font-size:0.72rem; color:#cbd5e1; line-height:1.7; }
.m-gm-promptbox { background:#070710; border:1px solid #31225e; border-radius:14px; padding:16px; }
.m-gm-tier { border-radius:16px; padding:18px; border:1px solid rgba(179,136,255,0.14); background:linear-gradient(180deg,rgba(255,255,255,0.03),rgba(255,255,255,0.01)); }
.m-gm-tier-label { display:inline-block; padding:4px 10px; border-radius:999px; font-size:0.68rem; font-weight:800; letter-spacing:0.04em; margin-bottom:10px; }
.m-gm-play { border-radius:16px; padding:18px; border:1px solid rgba(179,136,255,0.16); background:rgba(255,255,255,0.02); }
.m-gm-play h4 { margin:0 0 8px; color:#fff; }
@media (max-width:900px){ .m-gm-grid-2,.m-gm-grid-3 { grid-template-columns:1fr; } }
@media (max-width:900px){ .m-gm-matrix { grid-template-columns:1fr; } }

/* =========================================================================
   MÓDULO MANUS AI
   ========================================================================= */
:root {
  --ma-primary: #f43f5e;
  --ma-secondary: #fb7185;
  --ma-bg: rgba(9, 9, 11, 0.8);
  --ma-border: rgba(244, 63, 114, 0.2);
}
.m-ma-container { color: #e4e4e7; font-family: 'Inter', sans-serif; }
.m-ma-card { 
  background: var(--glass-bg); 
  border: 1px solid var(--ma-border); 
  border-radius: 20px; 
  padding: 30px; 
  margin-bottom: 25px; 
  position: relative; 
  overflow: hidden; 
  backdrop-filter: var(--blur-std); 
  box-shadow: var(--shadow-lux); 
}
.m-ma-header-bg { position: absolute; top:0; left:0; width:100%; height:100px; background: linear-gradient(180deg, rgba(244,63,94,0.1) 0%, transparent 100%); pointer-events:none; }
.m-ma-hero { background: linear-gradient(135deg, rgba(244,63,94,0.1), rgba(251,113,133,0.02)); border: 1px solid rgba(244,63,94,0.2); border-radius: 20px; padding: 25px; margin-bottom: 25px; backdrop-filter: blur(10px); }
.m-ma-chip-row { display:flex; flex-wrap:wrap; gap:12px; margin-top:15px; }
.m-ma-chip { background: rgba(255,255,255,0.05); border: 1px solid rgba(244,63,94,0.2); color:#fecdd3; border-radius:999px; padding:8px 14px; font-size:0.75rem; font-weight:700; cursor: default; }
.m-ma-grid-3 { display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; }
.m-ma-panel { background: rgba(255,255,255,0.02); border:1px solid rgba(255,255,255,0.08); border-radius:16px; padding:20px; box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.m-ma-note { background: rgba(244,63,94,0.1); border-left:4px solid var(--ma-primary); border-radius:0 12px 12px 0; padding:15px 18px; color:#fda4af; font-size:0.85rem; line-height:1.7; }
.m-ma-step { display:flex; gap:14px; align-items:flex-start; padding:18px 0; border-top:1px solid rgba(255,255,255,0.05); }
.m-ma-step:first-child { border-top:none; padding-top:0; }
.m-ma-step-badge { width:30px; height:30px; border-radius:999px; background:rgba(244,63,94,0.2); border:1px solid rgba(244,63,94,0.4); color:#fb7185; display:flex; align-items:center; justify-content:center; font-size:0.85rem; font-weight:800; flex-shrink:0; box-shadow: 0 0 10px rgba(244,63,94,0.3); }

/* Tabs Bar */
.premium-tab-ma { background: none; border: none; padding: 10px 15px; color: #71717a; cursor: pointer; border-bottom: 2px solid transparent; transition: 0.3s; font-weight: 600; white-space: nowrap; }
.premium-tab-ma.active { color: var(--ma-primary); border-bottom-color: var(--ma-primary); }

/* Agent UI */
.m-ma-agent-window { border: 1px solid var(--ma-border); border-radius: 16px; background: #000; overflow: hidden; margin-top: 25px; box-shadow: 0 15px 40px rgba(0,0,0,0.6); }
.m-ma-win-header { background: #18181b; padding: 12px 18px; border-bottom: 1px solid var(--ma-border); display: flex; justify-content: space-between; align-items: center; }

.m-ma-viewport { display: grid; grid-template-columns: 1fr 280px; height: 380px; }
.m-ma-browser-view { background: #111; position: relative; border-right: 1px solid var(--ma-border); overflow: hidden; }
.m-ma-logs-view { background: #09090b; padding: 18px; overflow-y: auto; font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; color: #a1a1aa; }

.m-ma-thought { display: flex; gap: 10px; margin-bottom: 12px; opacity: 0; transform: translateX(-10px); transition: 0.4s cubic-bezier(0.4, 0, 0.2, 1); }
.m-ma-thought.show { opacity: 1; transform: translateX(0); }
.m-ma-t-icon { color: var(--ma-primary); font-weight: bold; }

/* Grid 2 */
.m-ma-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
@media (max-width: 900px) { .m-ma-grid-3 { grid-template-columns:1fr; } }
@media (max-width: 768px) { .m-ma-grid { grid-template-columns: 1fr; } }

.ma-btn-glow { 
  background: linear-gradient(135deg, #f43f5e 0%, #fb7185 100%); 
  color: white; border: none; padding: 12px 24px; border-radius: 8px;
  font-weight: 700; cursor: pointer; transition: 0.3s; box-shadow: 0 4px 15px rgba(244,63,94,0.3);
}
.ma-btn-glow:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(244,63,94,0.5); }

/* =========================================================================
   MÓDULO NOTEBOOKLM (ESTRATEGIA)
   ========================================================================= */
.kit-header { background: linear-gradient(135deg, rgba(251,191,36,0.15), rgba(251,191,36,0.03)); border: 1px solid rgba(251,191,36,0.4); border-radius: 12px; padding: 20px; margin-bottom: 20px; }
.kit-badge { background: #f59e0b; color: #000; padding: 3px 12px; border-radius: 20px; font-size: 0.7rem; font-weight: 800; display: inline-block; margin-bottom: 8px; }
.kit-title { font-size: 1.1rem; font-weight: 800; color: #f59e0b; margin: 0 0 6px; }
.kit-sub { font-size: 0.85rem; color: #94a3b8; margin: 0; }
.kit-assets { display: flex; flex-direction: column; gap: 10px; margin: 16px 0; }
.kit-asset { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 8px; padding: 12px 15px; display: flex; align-items: center; gap: 12px; }
.kit-asset-icon { font-size: 1.4rem; flex-shrink: 0; }
.kit-asset-body { flex: 1; }
.kit-asset-name { font-weight: 700; font-size: 0.85rem; color: #e2e8f0; margin: 0 0 2px; }
.kit-asset-desc { font-size: 0.75rem; color: #64748b; margin: 0; }
.kit-copy-btn { background: rgba(251,191,36,0.1); border: 1px solid rgba(251,191,36,0.3); color: #f59e0b; padding: 5px 12px; border-radius: 6px; font-size: 0.72rem; font-weight: 700; cursor: pointer; white-space: nowrap; transition: 0.2s; }
.kit-copy-btn:hover { background: rgba(251,191,36,0.25); }
.kit-copy-btn.copied { background: rgba(16,185,129,0.2); border-color: #10b981; color: #10b981; }
.kit-steps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.kit-step { display: flex; gap: 12px; align-items: flex-start; padding: 12px 14px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.06); cursor: pointer; transition: 0.2s; }
.kit-step:hover { background: rgba(255,255,255,0.03); }
.kit-step.done { border-color: rgba(16,185,129,0.4); background: rgba(16,185,129,0.05); }
.kit-step-check { width: 20px; height: 20px; border: 2px solid #475569; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.65rem; margin-top: 2px; transition: 0.2s; }
.kit-step.done .kit-step-check { background: #10b981; border-color: #10b981; color: #fff; }
.kit-step-body { flex: 1; }
.kit-step-title { font-weight: 700; font-size: 0.85rem; color: #e2e8f0; margin: 0 0 4px; }
.kit-step-detail { font-size: 0.78rem; color: #64748b; margin: 0; line-height: 1.5; }
.kit-step-tip { font-size: 0.72rem; background: rgba(251,191,36,0.08); border-left: 2px solid #f59e0b; padding: 4px 8px; border-radius: 0 4px 4px 0; color: #fbbf24; margin-top: 6px; }
.kit-step-xp { font-size: 0.7rem; font-weight: 800; color: #10b981; margin-left: auto; flex-shrink: 0; padding-top: 2px; }
.kit-copyblock { background: #0f172a; border: 1px solid #1e293b; border-radius: 8px; padding: 12px 14px; font-family: monospace; font-size: 0.78rem; color: #a78bfa; line-height: 1.6; white-space: pre-wrap; position: relative; }
.kit-result-box { background: rgba(16,185,129,0.07); border: 1px solid rgba(16,185,129,0.3); border-radius: 8px; padding: 14px; margin-top: 16px; }
.kit-xp-total { background: linear-gradient(135deg, #10b981, #059669); color: #fff; border-radius: 8px; padding: 12px 16px; display: flex; align-items: center; justify-content: space-between; margin-top: 16px; font-weight: 800; }

/* =========================================================================
   MÓDULO ANTIGRAVITY
   ========================================================================= */
.antigravity-hub {
    padding: 2rem;
    color: white;
    font-family: 'Outfit', sans-serif;
}
.glass-header h1 {
    font-size: 2.5rem;
    background: linear-gradient(90deg, #00f2fe 0%, #4facfe 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.badge-v7 {
    font-size: 0.8rem;
    background: rgba(79, 172, 254, 0.2);
    padding: 4px 10px;
    border-radius: 20px;
    border: 1px solid #4facfe;
    vertical-align: middle;
}
.progress-track {
    display: flex;
    justify-content: space-between;
    margin: 2rem 0;
    padding: 10px;
    background: rgba(255, 255, 255, 0.05);
    border-radius: 15px;
}
.track-step {
    opacity: 0.5;
    font-size: 0.9rem;
    padding: 8px 15px;
    border-radius: 10px;
    transition: all 0.3s;
}
.track-step.active {
    opacity: 1;
    background: rgba(79, 172, 254, 0.3);
    box-shadow: 0 0 15px rgba(79, 172, 254, 0.5);
}
.glass-card {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 2rem;
    border-radius: 24px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3);
}
.btn-premium {
    background: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);
    border: none;
    color: white;
    padding: 12px 30px;
    border-radius: 12px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
}
.btn-premium:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(79, 172, 254, 0.4);
}
.mini-telemetry {
    display: flex;
    gap: 20px;
    margin-top: 2rem;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* CENTAURO PREMIUM LOADERS & RESULTS */
.centauro-loader-box { border: 1px dashed rgba(99,102,241,0.3); border-radius: 12px; padding: 20px; text-align: center; color: #a5b4fc; font-size: 0.9rem; background: rgba(30,41,59,0.5); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; }
.centauro-spinner { width: 30px; height: 30px; border: 3px solid rgba(99,102,241,0.2); border-top-color: #818cf8; border-radius: 50%; animation: c-spin 1s linear infinite; box-shadow: 0 0 15px rgba(99,102,241,0.4); }
@keyframes c-spin { to { transform: rotate(360deg); } }

.centauro-result-ai { background: rgba(16,185,129,0.08); border: 1px solid rgba(16,185,129,0.2); border-left: 4px solid #10b981; border-radius: 12px; padding: 20px; backdrop-filter: blur(12px); box-shadow: 0 10px 25px rgba(0,0,0,0.2); }
.centauro-result-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; color: #34d399; font-size: 1.05rem; }
.centauro-result-ai p { color: #d1fae5; font-size: 0.9rem; margin: 0 0 14px; line-height: 1.6; }
.centauro-sources { display: flex; flex-wrap: wrap; gap: 10px; }
.centauro-source-chip { font-size: 0.75rem; background: rgba(16,185,129,0.15); color: #6ee7b7; padding: 6px 12px; border-radius: 8px; border: 1px solid rgba(16,185,129,0.2); font-weight: 700; }

.centauro-visual-asset { display: flex; flex-direction: column; align-items: center; text-align: center; }
.centauro-visual-frame { width: 100%; height: 220px; background: linear-gradient(135deg, #ef4444, #991b1b); border-radius: 16px; border: 2px solid rgba(248,113,113,0.4); box-shadow: 0 15px 35px rgba(239,68,68,0.25); display: flex; flex-direction: column; align-items: center; justify-content: center; color: #fff; position: relative; overflow: hidden; padding: 20px; }
.centauro-visual-overlay { position: absolute; inset: 0; background: url('data:image/svg+xml;utf8,<svg width="40" height="40" xmlns="http://www.w3.org/2000/svg"><path d="M0 0l40 40M40 0L0 40" stroke="rgba(255,255,255,0.05)" stroke-width="1"/></svg>'); opacity: 0.5; pointer-events: none; }
.centauro-visual-icon { font-size: 2.5rem; margin-bottom: 10px; text-shadow: 0 0 20px rgba(255,255,255,0.6); position: relative; z-index: 1; }
.centauro-visual-frame h4 { margin: 0 0 8px; font-size: 1.3rem; font-weight: 800; letter-spacing: 1px; position: relative; z-index: 1; }
.centauro-visual-frame p { margin: 0; font-size: 0.9rem; opacity: 0.9; position: relative; z-index: 1; }
.centauro-visual-meta { display: flex; gap: 12px; margin-top: 15px; }
.centauro-meta-badge { font-size: 0.72rem; font-weight: 700; color: #f87171; background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.2); padding: 6px 12px; border-radius: 8px; }

.centauro-term-line { color: #8fa0c7; margin-bottom: 6px; font-family: monospace; animation: typing-c 0.3s steps(20, end); overflow: hidden; white-space: nowrap; }
@keyframes typing-c { from { width: 0; } to { width: 100%; } }
.centauro-term-success { display: flex; gap: 14px; background: rgba(16,185,129,0.05); border: 1px solid rgba(16,185,129,0.15); padding: 15px; border-radius: 12px; margin-top: 15px; border-left: 3px solid #10b981; }
.centauro-term-icon { font-size: 1.5rem; }
.centauro-term-success strong { display: block; margin-bottom: 5px; font-family: 'Space Grotesk', sans-serif; }
.centauro-term-success p { margin: 0; color: #a7f3d0; font-family: 'Outfit', sans-serif; font-size: 0.85rem; line-height: 1.5; }
