/* vos-encheres.com — Écran de pub / promo de l'accueil : BANNIÈRE EN HAUT DU FEED (pas une
   popup), carrousel défilant et masquable. Mobile-first (autorité). Calquée sur
   la bannière de parrainage (#feed-parrain) : mêmes marges, coins, ombre. Aucun
   style inline : l'autoplay/les gestes vivent dans app.promo.js. */

/* Bandeau in-feed : pleine largeur du contenu (mêmes gouttières que la grille),
   coins arrondis, ombre chaude. Le carrousel vit à l'intérieur. */
.feed-promo {
  position: relative;
  /* Largeur PLAFONNÉE + centrée : sur mobile elle garde ses gouttières (14 px de
     chaque côté) ; sur desktop (feed pleine largeur) elle ne s'étire PAS au-delà
     de 600 px → la bannière a le MÊME rendu, à la même taille, sur iPhone comme
     sur desktop (au lieu d'une image démesurée à droite sur grand écran). */
  margin: 10px auto 8px;
  max-width: min(calc(100% - 28px), 520px);
  border-radius: 16px;
  overflow: hidden;
  background: var(--card, #fff);
  box-shadow: 0 8px 22px -10px rgba(24, 17, 9, 0.45);
}

/* Croix de masquage — au-dessus des slides, lisible sur fond coloré. */
.promo-close {
  position: absolute; top: 8px; right: 8px; z-index: 3;
  width: 28px; height: 28px; border: 0; border-radius: 50%;
  background: rgba(0, 0, 0, 0.28); color: #fff;
  font-size: 13px; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.promo-close:active { background: rgba(0, 0, 0, 0.45); }

/* Fenêtre du carrousel : on masque le débordement, la piste glisse en translateX. */
.promo-viewport { overflow: hidden; width: 100%; }
.promo-track {
  display: flex;
  transition: transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform;
}
.promo-track.no-anim { transition: none; }

/* Une slide = une pub courte (format bandeau), fond dégradé chaud, texte à gauche. */
.promo-slide {
  flex: 0 0 100%; min-width: 100%;
  box-sizing: border-box;
  min-height: 92px;
  display: flex; flex-direction: column; justify-content: center;
  gap: 5px;
  padding: 16px 40px 18px 18px;   /* place à droite pour la croix, en bas pour les points */
  color: #fff;
  background: linear-gradient(120deg, #FD6802 0%, #E0480B 60%, #B5320A 100%);
}
/* Teintes alternées pour distinguer les slides qui défilent (par défaut, quand
   l'admin n'a fixé NI image NI couleur). Une couleur/image inline les écrase. */
.promo-slide:nth-child(3n+2) {
  background: linear-gradient(120deg, #1f6f5c 0%, #14564a 60%, #0d3f37 100%);
}
.promo-slide:nth-child(3n+3) {
  background: linear-gradient(120deg, #3a3a55 0%, #2a2a44 60%, #1c1c30 100%);
}
/* Slide avec image de fond : l'image (+ voile sombre) est posée en INLINE par le
   JS ; on assure juste le cadrage en cover. */
.promo-slide.has-image {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.promo-slide.clickable { cursor: pointer; }

/* Mode « image seule » : la bannière conçue s'affiche EN PLEIN, au premier plan,
   sans voile ni texte. L'image porte la hauteur (largeur 100 %, ratio conservé). */
.promo-slide.image-only {
  padding: 0; min-height: 0; gap: 0;
  background: none;
}
.promo-img {
  display: block; width: 100%; height: auto;
  /* L'image garde son ratio NATUREL et REMPLIT la largeur (bannière conçue
     affichée EN ENTIER, sans bandes). La largeur étant plafonnée par .feed-promo,
     le rendu est IDENTIQUE iPhone/desktop (mêmes proportions, même cadrage) — pas
     de max-height qui provoquerait un letterbox seulement sur grand écran. */
}

/* Bouton d'appel à l'action (pastille blanche translucide, façon CTA discret). */
.promo-cta {
  align-self: flex-start;
  margin-top: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.95);
  color: #1a1a1a;
  font-size: 12.5px; font-weight: 800;
  white-space: nowrap;
}

.promo-eyebrow {
  font-size: 10.5px; font-weight: 800; letter-spacing: 0.1em;
  text-transform: uppercase; opacity: 0.8;
}
.promo-title {
  margin: 0; font-size: 16px; line-height: 1.25;
  font-weight: 900; letter-spacing: -0.01em;
}
.promo-subtitle {
  margin: 0; font-size: 12.5px; line-height: 1.35;
  font-weight: 500; opacity: 0.92;
}

/* Points de pagination (cliquables), en surimpression en bas de la bannière. */
.promo-dots {
  position: absolute; left: 0; right: 0; bottom: 7px;
  display: flex; gap: 6px; justify-content: center;
  pointer-events: none;   /* seuls les points captent le clic */
}
.promo-dots:empty { display: none; }
.promo-dot {
  width: 6px; height: 6px; border-radius: 50%; border: 0; padding: 0;
  background: rgba(255, 255, 255, 0.45); cursor: pointer;
  pointer-events: auto;
  transition: width 0.25s ease, background 0.25s ease;
}
.promo-dot.active { width: 16px; border-radius: 3px; background: #fff; }

@media (prefers-reduced-motion: reduce) {
  .promo-track { transition: none !important; }
}

/* ---------- Console admin « Écrans de pub » (#promos-sheet) ---------- */
.promos-row {
  border: 1px solid var(--line, #e3ded7); border-radius: 14px;
  padding: 12px; margin-bottom: 10px;
  background: var(--card, #fff);
}
.promos-row.inactive { opacity: 0.6; }
.promos-row-inputs { display: flex; flex-direction: column; gap: 8px; }
.promos-input {
  width: 100%; box-sizing: border-box;
  border: 1px solid var(--line, #e3ded7); border-radius: 10px;
  padding: 10px 12px; font-size: 16px;       /* ≥16px : pas de zoom iOS au focus */
  background: var(--bg, #fbf8f3); color: var(--ink, #1a1a1a);
}
.promos-row-foot {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-top: 10px;
}
.promos-toggle { display: flex; align-items: center; gap: 7px; font-size: 14px; cursor: pointer; }
.promos-toggle input { width: 18px; height: 18px; }
.promos-row-actions { display: flex; gap: 8px; }
.promos-save, .promos-del {
  border: 0; border-radius: 10px; padding: 8px 14px;
  font-size: 14px; font-weight: 700; cursor: pointer;
}
.promos-save { background: var(--orange, #FD6802); color: #fff; }
.promos-save:disabled { opacity: 0.5; cursor: default; }
.promos-del { background: var(--chip-bg, #f1ece4); color: var(--danger, #c0392b); }

/* Aperçu WYSIWYG dans la carte admin : mime la bannière réelle (mêmes classes
   .promo-slide à l'intérieur → rendu identique au carrousel public). */
.promos-prev-label {
  font-size: 11px; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--muted2, #8a8175);
  margin: 2px 0 6px;
}
.promos-preview {
  border-radius: 14px; overflow: hidden; margin-bottom: 12px;
  background: var(--card, #fff);
  box-shadow: 0 4px 14px -8px rgba(24, 17, 9, 0.5);
  border: 1px solid var(--line, #e3ded7);
}
.promos-preview-empty {
  padding: 20px 14px; text-align: center;
  font-size: 13px; color: var(--muted, #9a9286);
}
/* Dans l'aperçu, le slide ne défile pas → il occupe toute la largeur de la carte. */
.promos-preview .promo-slide { min-width: 0; }

/* Carte d'AJOUT : se distingue par un liseré pointillé + en-tête. */
.promos-row.promos-new {
  border-style: dashed;
  background: var(--bg, #fbf8f3);
}
.promos-add-label {
  font-size: 13px; font-weight: 800; color: var(--muted2, #8a8175);
  margin-bottom: 8px;
}

/* Ligne MÉDIA : bouton image + aperçu + retrait, et couleur. */
.promos-media {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
  margin-top: 10px;
}
.promos-imgbtn {
  border: 1px solid var(--line, #e3ded7); border-radius: 10px;
  padding: 8px 12px; font-size: 13px; font-weight: 700; cursor: pointer;
  background: var(--card, #fff); color: var(--ink, #1a1a1a);
}
.promos-thumb {
  width: 0; height: 36px; border-radius: 8px;
  background-size: cover; background-position: center;
  transition: width 0.15s ease;
}
.promos-thumb.has { width: 56px; border: 1px solid var(--line, #e3ded7); }
.promos-imgclear {
  border: 0; border-radius: 50%; width: 24px; height: 24px;
  background: var(--chip-bg, #f1ece4); color: var(--ink-soft, #555);
  font-size: 11px; cursor: pointer;
}
.promos-color {
  display: flex; align-items: center; gap: 6px; margin-left: auto;
  font-size: 13px; cursor: pointer;
}
.promos-color input[type="checkbox"] { width: 16px; height: 16px; }
.promos-color input[type="color"] {
  width: 30px; height: 26px; padding: 0; border: 1px solid var(--line, #e3ded7);
  border-radius: 6px; background: none; cursor: pointer;
}
.promos-color input[type="color"]:disabled { opacity: 0.35; cursor: default; }
.promos-full {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; cursor: pointer;
}
.promos-full input[type="checkbox"] { width: 16px; height: 16px; }

.promos-empty { color: var(--muted, #9a9286); font-size: 14px; padding: 8px 2px 4px; }

/* ---------- Section « Qui peut gérer les pubs » (admins complets) ---------- */
.promos-sec-label {
  font-size: 13px; font-weight: 800; color: var(--ink, #1a1a1a);
  margin: 4px 0 8px;
}
.promos-sec-sep {
  height: 1px; background: var(--line, #e3ded7); margin: 14px 0;
}
.promos-mgr-row, .promos-mgr-result {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 8px 0;
}
.promos-mgr-result { border-bottom: 1px solid var(--line, #e3ded7); }
.promos-mgr-info { min-width: 0; display: flex; flex-direction: column; }
.promos-mgr-name { font-size: 14px; font-weight: 700; color: var(--ink, #1a1a1a); }
.promos-mgr-mail {
  font-size: 12px; color: var(--muted, #9a9286);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.promos-mgr-rm, .promos-mgr-add {
  flex: none; border: 0; border-radius: 9px; padding: 7px 12px;
  font-size: 13px; font-weight: 700; cursor: pointer;
}
.promos-mgr-rm { background: var(--chip-bg, #f1ece4); color: var(--danger, #c0392b); }
.promos-mgr-add { background: var(--orange, #FD6802); color: #fff; }
.promos-mgr-empty { font-size: 13px; color: var(--muted, #9a9286); padding: 4px 0 8px; }
#promos-mgr-search { margin-top: 8px; }
#promos-mgr-results:not(:empty) { margin-top: 6px; }
