/* ============================================================
   Nido — Design System (v2)
   Light default · Dark via prefers-color-scheme + data-theme
   ============================================================ */

/* ── Tokens light (défaut) ── */
:root {
  --ocre:  #EF9F27;  --sable: #FAC775;
  --creme: #FAEEDA;  --terre: #412402;  --bois:  #633806;

  --bg-base:     #FBF7F1;
  --bg-surface:  #FFFFFF;
  --bg-raised:   #F5EDE0;
  --bg-overlay:  #EDE0CC;

  --text-primary:   #1A1008;
  --text-secondary: #633806;
  --text-muted:     #9A7040;
  --text-disabled:  #C8A878;

  --border-subtle:  rgba(65,36,2,.07);
  --border-default: rgba(65,36,2,.13);
  --border-strong:  rgba(65,36,2,.28);

  --success: #4CAF78;
  --danger:  #E05050;
  --info:    #5B9BD5;

  --shadow-sm: 0 2px 8px rgba(65,36,2,.08);
  --shadow-md: 0 4px 20px rgba(65,36,2,.12);
  --shadow-lg: 0 8px 40px rgba(65,36,2,.16);

  --radius-xs:   6px;  --radius-sm:   10px; --radius-md:   14px;
  --radius-lg:   20px; --radius-xl:   28px; --radius-full: 9999px;

  --tr-fast:   120ms ease;
  --tr-normal: 220ms ease;
  --tr-slow:   380ms ease;
}

/* ── Tokens dark (media query) ── */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-base:     #0E0C0A; --bg-surface:  #181410;
    --bg-raised:   #221C14; --bg-overlay:  #2E2418;
    --text-primary:   #F0E8D8; --text-secondary: #C8A878;
    --text-muted:     #8A7060; --text-disabled:  #4A3828;
    --border-subtle:  rgba(239,159,39,.10);
    --border-default: rgba(239,159,39,.18);
    --border-strong:  rgba(239,159,39,.35);
    --shadow-sm: 0 2px 8px rgba(0,0,0,.40);
    --shadow-md: 0 4px 20px rgba(0,0,0,.50);
    --shadow-lg: 0 8px 40px rgba(0,0,0,.60);
  }
}

/* ── Tokens light (forçage manuel) ── */
html[data-theme="light"] {
  --bg-base:     #FBF7F1; --bg-surface:  #FFFFFF;
  --bg-raised:   #F5EDE0; --bg-overlay:  #EDE0CC;
  --text-primary:   #1A1008; --text-secondary: #633806;
  --text-muted:     #9A7040; --text-disabled:  #C8A878;
  --border-subtle:  rgba(65,36,2,.07);
  --border-default: rgba(65,36,2,.13);
  --border-strong:  rgba(65,36,2,.28);
  --shadow-sm: 0 2px 8px rgba(65,36,2,.08);
  --shadow-md: 0 4px 20px rgba(65,36,2,.12);
  --shadow-lg: 0 8px 40px rgba(65,36,2,.16);
}

/* ── Tokens dark (forçage manuel) ── */
html[data-theme="dark"] {
  --bg-base:    #0E0C0A;  --bg-surface:  #181410;
  --bg-raised:  #221C14;  --bg-overlay:  #2E2418;
  --text-primary:   #F0E8D8; --text-secondary: #C8A878;
  --text-muted:     #8A7060; --text-disabled:  #4A3828;
  --border-subtle:  rgba(239,159,39,.10);
  --border-default: rgba(239,159,39,.18);
  --border-strong:  rgba(239,159,39,.35);
  --shadow-sm: 0 2px 8px rgba(0,0,0,.40);
  --shadow-md: 0 4px 20px rgba(0,0,0,.50);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.60);
}

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg-base);
  color: var(--text-primary);
  font-size: 15px; line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img  { max-width: 100%; display: block; }
a    { color: var(--ocre); text-decoration: none; }
a:hover { color: var(--sable); }

/* ── Shell ── */
#app { min-height: 100vh; display: flex; flex-direction: column; }

.app-header {
  position: sticky; top: 0; z-index: 100;
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 16px;
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border-default);
  box-shadow: var(--shadow-sm);
}
.app-title {
  font-weight: 600; font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  color: var(--text-primary);
}
.app-title img { height: 44px; }
.header-actions { display: flex; gap: 6px; align-items: center; }

.btn-icon {
  background: none; border: none; cursor: pointer; padding: 7px;
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  transition: background var(--tr-fast), color var(--tr-fast);
  display: flex; align-items: center; justify-content: center;
}
.btn-icon:hover { background: var(--bg-raised); color: var(--text-primary); }
.btn-icon svg   { display: block; }
.avatar-sm { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; border: 1.5px solid var(--border-default); }
.header-sep { width: 1px; height: 18px; background: var(--border-default); margin: 0 2px; flex-shrink: 0; }

/* Install prompt */
.btn-install {
  display: none; align-items: center; gap: 5px;
  font-size: .78rem; padding: 5px 10px;
  background: var(--bg-raised); border: 1px solid var(--border-default);
  border-radius: var(--radius-full); cursor: pointer;
  color: var(--ocre); font-family: inherit;
  transition: background var(--tr-fast);
}
.btn-install:hover { background: var(--bg-overlay); }
.btn-install.visible { display: flex; }

/* Toast */
.toast {
  position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%);
  background: var(--bg-raised); border: 1px solid var(--border-strong);
  color: var(--text-primary); padding: 10px 20px;
  border-radius: var(--radius-full); font-size: .88rem;
  box-shadow: var(--shadow-md); z-index: 500;
  animation: toastIn .22s ease, toastOut .22s ease 1.8s forwards;
  pointer-events: none;
}
@keyframes toastIn  { from { opacity:0; transform: translateX(-50%) translateY(8px); } to { opacity:1; transform: translateX(-50%) translateY(0); } }
@keyframes toastOut { from { opacity:1; } to { opacity:0; } }

#main-content { flex: 1; padding: 0 0 80px; max-width: 640px; margin: 0 auto; width: 100%; }

/* ── Auth ── */
.auth-page  { display: flex; align-items: center; justify-content: center; min-height: 100vh; padding: 20px; background: var(--bg-base); }
.auth-card  {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg);
  padding: 36px 28px; width: 100%; max-width: 420px;
}
.auth-logo  { display: flex; flex-direction: column; align-items: center; gap: 8px; margin-bottom: 16px; }
.auth-logo img { height: clamp(100px, 30vw, 200px); width: auto; max-width: 85%; }
.auth-logo h1  { font-size: 2rem; font-weight: 500; letter-spacing: .5px; color: var(--text-primary); }
.subtitle   { text-align: center; color: var(--text-muted); margin-bottom: 24px; font-size: .9rem; }

/* Onglets */
.tabs       { display: flex; margin-bottom: 20px; border: 1px solid var(--border-default); border-radius: var(--radius-sm); overflow: hidden; }
.tab        { flex: 1; background: none; border: none; padding: 10px; cursor: pointer; font-size: .9rem; color: var(--text-muted); transition: background var(--tr-fast), color var(--tr-fast); font-family: inherit; }
.tab.active { background: var(--ocre); color: var(--terre); font-weight: 600; }

/* Formulaires */
label { display: block; font-size: .82rem; font-weight: 500; color: var(--text-secondary); margin-bottom: 4px; margin-top: 14px; }
input, textarea, select {
  width: 100%; padding: 11px 14px;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  font-size: .95rem; font-family: inherit;
  background: var(--bg-overlay); color: var(--text-primary);
  transition: border-color var(--tr-fast);
}
input::placeholder, textarea::placeholder { color: var(--text-disabled); }
input:focus, textarea:focus { outline: none; border-color: var(--ocre); box-shadow: 0 0 0 3px rgba(239,159,39,.12); }
textarea { resize: vertical; }
.required { color: var(--danger); }
.small    { font-size: .8rem; color: var(--text-muted); }

/* Boutons */
.btn-primary {
  display: block; width: 100%; margin-top: 18px;
  padding: 13px; border: none; border-radius: var(--radius-full);
  background: var(--ocre); color: var(--terre);
  font-size: .95rem; font-weight: 600; cursor: pointer; font-family: inherit;
  transition: background var(--tr-fast), transform var(--tr-fast);
}
.btn-primary:hover:not(:disabled) { background: var(--sable); }
.btn-primary:active:not(:disabled) { transform: scale(.98); }
.btn-primary:disabled { opacity: .4; cursor: not-allowed; }
.btn-primary.small { display: inline-block; width: auto; padding: 8px 18px; font-size: .85rem; margin-top: 0; }

.btn-secondary {
  display: block; width: 100%; margin-top: 10px;
  padding: 12px; border: 1px solid var(--border-strong);
  border-radius: var(--radius-full); background: transparent;
  color: var(--text-secondary); font-size: .95rem; cursor: pointer; font-family: inherit;
  transition: background var(--tr-fast);
}
.btn-secondary:hover { background: var(--bg-raised); }

.btn-sm {
  padding: 6px 14px; border: 1px solid var(--border-default);
  border-radius: var(--radius-full); background: var(--bg-raised);
  color: var(--text-secondary); cursor: pointer; font-size: .82rem; font-family: inherit;
  transition: background var(--tr-fast);
}
.btn-sm:hover { background: var(--bg-overlay); color: var(--text-primary); }

.btn-sm-danger {
  padding: 6px 14px; border: 1px solid rgba(224,80,80,.3);
  border-radius: var(--radius-full); background: rgba(224,80,80,.08);
  color: var(--danger); cursor: pointer; font-size: .82rem; font-family: inherit;
  transition: background var(--tr-fast);
}
.btn-sm-danger:hover { background: rgba(224,80,80,.16); }

.btn-back { background: none; border: none; cursor: pointer; color: var(--ocre); font-size: .9rem; padding: 0 0 10px; display: inline-flex; align-items: center; gap: 4px; font-family: inherit; }

.btn-approve { padding: 6px 12px; border: none; border-radius: var(--radius-full); background: rgba(76,175,120,.15); color: var(--success); cursor: pointer; font-size: .82rem; font-weight: 600; transition: background var(--tr-fast); font-family: inherit; }
.btn-approve:hover { background: rgba(76,175,120,.25); }
.btn-reject  { padding: 6px 12px; border: none; border-radius: var(--radius-full); background: rgba(224,80,80,.12); color: var(--danger); cursor: pointer; font-size: .82rem; font-weight: 600; transition: background var(--tr-fast); font-family: inherit; }
.btn-reject:hover  { background: rgba(224,80,80,.22); }

.btn-delete     { background: none; border: none; cursor: pointer; opacity: .35; color: var(--danger); transition: opacity var(--tr-fast); padding: 4px; }
.btn-delete:hover { opacity: 1; }
.btn-delete-sm  { background: none; border: none; cursor: pointer; opacity: .35; color: var(--danger); transition: opacity var(--tr-fast); padding: 2px; font-size: .9rem; }
.btn-delete-sm:hover { opacity: 1; }

.center-link { text-align: center; margin-top: 18px; font-size: .88rem; color: var(--text-muted); }

/* Section inscription page login */
.auth-register-section {
  margin-top: 24px; padding-top: 20px;
  border-top: 1px solid var(--border-subtle);
  display: flex; flex-direction: column; gap: 10px;
}
.auth-register-title {
  text-align: center; font-size: .82rem;
  color: var(--text-muted); margin-bottom: 2px;
}
.btn-register-choice {
  display: flex; align-items: center; gap: 14px;
  padding: 12px 14px; border-radius: var(--radius-md);
  border: 1px solid var(--border-default);
  background: var(--bg-raised);
  text-decoration: none; color: var(--text-primary);
  transition: border-color var(--tr-fast), background var(--tr-fast);
}
.btn-register-choice:hover { border-color: var(--ocre); background: var(--bg-overlay); color: var(--text-primary); }
.btn-register-icon { font-size: 1.4rem; flex-shrink: 0; }
.btn-register-choice span:last-child { display: flex; flex-direction: column; gap: 2px; }
.btn-register-choice strong { font-size: .9rem; font-weight: 600; }
.btn-register-choice small  { font-size: .78rem; color: var(--text-muted); }

/* Messages */
.error-msg   { color: var(--danger); font-size: .88rem; margin-top: 8px; }
.success-msg { color: var(--success); font-size: .9rem; background: rgba(76,175,120,.1); border: 1px solid rgba(76,175,120,.25); padding: 12px; border-radius: var(--radius-sm); margin-top: 12px; }

/* ── Feed ── */
.feed-header { padding: 16px; border-bottom: 1px solid var(--border-default); background: var(--bg-surface); }
.feed-header h2 { font-size: 1.1rem; font-weight: 500; }
.feed-desc   { color: var(--text-muted); font-size: .88rem; margin-top: 4px; }

#feed-list   { padding: 12px 12px 0; }
.empty-state { text-align: center; padding: 48px 20px; color: var(--text-muted); line-height: 1.9; }
.loading     { text-align: center; padding: 40px; color: var(--text-muted); }
.loading-sm  { padding: 10px; font-size: .85rem; color: var(--text-muted); }
.loader      { text-align: center; padding: 16px; color: var(--text-muted); }
.feed-end    { text-align: center; padding: 20px; color: var(--border-strong); font-size: .82rem; }

/* FAB */
#fab-zone    { position: fixed; bottom: 24px; right: 20px; z-index: 50; }
.btn-fab     {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--ocre); color: var(--terre);
  border: none; font-size: 1.6rem; cursor: pointer;
  box-shadow: 0 4px 16px rgba(239,159,39,.4);
  display: flex; align-items: center; justify-content: center;
  transition: transform var(--tr-fast), box-shadow var(--tr-fast);
}
.btn-fab:hover { transform: scale(1.08); box-shadow: 0 6px 20px rgba(239,159,39,.5); }

/* ── Album / publication cards ── */
.album-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  margin-bottom: 14px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.album-meta  { display: flex; align-items: flex-start; gap: 8px; padding: 12px 14px 8px; font-size: .82rem; color: var(--text-muted); }
.album-author{ font-weight: 600; color: var(--text-primary); display: flex; align-items: center; gap: 7px; flex: 1; min-width: 0; }
.album-meta-right { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; flex-shrink: 0; }
.album-event-tag  { font-size: .72rem; font-weight: 500; padding: 2px 8px; border-radius: var(--radius-full); background: rgba(239,159,39,.12); color: var(--ocre); border: 1px solid rgba(239,159,39,.30); white-space: nowrap; }
.album-date       { font-size: .78rem; }
.album-body  { padding: 10px 14px 14px; }
.album-title { font-size: .98rem; font-weight: 500; margin-bottom: 4px; color: var(--text-primary); }
.album-desc  { font-size: .88rem; color: var(--text-muted); margin-bottom: 6px; }
.album-title-wrap { display:flex; align-items:center; gap:6px; }
.btn-edit-desc { background:none; border:none; cursor:pointer; font-size:.9rem; opacity:.5; padding:0 2px; line-height:1; flex-shrink:0; }
.btn-edit-desc:hover { opacity:1; }
.album-edit-form { display:flex; flex-direction:column; gap:8px; margin-bottom:8px; }
.album-edit-title { font-size:.98rem; font-weight:500; padding:6px 10px; border:1px solid var(--border-default); border-radius:var(--radius-sm); background:var(--bg-raised); color:var(--text-primary); }
.album-edit-desc  { font-size:.88rem; padding:6px 10px; border:1px solid var(--border-default); border-radius:var(--radius-sm); background:var(--bg-raised); color:var(--text-primary); resize:vertical; font-family:inherit; }
.album-edit-actions { display:flex; gap:8px; }
.album-count { font-size: .75rem; color: var(--text-muted); }

/* Avatar auteur dans le feed */
.avatar-feed {
  width: 30px; height: 30px; border-radius: 50%; object-fit: cover;
  border: 1.5px solid var(--border-default); flex-shrink: 0;
}
.avatar-feed-initial {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--bg-overlay); border: 1.5px solid var(--border-default);
  display: flex; align-items: center; justify-content: center;
  font-size: .78rem; font-weight: 600; color: var(--text-secondary);
  flex-shrink: 0;
}

/* Event badge (flux mixte) */
.event-badge-wrap { padding: 0 14px 6px; }
.event-badge      { display: inline-block; background: rgba(239,159,39,.12); color: var(--text-secondary); font-size: .72rem; font-weight: 500; padding: 3px 10px; border-radius: var(--radius-full); border: 1px solid rgba(239,159,39,.30); }

/* Photo slider */
.photo-slider { position: relative; margin: 0 12px; border-radius: var(--radius-sm); overflow: hidden; }
.photo-slider-img { width: 100%; height: auto; aspect-ratio: 4 / 5; object-fit: cover; cursor: pointer; display: block; transition: opacity .15s; }
.slider-btn {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: rgba(0,0,0,.45); border: none; border-radius: 50%;
  width: 38px; height: 38px; cursor: pointer; color: #fff; font-size: 1.5rem;
  display: flex; align-items: center; justify-content: center;
  z-index: 2; transition: background .12s; line-height: 1;
}
.slider-btn:hover { background: rgba(0,0,0,.68); }
.slider-prev { left: 8px; }
.slider-next { right: 8px; }
.slider-count {
  position: absolute; bottom: 8px; right: 10px;
  background: rgba(0,0,0,.50); color: #fff; font-size: .72rem;
  padding: 2px 8px; border-radius: var(--radius-full); pointer-events: none;
}

/* Emoji picker */
.btn-emoji-toggle {
  background: none; border: none; cursor: pointer; padding: 4px 6px;
  font-size: 1.1rem; border-radius: var(--radius-xs); flex-shrink: 0;
  transition: background .12s; line-height: 1;
}
.btn-emoji-toggle:hover { background: var(--bg-raised); }
.emoji-picker {
  display: grid; grid-template-columns: repeat(8, 1fr);
  gap: 2px; padding: 8px;
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md);
  margin-top: 6px;
}
.emoji-btn {
  background: none; border: none; cursor: pointer; font-size: 1.2rem;
  padding: 5px 3px; border-radius: var(--radius-xs); text-align: center;
  transition: background .1s; line-height: 1;
}
.emoji-btn:hover { background: var(--bg-raised); }

/* Auth tagline */
.auth-tagline { text-align: center; font-size: .88rem; color: var(--text-muted); margin: 0 0 20px; line-height: 1.6; }
.auth-tagline small { display: block; font-size: .78rem; color: var(--text-disabled); margin-top: 2px; }

/* Grille photos — hauteur uniforme 280px */
.album-photos   { display: grid; gap: 2px; margin: 0 12px; border-radius: var(--radius-sm); overflow: hidden; }
.album-photos img { width: 100%; height: 100%; object-fit: cover; cursor: pointer; display: block; }
.photos-1 { grid-template-columns: 1fr; }
.photos-1 img { height: 280px; }
.photos-2 { grid-template-columns: 1fr 1fr; }
.photos-2 img { height: 280px; }
.photos-3 { grid-template-columns: 1fr 1fr; grid-template-rows: 190px 90px; }
.photos-3 img:first-child { grid-column: 1 / -1; height: 190px; }
.photos-3 img:not(:first-child) { height: 90px; }
.photos-4 { grid-template-columns: 1fr 1fr; grid-template-rows: 140px 140px; }
.photos-4 img { height: 140px; }

/* Vidéo */
.video-wrap       { background: #000; }
.video-wrap video { width: 100%; max-height: 400px; display: block; }

/* ── Likes & commentaires ── */
.post-actions { display: flex; gap: 10px; align-items: center; margin-top: 12px; }

/* Like wrap (❤️ bouton + compteur) */
.like-wrap { display: inline-flex; align-items: center; border: 1px solid var(--border-default); border-radius: var(--radius-full); overflow: hidden; }
.btn-like {
  background: none; border: none; border-right: 1px solid var(--border-default);
  padding: 5px 10px; cursor: pointer; font-size: .88rem; color: var(--text-muted);
  transition: background var(--tr-fast), color var(--tr-fast); font-family: inherit;
  display: inline-flex; align-items: center;
}
.btn-like:hover { background: rgba(224,80,80,.08); }
.btn-like.liked { background: rgba(224,80,80,.10); color: #E05050; }
.btn-like-count {
  background: none; border: none; padding: 5px 10px; cursor: pointer;
  font-size: .82rem; color: var(--text-muted); font-family: inherit;
  min-width: 24px; text-align: center;
  transition: background var(--tr-fast);
}
.btn-like-count:hover { background: var(--bg-raised); }

/* Popover qui a liké */
.likes-popover {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md);
  padding: 10px 14px; min-width: 160px; max-width: 260px; max-height: 220px;
  overflow-y: auto;
}
.likes-popover-title { font-size: .78rem; font-weight: 700; color: var(--text-secondary); margin-bottom: 8px; }
.likes-popover-name  { font-size: .85rem; color: var(--text-primary); padding: 3px 0; border-bottom: 1px solid var(--border-subtle); }
.likes-popover-name:last-child { border-bottom: none; }

.btn-comment {
  display: inline-flex; align-items: center; gap: 5px;
  background: none; border: 1px solid var(--border-default);
  border-radius: var(--radius-full);
  padding: 5px 12px; cursor: pointer; font-size: .88rem; color: var(--text-muted);
  transition: background var(--tr-fast);
  font-family: inherit;
}
.btn-comment:hover { background: rgba(91,155,213,.08); border-color: rgba(91,155,213,.3); }

.comments-section { border-top: 1px solid var(--border-subtle); margin-top: 10px; padding-top: 8px; }
.comment-list     { display: flex; flex-direction: column; gap: 10px; padding: 4px 0 8px; }
.comment-item     { display: flex; flex-direction: column; gap: 3px; font-size: .85rem; }
.comment-header   { display: flex; align-items: center; gap: 6px; }
.comment-author   { font-weight: 600; color: var(--text-secondary); white-space: nowrap; flex-shrink: 0; }
.comment-time     { font-size: .75rem; color: var(--text-muted); flex: 1; }
.comment-text     { color: var(--text-primary); word-break: break-word; padding-left: 2px; }
.comment-actions  { display: flex; align-items: center; gap: 8px; margin-top: 2px; }
.btn-del-comment  { background: none; border: none; cursor: pointer; opacity: .3; color: var(--danger); font-size: .75rem; padding: 0 2px; flex-shrink: 0; }
.btn-del-comment:hover { opacity: 1; }
.no-comments      { font-size: .82rem; color: var(--text-muted); padding: 2px 0; }
.btn-comment-like {
  background: none; border: 1px solid var(--border-subtle); border-radius: var(--radius-full);
  padding: 2px 8px; font-size: .75rem; cursor: pointer; color: var(--text-muted);
  transition: all var(--tr-fast);
}
.btn-comment-like:hover { border-color: rgba(239,60,60,.3); color: var(--danger); }
.btn-comment-like.liked { color: var(--danger); border-color: rgba(239,60,60,.3); }
.btn-reply-toggle {
  background: none; border: none; font-size: .75rem; color: var(--text-muted);
  cursor: pointer; padding: 0; text-decoration: underline;
}
.btn-reply-toggle:hover { color: var(--text-secondary); }
.comment-reply {
  margin-left: 16px; padding-left: 10px;
  border-left: 2px solid var(--border-subtle);
}
.reply-input-wrap { display: flex; gap: 6px; align-items: center; margin-top: 4px; margin-left: 16px; }

.comment-input-wrap { display: flex; gap: 6px; align-items: center; }
.comment-input {
  flex: 1; padding: 8px 12px; border: 1px solid var(--border-default);
  border-radius: var(--radius-full); font-size: .88rem;
  background: var(--bg-overlay); color: var(--text-primary); font-family: inherit;
}
.comment-input:focus { outline: none; border-color: var(--ocre); }
.btn-send-comment {
  background: var(--ocre); color: var(--terre); border: none;
  border-radius: 50%; width: 32px; height: 32px;
  font-size: 1rem; cursor: pointer; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--tr-fast);
}
.btn-send-comment:hover { background: var(--sable); }

/* ── Lightbox ── */
.lightbox {
  position: fixed; inset: 0; z-index: 300;
  display: flex; align-items: center; justify-content: center;
}
.lightbox-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.92); }

.lb-prev, .lb-next {
  position: fixed; top: 50%; transform: translateY(-50%);
  z-index: 10;
  background: rgba(255,255,255,.12);
  border: 2px solid rgba(255,255,255,.50);
  color: #fff; font-size: 2rem; line-height: 1;
  cursor: pointer; width: 52px; height: 52px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--tr-fast);
}
.lb-prev { left: 16px; }
.lb-next { right: 16px; }
.lb-prev:hover, .lb-next:hover { background: rgba(255,255,255,.25); }

.lb-close {
  position: fixed; top: 16px; right: 16px; z-index: 10;
  background: rgba(0,0,0,.6); color: #fff;
  border: 2px solid rgba(255,255,255,.4); border-radius: 50%;
  width: 42px; height: 42px; font-size: 1.1rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background var(--tr-fast);
}
.lb-close:hover { background: rgba(0,0,0,.85); }

.lightbox-img-wrap {
  position: relative; z-index: 5;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  max-width: calc(100vw - 120px);
}
.lightbox-img-wrap img { max-width: 100%; max-height: 82vh; object-fit: contain; border-radius: var(--radius-sm); }
.lb-caption-wrap { display: flex; align-items: center; gap: 8px; justify-content: center; padding: 0 8px; }
.lb-caption { color: rgba(255,255,255,.85); font-size: .9rem; text-align: center; margin: 0; flex: 1; }
.lb-caption-empty { color: rgba(255,255,255,.3); font-style: italic; }
.lb-edit-cap { background: none; border: none; cursor: pointer; font-size: .9rem; opacity: .5; padding: 2px 4px; flex-shrink: 0; }
.lb-edit-cap:hover { opacity: 1; }
.lb-cap-input { background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.3); border-radius: var(--radius-xs); color: #fff; padding: 6px 10px; font-size: .88rem; width: 100%; font-family: inherit; }
.lb-cap-input:focus { outline: none; border-color: rgba(255,255,255,.7); }
.lb-counter { color: rgba(255,255,255,.5); font-size: .82rem; }

/* ── Upload ── */
.upload-container { padding: 20px; }
.upload-container h2 { font-size: 1.2rem; font-weight: 500; margin-bottom: 4px; }

.upload-tabs {
  display: flex; margin: 16px 0;
  border: 1px solid var(--border-default); border-radius: var(--radius-sm); overflow: hidden;
}
.upload-tab {
  flex: 1; background: none; border: none; padding: 10px;
  cursor: pointer; font-size: .9rem; color: var(--text-muted);
  transition: background var(--tr-fast), color var(--tr-fast); font-family: inherit;
}
.upload-tab.active { background: var(--ocre); color: var(--terre); font-weight: 600; }

.drop-zone {
  border: 2px dashed var(--border-default); border-radius: var(--radius-md);
  min-height: 150px; display: flex; align-items: center; justify-content: center;
  cursor: pointer; margin: 16px 0;
  background: var(--bg-raised);
  transition: border-color var(--tr-fast), background var(--tr-fast);
}
.drop-zone:hover, .drop-zone.drag-over { border-color: var(--ocre); background: var(--bg-overlay); }
#drop-hint, #video-drop-hint { text-align: center; padding: 20px; color: var(--text-muted); }

.preview-grid  { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; margin: 12px 0; }
.preview-item  { position: relative; border-radius: var(--radius-sm); overflow: hidden; background: var(--bg-raised); }
.preview-item img { width: 100%; height: 130px; object-fit: cover; display: block; }
.preview-remove { position: absolute; top: 4px; right: 4px; background: rgba(0,0,0,.65); color: #fff; border: none; border-radius: 50%; width: 24px; height: 24px; cursor: pointer; font-size: .8rem; line-height: 24px; text-align: center; padding: 0; }
.preview-caption { width: 100%; padding: 5px 8px; font-size: .78rem; border: none; border-top: 1px solid var(--border-subtle); background: var(--bg-surface); color: var(--text-primary); font-family: inherit; }
.preview-add   { height: 130px; border: 2px dashed var(--border-default); border-radius: var(--radius-sm); display: flex; flex-direction: column; align-items: center; justify-content: center; cursor: pointer; color: var(--text-muted); font-size: 1.5rem; gap: 4px; transition: border-color var(--tr-fast), color var(--tr-fast); }
.preview-add:hover { border-color: var(--ocre); color: var(--ocre); }

#progress-bar-bg, #video-progress-bar-bg { height: 6px; background: var(--bg-raised); border-radius: var(--radius-full); margin: 12px 0 4px; overflow: hidden; border: 1px solid var(--border-subtle); }
#progress-bar, #video-progress-bar { height: 100%; background: var(--ocre); width: 0; transition: width .2s; border-radius: var(--radius-full); }
#progress-txt, #video-progress-txt { font-size: .82rem; color: var(--text-muted); }

/* ── Profil ── */
.profile-container { padding: 20px; display: flex; flex-direction: column; }
.profile-container h2 { font-size: 1.2rem; font-weight: 500; margin-bottom: 12px; }

.profile-avatar-section { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 28px 18px 20px; }
.profile-avatar-wrap    { margin-bottom: 12px; cursor: pointer; }
.profile-avatar {
  width: 96px; height: 96px; border-radius: 50%;
  object-fit: cover; border: 3px solid var(--border-strong);
  transition: opacity var(--tr-fast);
}
.profile-avatar:hover   { opacity: .85; }
.profile-avatar-placeholder {
  width: 96px; height: 96px; border-radius: 50%;
  background: var(--bg-raised); border: 3px solid var(--border-default);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.5rem; cursor: pointer;
  transition: background var(--tr-fast);
}
.profile-avatar-placeholder:hover { background: var(--bg-overlay); }
.profile-name { font-size: 1.1rem; font-weight: 600; margin-top: 8px; color: var(--text-primary); }

.event-membership-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--border-subtle); gap: 10px; }
.event-membership-row:last-child { border-bottom: none; }
.event-membership-row .ev-name { font-weight: 500; font-size: .95rem; }

/* Crop modal */
.crop-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.85);
  z-index: 400; display: flex; align-items: center; justify-content: center; padding: 20px;
}
.crop-modal {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-xl); padding: 24px; width: 100%; max-width: 360px;
  box-shadow: var(--shadow-lg);
}
.crop-modal h3 { text-align: center; font-weight: 500; margin-bottom: 16px; font-size: 1rem; color: var(--text-secondary); }
.crop-viewport {
  width: 220px; height: 220px; margin: 0 auto;
  border-radius: 50%; overflow: hidden; position: relative;
  background: var(--bg-raised); cursor: grab;
  border: 3px solid var(--border-strong);
}
.crop-viewport:active { cursor: grabbing; }
.crop-viewport img {
  position: absolute; top: 0; left: 0;
  width: 100%; height: auto;
  transform-origin: center;
  user-select: none; -webkit-user-drag: none;
  max-width: none;
}
.crop-controls { margin: 14px 0 6px; }
.crop-controls label { text-align: center; font-size: .8rem; margin-bottom: 6px; }
.crop-controls input[type="range"] { width: 100%; accent-color: var(--ocre); }
.crop-actions { display: flex; gap: 10px; margin-top: 16px; }
.crop-actions button { flex: 1; }

/* ── Admin ── */
.card { background: var(--bg-surface); border: 1px solid var(--border-default); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: 18px; margin: 10px 12px; }

.admin-header { display: flex; justify-content: space-between; align-items: center; padding: 16px; }
.admin-header h2 { font-size: 1.1rem; font-weight: 500; }
.admin-event-header { padding: 12px 16px; }

.event-card  { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.event-info h3 { font-size: 1rem; font-weight: 500; color: var(--text-primary); }
.event-info p  { font-size: .88rem; color: var(--text-muted); margin: 4px 0; }
.event-stats { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; font-size: .8rem; }
.event-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: flex-start; }

.join-code   {
  background: rgba(239,159,39,.12); color: var(--ocre);
  padding: 3px 10px; border-radius: var(--radius-full);
  font-family: monospace; font-weight: 700; font-size: .85rem;
  border: 1px solid rgba(239,159,39,.25);
  cursor: pointer; user-select: none;
  transition: background var(--tr-fast);
}
.join-code:hover { background: rgba(239,159,39,.22); }

.badge-pending { background: rgba(239,159,39,.12); color: var(--sable); padding: 3px 10px; border-radius: var(--radius-full); font-size: .78rem; border: 1px solid rgba(239,159,39,.2); }
.status-active   { color: var(--success); font-weight: 600; font-size: .82rem; }
.status-inactive { color: var(--text-muted); font-size: .82rem; }

.event-form  { margin: 0 12px 12px; }
.event-form h3 { margin-bottom: 8px; font-size: 1rem; font-weight: 500; }

.participant-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border-subtle); flex-wrap: wrap; }
.participant-row:last-child { border-bottom: none; }
.part-info   { display: flex; flex-direction: column; gap: 3px; }
.part-info strong { font-size: .95rem; color: var(--text-primary); }
.part-email  { font-size: .8rem; color: var(--text-muted); }
.student-tag { font-size: .8rem; color: var(--ocre); }
.part-role.contributor { font-size: .78rem; color: var(--success); }
.part-role.viewer      { font-size: .78rem; color: var(--text-muted); }
.part-actions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }

.join-link-box { display: flex; gap: 8px; align-items: center; margin: 10px 0; flex-wrap: wrap; }
.join-link-box code { background: var(--bg-raised); padding: 7px 12px; border-radius: var(--radius-sm); font-size: .82rem; word-break: break-all; flex: 1; color: var(--text-secondary); border: 1px solid var(--border-subtle); }

/* Toggles admin */
.event-toggles { margin-top: 14px; display: flex; flex-direction: column; gap: 12px; }
.toggle-row    { display: flex; align-items: center; justify-content: space-between; }
.toggle-label  { font-size: .9rem; color: var(--text-primary); font-weight: 400; }

/* Toggle switch */
.toggle-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0; cursor: pointer;
  background: var(--bg-overlay); border: 1px solid var(--border-default);
  border-radius: var(--radius-full); transition: background var(--tr-normal);
}
.toggle-slider::before {
  content: ''; position: absolute;
  width: 18px; height: 18px; left: 2px; top: 2px;
  background: var(--text-muted); border-radius: 50%;
  transition: transform var(--tr-normal), background var(--tr-normal);
}
.toggle-switch input:checked + .toggle-slider { background: var(--ocre); border-color: var(--ocre); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); background: var(--terre); }

/* Commentaires admin */
.comment-manager-item {
  padding: 10px 0; border-bottom: 1px solid var(--border-subtle);
  display: flex; flex-direction: column; gap: 4px;
}
.comment-manager-item:last-child { border-bottom: none; }
.comment-manager-meta { font-size: .75rem; color: var(--text-muted); display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.comment-manager-content { font-size: .9rem; color: var(--text-primary); }
.comment-post-tag { background: var(--bg-raised); color: var(--text-secondary); padding: 2px 8px; border-radius: var(--radius-full); font-size: .72rem; border: 1px solid var(--border-subtle); }

/* ── Help ── */
.help-container { max-width: 680px; margin: 0 auto; }
.help-tabs {
  display: flex; gap: 0; border-bottom: 2px solid var(--border-subtle);
  padding: 16px 16px 0; overflow-x: auto; scrollbar-width: none;
}
.help-tabs::-webkit-scrollbar { display: none; }
.help-tab {
  flex-shrink: 0; padding: 10px 18px; background: none; border: none;
  font-size: .88rem; font-weight: 500; color: var(--text-muted);
  cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px;
  transition: all var(--tr-fast); font-family: inherit; white-space: nowrap;
}
.help-tab:hover { color: var(--text-secondary); }
.help-tab.active { color: var(--ocre); border-bottom-color: var(--ocre); font-weight: 600; }
.help-content { padding: 20px 16px 40px; }
.help-section { margin-bottom: 28px; }
.help-section h3 { font-size: .95rem; font-weight: 600; color: var(--ocre); margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border-subtle); }
.help-section p, .help-section li { font-size: .88rem; color: var(--text-secondary); line-height: 1.75; }
.help-section ul, .help-section ol { padding-left: 20px; display: flex; flex-direction: column; gap: 5px; }
.help-tip { background: rgba(239,159,39,.08); border: 1px solid rgba(239,159,39,.2); border-radius: var(--radius-sm); padding: 10px 14px; margin-top: 10px; font-size: .84rem; color: var(--text-secondary); }
.help-icon-inline { font-style: normal; }
kbd { background: var(--bg-raised); border: 1px solid var(--border-default); border-radius: 4px; padding: 1px 6px; font-size: .8rem; font-family: monospace; }

/* ── Stats ── */
.stats-container { max-width: 920px; margin: 0 auto; padding: 20px 16px 40px; }
.stats-header { margin-bottom: 20px; }
.stats-header h2 { font-size: 1.3rem; font-weight: 600; color: var(--text-primary); margin: 0; }

.stat-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 16px; }
@media (max-width: 700px) { .stat-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 380px) { .stat-cards { grid-template-columns: 1fr; } }

.stat-card {
  background: var(--bg-surface); border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle); padding: 18px 16px;
  box-shadow: var(--shadow-sm); display: flex; flex-direction: column; gap: 5px;
}
.stat-num   { font-size: 2.2rem; font-weight: 700; color: var(--ocre); line-height: 1; }
.stat-label { font-size: .82rem; font-weight: 600; color: var(--text-secondary); margin-top: 2px; }
.stat-sub   { font-size: .75rem; color: var(--text-muted); }

.stat-card-storage { justify-content: center; gap: 8px; }
.storage-bar-wrap  { width: 100%; height: 8px; background: var(--bg-overlay); border-radius: var(--radius-full); overflow: hidden; }
.storage-bar-fill  { height: 100%; background: var(--ocre); border-radius: var(--radius-full); transition: width .5s ease; }
.storage-bar-fill.danger { background: var(--danger); }
.storage-label     { font-size: .78rem; color: var(--text-muted); }
.storage-unlimited { font-size: 1.1rem; color: var(--success); font-weight: 600; }

.charts-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 16px; }
@media (max-width: 600px) { .charts-row { grid-template-columns: 1fr; } }
.chart-card {
  background: var(--bg-surface); border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle); padding: 18px 16px;
  box-shadow: var(--shadow-sm);
}
.chart-wrap { position: relative; height: 200px; }
.chart-card h3 { font-size: .88rem; font-weight: 600; color: var(--text-secondary); margin: 0 0 16px; }

.stats-table-wrap {
  background: var(--bg-surface); border-radius: var(--radius-md);
  border: 1px solid var(--border-subtle); padding: 18px 16px;
  box-shadow: var(--shadow-sm);
}
.stats-table-wrap h3 { font-size: .88rem; font-weight: 600; color: var(--text-secondary); margin: 0 0 14px; }
.stats-table-scroll  { overflow-x: auto; }
.stats-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.stats-table th { text-align: left; padding: 8px 12px; color: var(--text-muted); font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .05em; border-bottom: 1px solid var(--border-default); }
.stats-table td { padding: 11px 12px; color: var(--text-primary); border-bottom: 1px solid var(--border-subtle); }
.stats-table tr:last-child td { border-bottom: none; }
.stats-table tbody tr:hover td { background: var(--bg-raised); }
.event-status-badge { display: inline-block; padding: 2px 9px; border-radius: var(--radius-full); font-size: .72rem; font-weight: 600; }
.event-status-badge.active   { background: rgba(76,175,120,.15); color: var(--success); }
.event-status-badge.inactive { background: var(--bg-overlay); color: var(--text-muted); }

/* ── Feed filter ── */
.feed-filter { display: flex; gap: 8px; padding: 12px 16px 6px; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.feed-filter::-webkit-scrollbar { display: none; }
.filter-btn {
  flex-shrink: 0; padding: 6px 16px; border-radius: var(--radius-full);
  border: 1px solid var(--border-default); background: var(--bg-surface);
  color: var(--text-secondary); font-size: .82rem; cursor: pointer;
  transition: all var(--tr-fast); white-space: nowrap; font-family: inherit;
}
.filter-btn:hover:not(.active) { border-color: var(--ocre); color: var(--ocre); }
.filter-btn.active { background: var(--ocre); color: var(--terre); border-color: var(--ocre); font-weight: 600; }
.filter-more-wrap { position: relative; flex-shrink: 0; }
.filter-more-dropdown {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 50;
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md);
  min-width: 180px; padding: 4px;
  display: flex; flex-direction: column; gap: 2px;
}
.filter-more-item {
  text-align: left; background: none; border: none; padding: 9px 12px;
  border-radius: var(--radius-sm); font-size: .85rem; color: var(--text-primary);
  cursor: pointer; font-family: inherit; transition: background var(--tr-fast);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.filter-more-item:hover { background: var(--bg-raised); }

/* ── Empty state admin ── */
.empty-state-admin {
  display: flex; flex-direction: column; align-items: center;
  padding: 48px 24px; text-align: center; gap: 12px;
}
.empty-state-icon { font-size: 3rem; line-height: 1; }
.empty-state-admin h3 { font-size: 1.15rem; font-weight: 600; color: var(--text-primary); margin: 0; }
.empty-state-admin p { color: var(--text-muted); font-size: .9rem; margin: 0; line-height: 1.6; }
.empty-state-admin .btn-primary { margin-top: 8px; }
.empty-state-join-btn { margin-top: 0; font-size: .82rem; opacity: .75; }

/* ── Super-admin ── */
.superadmin-wrap { max-width: 860px; margin: 0 auto; padding: 24px 16px; }
.superadmin-header { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; margin-bottom: 20px; }
.superadmin-header h2 { margin: 0; font-size: 1.3rem; font-weight: 700; color: var(--text-primary); }
.superadmin-summary { display: flex; gap: 8px; flex-wrap: wrap; }
.superadmin-summary span { font-size: .82rem; color: var(--text-muted); padding: 3px 10px; background: var(--bg-raised); border-radius: var(--radius-full); }

.sa-cards { display: flex; flex-direction: column; gap: 14px; }

.sa-card {
  background: var(--bg-surface); border: 1px solid var(--border-default);
  border-radius: var(--radius-md); padding: 20px;
  display: flex; flex-direction: column; gap: 16px;
}
.sa-card-self { border-color: rgba(239,159,39,.4); background: rgba(239,159,39,.03); }

.sa-card-top { display: flex; align-items: flex-start; gap: 16px; flex-wrap: wrap; justify-content: space-between; }
.sa-card-identity { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.sa-card-name  { font-size: 1rem; font-weight: 700; color: var(--text-primary); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.sa-card-email { font-size: .85rem; color: var(--text-muted); }
.sa-card-meta  { font-size: .78rem; color: var(--text-disabled); margin-top: 2px; }
.sa-card-actions { display: flex; flex-direction: column; gap: 8px; flex-shrink: 0; min-width: 160px; }

.sa-card-bottom { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width: 540px) { .sa-card-bottom { grid-template-columns: 1fr; } }

.sa-card-storage { display: flex; flex-direction: column; gap: 6px; }
.sa-card-storage-label { display: flex; justify-content: space-between; align-items: baseline; font-size: .82rem; color: var(--text-muted); }
.sa-card-storage-label strong { color: var(--text-primary); font-size: .85rem; }
.sa-storage-bar-bg { height: 6px; background: var(--bg-overlay); border-radius: 999px; }
.sa-storage-bar-fill { height: 100%; border-radius: 999px; transition: width var(--tr-normal); }
.sa-storage-pct { font-size: .72rem; color: var(--text-muted); text-align: right; }
.sa-storage-header { display: flex; justify-content: space-between; align-items: baseline; font-size: .82rem; color: var(--text-muted); margin-bottom: 6px; }
.sa-storage-header strong { font-size: .88rem; color: var(--text-primary); }
.sa-unlimited { font-size: .75rem; color: var(--success); font-weight: 600; margin-left: 4px; }
.sa-quota-of  { font-size: .78rem; color: var(--text-muted); font-weight: 400; }

.sa-card-quota { display: flex; flex-direction: column; gap: 6px; }
.sa-quota-label { font-size: .78rem; color: var(--text-muted); }
.sa-quota-row { display: flex; align-items: center; gap: 8px; }
.sa-quota-input {
  flex: 1; min-width: 0; max-width: 100px;
  padding: 7px 10px; border-radius: var(--radius-xs);
  border: 1px solid var(--border-default); background: var(--bg-base);
  color: var(--text-primary); font-size: .9rem; font-family: inherit;
}
.sa-quota-input:focus { outline: none; border-color: var(--ocre); }
.sa-quota-unit { font-size: .82rem; color: var(--text-muted); flex-shrink: 0; }

.sa-badge { display: inline-block; padding: 2px 8px; border-radius: var(--radius-full); font-size: .68rem; font-weight: 700; background: var(--ocre); color: var(--terre); }

/* Boutons super-admin — même taille garantie */
.btn-sa {
  display: block; width: 100%; padding: 8px 12px;
  border-radius: var(--radius-xs); border: none; cursor: pointer;
  font-size: .82rem; font-family: inherit; font-weight: 600;
  text-align: center; transition: opacity var(--tr-fast); white-space: nowrap;
}
.btn-sa:hover { opacity: .82; }
.btn-sa-primary   { background: var(--ocre); color: var(--terre); }
.btn-sa-secondary { background: var(--bg-overlay); color: var(--text-secondary); }
.btn-sa-danger    { background: rgba(224,80,80,.12); color: var(--danger); }
.btn-sa-placeholder { height: 34px; } /* maintient l'alignement pour la ligne "vous" */

/* Barre de recherche */
.sa-search-wrap { margin-bottom: 16px; }
.sa-search {
  width: 100%; padding: 10px 16px; border-radius: var(--radius-md);
  border: 1px solid var(--border-default); background: var(--bg-surface);
  color: var(--text-primary); font-size: .9rem; font-family: inherit;
  box-sizing: border-box;
}
.sa-search:focus { outline: none; border-color: var(--ocre); box-shadow: 0 0 0 3px rgba(239,159,39,.15); }

/* Anciens btn-sm conservés pour d'autres vues */
.btn-sm { padding: 6px 12px; border-radius: var(--radius-xs); border: none; cursor: pointer; font-size: .8rem; font-family: inherit; font-weight: 600; transition: opacity var(--tr-fast); white-space: nowrap; }
.btn-sm:hover { opacity: .82; }
.btn-sm.btn-primary   { background: var(--ocre); color: var(--terre); }
.btn-sm.btn-secondary { background: var(--bg-overlay); color: var(--text-secondary); }
.btn-sm.btn-danger    { background: rgba(224,80,80,.12); color: var(--danger); }

/* ── Crop modal upload ── */
.crop-modal-upload {
  background: var(--bg-surface); border-radius: var(--radius-lg);
  width: calc(100% - 32px); max-width: 400px; margin: auto;
  overflow: hidden; padding: 20px 20px 24px; display: flex; flex-direction: column; gap: 14px;
}
.crop-modal-header { display: flex; justify-content: space-between; align-items: center; }
.crop-modal-header h3 { margin: 0; font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.crop-counter { font-size: .85rem; color: var(--text-muted); background: var(--bg-raised); padding: 2px 10px; border-radius: var(--radius-full); }
.crop-vp-upload {
  width: 100%; aspect-ratio: 4 / 5; overflow: hidden; position: relative;
  background: #111; border-radius: var(--radius-md);
  cursor: grab; touch-action: none; user-select: none;
}
.crop-vp-upload:active { cursor: grabbing; }
.crop-vp-upload img { position: absolute; max-width: none; pointer-events: all; }
.crop-controls { display: flex; align-items: center; gap: 10px; }
.crop-controls input[type=range] { flex: 1; accent-color: var(--ocre); }
.crop-tip { font-size: .78rem; color: var(--text-muted); text-align: center; margin: -6px 0; }

/* ── Bannière nouvelles publications ── */
.new-items-banner { position: sticky; top: 0; z-index: 40; padding: 6px 12px; }
.new-items-btn {
  display: block; width: 100%; padding: 10px 16px;
  background: var(--ocre); color: var(--terre); border: none;
  border-radius: var(--radius-md); font-size: .88rem; font-weight: 700;
  cursor: pointer; font-family: inherit; box-shadow: var(--shadow-sm);
  animation: slideDown .25s ease;
}
@keyframes slideDown { from { transform: translateY(-100%); opacity: 0; } to { transform: none; opacity: 1; } }

/* ── Utilitaires ── */
.center { text-align: center; }
