/* Écran « Importer depuis Vinted » — mobile-first.
   Réutilise les tokens (--orange, --line…) et les patrons existants
   (.page-pad, .list-head, .page-title). Aucune règle desktop ici : l'écran est
   en .page-pad → il hérite de la largeur lecture + du rail (app.desktop.css). */

.imp-lead {
  color: var(--ink-soft);
  font-size: 14px;
  line-height: 1.5;
  margin: 12px 0 16px;
}

/* Bannière PARRAINAGE de l'accueil (accès facile, visible de tous). */
.feed-parrain {
  display: flex;
  align-items: stretch;
  margin: 10px 14px 6px;
  border-radius: 16px;
  background: linear-gradient(120deg, #FD6802, #CC5402);
  overflow: hidden;
  box-shadow: 0 8px 22px -10px rgba(253, 104, 2, 0.6);
}
.feed-parrain-main {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border: none;
  background: none;
  color: #fff;
  text-align: left;
}
.feed-parrain-emoji { flex: 0 0 auto; font-size: 28px; }
.feed-parrain-txt { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.feed-parrain-txt b { font-size: 15px; font-weight: 900; }
.feed-parrain-txt span {
  font-size: 12.5px;
  opacity: 0.92;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
}
.feed-parrain-arrow { flex: 0 0 auto; font-size: 26px; font-weight: 900; }
.feed-parrain-close {
  flex: 0 0 auto;
  width: 36px;
  border: none;
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

/* Étapes guidées + libellé + aide « comment récupérer le lien ». */
.imp-steps {
  margin: 4px 0 16px;
  padding-left: 20px;
  color: var(--ink-soft);
  font-size: 14px;
  line-height: 1.6;
}
.imp-steps li { margin: 2px 0; }
.imp-steps b { color: var(--ink); }
.imp-field-label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px;
}
.imp-help {
  margin: 8px 0 4px;
  font-size: 13px;
  color: var(--ink-soft);
}
.imp-help summary {
  cursor: pointer;
  color: var(--orange-dark);
  font-weight: 700;
}
.imp-help p { margin: 8px 0 0; line-height: 1.5; }
.imp-help b { color: var(--ink); }

.imp-form {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}
.imp-url-input {
  flex: 1;
  min-width: 0;
  font-size: 16px;            /* ≥ 16px : pas de zoom iOS au focus */
  padding: 12px 14px;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
}
.imp-url-input:focus {
  outline: none;
  border-color: var(--orange);
}
.imp-preview-btn {
  flex: 0 0 auto;
  font-size: 15px;
  font-weight: 800;
  padding: 12px 16px;
  border: none;
  border-radius: 12px;
  background: var(--ink);
  color: #fff;
}
.imp-preview-btn:disabled { opacity: 0.5; }

.imp-error {
  color: var(--red);
  font-size: 14px;
  margin: 6px 0 0;
}
.imp-status { margin: 10px 0; }
.imp-loading, .imp-empty { color: var(--muted); font-size: 14px; }
.imp-ok { color: var(--green-ink); font-weight: 700; font-size: 14px; margin: 2px 0; }
.imp-fail-head { color: var(--ink-soft); font-weight: 700; font-size: 14px; margin: 8px 0 2px; }
.imp-fail-row { color: var(--muted); font-size: 13px; margin: 1px 0; line-height: 1.4; }

.imp-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 6px 0 10px;
}
.imp-selectall {
  background: none;
  border: none;
  color: var(--orange);
  font-size: 14px;
  font-weight: 800;
  padding: 4px 0;
}
.imp-count { color: var(--muted); font-size: 13px; }

.imp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.imp-card {
  border: 1.5px solid var(--card-line);
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  cursor: pointer;
  transition: border-color 0.12s ease;
}
.imp-card.sel { border-color: var(--orange); }
.imp-cover {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  background-color: var(--chip-bg);
}
.imp-cover.empty::after {
  content: '📦';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 30px;
  opacity: 0.5;
}
/* Pastille de sélection (coche), en haut à droite de la cover. */
.imp-check {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  border: 1.5px solid var(--faint);
  color: transparent;
  font-size: 15px;
  font-weight: 900;
  line-height: 21px;
  text-align: center;
}
.imp-card.sel .imp-check {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
}
.imp-meta { padding: 8px 10px 10px; }
.imp-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.3;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.imp-price {
  font-size: 14px;
  font-weight: 900;
  color: var(--ink);
  margin-top: 4px;
}
.imp-cat {
  font-size: 12px;
  color: var(--muted);
  margin-top: 2px;
}
/* Article déjà importé : grisé + badge, non sélectionnable. */
.imp-card.imported { opacity: 0.5; }
.imp-card.imported .imp-check { display: none; }
.imp-imported-badge {
  position: absolute;
  left: 8px;
  bottom: 8px;
  font-size: 11px;
  font-weight: 800;
  color: #fff;
  background: rgba(34, 26, 18, 0.78);
  padding: 3px 8px;
  border-radius: 999px;
}

/* Calque d'état live pendant l'import (⏳ → ✓/✗). */
.imp-overlay {
  position: absolute;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.55);
}
.imp-card.importing .imp-overlay,
.imp-card.done .imp-overlay,
.imp-card.failed .imp-overlay { display: flex; }
.imp-card.done .imp-overlay { background: rgba(255, 255, 255, 0.3); }
/* Spinner pur CSS (CSP-safe). */
.imp-spin {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 3px solid rgba(0, 0, 0, 0.15);
  border-top-color: var(--orange);
  animation: imp-spin 0.7s linear infinite;
}
.imp-card.done .imp-spin,
.imp-card.failed .imp-spin { display: none; }
@keyframes imp-spin { to { transform: rotate(360deg); } }
.imp-mark { display: none; font-size: 30px; font-weight: 900; }
.imp-card.done .imp-mark { display: block; color: var(--green-ink); }
.imp-card.failed .imp-mark { display: block; color: var(--red); }
.imp-card.done { opacity: 0.6; }
.imp-card.failed { border-color: var(--red); }
/* Pendant/après l'import, la pastille de sélection laisse place à l'état. */
.imp-card.importing .imp-check,
.imp-card.done .imp-check,
.imp-card.failed .imp-check { display: none; }
.imp-reason { color: var(--red); font-size: 12px; line-height: 1.3; margin-top: 4px; }
.imp-progress { color: var(--ink-soft); font-size: 14px; font-weight: 700; }

/* Déroulé d'import EN DIRECT : une ligne par article, près du bouton. */
.imp-prog {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 10px 0 4px;
}
.imp-prow {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px;
  border: 1.5px solid var(--card-line);
  border-radius: 12px;
  background: #fff;
}
.imp-prow.ok { border-color: var(--green-ink); background: var(--green-bg); }
.imp-prow.fail { border-color: var(--red); }
.imp-prow.skip { opacity: 0.6; }
.imp-prow-thumb {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background-color: var(--chip-bg);
}
.imp-prow-main { flex: 1; min-width: 0; }
.imp-prow-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.imp-prow-sub { font-size: 12px; color: var(--muted); margin-top: 2px; }
.imp-prow.fail .imp-prow-sub { color: var(--red); }
.imp-prow-status {
  flex: 0 0 auto;
  width: 28px;
  text-align: center;
  font-size: 20px;
  font-weight: 900;
}
.imp-prow.ok .imp-prow-status { color: var(--green-ink); }
.imp-prow.fail .imp-prow-status { color: var(--red); }
.imp-prow.skip .imp-prow-status { color: var(--muted); }

/* Bouton « comptes en attente » poussé à droite de l'en-tête. */
.imp-accounts-btn { margin-left: auto; }

/* Sheet « Comptes en attente ». */
.imp-accounts-list {
  max-height: 60vh;
  overflow-y: auto;
  padding: 4px 0 8px;
}
.imp-acc-empty { color: var(--muted); font-size: 14px; padding: 16px 4px; text-align: center; }
.imp-acc {
  display: flex;
  gap: 12px;
  padding: 12px 4px;
  border-bottom: 1px solid var(--line);
}
.imp-acc-avatar {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: var(--chip-bg);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: var(--chip-ink);
}
.imp-acc-main { flex: 1; min-width: 0; }
.imp-acc-name { font-size: 15px; font-weight: 800; color: var(--ink); }
.imp-acc-sub {
  font-size: 12px;
  color: var(--muted);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.imp-acc-linkrow { display: flex; align-items: center; gap: 8px; margin-top: 6px; }
.imp-acc-link {
  flex: 1;
  min-width: 0;
  font-size: 12px;
  color: var(--orange-dark);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.imp-acc-copy, .imp-acc-regen {
  font-size: 13px;
  font-weight: 800;
  border: none;
  border-radius: 999px;
  padding: 6px 12px;
}
.imp-acc-copy { background: var(--ink); color: #fff; flex: 0 0 auto; }
.imp-acc-regen { background: var(--chip-bg); color: var(--ink); margin-top: 8px; }
.imp-acc-code { font-size: 15px; font-weight: 900; letter-spacing: 1px; margin-top: 8px; color: var(--green-ink); }
.imp-affil-total { font-size: 17px; font-weight: 900; color: var(--ink); margin: 6px 4px 12px; }

/* Bloc « rattacher mes gains » (parrain anonyme, à la fin). */
.imp-affil-claim {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.imp-affil-claim-lead { font-size: 14px; font-weight: 700; color: var(--ink); margin: 0 0 8px; }
.imp-aff-submit {
  width: 100%;
  margin-top: 8px;
  font-size: 15px;
  font-weight: 800;
  padding: 12px;
  border: none;
  border-radius: 12px;
  background: var(--ink);
  color: #fff;
}
.imp-aff-submit:disabled { opacity: 0.5; }
.imp-aff-create {
  width: 100%;
  margin-top: 8px;
  font-size: 15px;
  font-weight: 800;
  padding: 12px;
  border: 1.5px solid var(--orange);
  border-radius: 12px;
  background: #fff;
  color: var(--orange-dark);
}
.imp-aff-msg { font-size: 13px; color: var(--red); margin: 8px 0 0; }
.imp-aff-msg.ok { color: var(--green-ink); font-weight: 700; }
.imp-affil-note { font-size: 13px; color: var(--green-ink); font-weight: 700; margin: 12px 0 0; }
.imp-acc-code:empty { display: none; }

/* Aperçu de la photo de profil Vinted (importée comme avatar). */
.imp-avatar-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 6px 0 4px;
}
.imp-avatar-prev {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background-color: var(--chip-bg);
  background-size: cover;
  background-position: center;
  border: 1.5px solid var(--card-line);
}
.imp-avatar-cap { font-size: 13px; color: var(--ink-soft); }

/* Champ e-mail de la personne (compte créé à son nom). */
.imp-target { margin: 10px 0; }
.imp-target-label {
  display: block;
  font-size: 13px;
  color: var(--ink-soft);
  margin-bottom: 6px;
}
.imp-email-input {
  width: 100%;
  font-size: 16px;
  padding: 12px 14px;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
}
.imp-email-input:focus { outline: none; border-color: var(--orange); }
.imp-target .imp-target-label { margin-top: 12px; }
.imp-slug-row {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--line);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}
.imp-slug-row:focus-within { border-color: var(--orange); }
.imp-slug-prefix {
  flex: 0 0 auto;
  padding: 12px 4px 12px 14px;
  font-size: 16px;
  color: var(--muted);
}
.imp-slug-input {
  flex: 1;
  min-width: 0;
  font-size: 16px;
  padding: 12px 14px 12px 0;
  border: none;
  background: transparent;
  color: var(--ink);
}
.imp-slug-input:focus { outline: none; }

/* Panneau « à transmettre » : code + lien. */
.imp-result {
  margin: 12px 0;
  padding: 14px;
  border: 1.5px solid var(--green-ink);
  border-radius: 14px;
  background: var(--green-bg);
}
.imp-result-lead {
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 10px;
}
.imp-result-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.imp-result-key {
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  width: 44px;
}
.imp-result-code {
  flex: 1;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: 2px;
  color: var(--ink);
}
.imp-result-link {
  flex: 1;
  min-width: 0;
  font-size: 12px;
  color: var(--ink-soft);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.imp-result-copy {
  flex: 0 0 auto;
  font-size: 13px;
  font-weight: 800;
  padding: 6px 12px;
  border: none;
  border-radius: 999px;
  background: var(--ink);
  color: #fff;
}

.imp-commit-btn {
  display: block;
  width: 100%;
  margin: 16px 0 24px;
  font-size: 16px;
  font-weight: 800;
  padding: 15px;
  border: none;
  border-radius: 14px;
  background: var(--orange);
  color: #fff;
}
.imp-commit-btn:disabled { opacity: 0.5; }
