.analyzer-wrap { padding: 0; width: 100%; }

/* ─── Analyzer page · 2-col layout en PC ─────────────────────
   En PC (>=1024px) el panel izquierdo (búsqueda, BD, chips) se mantiene
   compacto y la derecha (plataforma + acciones + resultados) ocupa el
   espacio sobrante — antes quedaba ~60% del ancho vacío en monitores
   amplios. En tablet/móvil se colapsa a 1 columna en flujo vertical.
*/
.az-page { padding: 20px; }
.az-page-head { display:flex; align-items:center; gap:12px; margin-bottom:16px; flex-wrap: wrap; }
.az-grid { display: block; }
.az-col-left, .az-col-right { min-width: 0; }

@media (min-width: 1024px) {
  .az-grid {
    display: grid;
    grid-template-columns: minmax(380px, 460px) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
  }
  .az-col-left  { position: sticky; top: 0; align-self: start; }
  .az-col-left  > *:last-child { margin-bottom: 0 !important; }
  #analyzerResults:empty::before {
    content: 'Selecciona uno o más canales y elige una acción para empezar el análisis.';
    display: block;
    padding: 40px 20px;
    text-align: center;
    color: var(--text3);
    font-family: var(--mono);
    font-size: 11px;
    border: 1px dashed var(--line);
    border-radius: var(--radius-lg);
    background: var(--bg1);
    margin-top: 4px;
  }
}

/* ─── Pantallas anchas (≥1500px) ── 3 zonas ──
   Para que monitores grandes no queden con un océano vacío a la derecha,
   el panel derecho se vuelve un grid: controles a la izquierda, resultados
   a la derecha tomando todo el espacio sobrante. */
@media (min-width: 1500px) {
  .az-grid {
    grid-template-columns: minmax(380px, 460px) minmax(380px, 480px) minmax(0, 1fr);
  }
  .az-col-right {
    display: contents;
  }
  .az-controls {
    grid-column: 2;
    display: flex;
    flex-direction: column;
  }
  #analyzerResults {
    grid-column: 3;
    align-self: start;
    min-width: 0;
  }
  #analyzerResults:empty::before {
    min-height: 280px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.az-platform-btn {
  background: var(--bg2);
  border: 1px solid var(--line);
  color: var(--text2);
  padding: 5px 11px;
  border-radius: 6px;
  font-family: var(--mono);
  font-size: 10px;
  cursor: pointer;
  transition: all 0.15s;
}
.az-platform-btn:hover { background: var(--bg3); color: var(--text); }
.az-platform-btn.on {
  background: var(--accent);
  border-color: var(--accent);
  color: #000;
  font-weight: 700;
}
.az-card { background:var(--bg1); border:1px solid var(--line); border-radius:var(--radius-lg); padding:16px; margin-bottom:12px; }
.az-card-title { font-size:13px; font-weight:700; margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.az-metrics { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.az-metric { background:var(--bg2); border:1px solid var(--line); border-radius:var(--radius); padding:8px 12px; text-align:center; min-width:80px; }
.az-metric-v { font-size:16px; font-weight:700; font-family:var(--mono); }
.az-metric-l { font-size:8px; color:var(--text3); text-transform:uppercase; letter-spacing:.05em; margin-top:2px; }
.az-kw-cloud { display:flex; flex-wrap:wrap; gap:4px; }
.az-kw { font-family:var(--mono); font-size:9px; padding:2px 8px; background:var(--bg3); border:1px solid var(--line); border-radius:12px; color:var(--text2); cursor:pointer; transition:all .15s; }
.az-kw:hover { border-color:var(--accent); color:var(--accent); }
.az-kw-count { color:var(--text3); font-size:8px; margin-left:2px; }
.az-bar-wrap { height:6px; background:var(--bg3); border-radius:3px; overflow:hidden; flex:1; }
.az-bar { height:100%; border-radius:3px; transition:width .3s; }
.az-signal { font-family:var(--mono); font-size:9px; padding:4px 8px; border-radius:var(--radius); margin-bottom:3px; }
.az-signal.positive { background:rgba(34,197,94,.06); border:1px solid rgba(34,197,94,.15); color:var(--green); }
.az-signal.warning { background:rgba(240,180,41,.06); border:1px solid rgba(240,180,41,.15); color:var(--accent); }
.az-signal.negative { background:rgba(239,68,68,.06); border:1px solid rgba(239,68,68,.15); color:var(--red); }
.az-section { margin-bottom:12px; }
.az-section-title { font-size:10px; font-weight:600; color:var(--text2); text-transform:uppercase; letter-spacing:.05em; margin-bottom:6px; }
.az-ch-item { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:var(--radius); cursor:pointer; transition:background .1s; }
.az-ch-item:hover { background:var(--bg2); }
.az-ch-item.selected { background:rgba(240,180,41,.06); border:1px solid rgba(240,180,41,.15); }
.az-ch-chip { font-family:var(--mono); font-size:9px; padding:2px 8px; background:var(--bg2); border:1px solid var(--line); border-radius:12px; display:flex; align-items:center; gap:4px; }
.az-ch-chip .remove { cursor:pointer; color:var(--text3); }
.az-ch-chip .remove:hover { color:var(--red); }
.az-aggregate { background:linear-gradient(135deg, rgba(240,180,41,.03), rgba(168,85,247,.03)); border:1px solid rgba(240,180,41,.15); }
.az-score-badge { font-family:var(--mono); font-size:14px; font-weight:700; padding:4px 12px; border-radius:var(--radius); }
.az-day-bar { display:inline-block; width:14px; margin:0 1px; border-radius:2px 2px 0 0; vertical-align:bottom; }
.az-compare-table { width:100%; border-collapse:collapse; font-family:var(--mono); font-size:9px; }
.az-compare-table th { text-align:left; padding:6px 8px; border-bottom:1px solid var(--line); color:var(--text3); font-weight:500; }
.az-compare-table td { padding:6px 8px; border-bottom:1px solid var(--line); }
.az-ai-result { font-family:var(--mono); font-size:10px; line-height:1.8; white-space:pre-wrap; color:var(--text2); padding:12px; background:var(--bg2); border:1px solid var(--line); border-radius:var(--radius); max-height:500px; overflow-y:auto; }
.az-search-card:hover { border-color:var(--accent) !important; background:var(--bg3) !important; }
.az-search-card .btn-gold:hover { transform:scale(1.05); }

/* ─── Click feedback inmediato ─────────────────────────────
   Al hacer click en cualquier botón con .btn, da feedback visual
   instantáneo (animación + cambio de color) ANTES de que el handler
   async termine. Garantiza que el usuario sepa que su click se registró
   incluso si el API call está lento o falla. */
.btn:active,
button.btn:active {
  transform: scale(0.94) !important;
  filter: brightness(0.85);
  transition: transform 0.06s ease, filter 0.06s ease;
}
.btn-flash {
  animation: kf-btn-flash 0.4s ease;
}
@keyframes kf-btn-flash {
  0%   { background: rgba(34,197,94,.6); transform: scale(1); }
  50%  { background: rgba(34,197,94,.3); transform: scale(1.05); }
  100% { background: inherit; transform: scale(1); }
}
.btn-flash-err {
  animation: kf-btn-flash-err 0.4s ease;
}
@keyframes kf-btn-flash-err {
  0%   { background: rgba(239,68,68,.6); transform: scale(1); }
  50%  { background: rgba(239,68,68,.3); }
  100% { background: inherit; transform: scale(1); }
}

/* ─── Toast notification (centrado, gigante, no se puede no ver) ── */
.kf-toast-container {
  position: fixed;
  top: 80px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.kf-toast {
  min-width: 280px;
  max-width: 480px;
  padding: 14px 22px;
  border-radius: 12px;
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  box-shadow: 0 8px 32px rgba(0,0,0,.4), 0 2px 8px rgba(0,0,0,.3);
  pointer-events: auto;
  animation: kf-toast-in 0.25s cubic-bezier(.2,.9,.3,1.2);
  display: flex;
  align-items: center;
  gap: 10px;
}
.kf-toast.ok  { background: linear-gradient(135deg,#16a34a,#22c55e); border: 1px solid rgba(255,255,255,.15); }
.kf-toast.err { background: linear-gradient(135deg,#dc2626,#ef4444); border: 1px solid rgba(255,255,255,.15); }
.kf-toast.info{ background: linear-gradient(135deg,#2563eb,#3b82f6); border: 1px solid rgba(255,255,255,.15); }
.kf-toast.fade-out { animation: kf-toast-out 0.3s ease forwards; }
@keyframes kf-toast-in  { from { opacity:0; transform: translateY(-12px); } to { opacity:1; transform: translateY(0); } }
@keyframes kf-toast-out { from { opacity:1; } to { opacity:0; transform: translateY(-12px); } }

/* ─── Analyzer · Plataforma + Acciones · grid simétrico ───────────
   Antes era una pila de botones de tamaños y estilos distintos
   (algunos con emoji, otros con SVG, distintos colores y bordes).
   Ahora hay dos secciones claras con grid uniforme:
     1. Plataforma — 4 cols, cuadrados, cada uno con icon + label
     2. Acciones — grid 2-col adaptable, primary destaca arriba
*/
.az-section-label {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text3);
  margin: 0 0 8px;
  padding: 0 2px;
}

/* Plataforma: 4 botones iguales, icon arriba label abajo */
.az-platform-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
.az-platform-btn {
  height: 70px;
  padding: 8px 6px;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: 1px solid var(--line);
  background: var(--bg2);
  color: var(--text2);
  border-radius: 12px;
  cursor: pointer;
  transition: all .15s ease;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
}
.az-platform-btn:hover { border-color: var(--text3); color: var(--text); }
.az-platform-btn.on {
  background: rgba(240,180,41,.10);
  border-color: var(--accent);
  color: var(--accent);
  font-weight: 600;
}
.az-platform-btn .az-pf-ico {
  width: 24px; height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.az-platform-btn .az-pf-ico svg {
  width: 22px; height: 22px;
  stroke-width: 1.6;
}
.az-platform-btn .az-pf-lbl {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}
.az-platform-hint {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--text3);
  margin-bottom: 16px;
  min-height: 14px;
  padding: 0 2px;
}

/* Acciones: grid 2-col, primary action span 2 cols arriba */
.az-actions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}
.az-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 14px;
  border: 1px solid var(--line);
  background: var(--bg2);
  color: var(--text);
  border-radius: 10px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s ease;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.az-action-btn svg { width: 16px; height: 16px; flex-shrink: 0; opacity: .85; }
.az-action-btn:hover { border-color: var(--text3); }
.az-action-btn.primary {
  grid-column: 1 / -1;
  background: var(--accent);
  border-color: var(--accent);
  color: #000;
  font-weight: 700;
  height: 50px;
  font-size: 14px;
}
.az-action-btn.primary:hover { background: #f5c030; }
.az-action-btn.purple { color: var(--purple); border-color: rgba(168,85,247,.3); }
.az-action-btn.green  { color: var(--green);  border-color: rgba(34,197,94,.3); }
.az-action-btn.blue   { color: var(--a2);     border-color: rgba(96,165,250,.3); }
.az-action-btn.amber  { color: var(--accent); border-color: rgba(240,180,41,.3); }
.az-action-btn.purple:hover { background: rgba(168,85,247,.08); }
.az-action-btn.green:hover  { background: rgba(34,197,94,.08); }
.az-action-btn.blue:hover   { background: rgba(96,165,250,.08); }
.az-action-btn.amber:hover  { background: rgba(240,180,41,.08); }

/* Mobile: misma estructura pero más compacta y plataforma 2 cols si
   no caben las 4. */
@media (max-width: 540px) {
  .az-platform-btn { height: 64px; font-size: 10px; padding: 6px 4px; gap: 4px; }
  .az-platform-btn .az-pf-ico svg { width: 18px; height: 18px; }
  .az-action-btn { height: 42px; font-size: 12px; padding: 0 10px; }
  .az-action-btn.primary { height: 46px; font-size: 13px; }
}
