/* Modale "Montage vidéo" (wizard v2, étape 3).
   Surcharge le squelette .genv2-modal* hérité de generate_v2.css avec
   les éléments spécifiques au sub-flow. Aucune couleur hardcodée :
   toutes les valeurs utilisent les variables de main.css. */

/* ── Conteneur ──────────────────────────────────────────────────────── */
.genv2-modal-content.genv2-modal--montage {
  width: min(960px, 95vw);
  max-height: 92vh;
}

.genv2-montage-body {
  padding: 16px 20px;
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.genv2-montage-intro {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.4;
}

/* ── Compteur rate-limit dans le header ─────────────────────────────── */
.genv2-montage-ratelimit {
  margin-left: auto;
  margin-right: 12px;
  font-size: 11px;
  color: var(--muted);
  padding: 3px 8px;
  border-radius: 6px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  white-space: nowrap;
}
.genv2-montage-ratelimit.is-blocked {
  color: var(--error);
  border-color: var(--error);
}

/* ── Boutons d'ajout de clips ───────────────────────────────────────── */
.genv2-montage-add {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.genv2-montage-add-btn {
  flex: 1;
  min-width: 200px;
  padding: 12px 14px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text);
  background: var(--surface2);
  border: 1px dashed var(--border2);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.genv2-montage-add-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--surface);
}
.genv2-montage-add-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

/* ── Liste des clips ────────────────────────────────────────────────── */
.genv2-montage-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.genv2-montage-list:empty {
  display: none;
}

.genv2-montage-clip {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 10px;
  cursor: grab;
  transition: border-color .15s, background .15s;
}
.genv2-montage-clip:hover {
  border-color: var(--accent2);
}
.genv2-montage-clip.is-dragging {
  opacity: .5;
  cursor: grabbing;
}
.genv2-montage-clip.is-drop-target {
  border-color: var(--accent);
  background: var(--surface);
}

.genv2-montage-clip-thumb {
  width: 80px;
  height: 80px;
  border-radius: 8px;
  object-fit: cover;
  background: var(--surface);
  flex-shrink: 0;
}

.genv2-montage-clip-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.genv2-montage-clip-name {
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.genv2-montage-clip-name .genv2-montage-clip-kind {
  font-size: 10px;
  color: var(--muted);
  margin-left: 6px;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--surface);
  border: 1px solid var(--border2);
}

.genv2-montage-clip-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.genv2-montage-clip-controls label {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--muted);
}

.genv2-montage-clip-controls input[type="number"],
.genv2-montage-clip-controls select {
  font-size: 12px;
  font-family: inherit;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 4px 8px;
}
.genv2-montage-clip-controls input[type="number"] {
  width: 64px;
}
.genv2-montage-clip-controls input[type="number"]:disabled {
  color: var(--muted);
  cursor: not-allowed;
}
.genv2-montage-clip-controls select {
  min-width: 120px;
  cursor: pointer;
}

.genv2-montage-clip-actions {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}

.genv2-montage-clip-icon-btn {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-family: inherit;
  color: var(--muted);
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  cursor: pointer;
  padding: 0;
}
.genv2-montage-clip-icon-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.genv2-montage-clip-icon-btn.is-danger:hover {
  border-color: var(--error);
  color: var(--error);
}
.genv2-montage-clip-icon-btn:disabled {
  opacity: .3;
  cursor: not-allowed;
}

/* État upload en cours / erreur */
.genv2-montage-clip.is-uploading .genv2-montage-clip-thumb {
  opacity: .55;
}
.genv2-montage-clip-status {
  font-size: 10px;
  color: var(--muted);
}
.genv2-montage-clip.is-error .genv2-montage-clip-status {
  color: var(--error);
}

/* ── État vide ──────────────────────────────────────────────────────── */
.genv2-montage-empty {
  padding: 28px 20px;
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  background: var(--surface2);
  border: 1px dashed var(--border2);
  border-radius: 10px;
}
.genv2-montage-empty[hidden] { display: none; }

/* ── Summary durée totale + warnings ────────────────────────────────── */
.genv2-montage-summary {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 8px;
}

.genv2-montage-total {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

.genv2-montage-warning {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 6px;
  border: 1px solid;
}
.genv2-montage-warning[hidden] { display: none; }
.genv2-montage-warning.is-long {
  color: var(--accent2);
  border-color: var(--accent2);
  background: color-mix(in srgb, var(--accent2) 12%, transparent);
}
.genv2-montage-warning.is-max {
  color: var(--error);
  border-color: var(--error);
  background: color-mix(in srgb, var(--error) 12%, transparent);
}

/* ── Panneau Trim ───────────────────────────────────────────────────── */
.genv2-montage-trim {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  background: var(--surface2);
  border: 1px solid var(--accent2);
  border-radius: 10px;
}
.genv2-montage-trim[hidden] { display: none; }

.genv2-montage-trim-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

.genv2-montage-trim-video {
  width: 100%;
  max-height: 240px;
  border-radius: 8px;
  background: #000;
}

.genv2-montage-trim-range {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.genv2-montage-trim-label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--muted);
}
.genv2-montage-trim-label > span { min-width: 48px; }
.genv2-montage-trim-label input[type="range"] {
  flex: 1;
  accent-color: var(--accent);
  cursor: pointer;
}

.genv2-montage-trim-times {
  font-size: 12px;
  color: var(--text);
  font-family: 'JetBrains Mono', monospace;
}

.genv2-montage-trim-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}
.genv2-montage-trim-actions button {
  padding: 6px 14px;
  font-size: 12px;
  font-family: inherit;
  color: var(--text);
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  cursor: pointer;
}
.genv2-montage-trim-actions button:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.genv2-montage-trim-actions button[data-action="trim-validate"] {
  background: var(--accent);
  color: var(--surface);
  border-color: var(--accent);
}
.genv2-montage-trim-actions button[data-action="trim-validate"]:hover {
  filter: brightness(1.08);
}

/* ── Processing (encodage en cours) ─────────────────────────────────── */
.genv2-montage-processing {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 40px 20px;
}
.genv2-montage-processing[hidden] { display: none; }

.genv2-montage-processing .genv2-loader {
  /* override du .genv2-loader (texte placeholder galerie) en vrai
     spinner CSS pour la phase d'encodage. */
  padding: 0;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 3px solid var(--border2);
  border-top-color: var(--accent);
  animation: genv2-montage-spin 0.9s linear infinite;
}

@keyframes genv2-montage-spin {
  to { transform: rotate(360deg); }
}

.genv2-montage-processing-msg {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  text-align: center;
}

/* ── Résultat ───────────────────────────────────────────────────────── */
.genv2-montage-result {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.genv2-montage-result[hidden] { display: none; }

.genv2-montage-result-title {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
}

.genv2-montage-result-video {
  width: 100%;
  max-height: 420px;
  border-radius: 10px;
  background: #000;
}

/* ── Footer + boutons ───────────────────────────────────────────────── */
.genv2-modal-footer.genv2-montage-footer {
  gap: 8px;
  justify-content: flex-end;
}

.genv2-montage-btn-primary,
.genv2-montage-btn-secondary {
  padding: 9px 18px;
  font-size: 13px;
  font-family: inherit;
  border-radius: 8px;
  cursor: pointer;
  transition: filter .15s, border-color .15s, background .15s, color .15s;
}

.genv2-montage-btn-secondary {
  color: var(--text);
  background: var(--surface2);
  border: 1px solid var(--border2);
}
.genv2-montage-btn-secondary:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.genv2-montage-btn-primary {
  color: var(--surface);
  background: var(--accent);
  border: 1px solid var(--accent);
  font-weight: 600;
}
.genv2-montage-btn-primary:hover {
  filter: brightness(1.08);
}
.genv2-montage-btn-primary:disabled,
.genv2-montage-btn-secondary:disabled {
  opacity: .5;
  cursor: not-allowed;
  filter: none;
}

/* ── Mobile responsive (< 640px) ────────────────────────────────────── */
@media (max-width: 640px) {
  .genv2-modal-content.genv2-modal--montage {
    width: 100vw;
    max-width: 100vw;
    height: 100vh;
    max-height: 100vh;
    border-radius: 0;
  }

  .genv2-montage-body {
    padding: 12px 14px;
  }

  .genv2-modal-header h3 { font-size: 15px; }

  .genv2-montage-ratelimit {
    /* on cache le compteur dans le header en mobile pour ne pas
       déborder ; remontable via une pastille séparée dans le body
       au besoin en Phase 3. */
    display: none;
  }

  .genv2-montage-add {
    flex-direction: column;
  }
  .genv2-montage-add-btn {
    min-width: 0;
    width: 100%;
  }

  .genv2-montage-clip {
    flex-wrap: wrap;
    gap: 8px;
  }
  .genv2-montage-clip-thumb {
    width: 64px;
    height: 64px;
  }
  .genv2-montage-clip-info {
    flex: 1 1 calc(100% - 64px - 36px - 16px);
  }
  .genv2-montage-clip-controls {
    width: 100%;
  }
  .genv2-montage-clip-controls input[type="number"] { width: 56px; }
  .genv2-montage-clip-controls select { min-width: 100px; }

  .genv2-montage-clip-actions {
    flex-direction: row;
    flex-basis: 100%;
    justify-content: flex-end;
  }

  .genv2-montage-summary {
    padding: 8px 10px;
  }

  .genv2-montage-trim-video { max-height: 180px; }
  .genv2-montage-trim-label > span { min-width: 36px; }

  .genv2-modal-footer.genv2-montage-footer {
    flex-wrap: wrap;
  }
  .genv2-montage-btn-primary,
  .genv2-montage-btn-secondary {
    flex: 1;
    min-width: 110px;
  }
}
