/* ============================================================
   CELESTIAL SCAN — Feuille de style principale
   Design : éditorial / magazine manga — Archivo Black + Inter
   Palette : violet électrique (logo) + fuchsia + lavande
   ============================================================ */

/* ── Variables ────────────────────────────────────────────── */
:root {
  /* Backgrounds — nuit violette profonde (cosmos / sparkle) */
  --bg-primary:    #0d0520;
  --bg-secondary:  #130828;
  --bg-tertiary:   #1d0f3d;
  --bg-card:       #160a30;
  --bg-card-hover: #231246;

  /* Accent principal : violet électrique — direct match du logo ✦ */
  --accent:         #a020f0;
  --accent-hover:   #b84cff;
  --accent-deep:    #4a0e7a;          /* violet profond pour ombres dures */
  --accent-glow:    rgba(160,32,240,.35);
  --accent-soft:    rgba(160,32,240,.12);

  /* Accent secondaire : fuchsia / rose-violet (rehauts, pops éditoriaux) */
  --accent-alt:      #d946ef;
  --accent-alt-soft: rgba(217,70,239,.14);

  /* Lavande / mauve — touche violette douce (transitions, texte) */
  --lavender:       #c4a7ff;
  --lavender-soft:  rgba(196,167,255,.14);

  /* Indigo — pour les zones profondes */
  --indigo:         #6d28d9;

  /* Gold (étoiles notation) — doré chaud */
  --gold:          #ffc857;
  --gold-dim:      rgba(255,200,87,.15);

  /* Statuts */
  --danger:        #ff4d63;
  --success:       #36d6a2;
  --warning:       #ffc857;
  --discord:       #5865f2;

  /* Texte — reflet violet/lavande pour cohérence */
  --text-primary:   #f2ecff;
  --text-secondary: #b5aad1;
  --text-muted:     #7a6d9a;
  --text-accent:    #c4a7ff;          /* lavande pour accents texte doux */

  /* Bordures */
  --border:        rgba(255,255,255,.06);
  --border-hover:  rgba(160,32,240,.32);

  /* Coins plus nets pour un feel print/éditorial */
  --radius-sm: 3px;
  --radius-md: 6px;
  --radius-lg: 10px;
  --radius-xl: 18px;

  /* Shadows — plus contrastées (brutalist/print) */
  --shadow-card: 0 6px 28px rgba(0,0,0,.6);
  --shadow-glow: 0 0 0 1px var(--accent), 0 0 24px var(--accent-glow);
  --shadow-hard: 4px 4px 0 0 var(--accent-deep);

  --header-h: 64px;
  --container: 1280px;

  /* Typographie : Archivo Black (display) + Inter (body) */
  --font-display: 'Archivo Black', 'Impact', sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;
}

/* ── Reset & base ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  max-width: 100%;
}
body {
  overflow-x: hidden;
  font-family: var(--font-body);
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: 1.6;
  font-size: 15px;
  font-feature-settings: "ss01", "cv11";
  min-height: 100vh;
  /* Effet de fond discret — grain / vignettage */
  background-image:
    radial-gradient(1200px circle at 80% -10%, rgba(160,32,240,.14), transparent 60%),
    radial-gradient(900px circle at 0% 100%, rgba(217,70,239,.08), transparent 55%),
    radial-gradient(700px circle at 50% 50%, rgba(196,167,255,.05), transparent 70%);
  background-attachment: fixed;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; }

/* Sélection personnalisée pour accent éditorial */
::selection { background: var(--accent); color: #fff; }

/* ── Container ────────────────────────────────────────────── */
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}
.section { padding: 48px 0; }

/* ── Typography ───────────────────────────────────────────── */
.page-title {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 4.5vw, 2.6rem);
  font-weight: 400; /* Archivo Black n'a qu'un poids */
  letter-spacing: -.02em;
  line-height: 1.05;
  color: var(--text-primary);
  text-transform: uppercase;
}
.page-title::after {
  content: '';
  display: block;
  width: 56px;
  height: 4px;
  background: var(--accent);
  margin-top: 14px;
}
.page-subtitle { color: var(--text-secondary); margin-top: 12px; font-size: .95rem; font-weight: 500; }
.page-header { margin-bottom: 36px; }
.text-muted  { color: var(--text-muted); }
.text-sm     { font-size: .85rem; }
.text-accent { color: var(--text-accent); }
.text-center { text-align: center; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-4 { margin-top: 32px; }

/* Eyebrow — petit texte en haut des sections (style magazine) */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent);
}
.eyebrow::before {
  content: '';
  width: 24px;
  height: 2px;
  background: var(--accent);
}

/* ── Buttons ──────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 22px;
  border-radius: var(--radius-md);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: 1.5px solid transparent;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  white-space: nowrap;
  cursor: pointer;
  position: relative;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  box-shadow: 3px 3px 0 0 rgba(13,5,32,.9);
}
.btn-primary:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 0 var(--accent-deep);
}
.btn-primary:active { transform: translate(0,0); box-shadow: 2px 2px 0 0 var(--accent-deep); }

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
  border-color: rgba(255,255,255,.15);
}
.btn-ghost:hover { background: var(--bg-tertiary); color: var(--text-primary); border-color: var(--accent); }

.btn-danger { background: var(--danger); color: #fff; border-color: var(--danger); }
.btn-danger:hover { opacity: .9; transform: translateY(-1px); }
.btn-success { background: var(--success); color: #0d1a12; border-color: var(--success); }
.btn-discord { background: var(--discord); color: #fff; border-color: var(--discord); }
.btn-discord:hover { opacity: .9; }
.btn-liked, .btn-favorited { color: var(--gold); border-color: var(--gold); background: var(--gold-dim); }
.btn-lg { padding: 14px 30px; font-size: .85rem; }
.btn-sm { padding: 6px 14px; font-size: .7rem; }
.btn-xs { padding: 3px 10px; font-size: .65rem; border-radius: var(--radius-sm); letter-spacing: .05em; }
.btn-block { width: 100%; justify-content: center; }
.btn-icon { padding: 9px; letter-spacing: 0; }
.btn-group { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none; box-shadow: none; }

/* ── Header ───────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--header-h);
  background: rgba(13,5,32,.85);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border-bottom: 1px solid var(--border);
}
.site-header::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent) 40%, var(--accent-alt) 60%, transparent);
  opacity: .35;
}
.header-inner {
  height: 100%;
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 100%;
  overflow: visible;
}
.header-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 1.1rem;
  letter-spacing: .01em;
  text-transform: uppercase;
  color: var(--text-primary);
  white-space: nowrap;
  flex-shrink: 0;
}
.logo-star {
  color: var(--accent);
  font-size: 1rem;
  display: inline-flex;
  transform: rotate(-8deg);
  filter: drop-shadow(0 0 6px var(--accent-glow));
}
.logo-accent { color: var(--accent); }
.header-nav {
  display: flex;
  align-items: center;
  gap: 2px;
}
.nav-link {
  padding: 7px 14px;
  border-radius: var(--radius-sm);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  transition: color .2s;
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  left: 14px; right: 14px;
  bottom: 2px;
  height: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s ease;
}
.nav-link:hover { color: var(--text-primary); }
.nav-link:hover::after {
  transform: scaleX(1);
}
.nav-link.active {
  color: var(--accent);
}
.nav-link.active::after {
  transform: scaleX(1);
}

/* Search */
.header-search { flex: 1; max-width: 340px; position: relative; }
.search-form { display: flex; align-items: center; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-md); overflow: hidden; transition: border-color .15s; }
.search-form:focus-within { border-color: var(--accent); }
.search-input { flex: 1; background: none; border: none; outline: none; padding: 8px 12px; font-size: .875rem; color: var(--text-primary); }
.search-input::placeholder { color: var(--text-muted); }
.search-btn { background: none; border: none; padding: 8px 12px; color: var(--text-secondary); display: flex; }
.search-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  z-index: 200;
}
.search-result-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  transition: background .12s;
}
.search-result-item:hover { background: var(--bg-tertiary); }
.search-result-cover { width: 36px; height: 50px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.search-result-title { font-size: .875rem; font-weight: 600; }
.search-result-meta { font-size: .75rem; color: var(--text-muted); }

/* User menu */
.header-user { display: flex; align-items: center; gap: 6px; margin-left: auto; flex-shrink: 0; min-width: 0; }
.header-icon-btn {
  position: relative;
  background: none;
  border: none;
  color: var(--text-secondary);
  padding: 8px;
  border-radius: var(--radius-sm);
  display: flex;
  transition: color .15s, background .15s;
}
.header-icon-btn:hover { color: var(--text-primary); background: var(--bg-tertiary); }
.badge {
  position: absolute;
  top: 2px; right: 2px;
  background: var(--danger);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
}
.badge[hidden] { display: none !important; }
.user-menu-wrap { position: relative; }
.user-avatar-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 5px 12px 5px 6px;
  color: var(--text-primary);
  font-size: .875rem;
  font-weight: 600;
  transition: border-color .15s;
}
.user-avatar-btn:hover { border-color: var(--accent); }
.user-avatar { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; }
.user-avatar-placeholder {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  font-weight: 700;
  flex-shrink: 0;
}
.user-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 210px;
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: 6px;
  z-index: 200;
}
.dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: var(--radius-sm);
  font-size: .875rem;
  color: var(--text-secondary);
  transition: all .12s;
}
.dropdown-item:hover { background: var(--bg-tertiary); color: var(--text-primary); }
.dropdown-item--accent { color: var(--accent); }
.dropdown-item--accent:hover { background: var(--accent-glow); color: var(--accent); }
.dropdown-item--admin { color: var(--gold); }
.dropdown-item--admin:hover { background: var(--gold-dim); }
.dropdown-item--danger:hover { background: rgba(232,93,74,.12); color: var(--danger); }
.dropdown-separator { height: 1px; background: var(--border); margin: 4px 0; }

/* Burger mobile */
.burger-btn { display: none; flex-direction: column; gap: 5px; background: none; border: none; padding: 8px; }
.burger-btn span { display: block; width: 22px; height: 2px; background: var(--text-secondary); border-radius: 2px; transition: all .2s; }

/* ── Footer ───────────────────────────────────────────────── */
.site-footer {
  background: var(--bg-secondary);
  border-top: 3px solid var(--accent);
  padding: 60px 0 24px;
  margin-top: 80px;
  position: relative;
}
.site-footer::before {
  content: '';
  position: absolute;
  top: -3px; left: 0;
  height: 3px;
  width: 33%;
  background: var(--accent-alt);
}
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.5fr; gap: 40px; margin-bottom: 40px; }
.footer-logo {
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: .01em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.footer-tagline {
  color: var(--text-muted);
  font-size: .875rem;
  margin: 14px 0 20px;
  line-height: 1.6;
  max-width: 260px;
}
.discord-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  background: var(--discord);
  color: #fff;
  border-radius: var(--radius-sm);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: opacity .15s, transform .15s;
}
.discord-btn:hover { opacity: .92; transform: translateY(-1px); }
.footer-heading {
  font-family: var(--font-body);
  font-size: .7rem;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
  display: inline-block;
  padding-bottom: 6px;
  border-bottom: 2px solid var(--accent);
}
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-links a {
  font-size: .85rem;
  color: var(--text-muted);
  transition: color .15s, padding-left .15s;
  font-weight: 500;
}
.footer-links a:hover { color: var(--accent); padding-left: 6px; }
.footer-disclaimer { font-size: .72rem; color: var(--text-muted); margin-top: 18px; line-height: 1.6; opacity: .75; }
.footer-bottom {
  border-top: 1px solid var(--border);
  padding-top: 20px;
  text-align: center;
  font-size: .72rem;
  color: var(--text-muted);
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* ── Carousel ─────────────────────────────────────────────── */
.carousel-section {
  position: relative;
  height: 580px;
  overflow: hidden;
  border-bottom: 3px solid var(--accent);
}
.carousel { width: 100%; height: 100%; position: relative; }
.carousel-track { width: 100%; height: 100%; }
.carousel-slide { position: absolute; inset: 0; opacity: 0; transition: opacity .6s ease; pointer-events: none; }
.carousel-slide.active { opacity: 1; pointer-events: auto; }
.carousel-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.04); transition: transform 6s ease; filter: saturate(1.05); }
.carousel-slide.active .carousel-bg { transform: scale(1); }
.carousel-slide.active:hover .carousel-bg { transform: scale(1.06); transition: transform 4s ease; }
/* Overlay : gradient sombre avec touche fuchsia */
.carousel-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(to right, rgba(13,5,32,.92) 30%, rgba(13,5,32,.3) 70%, transparent 90%),
    linear-gradient(to top, rgba(13,5,32,.55) 0%, transparent 45%);
}
/* Effet halftone / grain discret */
.carousel-overlay::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.04) 1px, transparent 0);
  background-size: 3px 3px;
  pointer-events: none;
  mix-blend-mode: overlay;
}
/* Foreground (perso détouré) */
.carousel-foreground {
  position: absolute; inset: 0; z-index: 1;
  display: flex; align-items: flex-end; justify-content: flex-end;
  pointer-events: none;
  padding-right: 5%;
}
.carousel-foreground-img {
  height: 95%; max-height: 560px; width: auto; object-fit: contain;
  filter: drop-shadow(0 4px 24px rgba(0,0,0,.5)) drop-shadow(-4px 0 0 var(--accent-deep));
  transition: transform .5s cubic-bezier(.25,.46,.45,.94);
  transform: translateX(0);
}
.carousel-slide.active:hover .carousel-foreground-img {
  transform: translateX(-20px);
}
.carousel-slide.has-foreground .carousel-overlay {
  background:
    linear-gradient(to right, rgba(13,5,32,.95) 30%, rgba(13,5,32,.35) 58%, transparent 85%),
    linear-gradient(to top, rgba(13,5,32,.5) 0%, transparent 40%);
}
.carousel-content { position: relative; z-index: 2; height: 100%; display: flex; align-items: center; }
.carousel-text { max-width: 560px; position: relative; padding-left: 18px; }
.carousel-text::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 4px;
  height: calc(100% - 16px);
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent-glow);
}
.carousel-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-body);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  padding: 5px 12px 5px 10px;
  margin-bottom: 16px;
  clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
  padding-right: 20px;
}
.carousel-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5.5vw, 3.4rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: 16px;
  text-transform: uppercase;
  text-shadow: 0 2px 12px rgba(0,0,0,.7);
  color: var(--text-primary);
}
.carousel-subtitle {
  color: var(--text-secondary);
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.55;
  margin-bottom: 28px;
  text-shadow: 0 1px 6px rgba(0,0,0,.6);
  max-width: 480px;
}
.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(13,5,32,.85);
  border: 1.5px solid rgba(255,255,255,.2);
  color: var(--text-primary);
  width: 44px; height: 44px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
  z-index: 10;
  backdrop-filter: blur(8px);
}
.carousel-btn:hover {
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-50%) scale(1.08);
}
.carousel-btn--prev { left: 20px; }
.carousel-btn--next { right: 20px; }
.carousel-dots { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 10; padding: 6px 10px; background: rgba(13,5,32,.5); border-radius: 20px; backdrop-filter: blur(8px); }
.carousel-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  border: none;
  cursor: pointer;
  transition: all .25s;
}
.carousel-dot.active {
  width: 28px;
  border-radius: 4px;
  background: var(--accent);
  box-shadow: 0 0 10px var(--accent-glow);
}

/* ── Section headers ──────────────────────────────────────── */
.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
  position: relative;
}
.section-header::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 72px;
  height: 3px;
  background: var(--accent);
}
.section-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: -.01em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1.1;
}
.section-icon { font-size: 1.05rem; }
.section-more {
  font-size: .72rem;
  color: var(--text-secondary);
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  transition: color .15s, letter-spacing .15s;
}
.section-more:hover { color: var(--accent); letter-spacing: .2em; }

/* Numéro de section — style magazine */
.section-num {
  display: block;
  font-family: var(--font-mono);
  font-size: .7rem;
  font-weight: 500;
  letter-spacing: .15em;
  color: var(--accent-alt);
  margin-bottom: 4px;
  text-transform: uppercase;
}

/* ── Project grid & cards ─────────────────────────────────── */
.project-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 20px; }
.project-grid--lg { grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); }

/* Catalogue layout : grille + panel latéral */
.catalogue-layout { display: flex; gap: 28px; align-items: flex-start; }
.catalogue-layout .project-grid { flex: 1; min-width: 0; }

/* ── New project card (pcard) ───────────────────────────── */
.pcard {
  position: relative;
  border-radius: var(--radius-sm);
  overflow: visible;
  z-index: 1;
  cursor: pointer;
}
.pcard:hover { z-index: 20; }
.pcard__cover {
  position: relative;
  aspect-ratio: 2/3;
  overflow: hidden;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
}
.pcard__cover-link {
  display: block;
  width: 100%; height: 100%;
  text-decoration: none;
  color: inherit;
}
.pcard__cover img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease, filter .4s ease;
}
.pcard:hover .pcard__cover img {
  transform: scale(1.06);
  filter: brightness(.55);
}

/* Overlay permanent : titre en bas */
.pcard__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 14px;
  background: linear-gradient(to top, rgba(13,5,32,.78) 0%, transparent 50%);
  pointer-events: none;
  transition: opacity .3s ease;
}
.pcard:hover .pcard__overlay { opacity: 0; }

.pcard__title {
  font-family: var(--font-body);
  font-size: .88rem;
  font-weight: 800;
  line-height: 1.25;
  color: #fff;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Hover reveal panel (glisse du bas, dans la cover) */
.pcard__reveal {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 14px;
  background: linear-gradient(to top, rgba(13,5,32,.92) 0%, rgba(13,5,32,.5) 60%, transparent 100%);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .3s ease, transform .3s ease;
  pointer-events: none;
}
.pcard:hover .pcard__reveal {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.pcard__title--up { margin-bottom: 8px; }
.pcard__team {
  font-size: .7rem;
  color: var(--lavender);
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.pcard__tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 8px; }
.pcard__tag {
  font-size: .58rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 2px 7px;
  background: rgba(160,32,240,.2);
  color: var(--accent-alt);
  border-radius: 2px;
}
.pcard__last-ch {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: .68rem;
  font-weight: 700;
  padding: 5px 10px;
  background: var(--accent);
  color: #fff;
  border-radius: 3px;
  text-align: center;
  transition: background .15s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pcard__last-ch:hover { background: var(--accent-hover); }

/* ── Panel description (s'étend à droite au survol) ─────── */
.pcard__desc-expand {
  position: absolute;
  top: 0;
  left: calc(100% + 6px);
  width: 200px;
  height: 100%;
  background: var(--bg-secondary);
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm);
  padding: 14px 12px;
  box-shadow: 4px 4px 0 0 var(--accent-deep);
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity .25s ease, transform .25s ease;
  pointer-events: none;
  z-index: 20;
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow: hidden;
}
.pcard:hover .pcard__desc-expand {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
.pcard__desc-title {
  font-size: .82rem;
  font-weight: 800;
  color: var(--accent-alt);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex-shrink: 0;
}
.pcard__desc-text {
  font-size: .75rem;
  line-height: 1.55;
  color: var(--text-secondary);
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 9;
  -webkit-box-orient: vertical;
}

/* Flip : panel à gauche pour les cartes en bout de ligne */
.pcard--flip .pcard__desc-expand {
  left: auto;
  right: calc(100% + 6px);
  transform: translateX(8px);
}
.pcard--flip:hover .pcard__desc-expand { transform: translateX(0); }

/* Description side panel */
.desc-panel {
  width: 280px;
  flex-shrink: 0;
  position: sticky;
  top: 90px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 20px;
  min-height: 200px;
  transition: border-color .2s;
}
.desc-panel:has(.desc-panel__content:not([hidden])) {
  border-color: var(--accent);
}
.desc-panel--home { width: 240px; min-height: 160px; padding: 16px; }
.desc-panel__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 140px;
  color: var(--text-muted);
  text-align: center;
  font-size: .8rem;
}
.desc-panel__content[hidden] { display: none !important; }
.desc-panel__title {
  font-family: var(--font-body);
  font-size: .92rem;
  font-weight: 800;
  margin-bottom: 10px;
  color: var(--accent-alt);
  line-height: 1.3;
}
.desc-panel__text {
  font-size: .8rem;
  line-height: 1.6;
  color: var(--text-secondary);
}

/* Legacy compat: project-card-wrap for favorites page etc. */
.project-card-wrap { position: relative; }
.fav-remove-btn {
  position: absolute;
  top: 6px; right: 6px;
  z-index: 10;
  background: rgba(13,5,32,.82);
  border: none;
  color: var(--danger);
  width: 22px; height: 22px;
  border-radius: 50%;
  font-size: .7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity .15s;
}
.project-card-wrap:hover .fav-remove-btn { opacity: 1; }

/* Status badges */
.status-ongoing   { background: rgba(62,207,142,.15); color: var(--success); }
.status-completed { background: var(--accent-soft); color: var(--accent); }
.status-hiatus    { background: rgba(240,180,41,.15);  color: var(--gold); }
.status-cancelled { background: rgba(232,93,74,.15);   color: var(--danger); }

/* ── Release cards (homepage — cartes avec liste de chapitres) ── */
.releases-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(265px, 1fr));
  gap: 10px;
}
.rcard {
  display: flex;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.rcard:hover {
  border-color: var(--accent);
  box-shadow: 3px 3px 0 0 var(--accent-deep);
}
.rcard__cover-link {
  position: relative;
  flex-shrink: 0;
  width: 88px;
  display: block;
  text-decoration: none;
}
.rcard__img {
  width: 88px;
  height: 100%;
  min-height: 148px;
  object-fit: cover;
  display: block;
}
.rcard__img--placeholder {
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--text-muted);
  min-height: 148px;
}
.rcard__type-badge {
  position: absolute;
  top: 6px; left: 6px;
  background: var(--accent);
  color: #fff;
  font-size: .58rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 2px 6px;
  border-radius: 4px;
}
.rcard__info {
  flex: 1;
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.rcard__title {
  font-weight: 800;
  font-size: .88rem;
  color: var(--text-primary);
  text-decoration: none;
  line-height: 1.25;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 3px;
}
.rcard__title:hover { color: var(--accent-alt); }
.rcard__status {
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  align-self: flex-start;
  margin-bottom: 6px;
}
.rcard__chapters {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.rcard__ch-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 4px 6px;
  text-decoration: none;
  border-radius: 4px;
  transition: background .15s;
}
.rcard__ch-link:hover { background: var(--bg-tertiary); }
.rcard__ch-num {
  font-family: var(--font-mono);
  font-size: .75rem;
  color: var(--text-secondary);
}
.rcard__badge-new {
  font-size: .6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--accent-alt);
  background: rgba(217,70,239,.12);
  padding: 1px 6px;
  border-radius: 8px;
}
.rcard__ch-date {
  font-family: var(--font-mono);
  font-size: .68rem;
  color: var(--text-muted);
}

/* ── Legacy releases list (lignes horizontales — conservé pour compatibilité) ── */
.releases-list { display: flex; flex-direction: column; gap: 2px; }
.release-row {
  display: grid;
  grid-template-columns: 48px 1.4fr 1.6fr 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 10px 14px;
  background: var(--bg-card);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  transition: background .15s, border-color .15s;
  text-decoration: none;
  color: var(--text-primary);
}
.release-row:hover { background: var(--bg-tertiary); border-color: var(--accent); }
.release-row__cover { width: 48px; height: 64px; border-radius: 4px; overflow: hidden; background: var(--bg-tertiary); flex-shrink: 0; }
.release-row__cover img { width: 100%; height: 100%; object-fit: cover; }
.release-row__title { font-weight: 800; font-size: .88rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.release-row__chapter { font-family: var(--font-mono); font-size: .78rem; color: var(--accent-alt); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.release-row__team { font-size: .75rem; color: var(--text-muted); font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.release-row__time { font-family: var(--font-mono); font-size: .68rem; color: var(--text-muted); text-align: right; white-space: nowrap; }

/* ── Legacy release cards (user dashboard / history) ─────── */
.releases-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(128px, 1fr)); gap: 14px; }
.releases-grid--lg { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
.release-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1px solid var(--border);
  transition: border-color .15s, transform .15s, box-shadow .15s;
  text-decoration: none;
  color: inherit;
}
.release-card:hover {
  border-color: var(--accent);
  transform: translate(-2px, -2px);
  box-shadow: 4px 4px 0 0 var(--accent-deep);
}
.release-cover { position: relative; aspect-ratio: 2/3; background: var(--bg-tertiary); overflow: hidden; }
.release-cover img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.release-card:hover .release-cover img { transform: scale(1.04); }
.release-chapter {
  position: absolute;
  bottom: 6px; right: 6px;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-mono);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .05em;
  padding: 3px 7px;
  border-radius: 0;
  text-transform: uppercase;
}
.release-info { padding: 6px 10px 10px; }
.release-title {
  font-size: .78rem;
  font-weight: 700;
  line-height: 1.2;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 3px;
}
.release-date {
  font-family: var(--font-mono);
  font-size: .65rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* ── Cover placeholder ────────────────────────────────────── */
.cover-placeholder {
  width: 100%; height: 100%;
  background: var(--bg-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
}
.cover-placeholder span {
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--text-muted);
  text-transform: uppercase;
}
.cover-placeholder--lg span { font-size: 3rem; }

/* ── Project hero (fiche projet) ──────────────────────────── */
.project-hero {
  position: relative;
  min-height: 360px;
  display: flex;
  align-items: flex-end;
  padding-bottom: 0;
}
.project-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center top;
  filter: blur(60px) brightness(.4);
  transform: scale(1.1);
}
.project-hero::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 120px;
  background: linear-gradient(transparent, var(--bg-primary));
}
.project-hero-inner {
  position: relative;
  z-index: 2;
  display: flex;
  gap: 36px;
  padding: 48px 24px 0;
  align-items: flex-end;
}
.project-cover-wrap { flex-shrink: 0; }
.project-cover {
  width: 180px;
  border-radius: var(--radius-md);
  box-shadow: 0 8px 32px rgba(0,0,0,.6);
  border: 2px solid var(--border-hover);
}
.project-meta { flex: 1; padding-bottom: 24px; }
.project-title { font-family: var(--font-display); font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 700; line-height: 1.2; margin-bottom: 4px; }
.project-alt-title { color: var(--text-muted); margin-bottom: 12px; font-size: .9rem; }
.project-tags-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.project-stats { display: flex; gap: 20px; margin: 12px 0; }
.stat { display: flex; align-items: center; gap: 5px; font-size: .85rem; color: var(--text-secondary); }
.project-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 16px; }

/* Rating stars */
.stars-display { display: flex; gap: 2px; }
.star { color: var(--text-muted); font-size: 1rem; }
.star.full { color: var(--gold); }
.star.half { color: var(--gold); opacity: .6; }
.rating-score { font-size: 1rem; font-weight: 700; color: var(--gold); margin-left: 6px; }
.rating-count { font-size: .8rem; color: var(--text-muted); }
.project-rating { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.rate-wrap { display: flex; align-items: center; gap: 8px; }
.rate-label { font-size: .85rem; color: var(--text-secondary); }
.stars-interactive { display: flex; gap: 2px; }
.star-btn { font-size: 1.3rem; color: var(--text-muted); cursor: pointer; transition: color .1s, transform .1s; }
.star-btn:hover, .star-btn.star-active { color: var(--gold); transform: scale(1.2); }
.stars-interactive:hover .star-btn { color: var(--gold); }
.stars-interactive .star-btn:hover ~ .star-btn { color: var(--text-muted); }

/* ── Project body ─────────────────────────────────────────── */
.project-body { padding: 40px 0; }
.project-details-grid { display: grid; grid-template-columns: 1fr 280px; gap: 32px; }
.project-main-col { display: flex; flex-direction: column; gap: 32px; }
.project-section-title {
  font-family: var(--font-body);
  font-size: .85rem;
  font-weight: 800;
  letter-spacing: .15em;
  color: var(--accent);
  text-transform: uppercase;
  margin-bottom: 18px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--border);
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
}
.project-section-title::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -2px;
  width: 40px;
  height: 2px;
  background: var(--accent);
}
.project-summary { color: var(--text-secondary); line-height: 1.8; font-size: .95rem; }

/* Chapter list */
.chapter-list { display: flex; flex-direction: column; gap: 2px; }
.chapter-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  transition: all .15s;
  position: relative;
}
.chapter-item:hover { background: var(--bg-card-hover); border-color: var(--border); }
.chapter-item--read { opacity: .6; }
.chapter-item--read::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--success); border-radius: 3px 0 0 3px; }
.chapter-num { font-family: var(--font-mono); font-size: .8rem; font-weight: 700; letter-spacing: .04em; color: var(--accent); min-width: 60px; }
.chapter-info { flex: 1; }
.chapter-title { font-size: .875rem; font-weight: 600; }
.chapter-team { font-size: .75rem; color: var(--text-muted); }
.chapter-meta { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.chapter-views, .chapter-date { font-size: .75rem; color: var(--text-muted); }
.chapter-read-badge { color: var(--success); font-size: .85rem; font-weight: 700; }

/* Comments */
.comment-form { background: var(--bg-card); border-radius: var(--radius-md); padding: 16px; border: 1px solid var(--border); margin-bottom: 20px; }
.comment-input-wrap { display: flex; gap: 12px; align-items: flex-start; }
.comment-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.comment-avatar--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent);
  color: #fff;
  font-weight: 700;
  font-size: .85rem;
}
.comment-textarea { flex: 1; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 10px 12px; color: var(--text-primary); resize: vertical; min-height: 80px; transition: border-color .15s; }
.comment-textarea:focus { outline: none; border-color: var(--accent); }
.comment-form-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 10px; }
.comment-char-count { font-size: .75rem; color: var(--text-muted); }
.comment-login-prompt { font-size: .9rem; color: var(--text-muted); margin-bottom: 16px; }
.comment-login-prompt a { color: var(--accent); }
.comment-list { display: flex; flex-direction: column; gap: 12px; }
.comment-item { display: flex; gap: 12px; }
.comment-content { flex: 1; background: var(--bg-card); border-radius: var(--radius-md); padding: 12px 14px; border: 1px solid var(--border); }
.comment-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.comment-author { font-weight: 700; font-size: .875rem; color: var(--accent); }
.comment-date { font-size: .75rem; color: var(--text-muted); }
.comment-text { font-size: .9rem; line-height: 1.65; color: var(--text-secondary); }
.comment-actions { display: flex; gap: 12px; margin-top: 8px; }
.comment-like-btn, .comment-reply-btn { background: none; border: none; font-size: .8rem; color: var(--text-muted); cursor: pointer; transition: color .15s; }
.comment-like-btn:hover { color: var(--danger); }
.comment-reply-btn:hover { color: var(--accent); }

/* Sidebar */
.project-sidebar { display: flex; flex-direction: column; gap: 16px; }
.sidebar-card { background: var(--bg-card); border-radius: var(--radius-md); padding: 18px; border: 1px solid var(--border); }
.sidebar-card-title { font-family: var(--font-body); font-size: .72rem; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--accent); margin-bottom: 14px; padding-bottom: 8px; border-bottom: 2px solid var(--border); }
.info-list { display: grid; grid-template-columns: auto 1fr; gap: 8px 12px; font-size: .875rem; }
.info-list dt { color: var(--text-muted); font-weight: 600; }
.info-list dd { color: var(--text-secondary); }
.info-list dd a { color: var(--accent); }
.tag-cloud { display: flex; flex-wrap: wrap; gap: 6px; }
.tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: .75rem;
  font-weight: 600;
}
.tag--genre { background: var(--accent-soft); color: var(--accent); border: 1px solid rgba(160,32,240,.35); }
.tag--theme { background: var(--bg-tertiary); color: var(--text-secondary); border: 1px solid var(--border); }
.tag--type  { background: var(--bg-tertiary); color: var(--text-secondary); border: 1px solid var(--border); }
.tag--status { border-radius: 20px; font-size: .75rem; font-weight: 600; padding: 3px 10px; }
.count-badge { background: var(--bg-tertiary); color: var(--text-secondary); font-size: .75rem; padding: 2px 8px; border-radius: 20px; font-family: var(--font-body); font-weight: 600; }

/* Favorite dropdown */
.favorite-wrap { position: relative; }
.favorite-dropdown {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-md);
  overflow: hidden;
  min-width: 160px;
  z-index: 50;
  box-shadow: var(--shadow-card);
}
.fav-option { display: block; width: 100%; text-align: left; background: none; border: none; padding: 9px 14px; font-size: .875rem; color: var(--text-secondary); cursor: pointer; transition: background .12s; }
.fav-option:hover { background: var(--bg-tertiary); color: var(--text-primary); }

/* ── Reader ───────────────────────────────────────────────── */
.reader-mode { background: #000; }

/* Barre de navigation */
.reader-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: rgba(6,10,28,.95);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 0 16px;
  transition: transform .28s ease;
}
/* Header qui disparaît au scroll bas et réapparaît au scroll haut */
.reader-bar.bar-hidden-scroll,
/* Header qui disparaît après inactivité sur mobile (manga) */
.reader-bar.bar-hidden-touch { transform: translateY(-100%); }
.reader-bar-inner {
  max-width: 960px;
  margin: 0 auto;
  height: 56px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.reader-back {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .85rem;
  color: var(--text-secondary);
  flex-shrink: 0;
  transition: color .15s;
  text-decoration: none;
}
.reader-back:hover { color: var(--text-primary); }
.reader-project-title { font-weight: 600; max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.reader-controls { flex: 1; display: flex; align-items: center; justify-content: center; gap: 10px; }
.reader-chapter-label { font-size: .875rem; color: var(--text-secondary); white-space: nowrap; }
.reader-nav-btn { min-width: 90px; }

/* Paramètres */
.reader-settings { position: relative; display: flex; gap: 4px; flex-shrink: 0; }
.reader-setting-btn {
  background: none;
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 6px 8px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .15s;
}
.reader-setting-btn:hover { background: var(--bg-tertiary); color: var(--text-primary); border-color: var(--border-hover); }

/* Panel paramètres */
.reader-settings-panel[hidden] { display: none !important; }
.reader-settings-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-lg);
  padding: 16px;
  width: 270px;
  z-index: 200;
  box-shadow: 0 12px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(59,91,255,.1);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.rsp-section { display: flex; flex-direction: column; gap: 8px; }
.rsp-label {
  font-size: .67rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-muted);
  font-weight: 700;
}
.rsp-group {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}
.rsp-group--col { flex-direction: column; gap: 4px; }
.rsp-btn {
  flex: 1 1 auto;
  min-width: 0;
  padding: 7px 10px;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: .78rem;
  line-height: 1.3;
  text-align: center;
  transition: all .15s;
  white-space: nowrap;
}
.rsp-btn:hover { background: var(--bg-secondary); color: var(--text-primary); border-color: var(--border-hover); }
.rsp-btn--active { background: var(--accent); border-color: var(--accent); color: #fff; font-weight: 600; }
.rsp-icon { font-size: .9em; }
.rsp-hint {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  font-size: .72rem;
  color: var(--text-muted);
  line-height: 1.5;
  padding-top: 4px;
  border-top: 1px solid var(--border);
}
.rsp-hint svg { flex-shrink: 0; margin-top: 2px; }

/* Navigation paginée manga */
.paged-nav {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 2px;
  z-index: 150;
  background: rgba(6,10,28,.88);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 999px;
  padding: 5px 8px;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 4px 24px rgba(0,0,0,.5);
}
.paged-nav-btn {
  background: none;
  border: none;
  color: var(--text-secondary);
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}
.paged-nav-btn:hover:not(:disabled) { background: var(--bg-tertiary); color: var(--text-primary); }
.paged-nav-btn:disabled { opacity: .3; cursor: default; }
.paged-nav-counter {
  font-size: .8rem;
  color: var(--text-secondary);
  min-width: 72px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  letter-spacing: .02em;
}

/* Conteneur principal — margin-top compense la barre fixe */
.reader-container {
  max-width: 800px;
  margin: 56px auto 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  background: #000;
  min-height: calc(100vh - 56px);
}

/* Mode Webtoon — défilement vertical sans séparation */
.reader-container.reader-webtoon {
  gap: 0 !important;
  background: #000;
}
.reader-container.reader-webtoon .reader-page {
  display: block;
  line-height: 0;
  font-size: 0;
}
.reader-container.reader-webtoon .reader-img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

/* Mode Manga — géré en JS (height, overflow, flex) */
.reader-container.reader-manga { background: #000; padding: 0; }
.reader-container.reader-manga .reader-page { line-height: 0; }
.reader-container.reader-manga .reader-img { user-select: none; -webkit-user-drag: none; }

/* Page vide */
.reader-page { line-height: 0; }
.reader-img { width: 100%; height: auto; display: block; }
.reader-empty { padding: 80px 24px; text-align: center; color: var(--text-muted); }

/* Footer de navigation chapitres — mode webtoon (flux normal) */
.reader-footer {
  max-width: 800px;
  margin: 0 auto;
  padding: 24px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── Bouton retour en haut — mode webtoon, desktop uniquement ─────── */
.webtoon-top-btn {
  position: fixed;
  bottom: 36px;
  right: 36px;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  background: var(--bg-card);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 800;
  opacity: 0;
  transform: translateY(12px) scale(.92);
  transition: opacity .3s ease, transform .3s ease, background .2s;
  pointer-events: none;
  box-shadow: 0 4px 18px rgba(0,0,0,.45), 0 0 0 1px var(--border);
}
.webtoon-top-btn.wt-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.webtoon-top-btn:hover {
  background: var(--bg-tertiary);
  box-shadow: 0 4px 24px rgba(59,91,255,.35), 0 0 0 1px var(--accent);
}
.webtoon-top-btn:active { transform: scale(.95); }

/* Anneau SVG */
.webtoon-top-ring {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  transform: rotate(-90deg); /* démarre depuis 12h */
}
.webtoon-top-track {
  stroke: rgba(255,255,255,.08);
}
.webtoon-top-progress {
  stroke: url(#wt-ring-grad);
  stroke-dasharray: 125.66;   /* 2 × π × 20 */
  stroke-dashoffset: 125.66;  /* vide au départ */
  transition: stroke-dashoffset .12s linear;
  stroke-linecap: round;
}

/* Flèche */
.webtoon-top-arrow {
  position: relative;
  z-index: 1;
  color: var(--text-primary);
  transition: transform .2s ease;
}
.webtoon-top-btn:hover .webtoon-top-arrow {
  transform: translateY(-2px);
}

/* Masqué sur mobile — jamais visible */
@media (max-width: 768px) {
  .webtoon-top-btn { display: none !important; }
}

/* Bouton de nav paginée en mode "chapitre" (première / dernière page) */
.paged-nav-btn--chapter {
  color: var(--accent) !important;
  border: 1px solid var(--accent);
  border-radius: 6px;
}

/* Modal */
.modal-overlay[hidden] { display: none !important; }
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.modal {
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 480px;
  box-shadow: var(--shadow-card);
}
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--border); }
.modal-header h3 { font-family: var(--font-display); font-size: 1rem; }
.modal-close { background: none; border: none; color: var(--text-muted); font-size: 1.1rem; cursor: pointer; }
.modal-body { padding: 20px; display: flex; flex-direction: column; gap: 14px; }
.modal-footer { padding: 16px 20px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 10px; }

/* ── Auth pages ───────────────────────────────────────────── */
.auth-page { min-height: calc(100vh - var(--header-h)); display: flex; align-items: center; justify-content: center; padding: 48px 24px; }
.auth-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 40px;
  width: 100%;
  max-width: 420px;
  box-shadow: var(--shadow-card);
}
.auth-card--wide { max-width: 560px; }
.auth-card-header { text-align: center; margin-bottom: 28px; }
.auth-logo { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; color: var(--accent); letter-spacing: .08em; }
.auth-title { font-family: var(--font-display); font-size: 1.4rem; font-weight: 600; margin-top: 16px; }
.auth-form { display: flex; flex-direction: column; gap: 16px; }
.auth-footer-text { text-align: center; margin-top: 20px; font-size: .875rem; color: var(--text-muted); }
.auth-footer-text a { color: var(--accent); font-weight: 600; }

/* ── Forms ────────────────────────────────────────────────── */
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-label { font-size: .85rem; font-weight: 600; color: var(--text-secondary); }
.required { color: var(--danger); }
.form-input, .form-select, .form-textarea {
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 9px 12px;
  color: var(--text-primary);
  font-size: .9rem;
  transition: border-color .15s;
  width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-secondary);
}
.form-input:disabled { opacity: .5; cursor: not-allowed; }
.form-textarea { resize: vertical; min-height: 100px; line-height: 1.6; }
.form-hint { font-size: .78rem; color: var(--text-muted); }
.form-select option { background: var(--bg-secondary); }
.form-input-file { font-size: .85rem; color: var(--text-secondary); }
.form-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-footer { display: flex; justify-content: flex-end; gap: 12px; margin-top: 24px; padding-top: 20px; border-top: 1px solid var(--border); }
.form-divider { border: none; border-top: 1px solid var(--border); margin: 20px 0; }
.form-section-title { font-size: .9rem; font-weight: 700; color: var(--text-secondary); margin-bottom: 4px; }
.inline-form { display: inline-flex; align-items: center; gap: 6px; }
.filter-select--sm { padding: 4px 8px; font-size: .8rem; }

/* Filters bar */
.filters-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 24px; padding: 16px; background: var(--bg-card); border-radius: var(--radius-md); border: 1px solid var(--border); }
.filter-input { background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 8px 12px; color: var(--text-primary); font-size: .875rem; min-width: 180px; }
.filter-input:focus { outline: none; border-color: var(--accent); }
.filter-select { background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 8px 10px; color: var(--text-primary); font-size: .875rem; }

/* Checkboxes */
.checkbox-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 6px; }
.checkbox-label { display: flex; align-items: center; gap: 6px; font-size: .8rem; color: var(--text-secondary); cursor: pointer; }
.checkbox-label input { accent-color: var(--accent); }

/* Cover preview */
.cover-preview { width: 140px; height: 200px; object-fit: cover; border-radius: var(--radius-md); border: 1px solid var(--border); }
.cover-preview--empty { display: flex; align-items: center; justify-content: center; background: var(--bg-tertiary); color: var(--text-muted); font-size: .85rem; }

/* ── Upload zone ──────────────────────────────────────────── */
.upload-zone {
  border: 2px dashed var(--border-hover);
  border-radius: var(--radius-md);
  padding: 40px 24px;
  text-align: center;
  cursor: pointer;
  transition: all .2s;
  background: var(--bg-tertiary);
}
.upload-zone:hover, .upload-zone--hover { border-color: var(--accent); background: var(--accent-soft); }
.upload-zone-text { font-size: .95rem; font-weight: 600; color: var(--text-secondary); margin-top: 12px; }
.upload-browse-link { color: var(--accent); cursor: pointer; }
.upload-zone-hint { font-size: .8rem; color: var(--text-muted); margin-top: 4px; }
.upload-progress { position: relative; background: var(--bg-tertiary); border-radius: 20px; height: 6px; margin-top: 12px; overflow: hidden; }
.upload-progress-bar { height: 100%; background: var(--accent); border-radius: 20px; transition: width .3s; width: 0; }
.upload-progress-text { position: absolute; right: 0; top: 10px; font-size: .75rem; color: var(--text-muted); }
.pages-preview { display: grid; grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); gap: 8px; margin-top: 16px; }
.page-thumb { position: relative; aspect-ratio: 2/3; border-radius: var(--radius-sm); overflow: hidden; border: 2px solid var(--border); cursor: grab; }
.page-thumb.dragging { opacity: .5; border-color: var(--accent); }
.page-thumb img { width: 100%; height: 100%; object-fit: cover; }
.page-thumb-num { position: absolute; bottom: 3px; left: 3px; background: rgba(0,0,0,.7); color: #fff; font-size: .65rem; font-weight: 700; padding: 1px 5px; border-radius: 3px; }
.page-thumb-remove { position: absolute; top: 3px; right: 3px; background: var(--danger); border: none; color: #fff; width: 18px; height: 18px; border-radius: 50%; font-size: .6rem; display: flex; align-items: center; justify-content: center; cursor: pointer; opacity: 0; transition: opacity .15s; }
.page-thumb:hover .page-thumb-remove { opacity: 1; }

/* ── Sélecteur mode upload (pages / ZIP) ──────────────────── */
.upload-mode-tabs { display: flex; gap: 8px; margin-top: 6px; }
.upload-mode-tab {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 18px; border-radius: var(--radius-sm);
  border: 1.5px solid var(--border); background: var(--bg-card);
  color: var(--text-secondary); font-size: .9rem; font-weight: 600;
  cursor: pointer; transition: border-color .2s, color .2s, background .2s;
}
.upload-mode-tab:hover { border-color: var(--accent); color: var(--accent); }
.upload-mode-tab--active { border-color: var(--accent); background: rgba(59,91,255,.12); color: var(--accent); }
.upload-zone--zip { border-style: dashed; border-color: var(--lavender); }
.upload-zone--zip:hover, .upload-zone--zip.upload-zone--hover { border-color: var(--lavender); background: rgba(169,139,255,.07); }

/* ── ZIP : carte de prévisualisation du fichier sélectionné ─ */
.zip-preview-card {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px; border-radius: 10px;
  background: rgba(169,139,255,.08);
  border: 1px solid rgba(169,139,255,.35);
}
.zip-preview-icon { flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.zip-preview-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.zip-preview-name { font-size: .92rem; font-weight: 600; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.zip-preview-size { font-size: .8rem; color: var(--text-secondary); }
.zip-preview-remove {
  flex-shrink: 0; background: none; border: none; cursor: pointer;
  color: var(--text-secondary); padding: 4px; border-radius: 4px; transition: color .15s;
}
.zip-preview-remove:hover { color: var(--danger, #ff4d63); }

/* ── ZIP : barre de statut d'upload ─────────────────────────── */
.zip-upload-status {
  margin: 0 0 16px;
  padding: 14px 18px; border-radius: 10px;
  background: rgba(59,91,255,.10);
  border: 1px solid rgba(59,91,255,.35);
  animation: zipFadeIn .3s ease;
}
.zip-status-inner { display: flex; align-items: center; gap: 14px; }
.zip-status-text  { display: flex; flex-direction: column; gap: 3px; }
.zip-status-text strong { font-size: .93rem; color: var(--accent-hover); }
.zip-status-text span   { font-size: .82rem; color: var(--text-secondary); }
.zip-status-spinner {
  flex-shrink: 0; color: var(--accent);
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes zipFadeIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }

/* ── Panels ───────────────────────────────────────────────── */
.panel-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; flex-wrap: wrap; gap: 12px; }
.panel-subtitle { color: var(--text-secondary); font-size: .9rem; margin-top: 4px; }
.panel-header-actions { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.panel-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.panel-card-header .panel-card-title { margin-bottom: 0; }
.panel-grid--2 { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; align-items: start; }
.panel-grid--2fr1 { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; margin-bottom: 20px; align-items: start; }

/* Stats row 6 colonnes */
.stats-row--6 { grid-template-columns: repeat(6, 1fr); }
.stat-card--accent { border-color: rgba(160,32,240,.4); background: rgba(160,32,240,.06); }

/* Top projets dashboard */
.top-projects-list { display: flex; flex-direction: column; gap: 12px; }
.top-project-item { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border); }
.top-project-item:last-child { border-bottom: none; }
.top-project-rank { font-family: var(--font-display); font-size: 1.1rem; color: var(--accent); min-width: 28px; text-align: center; }
.top-project-cover { width: 36px; height: 48px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.top-project-info { flex: 1; min-width: 0; }
.top-project-title { font-weight: 700; font-size: .9rem; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; }
.top-project-title:hover { color: var(--accent); }
.top-project-meta { display: flex; gap: 10px; font-size: .78rem; color: var(--text-secondary); margin-top: 3px; flex-wrap: wrap; }
.panel-nav { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 28px; padding: 6px; background: var(--bg-card); border-radius: var(--radius-md); border: 1px solid var(--border); }
.panel-nav-link { padding: 8px 16px; border-radius: var(--radius-sm); font-size: .875rem; font-weight: 600; color: var(--text-secondary); transition: all .15s; display: flex; align-items: center; gap: 6px; }
.panel-nav-link:hover { color: var(--text-primary); background: var(--bg-tertiary); }
.panel-nav-link.active { background: var(--accent); color: #fff; }
.panel-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; align-items: start; }
.panel-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 20px; }
.panel-card--warning { border-color: rgba(240,180,41,.3); background: rgba(240,180,41,.04); }
.panel-card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.panel-card-title { font-family: var(--font-body); font-size: .78rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; color: var(--text-primary); margin-bottom: 16px; }
.panel-card-head .panel-card-title { margin-bottom: 0; }
.badge-count { background: var(--accent); color: #fff; font-size: .7rem; font-weight: 700; padding: 1px 6px; border-radius: 10px; }
.badge-count--danger { background: var(--danger); }

/* Stats */
.stats-row { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 14px; margin-bottom: 28px; }
.stats-row--lg { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
.stat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  text-align: center;
  transition: border-color .15s;
}
.stat-card--link { cursor: pointer; }
.stat-card--link:hover { border-color: var(--accent); }
.stat-card--danger { border-color: rgba(232,93,74,.4); }
.stat-card--warning { border-color: rgba(240,180,41,.4); }
.stat-card-icon { font-size: 1.4rem; }
.stat-card-value { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; color: var(--text-primary); }
.stat-card-label { font-size: .75rem; color: var(--text-muted); font-weight: 600; }

/* ── Graphiques admin (Chart.js) ──────────────────────────── */
/* IMPORTANT : maintainAspectRatio: false nécessite une hauteur
   fixe sur le conteneur, sinon le canvas grossit à l'infini.  */
.chart-grid {
  display: grid;
  gap: 20px;
  margin-bottom: 24px;
}
.chart-grid--1 { grid-template-columns: 1fr; }
.chart-grid--2 { grid-template-columns: 1fr 1fr; }
.chart-grid--3 { grid-template-columns: 1fr 1fr 1fr; }

.chart-card {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 20px 16px;
}
.chart-card--tall { /* pour les grands graphiques barres horizontales */ }

.chart-card-title {
  font-family: var(--font-body);
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin: 0 0 14px;
}

/* Le canvas lui-même doit avoir une hauteur fixe */
.chart-card canvas {
  display: block;
  width: 100% !important;
  height: 280px !important;
}
.chart-card--tall canvas {
  height: 420px !important;
}

/* Doughnuts : wrapper centré avec hauteur fixe */
.chart-doughnut-wrap {
  position: relative;
  width: 100%;
  height: 240px;
}
.chart-doughnut-wrap canvas {
  height: 240px !important;
}

/* Responsive graphiques */
@media (max-width: 900px) {
  .chart-grid--2,
  .chart-grid--3 { grid-template-columns: 1fr; }
  .chart-card canvas { height: 240px !important; }
  .chart-card--tall canvas { height: 320px !important; }
}
@media (max-width: 600px) {
  .chart-card canvas { height: 200px !important; }
}

/* Dashboard links */
.dashboard-links { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; margin-bottom: 36px; }
.dashboard-link-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-size: .9rem;
  font-weight: 600;
  color: var(--text-secondary);
  transition: all .15s;
}
.dashboard-link-card:hover { border-color: var(--accent); color: var(--accent); background: var(--bg-card-hover); }
.dashboard-section { margin-top: 36px; }

/* Data table */
.data-table { width: 100%; border-collapse: collapse; font-size: .875rem; }
.data-table th { text-align: left; padding: 10px 12px; font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--text-muted); border-bottom: 1px solid var(--border); }
.data-table td { padding: 11px 12px; border-bottom: 1px solid rgba(255,255,255,.04); vertical-align: middle; }
.data-table tbody tr:hover { background: var(--bg-tertiary); }
.data-table--full { width: 100%; }
.table-cover { width: 40px; height: 56px; object-fit: cover; border-radius: 4px; background: var(--bg-tertiary); display: flex; align-items: center; justify-content: center; color: var(--text-muted); font-weight: 700; }
.table-cover--round { border-radius: 50%; width: 36px; height: 36px; }
.table-cover--placeholder { font-size: .85rem; }
.role-badge { padding: 2px 8px; border-radius: 12px; font-size: .75rem; font-weight: 700; }
.role-user   { background: rgba(144,148,176,.15); color: var(--text-secondary); }
.role-writer { background: var(--accent-glow); color: var(--accent); }
.role-admin  { background: var(--gold-dim); color: var(--gold); }
.status-badge { padding: 2px 8px; border-radius: 12px; font-size: .75rem; font-weight: 700; }
.status-open      { background: rgba(232,93,74,.15); color: var(--danger); }
.status-reviewing { background: rgba(240,180,41,.15); color: var(--gold); }
.status-resolved  { background: rgba(62,207,142,.15); color: var(--success); }
.status-dismissed { background: rgba(144,148,176,.1); color: var(--text-muted); }
.status-pending   { background: rgba(240,180,41,.15); color: var(--gold); }
.status-approved  { background: rgba(62,207,142,.15); color: var(--success); }
.status-rejected  { background: rgba(232,93,74,.15); color: var(--danger); }
.badge-pill { padding: 2px 8px; border-radius: 12px; font-size: .75rem; font-weight: 700; }
.badge-pill--success { background: rgba(62,207,142,.15); color: var(--success); }
.badge-pill--muted   { background: rgba(144,148,176,.1); color: var(--text-muted); }
.code-inline { background: var(--bg-tertiary); padding: 2px 6px; border-radius: 4px; font-family: monospace; font-size: .8rem; color: var(--text-secondary); }

/* Simple list */
.simple-list { display: flex; flex-direction: column; gap: 2px; }
.simple-list-item { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; border-radius: var(--radius-sm); transition: background .12s; }
.simple-list-item:hover { background: var(--bg-tertiary); }
.simple-list-link { display: flex; align-items: center; gap: 8px; font-size: .875rem; font-weight: 600; }
.team-logo-sm { width: 24px; height: 24px; border-radius: 50%; object-fit: cover; }

/* Pagination */
.pagination { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 36px; }
.pagination-btn { padding: 7px 16px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-sm); font-size: .875rem; color: var(--text-secondary); transition: all .15s; }
.pagination-btn:hover { border-color: var(--accent); color: var(--accent); }
.pagination-pages { display: flex; gap: 4px; }
.pagination-page { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-sm); font-size: .875rem; font-weight: 600; color: var(--text-secondary); transition: all .15s; }
.pagination-page:hover { border-color: var(--accent); color: var(--accent); }
.pagination-page.active { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ── Teams ────────────────────────────────────────────────── */
.teams-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.team-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px;
  transition: all .2s;
}
.team-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: var(--shadow-glow); }
.team-card-logo { width: 60px; height: 60px; flex-shrink: 0; }
.team-card-logo img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-hover); }
.team-logo-placeholder {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
}
.team-logo-placeholder--lg { width: 80px; height: 80px; font-size: 2rem; }
.team-card-name { font-family: var(--font-display); font-size: 1rem; font-weight: 600; margin-bottom: 4px; }
.team-card-desc { font-size: .82rem; color: var(--text-muted); margin-bottom: 8px; }
.team-card-stats { display: flex; gap: 12px; font-size: .78rem; color: var(--text-secondary); }
.team-hero { display: flex; align-items: center; gap: 28px; padding: 32px 0 20px; }
.team-hero-img { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; border: 3px solid var(--accent); }
.team-hero-name { font-family: var(--font-display); font-size: 2rem; font-weight: 700; }
.team-hero-desc { color: var(--text-secondary); margin: 8px 0; }
.team-hero-links { display: flex; gap: 8px; margin-top: 12px; }
.team-body-grid { display: flex; flex-direction: column; gap: 36px; }
.members-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.member-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  transition: border-color .15s;
}
.member-card:hover { border-color: var(--accent); }
.member-avatar { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.member-avatar--placeholder {
  display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff; font-weight: 700; font-size: .9rem;
}
.member-name { font-size: .875rem; font-weight: 700; }
.member-role { font-size: .72rem; color: var(--text-muted); text-transform: capitalize; }

/* ── Messages ─────────────────────────────────────────────── */
.messages-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 0;
  height: calc(100vh - var(--header-h) - 80px);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.conversations-list { border-right: 1px solid var(--border); overflow-y: auto; display: flex; flex-direction: column; }
.conversations-header { padding: 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.conversations-header h2 { font-family: var(--font-display); font-size: .95rem; font-weight: 600; }
.conv-search-form { flex: 1; }
.conv-search-input { width: 100%; background: var(--bg-tertiary); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 6px 10px; font-size: .8rem; color: var(--text-primary); }
.conversation-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255,255,255,.03);
  cursor: pointer;
  transition: background .12s;
}
.conversation-item:hover, .conversation-item--active { background: var(--bg-tertiary); }
.conv-avatar-wrap { position: relative; flex-shrink: 0; }
.conv-avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; display: flex; align-items: center; justify-content: center; }
.conv-avatar--placeholder { background: var(--accent); color: #fff; font-weight: 700; }
.conv-unread-dot { position: absolute; bottom: 0; right: 0; width: 10px; height: 10px; border-radius: 50%; background: var(--success); border: 2px solid var(--bg-card); }
.conv-info { flex: 1; overflow: hidden; }
.conv-name-row { display: flex; align-items: center; justify-content: space-between; }
.conv-name { font-size: .875rem; font-weight: 700; }
.conv-time { font-size: .72rem; color: var(--text-muted); }
.conv-preview { font-size: .8rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.conv-preview--unread { color: var(--text-primary); font-weight: 600; }
.conv-badge { background: var(--accent); color: #fff; font-size: .7rem; font-weight: 700; padding: 2px 6px; border-radius: 10px; flex-shrink: 0; }
.messages-main {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 0;
  overflow: hidden;
}
.messages-main--empty { display: flex; align-items: center; justify-content: center; }
.messages-empty-state { text-align: center; color: var(--text-muted); display: flex; flex-direction: column; align-items: center; gap: 12px; }
.messages-header { padding: 14px 20px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; background: var(--bg-card); flex-shrink: 0; }
.messages-body { overflow-y: auto; min-height: 0; padding: 20px; display: flex; flex-direction: column; gap: 12px; }
.messages-empty { text-align: center; color: var(--text-muted); font-size: .875rem; }
.message-bubble-wrap { display: flex; align-items: flex-end; gap: 8px; }
.message-bubble-wrap--self { flex-direction: row-reverse; }
.msg-avatar { width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0; }
.msg-avatar--placeholder { display: flex; align-items: center; justify-content: center; background: var(--accent); color: #fff; font-size: .75rem; font-weight: 700; }
.message-bubble { background: var(--bg-tertiary); border-radius: 16px; border-bottom-left-radius: 4px; padding: 10px 14px; max-width: 70%; }
.message-bubble--self { background: var(--accent); border-radius: 16px; border-bottom-right-radius: 4px; }
.message-text { font-size: .9rem; line-height: 1.55; }
.message-time { font-size: .7rem; color: rgba(255,255,255,.4); margin-top: 4px; display: block; }
.message-form { padding: 14px 20px; border-top: 1px solid var(--border); display: flex; gap: 10px; align-items: flex-end; background: var(--bg-card); flex-shrink: 0; }
.message-input {
  flex: 1;
  background: var(--bg-tertiary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  color: var(--text-primary);
  resize: none;
  max-height: 120px;
  line-height: 1.5;
  font-size: .9rem;
  transition: border-color .15s;
}
.message-input:focus { outline: none; border-color: var(--accent); }
.message-send-btn { padding: 10px; border-radius: var(--radius-md); flex-shrink: 0; }

/* ── Profile ──────────────────────────────────────────────── */
.profile-hero { display: flex; gap: 28px; align-items: center; padding: 32px 0; border-bottom: 1px solid var(--border); margin-bottom: 32px; }
.profile-avatar { width: 100px; height: 100px; border-radius: 50%; object-fit: cover; border: 3px solid var(--accent); }
.profile-avatar--placeholder {
  display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff; font-family: var(--font-display); font-size: 2.5rem; font-weight: 700;
}
.profile-username { font-family: var(--font-display); font-size: 1.8rem; font-weight: 700; margin-bottom: 6px; }
.profile-bio { color: var(--text-secondary); margin: 8px 0; font-size: .9rem; }
.profile-since { font-size: .8rem; color: var(--text-muted); margin: 4px 0; }
.profile-stats { display: flex; gap: 20px; margin-top: 12px; font-size: .875rem; color: var(--text-secondary); }

/* Settings */
.settings-grid { display: grid; grid-template-columns: 1fr 300px; gap: 24px; align-items: start; }
.settings-form { display: flex; flex-direction: column; gap: 16px; }
.avatar-group { flex-direction: row; align-items: center; gap: 20px; }
.avatar-preview-wrap { flex-shrink: 0; }
.avatar-preview { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-hover); }
.avatar-preview--placeholder { display: flex; align-items: center; justify-content: center; background: var(--accent); color: #fff; font-size: 1.8rem; font-weight: 700; }

/* ── Notifications ────────────────────────────────────────── */
.notifications-list { display: flex; flex-direction: column; gap: 2px; max-width: 720px; }
.notif-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  transition: border-color .15s;
}
.notif-item--unread { border-color: var(--accent); background: var(--accent-soft); }
.notif-icon { width: 36px; height: 36px; border-radius: 50%; background: var(--bg-tertiary); display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: var(--accent); }
.notif-content { flex: 1; }
.notif-text { font-size: .9rem; font-weight: 500; }
.notif-time { font-size: .75rem; color: var(--text-muted); margin-top: 3px; }
.notif-link-btn { color: var(--accent); font-size: 1.1rem; padding: 4px 8px; }

/* ── Projects admin ───────────────────────────────────────── */
.projects-admin-grid { display: flex; flex-direction: column; gap: 8px; }
.project-admin-card {
  display: flex;
  align-items: center;
  gap: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  transition: border-color .15s;
}
.project-admin-card:hover { border-color: var(--border-hover); }
.project-admin-cover { width: 44px; height: 62px; flex-shrink: 0; border-radius: 4px; overflow: hidden; background: var(--bg-tertiary); }
.project-admin-cover img { width: 100%; height: 100%; object-fit: cover; }
.project-admin-info { flex: 1; }
.project-admin-title { font-size: .9rem; font-weight: 700; }
.project-admin-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 5px; }
.project-admin-actions { display: flex; gap: 6px; flex-wrap: wrap; }

/* Carousel admin */
.carousel-admin-list { display: flex; flex-direction: column; gap: 8px; }
.carousel-admin-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  padding: 10px 12px;
  border: 1px solid var(--border);
}
.carousel-admin-img { width: 80px; height: 45px; object-fit: cover; border-radius: 4px; }
.carousel-admin-info { flex: 1; font-size: .875rem; }
.carousel-admin-actions { display: flex; gap: 6px; }

/* ── Alerts ───────────────────────────────────────────────── */
.alert { padding: 12px 16px; border-radius: var(--radius-md); font-size: .875rem; font-weight: 500; margin-bottom: 16px; }
.alert-danger  { background: rgba(232,93,74,.12);  border: 1px solid rgba(232,93,74,.3);  color: #f08575; }
.alert-success { background: rgba(62,207,142,.12); border: 1px solid rgba(62,207,142,.3); color: #3ecf8e; }

/* ── Empty states ─────────────────────────────────────────── */
.empty-state { font-size: .875rem; color: var(--text-muted); padding: 16px 0; text-align: center; }
.empty-state-small { font-size: .85rem; color: var(--text-muted); padding: 20px 16px; text-align: center; }
.empty-state-big { padding: 60px 24px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 16px; }
.empty-state-big p { color: var(--text-secondary); font-size: 1rem; }

/* ── Error pages ──────────────────────────────────────────── */
.error-page { min-height: calc(100vh - var(--header-h)); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; text-align: center; padding: 48px; }
.error-code { font-family: var(--font-display); font-size: clamp(5rem, 15vw, 10rem); font-weight: 700; color: var(--accent); opacity: .3; line-height: 1; }
.error-title { font-family: var(--font-display); font-size: 1.8rem; font-weight: 600; }
.error-message { color: var(--text-secondary); max-width: 400px; }
.error-actions { display: flex; gap: 12px; margin-top: 8px; }

/* ── Legal pages ──────────────────────────────────────────── */
.legal-page { max-width: 720px; margin: 0 auto; }
.legal-section { margin-bottom: 32px; }
.legal-section h2 { font-family: var(--font-display); font-size: 1.1rem; font-weight: 600; margin-bottom: 12px; color: var(--text-primary); }
.legal-section p, .legal-section ul { color: var(--text-secondary); font-size: .9rem; line-height: 1.8; }
.legal-section ul { padding-left: 20px; margin-top: 8px; }
.legal-section a { color: var(--accent); }

/* Contact */
.contact-alternatives { margin-top: 8px; }
.contact-links { display: flex; justify-content: center; gap: 12px; margin-top: 12px; }
.contact-link-card {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px; background: var(--discord); color: #fff;
  border-radius: var(--radius-md); font-weight: 600; font-size: .9rem;
  transition: opacity .15s;
}
.contact-link-card:hover { opacity: .9; }

/* ── Main content spacing ─────────────────────────────────── */
.main-content { min-height: calc(100vh - var(--header-h) - 300px); }

/* ── Responsive ───────────────────────────────────────────── */

/* Tablette */
@media (max-width: 1024px) {
  .footer-grid                { grid-template-columns: 1fr 1fr; }
  .project-details-grid       { grid-template-columns: 1fr; }
  .project-sidebar            { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .settings-grid              { grid-template-columns: 1fr; }
  .panel-grid                 { grid-template-columns: 1fr; }
  .form-grid-2                { grid-template-columns: 1fr; }
  .admin-team-grid            { grid-template-columns: 1fr; }

  /* Description panel caché sous tablette */
  .desc-panel                 { display: none; }
  .catalogue-layout           { display: block; }
}

/* Mobile ≤ 768px */
@media (max-width: 768px) {
  :root { --header-h: 56px; }

  /* ── Header mobile ── */
  .site-header { overflow: visible; }

  .header-inner {
    padding: 0 16px;
    gap: 10px;
    position: relative;
  }

  /* Logo : garde la place, réduit un peu */
  .header-logo {
    font-size: 1rem;
    flex-shrink: 0;
    gap: 6px;
  }

  /* Nav principale : cachée, ouverte via burger */
  .header-nav { display: none; }
  .header-nav.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: var(--header-h);
    left: 0;
    right: 0;
    width: 100vw;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    padding: 12px 16px;
    z-index: 200;
    gap: 4px;
  }
  .header-nav.open .nav-link {
    padding: 10px 14px;
    border-radius: var(--radius-sm);
    font-size: 1rem;
  }

  /* Barre de recherche : masquée sur mobile */
  .header-search { display: none; }

  /* Zone utilisateur : compacte */
  .header-user {
    gap: 4px;
    margin-left: auto;
    flex-shrink: 0;
  }
  .user-name          { display: none; }
  .user-avatar-btn    { padding: 4px; gap: 4px; }

  /* Bouton burger : toujours visible, bien à droite */
  .burger-btn {
    display: flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    padding: 8px;
    cursor: pointer;
    flex-shrink: 0;
    order: 99;   /* Toujours en dernier dans le flex */
  }

  /* ── Reste du layout mobile ── */
  .footer-grid                { grid-template-columns: 1fr; gap: 28px; }
  .carousel-section           { height: 360px; }
  .carousel-title             { font-size: 1.3rem; }
  .carousel-btn               { display: none; }
  .carousel-foreground        { padding-right: 2%; }
  .carousel-foreground-img    { height: 80%; }
  .project-hero-inner         { flex-direction: column; gap: 20px; align-items: center; padding: 24px 16px 0; }
  .project-cover-wrap         { width: 100%; display: flex; justify-content: center; }
  .project-cover              { width: 160px; }
  .project-meta               { width: 100%; padding-bottom: 16px; }
  .project-title              { font-size: 1.4rem; }
  .project-actions            { flex-wrap: wrap; gap: 8px; }
  .messages-layout            { grid-template-columns: 1fr; height: calc(100vh - var(--header-h) - 40px); grid-template-rows: auto 1fr; }
  .conversations-list         { max-height: 180px; border-right: none; border-bottom: 1px solid var(--border); }
  .panel-nav                  { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .stats-row                  { grid-template-columns: repeat(2, 1fr); }
  .stats-row--6               { grid-template-columns: repeat(3, 1fr); }
  .panel-grid--2              { grid-template-columns: 1fr; }
  .panel-grid--2fr1           { grid-template-columns: 1fr; }
  .team-hero                  { flex-direction: column; text-align: center; }
  .section                    { padding: 28px 0; }
  .container                  { padding: 0 16px; }
  .panel-header               { flex-direction: column; align-items: flex-start; }
  .data-table th,
  .data-table td              { padding: 8px 10px; font-size: .82rem; }

  /* Releases cards tablette — 2 colonnes */
  .releases-cards { grid-template-columns: repeat(2, 1fr); }

  /* Legacy releases list tablette */
  .release-row { grid-template-columns: 44px 1fr 1.2fr auto; }
  .release-row__team          { display: none; }
}

/* Mobile ≤ 480px */
@media (max-width: 480px) {
  .header-logo span.logo-text { display: none; }  /* Garde uniquement l'étoile + "Scan" */

  .project-grid               { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }

  /* Releases cards mobile — 1 colonne */
  .releases-cards { grid-template-columns: 1fr; }

  /* Legacy releases list mobile */
  .release-row {
    grid-template-columns: 40px 1fr;
    gap: 8px 10px;
    padding: 8px 10px;
  }
  .release-row__chapter,
  .release-row__team { display: none; }
  .release-row__title { grid-column: 2; font-size: .8rem; }
  .release-row__time  { grid-column: 2; font-size: .62rem; }
  /* ── Fiche projet mobile ── */
  .project-actions            { flex-direction: row; flex-wrap: wrap; gap: 8px; align-items: center; }
  .project-actions .btn-lg    { flex: 0 0 100%; text-align: center; justify-content: center; }
  .rate-wrap                  { flex: 0 0 100%; padding: 4px 0; }
  .project-sidebar            { grid-template-columns: 1fr; }
  .project-hero-inner         { padding: 16px 16px 0; }
  .project-cover              { width: 140px; }
  .project-title              { font-size: 1.2rem; }
  .reader-bar-inner           { gap: 6px; padding: 0 10px; }
  .reader-project-title       { display: none; }
  .reader-nav-btn             { font-size: .75rem; padding: 5px 10px; min-width: unset; }

  /* Settings panel mobile : uniquement manga / webtoon */
  .reader-settings-panel .rsp-manga-only,
  #rsp-width,
  .reader-settings-panel .rsp-hint { display: none !important; }
  .reader-settings-panel      { width: 210px; padding: 12px; gap: 10px; }
  .rsp-btn                    { padding: 10px 12px; font-size: .85rem; }

  /* Nav paginée : grosses zones de toucher, au-dessus du bandeau iOS */
  .paged-nav                  { bottom: calc(env(safe-area-inset-bottom, 0px) + 16px); padding: 6px 8px; }
  .paged-nav-btn              { padding: 10px 18px; }
  .paged-nav-counter          { min-width: 56px; font-size: .82rem; }

  /* Manga mobile : toujours pleine largeur */
  .reader-container.reader-manga  { max-width: 100% !important; }

  /* Webtoon mobile : images bord à bord, pas de padding */
  .reader-container.reader-webtoon { max-width: 100% !important; padding: 0; }

  /* Footer mobile webtoon : une seule ligne, boutons compacts */
  .reader-footer {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    padding: 16px 12px;
  }
  .reader-footer .btn {
    font-size: .78rem;
    padding: 8px 10px;
    flex: 1 1 auto;
    min-width: 0;
    text-align: center;
    justify-content: center;
    white-space: nowrap;
  }
  .stats-row                  { grid-template-columns: 1fr 1fr; }
  .stats-row--6               { grid-template-columns: repeat(2, 1fr); }
  .auth-card                  { padding: 24px 16px; }
  .carousel-section           { height: 280px; }
  .carousel-content           { padding: 0; }
  .carousel-text              { padding: 0 16px; }
  .carousel-title             { font-size: 1.1rem; }
  .carousel-subtitle          { display: none; }
  .carousel-foreground-img    { height: 70%; }
  .carousel-foreground        { padding-right: 0; }
  .panel-card                 { padding: 16px; }

  /* Tables admin : masquer colonnes secondaires */
  .data-table .hide-mobile    { display: none; }
}

/* Très petits écrans ≤ 420px */
@media (max-width: 420px) {
  /* Contrôles lecteur : chapitre numéro seul */
  .reader-chapter-label { display: none; }

  /* Nav paginée plus basse */
  .paged-nav { gap: 0; }
}

/* ── Gestion membres team ─────────────────────────────────── */
.member-add-form {
  background: var(--bg-card);
  border: 1px solid var(--accent);
  border-radius: var(--radius-md);
  padding: 20px;
  margin-bottom: 20px;
  animation: slideDown .2s ease;
}
@keyframes slideDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.member-add-inner {
  display: flex;
  gap: 12px;
  align-items: flex-end;
  flex-wrap: wrap;
}
.member-add-actions {
  display: flex;
  gap: 8px;
  align-items: flex-end;
  padding-bottom: 1px;
}

.member-card-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.member-manage-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 4px;
}

/* Badges de rôle team */
.member-role-badge {
  font-size: .72rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  display: inline-block;
}
.member-role-badge--owner  { background: var(--gold-dim);    color: var(--gold);    }
.member-role-badge--admin  { background: var(--accent-glow); color: var(--accent);  }
.member-role-badge--member { background: var(--bg-tertiary); color: var(--text-muted); }

/* ── Admin team grid ──────────────────────────────────────── */
.admin-team-grid {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 900px) {
  .admin-team-grid { grid-template-columns: 1fr; }
}

/* ── Admin password form inline ───────────────────────────── */
.password-admin-form {
  margin-top: 8px;
  padding: 10px 12px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-hover);
  animation: slideDown .15s ease;
}
.pwd-inline-form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.form-input--sm {
  padding: 5px 9px;
  font-size: .82rem;
  border-radius: var(--radius-sm);
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--text-primary);
  max-width: 160px;
}
.form-input--sm:focus { outline: none; border-color: var(--accent); }

/* ── Bouton follow / notification chapitre ────────────────── */
.follow-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 6px;
}

.btn-following {
  color: var(--success);
  border-color: var(--success);
  background: rgba(62, 207, 142, .1);
}
.btn-following:hover {
  background: rgba(62, 207, 142, .18);
  border-color: var(--success);
}

.follow-toast {
  position: absolute;
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-card);
  border: 1px solid var(--border-hover);
  color: var(--text-primary);
  font-size: .78rem;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: var(--radius-md);
  white-space: nowrap;
  box-shadow: var(--shadow-card);
  z-index: 50;
  animation: fadeInUp .2s ease;
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateX(-50%) translateY(6px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* ── Webhook Discord UI ───────────────────────────────────── */
.webhook-status {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  flex-wrap: wrap;
}
.webhook-status-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  flex-shrink: 0;
}
.webhook-status-dot--active   { background: var(--success); box-shadow: 0 0 6px rgba(62,207,142,.5); }
.webhook-status-dot--inactive { background: var(--text-muted); }
.webhook-preview {
  font-size: .75rem;
  color: var(--text-muted);
  background: var(--bg-secondary);
  padding: 2px 8px;
  border-radius: 4px;
  font-family: monospace;
  word-break: break-all;
}
.webhook-test-result {
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  font-size: .875rem;
  font-weight: 600;
}
.webhook-test-result--success { background: rgba(62,207,142,.12); color: var(--success); border: 1px solid rgba(62,207,142,.3); }
.webhook-test-result--error   { background: rgba(232,93,74,.12);  color: var(--danger);  border: 1px solid rgba(232,93,74,.3);  }
.webhook-guide {
  padding-left: 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: var(--text-secondary);
  font-size: .875rem;
  line-height: 1.7;
}
.webhook-guide li strong { color: var(--text-primary); }
.webhook-guide code { background: var(--bg-tertiary); padding: 1px 5px; border-radius: 3px; font-size: .82rem; }
.webhook-example {
  margin-top: 16px;
  padding: 12px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
}
.webhook-example code { font-size: .78rem; color: var(--text-secondary); word-break: break-all; }

/* ── Discord Bot config UI ────────────────────────────────── */
.project-discord-config {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 8px;
  transition: border-color .15s;
}
.project-discord-config:hover { border-color: var(--border-hover); }

.project-discord-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--bg-tertiary);
  cursor: pointer;
}

.project-discord-panel {
  padding: 16px;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--bg-card);
}

.config-status-pill {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
  margin-top: 2px;
}
.config-status-pill--active { background: rgba(62,207,142,.15); color: var(--success); }
.config-status-pill--none   { background: var(--bg-secondary);  color: var(--text-muted); }

.save-feedback {
  font-size: .8rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
}
.save-feedback--success { background: rgba(62,207,142,.12); color: var(--success); }
.save-feedback--error   { background: rgba(232,93,74,.12);  color: var(--danger);  }

/* ── Import ZIP ───────────────────────────────────────────── */
.zip-info-card { margin-bottom: 20px; }

.zip-structure-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 640px) { .zip-structure-grid { grid-template-columns: 1fr; } }

.zip-structure-tree {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px 20px;
  font-family: monospace;
  font-size: .85rem;
  min-width: 220px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.tree-item { color: var(--text-secondary); line-height: 1.6; }
.tree-root  { color: var(--text-primary); font-weight: 700; margin-bottom: 4px; }
.tree-folder { padding-left: 14px; color: var(--accent); }
.tree-file   { padding-left: 28px; color: var(--text-muted); }
.tree-more   { padding-left: 28px; color: var(--text-muted); font-style: italic; }

.zip-structure-rules {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rule-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: .875rem;
  color: var(--text-secondary);
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  line-height: 1.5;
}
.rule-item--ok   { background: rgba(62,207,142,.07); }
.rule-item--warn { background: rgba(240,180,41,.07); }
.rule-icon { font-size: 1rem; flex-shrink: 0; margin-top: 1px; }
.rule-item--ok   .rule-icon { color: var(--success); }
.rule-item--warn .rule-icon { color: var(--warning); }
.rule-item code { background: var(--bg-tertiary); padding: 1px 5px; border-radius: 3px; font-size: .8rem; }

/* Drop zone ZIP */
.zip-drop-zone {
  border: 2px dashed var(--border-hover);
  border-radius: var(--radius-lg);
  padding: 48px 24px;
  text-align: center;
  cursor: pointer;
  transition: all .2s;
  position: relative;
  background: var(--bg-tertiary);
}
.zip-drop-zone:hover,
.zip-drop-zone--hover { border-color: var(--accent); background: var(--accent-soft); }
.zip-drop-text  { font-size: 1rem; font-weight: 600; color: var(--text-secondary); margin-top: 14px; line-height: 1.7; }
.zip-drop-hint  { font-size: .8rem; color: var(--text-muted); margin-top: 4px; }

.zip-file-info {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: var(--accent-soft);
  border: 1px solid rgba(160,32,240,.35);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: .9rem;
}

/* Barre de progression globale */
.zip-progress-header {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.zip-global-progress {
  height: 8px;
  background: var(--bg-tertiary);
  border-radius: 4px;
  overflow: hidden;
}
.zip-global-bar {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), var(--accent-alt));
  border-radius: 4px;
  width: 0%;
  transition: width .3s ease;
}
.zip-progress-label { font-size: .85rem; color: var(--text-secondary); }

/* Résultats */
.zip-result-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  border-radius: var(--radius-md);
  margin-bottom: 4px;
}
.zip-result-header--success { background: rgba(62,207,142,.08); border: 1px solid rgba(62,207,142,.2); }
.zip-result-header--warn    { background: rgba(240,180,41,.08);  border: 1px solid rgba(240,180,41,.2); }

.zip-result-chapter {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 14px;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  font-size: .875rem;
}
.zip-result-num {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--accent);
  min-width: 60px;
}

.zip-error-item {
  padding: 8px 12px;
  background: rgba(232,93,74,.08);
  border-left: 3px solid var(--danger);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  font-size: .85rem;
  color: var(--text-secondary);
}

/* ── Burger animation (barres → croix) ───────────────────── */
.burger-btn--open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.burger-btn--open span:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.burger-btn--open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ══════════════════════════════════════════════════════════════
   PANEL MODÉRATION
   ══════════════════════════════════════════════════════════════ */

/* Rôle badge modérateur */
.role-moderator { background: rgba(139, 92, 246, .15); color: #a78bfa; }

/* Dropdown item modérateur */
.dropdown-item--mod { color: #a78bfa !important; }
.dropdown-item--mod:hover { background: rgba(139, 92, 246, .1) !important; }

/* Badges de type de sanction */
.sanction-type-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: var(--radius-sm);
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.sanction-type-warning { background: rgba(240, 180, 41, .15); color: #f0b429; }
.sanction-type-mute    { background: rgba(59, 130, 246, .15); color: #60a5fa; }
.sanction-type-ban     { background: rgba(232, 93, 74, .15); color: #e85d4a; }

/* Badges de signalement */
.sanction-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: .7rem;
  font-weight: 600;
  background: var(--bg-tertiary);
  color: var(--text-secondary);
}
.sanction-broken_pages  { background: rgba(232, 93, 74, .12); color: #e85d4a; }
.sanction-wrong_chapter { background: rgba(240, 180, 41, .12); color: #f0b429; }
.sanction-quality       { background: rgba(59, 130, 246, .12); color: #60a5fa; }
.sanction-other         { background: rgba(148, 163, 184, .12); color: #94a3b8; }

/* Statuts de signalement */
.report-status {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: .7rem;
  font-weight: 600;
}
.report-status--open      { background: rgba(232, 93, 74, .12); color: #e85d4a; }
.report-status--reviewing { background: rgba(240, 180, 41, .12); color: #f0b429; }
.report-status--resolved  { background: rgba(52, 211, 153, .12); color: #34d399; }
.report-status--dismissed { background: rgba(148, 163, 184, .12); color: #94a3b8; }

/* Dots de statut */
.status-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 4px;
  vertical-align: middle;
}
.status-active  { background: #34d399; }
.status-expired { background: #94a3b8; }
.status-revoked { background: #f0b429; }

/* Row muted (sanction expirée) */
.row-muted { opacity: .5; }

/* User header modération */
.mod-user-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.mod-user-info {
  display: flex;
  align-items: center;
  gap: 16px;
}
.mod-user-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
}
.mod-user-avatar-placeholder {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
}
.mod-user-name {
  font-family: var(--font-display);
  font-size: 1.2rem;
  margin: 0 0 4px;
}
.mod-user-meta {
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  font-size: .8rem;
  color: var(--text-muted);
  margin-top: 6px;
}
.mod-user-quick-stats {
  display: flex;
  gap: 20px;
}
.mod-quick-stat {
  text-align: center;
}
.mod-quick-stat-value {
  display: block;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-primary);
}
.mod-quick-stat-label {
  font-size: .7rem;
  color: var(--text-muted);
  font-weight: 600;
}

/* Formulaire sanction — type selector */
.sanction-type-selector {
  display: flex;
  gap: 10px;
  margin-bottom: 12px;
}
.sanction-type-option {
  cursor: pointer;
}
.sanction-type-option input[type="radio"] {
  display: none;
}
.sanction-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 14px 20px;
  border: 2px solid var(--border);
  border-radius: var(--radius-md);
  font-size: .8rem;
  font-weight: 600;
  transition: all .15s;
  min-width: 90px;
}
.sanction-type-icon { font-size: 1.3rem; }
.sanction-type-option input:checked + .sanction-type-card {
  border-color: var(--accent);
  background: rgba(139, 92, 246, .08);
}
.sanction-type-option input:checked + .sanction-type-card.sanction-type-warning {
  border-color: #f0b429;
  background: rgba(240, 180, 41, .08);
}
.sanction-type-option input:checked + .sanction-type-card.sanction-type-mute {
  border-color: #60a5fa;
  background: rgba(59, 130, 246, .08);
}
.sanction-type-option input:checked + .sanction-type-card.sanction-type-ban {
  border-color: #e85d4a;
  background: rgba(232, 93, 74, .08);
}

/* Formulaire de sanction */
.mod-sanction-form .form-group { margin-bottom: 14px; }

/* Notes internes */
.mod-note-form { margin-bottom: 16px; }
.mod-notes-list { display: flex; flex-direction: column; gap: 10px; margin-top: 12px; }
.mod-note {
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
}
.mod-note-header {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .75rem;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.mod-note-content {
  font-size: .85rem;
  margin: 0;
  white-space: pre-wrap;
}
.btn-icon-delete {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 1rem;
  padding: 0 4px;
  transition: color .15s;
}
.btn-icon-delete:hover { color: #e85d4a; }

/* Journal de modération */
.mod-log-list { display: flex; flex-direction: column; gap: 8px; }
.mod-log-entry {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-tertiary);
  border-radius: va