/* =========================
   Page Équipe (public + admin preview)
   - Full width photo ONLY in Grille (square/portrait)
   ========================= */

.team-page{
  --team-accent: #111111;
  --team-cols: 2;

  --card-radius: 18px;
  --gap: 18px;

  /* tailles */
  --avatar: 120px;   /* Portraits + Liste */
  --gridW: 100%;     /* Grille: largeur photo (size) */
  --mult: 1;         /* portrait multiplier */
  --photo-radius: 999px;

  max-width: 1200px;
  margin: 18px auto;
  padding: 0 14px;
}

.team-page.team-size-s{ --avatar: 80px;  --gridW: 33%; }
.team-page.team-size-m{ --avatar: 120px; --gridW: 66%; }
.team-page.team-size-l{ --avatar: 180px; --gridW: 100%; }
.team-page.team-shape-round{ --photo-radius: 999px; --mult: 1; }
.team-page.team-shape-square{ --photo-radius: 16px; --mult: 1; }
.team-page.team-shape-portrait{ --photo-radius: 16px; --mult: 1.28; }

/* header */
.team-header{ margin-bottom: 14px; }
.team-title{ margin: 0 0 10px 0; font-size: 2rem; line-height: 1.1; }

.team-intro{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  background: rgba(0,0,0,.02);
  padding: 12px 14px;
}

/* featured zone -> TOUJOURS en haut, pleine largeur */
.team-split{
  display: flex;
  flex-direction: column;
  gap: var(--gap);
}

.team-featured{
  border: 1px solid rgba(0,0,0,.10);
  border-radius: calc(var(--card-radius) + 2px);
  background: linear-gradient(0deg, rgba(0,0,0,.02), rgba(0,0,0,.01));
  padding: 14px;
  
}
.team-featured-row{

  max-width: 700px;
  margin: 0 auto 10px auto;
}
.team-featured .team-member{
  border-color: rgba(0,0,0,.12);
}

/* members grid */
.team-members{
  display: grid;
  gap: var(--gap);
}

/* responsive */
@media (max-width: 780px){
  .team-members{ grid-template-columns: 1fr !important; }
}

/* Colonnes selon layout */
@media (min-width: 781px){
  .team-page.team-layout-list .team-members{
    grid-template-columns: 1fr !important;
  }
  .team-page.team-layout-cards-h .team-members{
    grid-template-columns: repeat(var(--team-cols), minmax(0, 1fr)) !important;
  }
  .team-page.team-layout-grid .team-members{
    grid-template-columns: repeat(var(--team-cols), minmax(0, 1fr)) !important;
  }
}

/* card */
.team-member{
  border-radius: var(--card-radius);
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  overflow: hidden;
}

/* inner layout */
.team-member-inner{
  display: grid;
  gap: 14px;
  padding: 14px;
}

/* ===== Portraits (cards-h) ===== */
.team-page.team-layout-cards-h .team-member-inner{
  grid-template-columns: auto 1fr;
  align-items: start;
}

/* ===== Liste ===== */
.team-page.team-layout-list .team-member-inner{
  grid-template-columns: auto 1fr;
  align-items: center;
}

/* ===== Grille ===== */
.team-page.team-layout-grid .team-member-inner{
  grid-template-columns: 1fr;
}

/* Grille :
   - size L => cover pleine largeur (photo collée en haut)
   - size S/M => photo centrée (avec padding)
*/
.team-page.team-layout-grid.team-size-l .team-member-inner{ padding: 0; }
.team-page.team-layout-grid:not(.team-size-l) .team-member-inner{ padding: 14px; }

/* photo container */
.team-photo{
  position: relative;
  overflow: hidden;
  background: #f3f4f6;
  border: 1px solid rgba(0,0,0,.10);
}

/* image cover */
.team-photo img,
.team-photo .photo-img{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block;
}

/* placeholder */
.team-photo-placeholder{
  width: 100%;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#64748b;
  font-weight: 800;
  cursor: pointer;
}

/* --- dimensions par layout --- */

/* Portraits: photo à gauche */
.team-page.team-layout-cards-h .team-photo{
  width: var(--avatar);
  height: calc(var(--avatar) * var(--mult));
  border-radius: var(--photo-radius);
}

/* Liste: photo plus petite */
.team-page.team-layout-list .team-photo{
  width: calc(var(--avatar) * .95);
  height: calc((var(--avatar) * .95) * var(--mult));
  border-radius: var(--photo-radius);
}

/* Featured: un peu plus grande */
.team-featured .team-photo{
  width: calc(var(--avatar) * 1.25);
  height: calc((var(--avatar) * 1.25) * var(--mult));
  border-radius: var(--photo-radius);
}

/* Grille:
   - square/portrait => FULL WIDTH cover
   - round => avatar centré (pas full width)
*/
/* Grille (trombinoscope)
   - Grand (size L) : photo cover pleine largeur
   - Moyen/Petit : photo centrée (2/3 et 1/3) pour une vraie différence visuelle
*/
.team-page.team-layout-grid.team-shape-square .team-photo{ aspect-ratio: 4 / 3; }
.team-page.team-layout-grid.team-shape-portrait .team-photo{ aspect-ratio: 4 / 5; }

/* size L : cover collée en haut */
.team-page.team-layout-grid.team-size-l.team-shape-square .team-photo,
.team-page.team-layout-grid.team-size-l.team-shape-portrait .team-photo{
  width: 100%;
  height: auto;
  margin: 0;
  border-radius: var(--card-radius) var(--card-radius) 0 0;
  border-left: 0;
  border-right: 0;
  border-top: 0;
}

/* size M/S : photo centrée (2/3, 1/3) */
.team-page.team-layout-grid:not(.team-size-l).team-shape-square .team-photo,
.team-page.team-layout-grid:not(.team-size-l).team-shape-portrait .team-photo{
  width: var(--gridW);
  height: auto;
  margin: 0 auto 10px auto;
  border-radius: 16px;
}

/* dans la grille, l'image doit toujours couvrir son cadre */
.team-page.team-layout-grid.team-shape-square .team-photo img,
.team-page.team-layout-grid.team-shape-portrait .team-photo img{
  border-radius: 0;
}
/* round en grille : avatar centré */
.team-page.team-layout-grid.team-shape-round .team-body{ padding: 0 !important; }


.team-page.team-layout-grid.team-shape-round .team-member-inner{
  padding: 14px;
}

.team-page.team-layout-grid.team-shape-round .team-photo{
  width: calc(var(--avatar) * 1.15);
  height: calc(var(--avatar) * 1.15);
  border-radius: 999px;
  margin: 0 auto 10px auto;
}

/* body */
.team-body{ min-width: 0; }
.team-name{ margin: 0; font-weight: 900; font-size: 1.05rem; }
.team-role{ margin-top: 6px; color: rgba(15,23,42,.72); font-weight: 700; }

/* Grille : body padding sous la cover */
.team-page.team-layout-grid.team-size-l .team-body{ padding: 14px; }
.team-page.team-layout-grid:not(.team-size-l) .team-body{ padding: 0; }

.team-links{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 12px;
}

.team-link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.85);
  text-decoration: none;
  color: inherit;
  font-weight: 800;
  font-size: .95rem;
}

.team-link:hover{
  border-color: var(--team-accent);
}

.team-bio{
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(15,23,42,.02);
  color: rgba(15,23,42,.92);
  line-height: 1.5;
}


/* Builder: bouton "Ajouter un membre" */
.builder-add-row{
  grid-column: 1 / -1;
}

.builder-add{
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 2px dashed rgba(0,0,0,.18);
  background: rgba(15,23,42,.02);
  color: rgba(15,23,42,.9);
  font-weight: 900;
  cursor: pointer;
}

.builder-add:hover{
  border-color: var(--team-accent);
  background: rgba(15,23,42,.03);
}

/* =========================================================
   TEAM (ADMIN) — controls + modals (theme preview)
   À coller en fin de assets/css/team_page.css
   ========================================================= */

/* ---------- Builder controls (admin cards) ---------- */
.team-page.is-builder .builder-controls-row{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin: 0 0 10px 0;
}

.team-page.is-builder .icon-btn{
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  color: var(--team-accent, #111);
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition: transform .12s ease, filter .12s ease, background .12s ease, border-color .12s ease, color .12s ease;
}

.team-page.is-builder .icon-btn:hover{
  background: var(--team-accent, #111);
  border-color: var(--team-accent, #111);
  color:#fff;
}

.team-page.is-builder .icon-btn:active{
  transform: translateY(1px);
}

.team-page.is-builder .icon-btn.danger{
  color:#b91c1c;
}

.team-page.is-builder .icon-btn.danger:hover{
  background:#b91c1c;
  border-color:#b91c1c;
  color:#fff;
}

/* étoile "active" quand le membre est en avant */
.team-page.is-builder .team-member.is-featured .icon-btn[data-action="feature"]{
  background: var(--team-accent, #111);
  border-color: var(--team-accent, #111);
  color:#fff;
}

.team-page.is-builder .pub-toggle{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  color:#0f172a;
  font-weight: 900;
  box-shadow: 0 10px 22px rgba(15,23,42,.08);
}

.team-page.is-builder .pub-toggle input{
  width:16px;
  height:16px;
  accent-color: var(--team-accent, #111);
}

/* inputs builder (nom / rôle) */
.team-page.is-builder .builder-input{
  width: 95%;
  border: 1px solid rgba(15,23,42,.14);
  border-radius: 12px;
  padding: 10px 12px;
  font: inherit;
  font-weight: 800;
  background:#fff;
}

.team-page.is-builder .builder-input:focus{
  outline:none;
  border-color: var(--team-accent, #111);
  box-shadow: 0 0 0 3px rgba(15,23,42,.06);
}

/* ---------- Photo zoom buttons (admin) ---------- */
.team-page.is-builder .photo-zoom-controls{
  display:flex;
  gap:8px;
  margin-top: 10px;
}

.team-page.is-builder .zoom-btn{
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(15,23,42,.14);
  background: var(--team-accent, #111);
  color:#fff;
  font-weight: 950;
  line-height: 1;
  cursor:pointer;
  box-shadow: 0 10px 22px rgba(15,23,42,.12);
  transition: transform .12s ease, filter .12s ease;
}

.team-page.is-builder .zoom-btn:hover{ filter: brightness(.98); }
.team-page.is-builder .zoom-btn:active{ transform: translateY(1px); }

/* ---------- Boutons "Ajouter" (intro + membre) ---------- */
.team-page.is-builder .intro-add,
.team-page.is-builder .builder-add{
  width: 100%;
  padding: 14px 16px;
  border-radius: 14px;
  border: 2px dashed rgba(15,23,42,.20);
  background: rgba(255,255,255,.86);
  font-weight: 950;
  cursor:pointer;
  transition: border-color .12s ease, background .12s ease, box-shadow .12s ease;
}

.team-page.is-builder .intro-add:hover,
.team-page.is-builder .builder-add:hover{
  border-color: var(--team-accent, #111);
  background: #fff;
  box-shadow: 0 10px 26px rgba(15,23,42,.10);
}

/* =========================================================
   THEME MODAL — restore previews (graphique)
   Le HTML est déjà dans team.php, il manque juste le CSS.
   ========================================================= */
#themeOverlay .theme-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}

#themeOverlay .theme-card{
  text-align:left;
  width:100%;
  padding:0;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 16px;
  background:#fff;
  overflow:hidden;
  cursor:pointer;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}

#themeOverlay .theme-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 34px rgba(15,23,42,.12);
  border-color: rgba(15,23,42,.18);
}

#themeOverlay .theme-card.is-selected{
  border-color: var(--team-accent, #111);
  box-shadow: 0 0 0 3px rgba(15,23,42,.06), 0 14px 34px rgba(15,23,42,.12);
}

#themeOverlay .theme-thumb{
  height: 156px;
  padding: 12px;
  position: relative;
  background:
    radial-gradient(140px 90px at 18% 14%, rgba(15,23,42,.08), transparent 60%),
    linear-gradient(180deg, #f8fafc, #ffffff);
}

#themeOverlay .theme-thumb:before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--team-accent, #111);
  opacity:.035;
  pointer-events:none;
}

#themeOverlay .theme-thumb > *{ position:relative; }

#themeOverlay .mock{
  height: 100%;
  border: 1px solid rgba(15,23,42,.12);
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  padding: 10px;
  display: grid;
  gap: 8px;
}

#themeOverlay .mock-row{
  display:grid;
  grid-template-columns: 38px 1fr;
  gap: 8px;
  align-items:center;
  border: 1px solid rgba(15,23,42,.10);
  border-radius: 12px;
  padding: 8px;
  background: rgba(248,250,252,.85);
  position:relative;
  overflow:hidden;
}

#themeOverlay .mock-row:before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:3px;
  background: var(--team-accent, #111);
  opacity:.75;
}

#themeOverlay .mock-avatar{
  width:38px;
  height:38px;
  background: radial-gradient(circle at 30% 30%, #e2e8f0, #cbd5e1);
  border-radius: 999px;
}

#themeOverlay .theme-shape-square .mock-avatar{ border-radius: 10px; }

#themeOverlay .mock-lines{ display:grid; gap:6px; }
#themeOverlay .mock-line{ height:8px; background:#e2e8f0; border-radius:999px; }
#themeOverlay .mock-line.big{ width:70%; }

#themeOverlay .theme-preview-grid{ grid-template-columns: 1fr 1fr; }
#themeOverlay .theme-preview-grid .mock-row{ grid-template-columns: 1fr; }
#themeOverlay .theme-preview-grid .mock-avatar{ width:100%; height:52px; border-radius:12px; }

#themeOverlay .theme-preview-cards-h .mock-row:nth-child(3),
#themeOverlay .theme-preview-grid .mock-row:nth-child(3){ display:none; }

#themeOverlay .theme-preview-list .mock-row{
  grid-template-columns: 28px 1fr;
  padding: 6px 8px;
}

#themeOverlay .theme-preview-list .mock-avatar{ width:28px; height:28px; }

#themeOverlay .theme-meta{
  padding: 12px 12px 14px;
  border-top: 1px solid rgba(15,23,42,.08);
}

#themeOverlay .theme-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

#themeOverlay .theme-title{ font-weight: 950; letter-spacing: -.01em; }
#themeOverlay .theme-sub{ color:#64748b; font-weight: 800; font-size:.92rem; margin-top:2px; }

#themeOverlay .theme-pill{
  display:inline-flex;
  align-items:center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(2,6,23,.04);
  font-weight: 900;
  font-size: .85rem;
  color:#0f172a;
}

#themeOverlay .theme-desc{
  margin-top: 8px;
  color:#64748b;
  font-size:.92rem;
  line-height: 1.25rem;
}

/* ✓ : caché par défaut, visible seulement si sélectionné */
#themeOverlay .theme-selected{
  position:absolute;
  top:10px;
  right:10px;
  width:30px;
  height:30px;
  border-radius:999px;
  display:none;
  align-items:center;
  justify-content:center;
  font-weight:950;
  border: 1px solid rgba(15,23,42,.16);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 22px rgba(15,23,42,.10);
}

#themeOverlay .theme-card.is-selected .theme-selected{
  display:inline-flex;
}

/* =========================================================
   ADMIN — Drag & drop (responsive + look)
   ========================================================= */

body.team-reordering{
  user-select: none;
}

.team-page.is-builder .drag-handle{
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px dashed rgba(15,23,42,.25);
  background: rgba(15,23,42,.03);
  color: rgba(15,23,42,.85);
  font-weight: 900;
  cursor: grab;
  touch-action: none;          /* IMPORTANT : permet le drag tactile */
  -webkit-user-select: none;
  user-select: none;
}

.team-page.is-builder .drag-handle:active{
  cursor: grabbing;
}

.team-page.is-builder .team-member.is-dragging{
  opacity: .75;
  transform: scale(.985);
  box-shadow: 0 24px 60px rgba(15,23,42,.18);
}

/* Responsive admin : évite 3/4 colonnes illisibles sur écran moyen */
@media (max-width: 1100px){
  .team-page.is-builder.team-layout-grid.team-cols-4 .team-members,
  .team-page.is-builder.team-layout-grid.team-cols-3 .team-members{
    grid-template-columns: repeat(2, minmax(0,1fr)) !important;
  }
}

@media (max-width: 780px){
  .team-page.is-builder .team-members{
    grid-template-columns: 1fr !important;
  }
  .team-page.is-builder .drag-handle{
    width: 100%;
  }
}

/* ===== Admin : poignée déplacement en icône (dans team-photo-col) ===== */
.team-page.is-builder .team-photo-col{
  position: relative;
}




/* Cache l'ancien bouton/texte si tu l'as laissé */
.team-page.is-builder .drag-hint,
.team-page.is-builder .drag-handle-text{
  display: none !important;
}

/* ===== Admin : centrer les boutons zoom +/− ===== */
.team-page.is-builder .photo-zoom-controls{
  width: 100%;
  display: flex;
  justify-content: center;   /* <-- centrage */
  gap: 10px;
  margin-top: 10px;
}

/* Style plus propre (si tu veux remplacer tes bleus/gris) */
.team-page.is-builder .zoom-btn{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.14);
  background: var(--team-accent, #111);
  color: #fff;
  font-weight: 950;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(15,23,42,.12);
}
.team-page.is-builder .zoom-btn:active{ transform: translateY(1px); }

/* ===== Drag reorder (admin) : carte flottante + placeholder ===== */
body.team-reordering{
  user-select: none;
  cursor: grabbing;
}

.team-page.is-builder .drag-placeholder{
  border: 2px dashed rgba(15,23,42,.25);
  border-radius: 14px;
  background: rgba(15,23,42,.03);
}

.team-page.is-builder .team-member.is-floating{
  box-shadow: 0 24px 70px rgba(15,23,42,.22);
  transform: translateZ(0);
  opacity: .95;
  border-color: rgba(15,23,42,.18);
}

.team-page.is-builder .drag-handle-ic{
  position: absolute;
  top: -25px;
  left: -15px;
  width: 15px;
  height: 22px;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 22px rgba(15,23,42,.12);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  cursor: grab;
  touch-action: none; /* important pour drag tactile */
  z-index: 10;
  opacity:0; transform: translateY(-2px); transition: .12s;
}

.team-page.is-builder .team-photo-col:hover .drag-handle-ic{ opacity:1; transform: translateY(0); }

.team-page.is-builder .drag-handle-ic:active{
  cursor: grabbing;
  transform: translateY(1px);
}