:root {
  --bg: #050505;
  --bg-soft: #0d0d0f;
  --panel: #151517;
  --panel-strong: #1d1d21;
  --text: #ffffff;
  --muted: #b8b8bd;
  --brand: #e50914;
  --brand-2: #ff3d47;
  --line: rgba(255, 255, 255, 0.12);
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.65);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--text);
  background: var(--bg);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }

.topbar {
  position: fixed;
  inset: 0 0 auto;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px clamp(18px, 4vw, 58px);
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.92), rgba(0, 0, 0, 0.55) 62%, transparent);
  transition: background 0.2s ease, border-color 0.2s ease;
}
.topbar.scrolled {
  background: rgba(5, 5, 5, 0.94);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(16px);
}

.leftnav, .rightnav { display: flex; align-items: center; gap: 22px; }
.rightnav { justify-content: flex-end; }
.brand-link { display: inline-flex; }

.logo {
  display: inline-flex;
  align-items: center;
  color: var(--brand);
  font-weight: 1000;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1;
  text-shadow: 0 0 22px rgba(229, 9, 20, 0.18);
}
.logo-small { font-size: 24px; }

.navlinks { display: flex; gap: 18px; color: #e9e9e9; font-size: 14px; }
.navlinks a { opacity: 0.82; transition: opacity 0.18s ease, color 0.18s ease; }
.navlinks a:hover { opacity: 1; color: #fff; }
.nav-pill {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  padding: 9px 13px;
  background: var(--brand);
  color: #fff;
  font-size: 13px;
  font-weight: 850;
}
.nav-pill.muted { background: rgba(255, 255, 255, 0.08); }
.avatar {
  width: 35px;
  height: 35px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #2d2d32, #111);
  border: 1px solid rgba(255, 255, 255, 0.18);
  font-weight: 900;
}

.hero {
  min-height: 92vh;
  position: relative;
  display: flex;
  align-items: center;
  padding: 120px clamp(18px, 4vw, 58px) 110px;
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -3;
  background:
    linear-gradient(90deg, rgba(0,0,0,.98), rgba(0,0,0,.78) 30%, rgba(0,0,0,.24) 62%, rgba(0,0,0,.9)),
    linear-gradient(0deg, var(--bg), rgba(0,0,0,.08) 42%, rgba(0,0,0,.65)),
    var(--hero-image, linear-gradient(135deg, #181818, #020202)),
    radial-gradient(circle at 74% 34%, rgba(229,9,20,.42), transparent 30%),
    linear-gradient(135deg, #181818, #020202);
  background-size: cover;
  background-position: center;
}
.hero::after {
  content: "";
  position: absolute;
  inset: auto -6% -12%;
  height: 36%;
  z-index: -1;
  background: linear-gradient(180deg, transparent, var(--bg) 68%);
}
.hero-content { max-width: 720px; }
.hero > .hero-content:not(.hero-featured) { display: none; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 18px;
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 12px;
}
.eyebrow::before {
  content: "";
  width: 34px;
  height: 3px;
  border-radius: 999px;
  background: var(--brand);
  box-shadow: 0 0 22px rgba(229, 9, 20, 0.8);
}
.eyebrow.compact { margin: 0 0 8px; color: var(--muted); }
.hero h1 {
  margin: 0;
  max-width: 740px;
  font-size: clamp(44px, 8.5vw, 104px);
  line-height: 0.9;
  letter-spacing: -0.055em;
  text-transform: uppercase;
}
.hero h1 span { color: var(--brand); text-shadow: 0 0 35px rgba(229,9,20,.32); }
.hero p {
  margin: 26px 0 0;
  max-width: 590px;
  color: #e8e8e8;
  line-height: 1.65;
  font-size: clamp(16px, 1.5vw, 20px);
  text-shadow: 0 2px 12px rgba(0,0,0,.7);
}
.hero-art {
  position: absolute;
  right: 2vw;
  top: 12vh;
  width: min(54vw, 760px);
  height: min(62vh, 640px);
  z-index: -2;
  opacity: .9;
  display: none;
}
.poster-cloud { position: absolute; inset: 0; transform: rotate(-4deg); filter: drop-shadow(0 34px 38px rgba(0,0,0,.7)); }
.floating-card {
  position: absolute;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(145deg, var(--c1), var(--c2));
  box-shadow: var(--shadow);
}
.floating-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 20%,rgba(255,255,255,.28),transparent 22%), linear-gradient(180deg,transparent,rgba(0,0,0,.76));
}
.floating-card::after {
  content: attr(data-title);
  position: absolute;
  left: 16px;
  right: 16px;
  bottom: 14px;
  font-weight: 950;
  font-size: 18px;
  line-height: 1.05;
  text-shadow: 0 3px 10px rgba(0,0,0,.8);
}
.fc1{--c1:#262626;--c2:#991b1b;width:230px;height:330px;left:12%;top:9%}
.fc2{--c1:#111;--c2:#b91c1c;width:255px;height:365px;left:43%;top:2%;transform:scale(1.05);z-index:2}
.fc3{--c1:#1f2937;--c2:#475569;width:210px;height:300px;left:69%;top:18%}
.fc4{--c1:#18181b;--c2:#9a3412;width:220px;height:315px;left:29%;top:46%;z-index:1}
.fc5{--c1:#0f172a;--c2:#334155;width:240px;height:340px;left:58%;top:50%}

.meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; color: #dedede; font-weight: 750; font-size: 14px; }
.meta span, .meta button { padding: 6px 10px; border-radius: 999px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.08); }
.meta .match { color: #64df80; background: rgba(80,214,107,.12); }
.recommendation-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  border: 1px solid transparent;
  border-radius: 999px;
  padding: 7px 12px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: -.01em;
  color: #fff;
  white-space: nowrap;
}
button.recommendation-pill { cursor: default; font: inherit; }
.recommendation-pill.big { padding: 10px 16px; font-size: 18px; }
.recommendation-good { color: #9af5ad; background: rgba(86,209,109,.15); border-color: rgba(86,209,109,.34); }
.recommendation-warn { color: #ffd18a; background: rgba(245,158,11,.17); border-color: rgba(245,158,11,.4); }
.recommendation-bad { color: #ffb0b0; background: rgba(239,68,68,.16); border-color: rgba(239,68,68,.42); }
.actions { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 28px; }
.btn {
  border: 0;
  border-radius: 6px;
  padding: 13px 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-weight: 850;
  cursor: pointer;
  transition: transform .18s ease, background .18s ease, opacity .18s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: #fff; color: #000; }
.btn-primary:hover { background: #dedede; }
.btn-ghost { background: rgba(109,109,110,.75); color: #fff; backdrop-filter: blur(8px); }

main { position: relative; margin-top: -74px; padding-bottom: 70px; }
.section { padding: 0 clamp(18px, 4vw, 58px); margin: 0 0 42px; }
.section-head { display: flex; align-items: center; justify-content: space-between; margin: 0 0 12px; }
.section h2 { font-size: clamp(20px, 2vw, 29px); margin: 0; letter-spacing: -0.025em; }
.see-all { font-size: 13px; color: #d8e5ff; opacity: 0; transform: translateX(-8px); transition: .18s ease; }
.section:hover .see-all { opacity: 1; transform: translateX(0); }

.row-wrap { position: relative; }
.row-wrap:hover { z-index: 20; }
.row {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(280px, 16vw);
  gap: 8px;
  overflow-x: auto;
  overflow-y: visible;
  padding: 18px 0 98px;
  scrollbar-width: none;
  scroll-snap-type: x proximity;
}
.row::-webkit-scrollbar { display: none; }
.scroll-btn {
  position: absolute;
  top: 6px;
  bottom: 34px;
  width: 44px;
  border: 0;
  color: #fff;
  background: rgba(0,0,0,.55);
  z-index: 5;
  cursor: pointer;
  opacity: 0;
  transition: opacity .18s ease;
  font-size: 28px;
}
.row-wrap:hover .scroll-btn { opacity: 1; }
.scroll-left { left: 0; border-radius: 8px 0 0 8px; }
.scroll-right { right: 0; border-radius: 0 8px 8px 0; }

.card {
  scroll-snap-align: start;
  min-height: 0;
  aspect-ratio: 16 / 9;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: linear-gradient(135deg, var(--a), var(--b));
  background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.78)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
  box-shadow: 0 14px 25px rgba(0,0,0,.3);
  border: 1px solid rgba(255,255,255,.08);
  transform-origin: center bottom;
  transition: transform .2s ease, box-shadow .2s ease, z-index .2s ease, border-radius .2s ease;
}
.card:hover { transform: scale(1.16) translateY(-18px); z-index: 50; border-radius: 5px; box-shadow: 0 28px 45px rgba(0,0,0,.72); }
.card:not(.rank-card) { overflow: visible; }
.card:not(.rank-card)::after {
  content: attr(data-title) "\A Lecture · Infos · " attr(data-chapters) " chapitres";
  white-space: pre-line;
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% - 3px);
  padding: 12px 14px 14px;
  border-radius: 0 0 5px 5px;
  background: #181818;
  color: #fff;
  font-size: 13px;
  line-height: 1.45;
  opacity: 0;
  pointer-events: none;
  box-shadow: 0 24px 38px rgba(0,0,0,.55);
  transform: translateY(-6px);
  transition: opacity .18s ease, transform .18s ease;
}
.card:not(.rank-card):hover::after {
  opacity: 1;
  transform: translateY(0);
}
.card .badge {
  position: absolute;
  top: 9px;
  left: 9px;
  background: var(--brand);
  border-radius: 4px;
  padding: 3px 6px;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
}
.card .title { position: absolute; left: 12px; right: 12px; bottom: 12px; font-weight: 950; font-size: 15px; line-height: 1.05; text-shadow: 0 3px 9px rgba(0,0,0,.85); }
.card .play-mini {
  position: absolute;
  right: 10px;
  top: 9px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.58);
  border: 1px solid rgba(255,255,255,.2);
  opacity: 0;
  transform: translateY(-5px);
  transition: .18s ease;
}
.card:hover .play-mini { opacity: 1; transform: translateY(0); }

.rank-row { grid-auto-columns: minmax(300px, 18vw); }
.rank-card { display: flex; align-items: stretch; background: transparent; border: 0; box-shadow: none; overflow: visible; min-height: 148px; }
.rank-card:hover { box-shadow: none; }
.rank-num {
  width: 86px;
  flex: 0 0 86px;
  font-size: 112px;
  line-height: .86;
  color: #050505;
  -webkit-text-stroke: 2px #777;
  font-weight: 1000;
  letter-spacing: -0.12em;
  transform: translateX(8px);
  z-index: 0;
}
.rank-poster {
  flex: 1;
  border-radius: 8px;
  margin-left: -6px;
  background: linear-gradient(135deg, var(--a), var(--b));
  background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  min-width: 140px;
}
.rank-poster .title { position: absolute; left: 11px; right: 11px; bottom: 11px; font-weight: 950; }

.plans { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; margin-top: 8px; }
.plan {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #1b1b1d, #0e0e0f);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 24px;
  box-shadow: 0 18px 35px rgba(0,0,0,.22);
}
.plan.featured { border-color: rgba(229,9,20,.62); box-shadow: 0 22px 50px rgba(229,9,20,.12); }
.plan-ribbon { position: absolute; right: 16px; top: 16px; background: var(--brand); padding: 5px 9px; border-radius: 999px; font-size: 11px; font-weight: 900; }
.plan h3 { margin: 0 0 10px; font-size: 22px; }
.price { font-size: 30px; font-weight: 950; margin: 16px 0 12px; }
.plan ul { margin: 0; padding: 0; list-style: none; color: #ddd; display: grid; gap: 9px; }
.plan li::before { content: "✓"; color: #56d16d; margin-right: 8px; font-weight: 900; }

.footer { padding: 42px clamp(18px, 4vw, 58px); color: #8c8c8c; border-top: 1px solid rgba(255,255,255,.08); background: #050505; }
.footer-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin: 24px 0; }
.footer a { font-size: 13px; text-decoration: underline; color: #929292; }
.disclaimer { max-width: 820px; font-size: 12px; line-height: 1.6; color: #787878; }

.modal { position: fixed; inset: 0; z-index: 80; display: none; align-items: center; justify-content: center; padding: 22px; background: rgba(0,0,0,.78); backdrop-filter: blur(10px); }
.modal.open { display: flex; }
.modal-card { width: min(940px, calc(100vw - 40px)); max-height: min(92vh, 920px); overflow: auto; border-radius: 8px; background: #161616; box-shadow: 0 35px 90px rgba(0,0,0,.75); border: 1px solid rgba(255,255,255,.12); position: relative; }
.modal-card::-webkit-scrollbar,
.reader-content::-webkit-scrollbar {
  width: 10px;
}
.modal-card::-webkit-scrollbar-track,
.reader-content::-webkit-scrollbar-track {
  background: #101012;
}
.modal-card::-webkit-scrollbar-thumb,
.reader-content::-webkit-scrollbar-thumb {
  background: #4a4a4f;
  border-radius: 999px;
  border: 2px solid #101012;
}
.modal-card::-webkit-scrollbar-thumb:hover,
.reader-content::-webkit-scrollbar-thumb:hover {
  background: #77777e;
}
.modal-visual {
  position: relative;
  height: min(54vh, 520px);
  background: linear-gradient(135deg, var(--a,#200122), var(--b,#6f0000));
  background-image: linear-gradient(180deg, transparent, rgba(22,22,22,1)), var(--image), linear-gradient(135deg, var(--a,#200122), var(--b,#6f0000));
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
.modal-slides { position: absolute; inset: 0; }
.modal-slide {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transform: scale(1.025);
  transition: opacity 1.1s ease, transform 4.2s ease;
}
.modal-slide.active { opacity: 1; transform: scale(1); }
.modal-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(22,22,22,1));
}
.modal-close { position: absolute; right: 16px; top: 16px; z-index: 3; width: 38px; height: 38px; border-radius: 999px; border: 0; background: rgba(0,0,0,.62); color: #fff; font-size: 24px; cursor: pointer; }
.modal-body { padding: 0 clamp(22px,4vw,48px) 34px; margin-top: -118px; position: relative; }
.modal-title { font-size: clamp(42px, 7vw, 82px); line-height: .88; margin: 0 0 16px; letter-spacing: -0.055em; max-width: 720px; }
.modal-body p { color: #d4d4d4; line-height: 1.65; max-width: 720px; }
.modal-detail-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(240px, .65fr);
  gap: 28px;
  margin-top: 18px;
}
.modal-slogan {
  margin: 0 0 14px;
  font-size: 18px;
  color: #fff !important;
  font-weight: 800;
}
.modal-chapters {
  margin-top: 18px;
}
.modal-chapters h3 {
  margin: 0 0 8px;
  font-size: 24px;
}
.modal-chapters p {
  margin: 0;
  color: var(--muted);
}
.modal-side-info {
  display: grid;
  align-content: start;
  gap: 12px;
  color: #fff;
}
.modal-side-info p {
  margin: 0;
  line-height: 1.45;
}
.modal-side-info span {
  color: #8f8f95;
}

.auth-page {
  min-height: 100vh;
  background:
    linear-gradient(90deg, rgba(0,0,0,.94), rgba(0,0,0,.54)),
    linear-gradient(135deg, #111, #300707 58%, #050505);
}
.auth-shell { min-height: 100vh; display: grid; place-items: center; padding: 28px; }
.auth-card {
  width: min(440px, 100%);
  padding: 34px;
  border-radius: 8px;
  background: rgba(12, 12, 14, 0.88);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.auth-card h1 { margin: 28px 0 8px; font-size: 34px; letter-spacing: -0.03em; }
.auth-card p { color: var(--muted); line-height: 1.55; }
.form-stack { display: grid; gap: 15px; margin-top: 22px; }
label { display: grid; gap: 7px; color: #dedede; font-weight: 750; font-size: 13px; }
input, textarea, select {
  width: 100%;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 6px;
  background: #0c0c0e;
  color: #fff;
  padding: 12px 13px;
}
textarea { resize: vertical; }
.form-error, .flash {
  padding: 12px 14px;
  border-radius: 6px;
  margin: 16px 0;
  border: 1px solid rgba(229,9,20,.4);
  background: rgba(229,9,20,.12);
  color: #ffd7da;
}
.flash { border-color: rgba(86,209,109,.4); background: rgba(86,209,109,.12); color: #d9ffe1; }
.auth-switch a { color: #fff; text-decoration: underline; }

.admin-page { background: #08080a; }
.admin-header {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px clamp(18px, 4vw, 42px);
  background: rgba(8,8,10,.94);
  border-bottom: 1px solid var(--line);
}
.admin-header nav { display: flex; gap: 14px; color: #ddd; font-size: 14px; }
.admin-layout { display: grid; grid-template-columns: 230px minmax(0, 1fr); gap: 28px; max-width: 1500px; margin: 0 auto; padding: 30px clamp(18px, 4vw, 42px) 70px; }
.admin-sidebar { position: sticky; top: 86px; align-self: start; display: grid; gap: 10px; padding: 18px; border: 1px solid var(--line); border-radius: 8px; background: #101012; }
.admin-sidebar a { color: #cfcfd4; font-size: 14px; }
.admin-content { display: grid; gap: 22px; }
.admin-title { display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.admin-title h1 { margin: 0; font-size: clamp(32px, 4vw, 52px); letter-spacing: -0.04em; }
.admin-panel { padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: #111114; box-shadow: 0 18px 38px rgba(0,0,0,.22); }
.panel-head { display: flex; justify-content: space-between; gap: 16px; align-items: center; margin-bottom: 18px; }
.panel-head h2 { margin: 0; font-size: 22px; }
.admin-grid { display: grid; gap: 14px; }
.admin-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-grid .wide { grid-column: 1 / -1; }
.table-scroll { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 820px; }
.admin-table th, .admin-table td { padding: 10px; border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; vertical-align: top; }
.admin-table th { color: #aaa; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.section-admin-title { margin: 26px 0 12px; }
.item-editor-list { display: grid; gap: 14px; }
.item-editor { display: grid; grid-template-columns: 180px minmax(0, 1fr) auto; gap: 16px; align-items: start; padding: 14px; border: 1px solid rgba(255,255,255,.1); border-radius: 8px; background: #0c0c0e; }
.item-preview {
  min-height: 116px;
  border-radius: 8px;
  padding: 12px;
  display: flex;
  align-items: flex-end;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
  font-weight: 950;
}
.danger-link {
  border: 1px solid rgba(229,9,20,.42);
  border-radius: 6px;
  background: rgba(229,9,20,.1);
  color: #ffb7bb;
  padding: 9px 10px;
  cursor: pointer;
}

.admin-shell {
  position: relative;
  margin-top: 0;
  max-width: 1460px;
  margin: 0 auto;
  padding: 30px clamp(18px, 4vw, 42px) 76px;
}
.admin-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}
.admin-hero h1 {
  margin: 0;
  font-size: clamp(34px, 4.5vw, 58px);
  letter-spacing: -0.045em;
}
.admin-hero p:not(.eyebrow) {
  margin: 10px 0 0;
  color: var(--muted);
  max-width: 720px;
  line-height: 1.55;
}
.admin-tabs {
  position: sticky;
  top: 65px;
  z-index: 9;
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 10px;
  margin: 0 0 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(10,10,12,.94);
  backdrop-filter: blur(14px);
}
.admin-tab {
  flex: 0 0 auto;
  border-radius: 6px;
  padding: 10px 13px;
  color: #d7d7dc;
  font-size: 14px;
  font-weight: 800;
}
.admin-tab:hover,
.admin-tab.active {
  background: #fff;
  color: #070707;
}
.admin-tab-panel { display: none; }
.admin-tab-panel.active { display: block; }
.admin-subpanel {
  padding: 16px;
  margin-bottom: 20px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #0c0c0e;
}
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.stat-grid article {
  padding: 20px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: linear-gradient(180deg, #17171a, #0d0d0f);
}
.stat-grid strong {
  display: block;
  font-size: 38px;
  line-height: 1;
}
.stat-grid span,
.muted-note {
  color: var(--muted);
  font-size: 13px;
}
.flash-error {
  border-color: rgba(229,9,20,.4);
  background: rgba(229,9,20,.12);
  color: #ffd7da;
}
.compact-list { gap: 10px; }
details.item-editor,
details.user-editor {
  display: block;
  padding: 0;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #0c0c0e;
  overflow: hidden;
}
details.item-editor summary,
details.user-editor summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 13px 14px;
  cursor: pointer;
  list-style: none;
}
details.item-editor summary::-webkit-details-marker,
details.user-editor summary::-webkit-details-marker { display: none; }
details.item-editor summary span:nth-child(2),
details.user-editor summary span:first-child { display: grid; gap: 3px; min-width: 0; }
details.item-editor summary small,
details.user-editor summary small { color: var(--muted); font-size: 12px; }
details.item-editor[open],
details.user-editor[open] { border-color: rgba(255,255,255,.18); }
details.item-editor .admin-grid,
details.user-editor .admin-grid {
  padding: 0 14px 14px;
}
.item-preview.mini {
  width: 96px;
  min-height: 58px;
  flex: 0 0 96px;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
}
details.item-editor .danger-link {
  margin: 0 14px 14px;
}
.screenshot-editor-list,
.user-editor-list {
  display: grid;
  gap: 14px;
  margin: 18px 0;
}
.screenshot-editor-list h3 {
  margin: 12px 0 0;
}
.screenshot-editor {
  display: grid;
  grid-template-columns: 210px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #0c0c0e;
}
.screenshot-editor img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 6px;
  background: #151515;
}
.permission-box {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 12px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px;
}
.permission-box legend {
  padding: 0 6px;
  color: #fff;
  font-size: 13px;
  font-weight: 850;
}
.permission-box label,
label:has(input[type="checkbox"]) {
  display: flex;
  align-items: center;
  gap: 9px;
}
input[type="checkbox"] {
  width: auto;
  accent-color: var(--brand);
}
.status-pill {
  border-radius: 999px;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 850;
}
.status-pill.ok {
  background: rgba(86,209,109,.13);
  color: #9af5ad;
}
.status-pill.off {
  background: rgba(229,9,20,.13);
  color: #ffb7bb;
}
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}
.catalog-tile {
  position: relative;
  min-width: 0;
}
.catalog-card {
  display: block;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: #0c0c0e;
  overflow: hidden;
}
.legacy-inline-editor { display: none; }
.catalog-link-card {
  min-height: 100%;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.catalog-link-card:hover {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  background: #131316;
}
.catalog-edit-cta {
  display: block;
  margin: 0 13px 13px;
  border-radius: 6px;
  padding: 9px 10px;
  background: #fff;
  color: #050505;
  text-align: center;
  font-size: 13px;
  font-weight: 900;
}
.catalog-card summary {
  display: grid;
  grid-template-rows: 150px auto;
  cursor: pointer;
  list-style: none;
}
.catalog-card summary::-webkit-details-marker { display: none; }
.catalog-poster {
  display: block;
  min-height: 150px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
}
.catalog-info {
  display: grid;
  gap: 4px;
  padding: 13px;
}
.catalog-info strong {
  font-size: 17px;
  line-height: 1.15;
}
.catalog-info small,
.catalog-info span {
  color: var(--muted);
  font-size: 12px;
}
.catalog-card[open] {
  grid-column: span 2;
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 26px 55px rgba(0,0,0,.34);
}
.catalog-editor {
  display: grid;
  gap: 18px;
  padding: 14px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.catalog-form {
  display: grid;
  gap: 14px;
}
.tile-delete {
  position: absolute;
  right: 9px;
  top: 9px;
  z-index: 3;
  width: 31px;
  height: 31px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(0,0,0,.72);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}
.tile-delete:hover {
  background: var(--brand);
}
.tile-delete.small {
  right: 8px;
  top: 8px;
  width: 25px;
  height: 25px;
  font-size: 18px;
}
.inline-screenshots {
  display: grid;
  gap: 14px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.inline-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.inline-title h3 {
  margin: 0;
}
.inline-title span {
  color: var(--muted);
  font-size: 12px;
}
.screenshot-inline-form {
  display: grid;
  gap: 13px;
}
.screenshot-strip {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
  gap: 12px;
}
.screenshot-chip {
  position: relative;
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #111114;
}
.screenshot-chip img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 6px;
  background: #18181b;
}
.screenshot-chip > div {
  display: grid;
  gap: 8px;
}
.banner-preview {
  display: grid;
  gap: 8px;
}
.banner-preview span {
  color: var(--muted);
  font-size: 13px;
}
.banner-preview img {
  width: 100%;
  max-height: 240px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.12);
}
.editor-shell {
  position: relative;
  margin-top: 0;
  max-width: 1420px;
  margin-left: auto;
  margin-right: auto;
  padding: 28px clamp(18px, 4vw, 42px) 76px;
}
.back-link {
  display: inline-flex;
  margin-bottom: 18px;
  color: #ddd;
  font-weight: 850;
}
.editor-hero {
  display: grid;
  grid-template-columns: minmax(260px, 420px) minmax(0, 1fr);
  gap: 24px;
  align-items: end;
  margin-bottom: 22px;
}
.editor-hero-preview {
  min-height: 230px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
  box-shadow: 0 22px 48px rgba(0,0,0,.28);
}
.editor-hero h1 {
  margin: 0;
  font-size: clamp(42px, 6vw, 82px);
  line-height: .9;
  letter-spacing: -0.055em;
}
.editor-hero p:not(.eyebrow) {
  color: var(--muted);
}
.editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 22px;
}
.editor-main-form {
  display: grid;
  gap: 14px;
}
.screenshot-strip.large {
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
}
.chapter-editor-list,
.music-editor-list {
  display: grid;
  gap: 16px;
}
.chapter-editor,
.music-cue-editor {
  display: grid;
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #0c0c0e;
}
.chapter-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.rich-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  grid-column: 1 / -1;
}
.rich-toolbar button {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 6px;
  background: #19191d;
  color: #fff;
  padding: 8px 10px;
  cursor: pointer;
}
.rich-editor {
  grid-column: 1 / -1;
  min-height: 280px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 8px;
  background: #08080a;
  color: #f5f5f5;
  line-height: 1.75;
  outline: none;
}
.rich-editor:focus {
  border-color: rgba(255,255,255,.36);
}
.reader-page {
  background: #070707;
}
.reader-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px clamp(18px,4vw,42px);
  background: rgba(7,7,7,.94);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
.reader-header nav {
  display: flex;
  gap: 14px;
  color: #ddd;
}
.reader-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1040px) 300px;
  gap: 28px;
  max-width: 1720px;
  margin: 0 auto;
  padding: 34px clamp(18px,4vw,42px) 80px;
}
.reader-sidebar,
.music-panel {
  position: sticky;
  top: 86px;
  align-self: start;
  display: grid;
  gap: 16px;
}
.reader-cover {
  aspect-ratio: 16 / 9;
  min-height: 0;
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)), var(--image), linear-gradient(135deg, var(--a), var(--b));
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.12);
}
.reader-sidebar h1 {
  margin: 0;
  font-size: 32px;
  line-height: .95;
  letter-spacing: -.035em;
}
.reader-sidebar p,
.reader-synopsis p {
  color: var(--muted);
  line-height: 1.6;
}
.reader-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.reader-tags span,
.chapter-nav a {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 8px 10px;
  background: rgba(255,255,255,.06);
  color: #ddd;
  font-size: 13px;
}
.chapter-nav {
  display: grid;
  gap: 8px;
}
.chapter-nav a {
  border-radius: 6px;
}
.chapter-nav a.active {
  background: #fff;
  color: #070707;
}
.reader-content {
  padding: clamp(22px,4vw,46px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #101012;
  box-shadow: 0 24px 70px rgba(0,0,0,.32);
  max-height: calc(100vh - 112px);
  overflow: auto;
}
.reader-content h2 {
  margin: 0 0 20px;
  font-size: clamp(34px,5vw,60px);
  line-height: .95;
  letter-spacing: -.045em;
}
.reader-synopsis {
  margin-bottom: 28px;
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.reader-text {
  color: #f1f1f1;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 21px;
  line-height: 1.95;
}
.reader-text p {
  margin: 0 0 1.25em;
}
.reader-text blockquote {
  margin: 1.6em 0;
  padding: .4em 1.2em;
  border-left: 3px solid var(--brand);
  color: #ddd;
  background: rgba(255,255,255,.04);
}
.reader-feedback {
  margin-top: 38px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.reader-feedback h2 {
  font-size: 28px;
}
.feedback-bars {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}
.feedback-bars div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 6px;
  background: rgba(255,255,255,.06);
}
.feedback-bars p {
  margin: 0;
  color: var(--muted);
}
.vote-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.music-panel {
  padding: 18px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #101012;
}
.music-panel h2 {
  margin: 0;
  font-size: 20px;
}
.music-cue {
  display: grid;
  gap: 7px;
  padding: 13px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: #0b0b0d;
}
.music-cue span {
  color: #fff;
}
.music-cue p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.music-cue a {
  color: #fff;
  text-decoration: underline;
}
.music-cue audio,
.youtube-player {
  width: 100%;
}
.youtube-player {
  aspect-ratio: 16 / 9;
  border: 0;
  border-radius: 6px;
}
.btn.disabled {
  opacity: .45;
  pointer-events: none;
}


.reader-header-actions {
  display: flex;
  align-items: center;
  gap: 16px;
}
.reader-panel-toggle {
  padding: 10px 14px;
}
.reader-page.panels-collapsed .reader-shell {
  grid-template-columns: minmax(0, 1fr);
  max-width: none;
}
.reader-page.panels-collapsed .reader-sidebar,
.reader-page.panels-collapsed .music-panel {
  display: none;
}
.reader-page.panels-collapsed .reader-content {
  max-height: none;
}
.reader-page.panels-collapsed .reader-text {
  max-width: 1160px;
  margin: 0 auto;
}
.reader-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 24px;
}
.reader-title-row h2 {
  margin-bottom: 0;
}
.reader-recommendation {
  margin-top: 38px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.recommendation-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}
.recommendation-head h2 {
  margin: 0 0 8px;
  font-size: 28px;
}
.recommendation-head p {
  margin: 0;
  color: var(--muted);
}
.music-selection-helper {
  display: grid;
  gap: 8px;
  margin: 10px 0 14px;
}
.inline-music-cue {
  display: inline-grid;
  grid-template-columns: minmax(0, auto);
  gap: 6px;
  max-width: min(100%, 430px);
  margin: 0 .28em;
  padding: 10px 12px;
  vertical-align: middle;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,.035));
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 13px;
  line-height: 1.25;
  color: #fff;
  box-shadow: 0 12px 34px rgba(0,0,0,.22);
}
.inline-music-cue strong,
.music-cue strong {
  font-size: 14px;
}
.music-cue-label {
  color: #d7d7dc;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.inline-music-cue small,
.music-cue small {
  color: var(--muted);
}
.music-cue-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.mini-control {
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: #fff;
  color: #000;
  padding: 7px 10px;
  font-weight: 900;
  cursor: pointer;
}
.mini-control.muted {
  background: rgba(255,255,255,.09);
  color: #fff;
}
.inline-music-cue.is-playing,
.music-cue.is-playing {
  border-color: rgba(86,209,109,.5);
  box-shadow: 0 0 0 1px rgba(86,209,109,.2), 0 14px 38px rgba(0,0,0,.28);
}
.music-after-text {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}
.music-external-link {
  color: #fff;
  text-decoration: underline;
}
.music-cue-compact {
  gap: 9px;
}

@media (max-width: 920px) {
  .navlinks { display: none; }
  .topbar { align-items: flex-start; }
  .rightnav { gap: 8px; flex-wrap: wrap; }
  .hero { min-height: 84vh; padding-top: 110px; }
  .hero-art { opacity: .32; right: -28vw; width: 95vw; }
  main { margin-top: -30px; }
  .row { grid-auto-columns: minmax(220px, 52vw); }
  .rank-row { grid-auto-columns: minmax(210px, 65vw); }
  .plans, .admin-grid.two, .admin-layout, .item-editor { grid-template-columns: 1fr; }
  .stat-grid, .screenshot-editor { grid-template-columns: 1fr; }
  .editor-hero { grid-template-columns: 1fr; }
  .reader-shell { grid-template-columns: 1fr; }
  .reader-header-actions { align-items: flex-end; flex-direction: column; gap: 9px; }
  .reader-title-row, .recommendation-head { flex-direction: column; }
  .reader-sidebar,
  .music-panel { position: static; }
  .modal-detail-grid { grid-template-columns: 1fr; }
  .catalog-card[open] { grid-column: auto; }
  .admin-hero { align-items: flex-start; flex-direction: column; }
  .admin-sidebar { position: static; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px) {
  .logo-word { font-size: 23px; }
  .logo-mark { width: 39px; height: 31px; }
  .hero p { font-size: 15px; }
  .actions .btn, .auth-card .btn { width: 100%; }
  .topbar, .section, .footer { padding-left: 16px; padding-right: 16px; }
  .footer-grid { grid-template-columns: 1fr; }
  .modal-visual { height: 240px; }
  .modal-title { font-size: 32px; }
}

/* v3 catalog hover: reserve invisible space around the horizontal rows so expanded cards are not clipped. */
.section {
  position: relative;
  z-index: 1;
}
.section:hover {
  z-index: 35;
}
.row-wrap {
  --hover-room-x: clamp(52px, 5vw, 82px);
  overflow: visible;
}
.row {
  padding: 32px var(--hover-room-x) 124px;
  margin: -18px calc(-1 * var(--hover-room-x)) -84px;
  overscroll-behavior-inline: contain;
}
.scroll-btn {
  top: 26px;
  bottom: 56px;
}
.card:hover {
  z-index: 80;
}
.card:not(.rank-card)::after {
  z-index: 81;
}

/* v3 admin editor: toolbar stays available while editing long chapters. */
.rich-toolbar {
  position: sticky;
  top: 68px;
  z-index: 18;
  padding: 8px;
  margin: -8px -8px 0;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: rgba(12,12,14,.96);
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
  backdrop-filter: blur(12px);
}
.rich-toolbar button:hover {
  background: #25252b;
}
.rich-editor strong,
.reader-text strong { font-weight: 900; }
.rich-editor em,
.reader-text em { font-style: italic; }
.rich-editor u,
.reader-text u { text-underline-offset: .16em; }
.rich-editor h2,
.reader-text h2 { margin: 1.1em 0 .45em; }
.rich-editor h3,
.reader-text h3 { margin: 1em 0 .4em; }
.rich-editor ul,
.rich-editor ol,
.reader-text ul,
.reader-text ol { padding-left: 1.35em; }

/* v3 reader panels: compact professional icon instead of a large header button. */
.reader-panel-icon {
  position: fixed;
  top: 96px;
  left: clamp(18px, 4vw, 42px);
  z-index: 45;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 12px;
  background: rgba(18,18,20,.84);
  color: #fff;
  cursor: pointer;
  box-shadow: 0 18px 42px rgba(0,0,0,.36);
  backdrop-filter: blur(14px);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.reader-panel-icon:hover {
  transform: translateY(-1px);
  background: rgba(32,32,36,.92);
  border-color: rgba(255,255,255,.32);
}
.panel-icon {
  position: relative;
  width: 18px;
  height: 16px;
  display: grid;
  gap: 3px;
}
.panel-icon i {
  display: block;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform .18s ease, opacity .18s ease, width .18s ease;
}
.panel-icon i:nth-child(1) { width: 18px; }
.panel-icon i:nth-child(2) { width: 13px; }
.panel-icon i:nth-child(3) { width: 18px; }
.reader-page.panels-collapsed .panel-icon i:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.reader-page.panels-collapsed .panel-icon i:nth-child(2) { opacity: 0; }
.reader-page.panels-collapsed .panel-icon i:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }
.reader-sidebar {
  padding-top: 50px;
}
.reader-page.panels-collapsed .reader-panel-icon {
  left: 18px;
}

@media (max-width: 920px) {
  .row-wrap { --hover-room-x: 44px; }
  .rich-toolbar { top: 62px; }
  .reader-panel-icon { top: 88px; }
  .reader-sidebar { padding-top: 46px; }
}

/* v5 music cues: subtle start/end markers around the selected passage + bottom player. */
.reader-shell {
  padding-bottom: 140px;
}
.reader-text .music-marker {
  display: inline-flex;
  align-items: center;
  gap: .28em;
  margin: 0 .32em;
  padding: 2px 7px 3px;
  vertical-align: .08em;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  color: rgba(255,255,255,.62);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: .01em;
  cursor: pointer;
  opacity: .78;
  transition: opacity .18s ease, color .18s ease, border-color .18s ease, background .18s ease, transform .18s ease;
}
.reader-text .music-marker:hover,
.reader-text .music-marker:focus-visible {
  opacity: 1;
  color: #fff;
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.08);
  transform: translateY(-1px);
}
.reader-text .music-marker-start.is-playing,
.reader-text .music-marker-end.is-playing,
.music-cue.is-playing,
.music-fallback-cue.is-playing {
  opacity: 1;
  color: #fff;
  border-color: rgba(86,209,109,.5);
  background: rgba(86,209,109,.1);
  box-shadow: 0 0 0 1px rgba(86,209,109,.12);
}
.reader-text .music-marker-end {
  color: rgba(255,255,255,.48);
  border-style: dashed;
}
.bottom-music-player[hidden] {
  display: none;
}
.bottom-music-player {
  position: fixed;
  left: 50%;
  bottom: 18px;
  z-index: 80;
  width: min(780px, calc(100vw - 32px));
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 13px 14px 13px 16px;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 18px;
  background: rgba(13,13,16,.92);
  color: #fff;
  box-shadow: 0 22px 70px rgba(0,0,0,.48);
  backdrop-filter: blur(18px);
  transform: translate(-50%, 16px);
  opacity: 0;
  transition: opacity .2s ease, transform .2s ease;
}
.bottom-music-player.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
.bottom-music-main {
  min-width: 0;
  display: grid;
  gap: 3px;
}
.bottom-music-kicker {
  color: #b9b9c1;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.bottom-music-main strong {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 14px;
}
.bottom-music-main small {
  overflow: hidden;
  color: var(--muted);
  white-space: nowrap;
  text-overflow: ellipsis;
}
.bottom-music-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.bottom-volume {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #d7d7dc;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.bottom-volume input {
  width: 110px;
}
@media (max-width: 720px) {
  .bottom-music-player {
    align-items: stretch;
    flex-direction: column;
    gap: 12px;
  }
  .bottom-music-controls {
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .bottom-volume input {
    width: 96px;
  }
}

/* v6: music markers float over the text without taking space in the reading layout. */
.reader-text .music-marker-anchor {
  position: relative;
  display: inline-block;
  width: 0;
  height: 0;
  overflow: visible;
  line-height: 0;
  vertical-align: baseline;
  scroll-margin-top: 120px;
}
.reader-text .music-marker-anchor .music-marker {
  position: absolute;
  z-index: 7;
  margin: 0;
  white-space: nowrap;
  pointer-events: auto;
  transform: scale(.92);
  transform-origin: left center;
}
.reader-text .music-marker-anchor-start .music-marker {
  left: 0;
  bottom: .55em;
}
.reader-text .music-marker-anchor-end .music-marker {
  right: 0;
  top: .25em;
  transform-origin: right center;
}
.reader-text .music-marker-anchor.is-playing .music-marker,
.reader-text .music-marker-anchor.cue-focus-pulse .music-marker {
  opacity: 1;
  color: #fff;
  border-color: rgba(86,209,109,.5);
  background: rgba(86,209,109,.1);
  box-shadow: 0 0 0 1px rgba(86,209,109,.12), 0 10px 28px rgba(0,0,0,.26);
}
.reader-text .music-marker-anchor.cue-focus-pulse .music-marker {
  animation: cuePulse 1.2s ease;
}
@keyframes cuePulse {
  0% { transform: scale(.92); }
  35% { transform: scale(1.04); }
  100% { transform: scale(.92); }
}
.music-cue-jump {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
}
.music-cue-jump-main {
  min-width: 0;
  display: grid;
  gap: 3px;
}
.music-cue-jump-main strong,
.music-cue-jump-main small {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.music-timecode-label {
  color: #aeb0b8;
  font-size: 11px;
}
.music-jump-link {
  flex-shrink: 0;
  text-decoration: none !important;
}

/* v6: compact chapter manager + full chapter editor with side music panel. */
.compact-add-chapter textarea {
  min-height: 76px;
}
.chapter-compact-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 12px;
  margin: 16px 0 22px;
}
.chapter-compact-card {
  display: grid;
  gap: 6px;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  background: #0c0c0e;
  color: #fff;
  text-decoration: none;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.chapter-compact-card:hover,
.chapter-compact-card.active {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.28);
  background: #151519;
}
.chapter-order {
  color: #aeb0b8;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.chapter-compact-card strong {
  font-size: 16px;
}
.chapter-compact-card small {
  color: var(--muted);
}
.chapter-full-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
  gap: 18px;
  align-items: start;
  margin-top: 20px;
}
.chapter-full-editor,
.chapter-music-aside,
.chapter-empty-state {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  background: #0c0c0e;
}
.chapter-full-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.chapter-full-head h2 {
  margin: 2px 0 0;
  font-size: clamp(28px, 4vw, 46px);
  line-height: .95;
  letter-spacing: -.04em;
}
.chapter-full-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}
.chapter-rich-editor {
  min-height: 72vh;
}
.chapter-music-aside {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 14px;
  max-height: calc(100vh - 110px);
  overflow: auto;
}
.panel-head.slim {
  align-items: flex-start;
}
.panel-head.slim h2 {
  margin-bottom: 6px;
}
.music-side-form,
.side-music-list,
.music-cue-editor.compact {
  display: grid;
  gap: 10px;
}
.music-side-form label,
.music-cue-editor.compact label {
  display: grid;
  gap: 6px;
}
.check-row {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.music-cue-editor.compact {
  padding: 13px;
}
.music-cue-editor.compact textarea {
  min-height: 78px;
}
.music-selection-helper.compact {
  margin: 0;
}
.chapter-empty-state {
  margin-top: 18px;
}

@media (max-width: 1080px) {
  .chapter-full-layout {
    grid-template-columns: 1fr;
  }
  .chapter-music-aside {
    position: static;
    max-height: none;
  }
}

/* v7: page d’édition chapitre dédiée + icônes musique dans la marge. */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.chapter-list-note {
  margin-top: 12px;
}
.chapter-page-shell {
  max-width: 1720px;
  margin: 0 auto;
  padding: 28px clamp(18px, 3.4vw, 48px) 90px;
}
.chapter-edit-topbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 22px;
}
.chapter-edit-topbar h1 {
  margin: 4px 0 8px;
  font-size: clamp(38px, 5vw, 76px);
  line-height: .9;
  letter-spacing: -.055em;
}
.chapter-switcher {
  min-width: min(360px, 100%);
  padding: 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
}
.chapter-switcher label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.chapter-switcher select {
  text-transform: none;
  letter-spacing: 0;
}
.chapter-editor-page-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
  gap: 22px;
  align-items: start;
}
.chapter-editor-workspace,
.chapter-music-studio {
  border-radius: 16px;
}
.chapter-page-form {
  display: grid;
  gap: 16px;
}
.chapter-editor-commandbar {
  position: sticky;
  top: 73px;
  z-index: 8;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: end;
  padding: 14px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  background: rgba(16,16,20,.94);
  box-shadow: 0 18px 45px rgba(0,0,0,.28);
  backdrop-filter: blur(16px);
}
.chapter-meta-fields {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 110px 90px;
  gap: 12px;
  align-items: end;
}
.chapter-meta-fields label,
.chapter-music-studio label {
  display: grid;
  gap: 7px;
}
.compact-check {
  min-height: 42px;
}
.chapter-editor-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}
.chapter-editor-card {
  display: grid;
  gap: 0;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  background: #08080a;
  overflow: clip;
}
.chapter-toolbar {
  position: sticky;
  top: 172px;
  z-index: 7;
  padding: 12px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: rgba(12,12,15,.94);
  backdrop-filter: blur(16px);
}
.chapter-page-rich-editor {
  min-height: calc(100vh - 310px);
  border: 0;
  border-radius: 0;
  padding: clamp(22px, 3vw, 42px);
  font-size: 18px;
  line-height: 1.86;
}
.chapter-music-studio {
  position: sticky;
  top: 88px;
  display: grid;
  gap: 16px;
  max-height: calc(100vh - 108px);
  overflow: auto;
}
.chapter-music-studio h3 {
  margin: 0;
  font-size: 16px;
}
.music-create-card,
.studio-cue-card {
  border-radius: 14px;
  background: #0b0b0d;
}
.timecode-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.full-width {
  width: 100%;
}

.reader-text .music-marker-anchor {
  scroll-margin-top: 120px;
}
.reader-text .music-marker-anchor .music-margin-icon {
  left: -46px;
  right: auto;
  top: -.35em;
  bottom: auto;
  width: 28px;
  height: 28px;
  display: inline-grid;
  place-items: center;
  padding: 0;
  border-radius: 999px;
  font-size: 13px;
  line-height: 1;
  color: rgba(255,255,255,.72);
  background: rgba(255,255,255,.045);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  transform: none;
}
.reader-text .music-marker-anchor-start .music-margin-icon,
.reader-text .music-marker-anchor-end .music-margin-icon {
  left: -46px;
  right: auto;
  top: -.35em;
  bottom: auto;
  transform-origin: center;
}
.reader-text .music-marker-anchor-end .music-margin-icon {
  font-size: 9px;
  color: rgba(255,255,255,.52);
  border-style: dashed;
}
.reader-text .music-marker-anchor .music-margin-icon:hover,
.reader-text .music-marker-anchor .music-margin-icon:focus-visible {
  transform: translateX(-2px) scale(1.06);
}
.reader-text .music-marker-anchor.is-playing .music-margin-icon,
.reader-text .music-marker-anchor.cue-focus-pulse .music-margin-icon {
  color: #fff;
  border-color: rgba(86,209,109,.55);
  background: rgba(86,209,109,.14);
  box-shadow: 0 0 0 1px rgba(86,209,109,.16), 0 14px 34px rgba(0,0,0,.32);
}
.reader-text .music-marker-anchor.cue-focus-pulse .music-margin-icon {
  animation: cueMarginPulse 1.15s ease;
}
@keyframes cueMarginPulse {
  0% { transform: scale(1); }
  35% { transform: scale(1.18); }
  100% { transform: scale(1); }
}

@media (max-width: 1180px) {
  .chapter-editor-page-grid {
    grid-template-columns: 1fr;
  }
  .chapter-music-studio {
    position: static;
    max-height: none;
  }
}
@media (max-width: 760px) {
  .chapter-edit-topbar,
  .chapter-editor-commandbar {
    grid-template-columns: 1fr;
    display: grid;
  }
  .chapter-meta-fields,
  .timecode-row {
    grid-template-columns: 1fr;
  }
  .chapter-editor-actions {
    justify-content: stretch;
  }
  .chapter-editor-actions .btn {
    flex: 1;
  }
  .reader-text .music-marker-anchor .music-margin-icon,
  .reader-text .music-marker-anchor-start .music-margin-icon,
  .reader-text .music-marker-anchor-end .music-margin-icon {
    left: -32px;
    width: 24px;
    height: 24px;
  }
}

/* v8: margin-only music controls + audio-style YouTube backend. */
.reader-text {
  position: relative;
  overflow: visible;
}
.reader-text .music-marker-anchor,
.reader-text .music-marker-anchor-start,
.reader-text .music-marker-anchor-end {
  position: static !important;
  display: inline !important;
  width: 0 !important;
  height: 0 !important;
  overflow: visible !important;
  line-height: inherit !important;
  vertical-align: baseline !important;
  scroll-margin-top: 120px;
}
.reader-text .music-marker-anchor .music-margin-icon,
.reader-text .music-marker-anchor-start .music-margin-icon,
.reader-text .music-marker-anchor-end .music-margin-icon {
  position: absolute !important;
  z-index: 12;
  right: auto !important;
  bottom: auto !important;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  padding: 0;
  margin: 0;
  border-radius: 999px;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 13px;
  line-height: 1;
  color: rgba(255,255,255,.76);
  background: rgba(18,18,22,.86);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
  backdrop-filter: blur(12px);
  transform: none !important;
}
.reader-text .music-marker-anchor-end .music-margin-icon {
  font-size: 10px;
  color: rgba(255,255,255,.58);
  border-style: solid;
}
.reader-text .music-marker-anchor .music-margin-icon:hover,
.reader-text .music-marker-anchor .music-margin-icon:focus-visible {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.3);
  transform: translateX(-2px) scale(1.06) !important;
}
.reader-text .music-marker-anchor.is-playing .music-margin-icon,
.reader-text .music-marker-anchor.cue-focus-pulse .music-margin-icon {
  color: #fff;
  border-color: rgba(86,209,109,.58);
  background: rgba(86,209,109,.16);
  box-shadow: 0 0 0 1px rgba(86,209,109,.18), 0 14px 34px rgba(0,0,0,.34);
}
.reader-text .music-marker-anchor.cue-focus-pulse .music-margin-icon {
  animation: cueMarginPulseV8 1.15s ease;
}
@keyframes cueMarginPulseV8 {
  0% { transform: scale(1) !important; }
  35% { transform: scale(1.18) !important; }
  100% { transform: scale(1) !important; }
}
.music-panel .music-jump-link,
.music-cue .music-jump-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.075);
  color: #fff !important;
  text-decoration: none !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
}
.music-panel .music-jump-link:hover,
.music-cue .music-jump-link:hover,
.music-panel .music-jump-link:focus-visible,
.music-cue .music-jump-link:focus-visible {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.13);
}
.youtube-audio-host {
  position: fixed;
  left: -9999px;
  bottom: 0;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
}
.youtube-audio-host iframe {
  width: 1px !important;
  height: 1px !important;
  opacity: 0;
  pointer-events: none;
}
.music-youtube-note {
  color: var(--muted) !important;
  font-size: 12px;
}
@media (max-width: 760px) {
  .reader-text .music-marker-anchor .music-margin-icon,
  .reader-text .music-marker-anchor-start .music-margin-icon,
  .reader-text .music-marker-anchor-end .music-margin-icon {
    width: 24px;
    height: 24px;
    font-size: 12px;
  }
}

/* Profil / avatars */
.avatar-link {
  position: relative;
  overflow: hidden;
  color: #fff;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.avatar-link:hover,
.avatar-link:focus-visible {
  transform: translateY(-1px) scale(1.04);
  border-color: rgba(255,255,255,.42);
  box-shadow: 0 10px 26px rgba(0,0,0,.34), 0 0 0 3px rgba(229,9,20,.16);
  outline: none;
}
.avatar.has-image,
.avatar-link.has-image {
  padding: 0;
  background: #151517;
}
.avatar img,
.avatar-link img,
.reader-account-avatar img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.reader-account-avatar {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: inline-grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, #2d2d32, #111);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  vertical-align: middle;
}
.reader-account-avatar:hover {
  border-color: rgba(255,255,255,.42);
}
.profile-page {
  min-height: 100vh;
  background:
    radial-gradient(circle at 15% 0%, rgba(229,9,20,.18), transparent 34%),
    radial-gradient(circle at 95% 10%, rgba(255,255,255,.05), transparent 28%),
    #050505;
}
.profile-topbar {
  position: sticky;
}
.profile-shell {
  width: min(1180px, calc(100% - 36px));
  margin: 0 auto;
  padding: 42px 0 80px;
}
.profile-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 230px;
  gap: 24px;
  align-items: stretch;
  padding: clamp(22px, 4vw, 36px);
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.025));
  box-shadow: var(--shadow);
  overflow: hidden;
}
.profile-hero-card h1 {
  margin: 0;
  font-size: clamp(36px, 5vw, 64px);
  line-height: .95;
  letter-spacing: -.055em;
}
.profile-hero-card .muted-note {
  max-width: 720px;
  margin-top: 16px;
  line-height: 1.7;
}
.profile-current-chip {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 10px 7px 7px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  color: #fff;
  font-size: 13px;
  font-weight: 850;
}
.profile-current-chip img,
.profile-current-chip > span {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: grid;
  place-items: center;
  background: #17171a;
}
.profile-preview {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 14px;
  background: #0d0d0f;
  text-align: center;
}
.profile-preview img,
.profile-preview-initial {
  width: 136px;
  height: 136px;
  border-radius: 26px;
  object-fit: cover;
  box-shadow: 0 18px 46px rgba(0,0,0,.48);
}
.profile-preview-initial {
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #2d2d32, #111);
  border: 1px solid rgba(255,255,255,.18);
  font-size: 54px;
  font-weight: 1000;
}
.profile-preview strong { margin-top: 4px; }
.profile-preview span { color: var(--muted); font-size: 13px; }
.flash.error {
  border-color: rgba(229,9,20,.4);
  background: rgba(229,9,20,.12);
  color: #ffd7da;
}
.avatar-category {
  margin-top: 28px;
  padding: 22px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: rgba(13,13,15,.84);
}
.profile-section-head {
  margin-bottom: 18px;
}
.profile-section-head h2 { margin: 0; }
.profile-section-head p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 13px;
}
.avatar-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 16px;
}
.avatar-choice { margin: 0; }
.avatar-choice button {
  width: 100%;
  padding: 0;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: #09090a;
  color: #fff;
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.avatar-choice button:hover,
.avatar-choice button:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(255,255,255,.32);
  background: #121216;
  box-shadow: 0 20px 42px rgba(0,0,0,.36);
  outline: none;
}
.avatar-choice.selected button {
  border-color: rgba(229,9,20,.86);
  box-shadow: 0 0 0 3px rgba(229,9,20,.17), 0 20px 42px rgba(0,0,0,.32);
}
.avatar-choice img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
}
.avatar-choice-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 13px;
}
.avatar-choice-meta strong {
  font-size: 16px;
}
.avatar-choice-meta small {
  color: #fff;
  background: rgba(255,255,255,.1);
  border-radius: 999px;
  padding: 5px 8px;
  font-weight: 850;
  font-size: 11px;
}
.avatar-choice.selected .avatar-choice-meta small {
  background: var(--brand);
}
.reset-avatar-form {
  margin-top: 18px;
}
@media (max-width: 760px) {
  .profile-hero-card {
    grid-template-columns: 1fr;
  }
  .profile-current-chip {
    display: none;
  }
}

/* v10: profil dropdown, fiche détail retravaillée, épisodes et images de chapitre. */
.account-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.account-menu-trigger {
  cursor: pointer;
  border: 1px solid rgba(255,255,255,.18);
}
.account-dropdown {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  min-width: 220px;
  padding: 8px;
  border-radius: 12px;
  background: rgba(18,18,21,.96);
  border: 1px solid rgba(255,255,255,.13);
  box-shadow: 0 24px 60px rgba(0,0,0,.55);
  backdrop-filter: blur(18px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px) scale(.98);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 120;
}
.account-menu.open .account-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}
.account-dropdown::before {
  content: "";
  position: absolute;
  top: -6px;
  right: 13px;
  width: 12px;
  height: 12px;
  transform: rotate(45deg);
  background: rgba(18,18,21,.96);
  border-left: 1px solid rgba(255,255,255,.13);
  border-top: 1px solid rgba(255,255,255,.13);
}
.account-dropdown a {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 40px;
  padding: 10px 12px;
  border-radius: 8px;
  color: #f1f1f1;
  font-size: 14px;
  font-weight: 750;
}
.account-dropdown a:hover,
.account-dropdown a:focus-visible {
  background: rgba(255,255,255,.09);
  outline: none;
}
.profile-current-name {
  color: #f4f4f5;
  font-size: 13px;
  font-weight: 850;
}
.reader-header .account-menu {
  vertical-align: middle;
}

.modal-card {
  width: min(1040px, calc(100vw - 40px));
}
.modal-body {
  padding-bottom: 40px;
}
.modal-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(230px, 320px);
  gap: clamp(22px, 4vw, 42px);
  align-items: start;
  margin-top: 18px;
}
.modal-main-copy {
  min-width: 0;
}
.modal-slogan {
  margin: 0 0 12px !important;
  color: #fff !important;
  font-size: clamp(18px, 2vw, 23px);
  line-height: 1.32 !important;
  font-weight: 950;
  letter-spacing: -.025em;
}
.modal-slogan:empty {
  display: none;
}
.modal-synopsis {
  margin: 0 !important;
  max-width: none !important;
  color: #dcdce0 !important;
  font-size: 16px;
  line-height: 1.78 !important;
  text-wrap: pretty;
}
.modal-side-info {
  padding: 16px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
}
.modal-side-info p {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 10px;
  margin: 0;
  align-items: baseline;
}
.modal-side-info span {
  color: #8f8f96;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 900;
}
.modal-side-info strong {
  color: #f3f3f4;
  font-size: 14px;
  line-height: 1.45;
}
.modal-chapters {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.1);
}
.modal-episodes-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}
.modal-episodes-head h3,
.modal-chapters h3 {
  margin: 0;
  font-size: 24px;
  letter-spacing: -.03em;
}
.modal-episodes-head span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}
.modal-episode-list {
  display: grid;
  gap: 10px;
}
.modal-episode {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 10px;
  background: rgba(255,255,255,.045);
  transition: background .16s ease, border-color .16s ease, transform .16s ease;
}
.modal-episode:hover,
.modal-episode:focus-visible {
  background: rgba(255,255,255,.075);
  border-color: rgba(255,255,255,.18);
  transform: translateY(-1px);
  outline: none;
}
.modal-episode-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 7px;
  background: linear-gradient(135deg, #242429, #101012);
  background-image: linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.62)), var(--episode-image), linear-gradient(135deg, #242429, #101012);
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.12);
}
.modal-episode-copy {
  display: grid;
  gap: 4px;
}
.modal-episode-copy small {
  color: #9e9ea5;
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.modal-episode-copy strong {
  color: #fff;
  font-size: 17px;
  line-height: 1.25;
}

.episode-nav {
  display: grid;
  gap: 10px;
}
.reader-tags span,
.chapter-nav:not(.episode-nav) a {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 8px 10px;
  background: rgba(255,255,255,.06);
  color: #ddd;
  font-size: 13px;
}
.chapter-nav.episode-nav a.chapter-episode-link {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 8px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 10px;
  background: rgba(255,255,255,.045);
  color: #fff;
}
.chapter-nav.episode-nav a.chapter-episode-link.active {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.28);
  color: #fff;
  box-shadow: inset 3px 0 0 var(--brand);
}
.chapter-episode-thumb,
.chapter-compact-thumb {
  display: block;
  aspect-ratio: 16 / 9;
  border-radius: 7px;
  background: linear-gradient(135deg, #242429, #101012);
  background-image: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.6)), var(--episode-image), linear-gradient(135deg, #242429, #101012);
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,.12);
}
.chapter-episode-copy,
.chapter-compact-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.chapter-episode-copy small,
.chapter-compact-copy small {
  color: #aaaab1;
  font-size: 11px;
  font-weight: 850;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.chapter-episode-copy strong,
.chapter-compact-copy strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  line-height: 1.25;
}

.chapter-compact-list {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}
.chapter-compact-card.chapter-compact-episode {
  display: grid;
  grid-template-columns: 120px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: auto;
}
.chapter-compact-card.chapter-compact-episode .chapter-order {
  width: fit-content;
}
.chapter-image-preview {
  min-height: 160px;
  border-radius: 12px;
  margin: 0 0 16px;
  border: 1px solid rgba(255,255,255,.12);
  background-image: linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.68)), var(--episode-image);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: end;
  padding: 14px;
  overflow: hidden;
}
.chapter-image-preview span {
  display: inline-flex;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: 12px;
  font-weight: 850;
  backdrop-filter: blur(8px);
}

@media (max-width: 860px) {
  .modal-overview-grid {
    grid-template-columns: 1fr;
  }
  .modal-side-info p {
    grid-template-columns: 74px minmax(0, 1fr);
  }
  .modal-episode {
    grid-template-columns: 112px minmax(0, 1fr);
  }
}
@media (max-width: 620px) {
  .account-dropdown {
    right: -4px;
  }
  .modal-episode,
  .chapter-nav.episode-nav a.chapter-episode-link,
  .chapter-compact-card.chapter-compact-episode {
    grid-template-columns: 1fr;
  }
  .chapter-episode-copy strong,
  .chapter-compact-copy strong {
    white-space: normal;
  }
}
.account-menu-trigger {
  padding: 0;
  appearance: none;
  -webkit-appearance: none;
}

/* v13 admin ergonomics */
.admin-grid.four {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}
.section-create-form,
.section-manager-form,
.admin-search-form {
    margin-top: 18px;
}
.section-admin-list {
    display: grid;
    gap: 16px;
    margin: 18px 0;
}
.section-admin-card {
    position: relative;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    background: linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.025));
}
.section-admin-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 14px;
}
.section-admin-card-head strong {
    font-size: 1.02rem;
}
.toggle-line {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between;
    gap: 10px;
}
.btn-danger.soft {
    margin-top: 12px;
    background: rgba(229, 9, 20, .12);
    border-color: rgba(229, 9, 20, .35);
    color: #fff;
}
.btn-danger.soft:hover {
    background: rgba(229, 9, 20, .25);
}
.section-checkbox-group {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px 14px;
}
.section-checkbox-group legend {
    margin-bottom: 10px;
}
.section-checkbox-group label {
    display: flex !important;
    flex-direction: row !important;
    align-items: center;
    gap: 8px;
    min-height: 34px;
}
.admin-search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 14px;
    align-items: end;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 18px;
    background: rgba(255,255,255,.035);
}
.empty-panel {
    margin-top: 18px;
    padding: 22px;
    border: 1px dashed rgba(255,255,255,.18);
    border-radius: 18px;
    color: rgba(255,255,255,.68);
    background: rgba(255,255,255,.025);
}
.user-search-results {
    display: grid;
    gap: 12px;
    margin-top: 18px;
}
.user-result-card {
    display: grid;
    grid-template-columns: 52px minmax(0, 1fr) auto;
    align-items: center;
    gap: 14px;
    padding: 14px;
    border: 1px solid rgba(255,255,255,.09);
    border-radius: 16px;
    background: rgba(255,255,255,.045);
    color: #fff;
    text-decoration: none;
    transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.user-result-card:hover {
    transform: translateY(-1px);
    border-color: rgba(255,255,255,.2);
    background: rgba(255,255,255,.075);
}
.user-result-card strong,
.user-result-card small {
    display: block;
}
.user-result-card small {
    color: rgba(255,255,255,.62);
    margin-top: 3px;
}
.user-result-avatar {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg, #e50914, #50070b);
    color: #fff;
    font-weight: 900;
    overflow: hidden;
}
.user-result-avatar.big {
    width: 88px;
    height: 88px;
    border-radius: 22px;
    font-size: 2rem;
}
.user-result-avatar.has-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.user-edit-shell .editor-hero,
.user-editor-hero {
    align-items: center;
}
.profile-account-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}
.profile-account-panel .admin-subpanel {
    margin: 0;
}
.compact-create-hero {
    min-height: 180px;
}
.catalog-grid .catalog-card small {
    line-height: 1.35;
}
@media (max-width: 900px) {
    .admin-grid.four,
    .profile-account-grid,
    .admin-search-form {
        grid-template-columns: 1fr;
    }
    .user-result-card {
        grid-template-columns: 44px minmax(0, 1fr);
    }
    .user-result-card .status-pill {
        grid-column: 2;
        justify-self: start;
    }
}

/* v14 admin category buttons */
.admin-tabs {
  top: 72px;
  gap: 10px;
  padding: 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(13,13,16,.82);
  box-shadow: 0 18px 50px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.05);
  backdrop-filter: blur(18px);
}
.admin-tabs .admin-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  color: rgba(255,255,255,.72);
  text-decoration: none;
  font-size: 13px;
  letter-spacing: .01em;
  font-weight: 850;
  transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}
.admin-tabs .admin-tab::before {
  content: "";
  width: 7px;
  height: 7px;
  margin-right: 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
  box-shadow: 0 0 0 4px rgba(255,255,255,.04);
  transition: background .18s ease, box-shadow .18s ease;
}
.admin-tabs .admin-tab:hover {
  transform: translateY(-1px);
  color: #fff;
  background: rgba(255,255,255,.08);
}
.admin-tabs .admin-tab.active {
  color: #fff;
  background: linear-gradient(135deg, rgba(229,9,20,.95), rgba(157,16,24,.92));
  box-shadow: 0 10px 30px rgba(229,9,20,.24), inset 0 1px 0 rgba(255,255,255,.18);
}
.admin-tabs .admin-tab.active::before {
  background: #fff;
  box-shadow: 0 0 0 4px rgba(255,255,255,.16);
}
.section-admin-card .btn-danger.soft,
.catalog-tile .tile-delete {
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.section-admin-card .btn-danger.soft:hover,
.catalog-tile .tile-delete:hover {
  transform: translateY(-1px);
}

.field-optional{color:#8c8c8c;font-size:.78rem;font-weight:500;margin-left:.35rem;text-transform:none;}

/* v23 home carousel controls: keep arrows on top, glued to viewport edges, and block card hover underneath. */
.row-wrap {
  isolation: isolate;
}
.row-wrap .scroll-btn {
  z-index: 1000;
  pointer-events: auto;
  opacity: 0;
  width: clamp(54px, 4.8vw, 76px);
  display: grid;
  place-items: center;
  background: linear-gradient(90deg, rgba(0,0,0,.78), rgba(0,0,0,.34), rgba(0,0,0,0));
  backdrop-filter: blur(2px);
}
.row-wrap .scroll-right {
  background: linear-gradient(270deg, rgba(0,0,0,.78), rgba(0,0,0,.34), rgba(0,0,0,0));
}
.row-wrap:hover .scroll-btn,
.row-wrap .scroll-btn:hover,
.row-wrap .scroll-btn:focus-visible {
  opacity: 1;
}
.section .row-wrap .scroll-left {
  left: calc(-1 * clamp(18px, 4vw, 58px));
  border-radius: 0 10px 10px 0;
}
.section .row-wrap .scroll-right {
  right: calc(-1 * clamp(18px, 4vw, 58px));
  border-radius: 10px 0 0 10px;
}
.row-wrap .scroll-btn:hover {
  background-color: rgba(0,0,0,.24);
}
.row-wrap.is-scroll-control-hover .card {
  pointer-events: none;
}
.row-wrap.is-scroll-control-hover .card:hover {
  transform: none;
  z-index: auto;
  border-radius: 4px;
  box-shadow: 0 14px 25px rgba(0,0,0,.3);
}
.row-wrap.is-scroll-control-hover .card:not(.rank-card):hover::after,
.row-wrap.is-scroll-control-hover .card:hover .play-mini {
  opacity: 0;
  transform: translateY(-6px);
}
.rank-row-wrap .scroll-left,
.row-wrap:has(.rank-row) .scroll-left {
  left: calc(-1 * clamp(18px, 4vw, 58px));
}
.rank-row-wrap .scroll-right,
.row-wrap:has(.rank-row) .scroll-right {
  right: calc(-1 * clamp(18px, 4vw, 58px));
}
@media (max-width: 760px) {
  .row-wrap .scroll-btn {
    width: 48px;
  }
}

/* v24: carousel infini + lisibilité du premier élément malgré les flèches collées à la fenêtre. */
.row-wrap .row {
  padding-left: clamp(70px, 5.8vw, 94px);
  padding-right: clamp(70px, 5.8vw, 94px);
  scroll-padding-left: clamp(70px, 5.8vw, 94px);
  scroll-padding-right: clamp(70px, 5.8vw, 94px);
}
.row-wrap:not(.is-scrollable) .scroll-btn {
  opacity: 0 !important;
  pointer-events: none;
}
.row-wrap .scroll-btn {
  top: 18px;
  bottom: 98px;
}

/* v24: vidéo YouTube en bannière de fiche, avec contrôle son discret. */
.modal-video-layer {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: none;
  overflow: hidden;
  background: #050505;
}
.modal-video-layer.active {
  display: block;
}
.modal-video-frame,
.modal-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100% !important;
  height: 100% !important;
}
.modal-visual.has-video .modal-slides {
  display: none;
}
.modal-video-mute {
  position: absolute;
  right: 18px;
  bottom: 22px;
  z-index: 4;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.26);
  border-radius: 999px;
  background: rgba(0,0,0,.62);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(10px);
  box-shadow: 0 12px 30px rgba(0,0,0,.38);
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
}
.modal-video-mute:hover {
  transform: translateY(-1px) scale(1.04);
  background: rgba(20,20,20,.82);
  border-color: rgba(255,255,255,.46);
}
.modal-video-mute.is-muted {
  background: rgba(229,9,20,.78);
}
.modal-visual.has-video::after {
  z-index: 2;
  pointer-events: none;
}
.modal-visual.has-video + .modal-body {
  z-index: 3;
}
.modal-video-layer::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(180deg, rgba(0,0,0,.08), rgba(22,22,22,1));
  pointer-events: none;
}
.modal-visual.has-video::after {
  display: none;
}
.modal-video-frame { z-index: 1; }
.modal-video-mute { z-index: 3; }

/* v25: corrections carousel, vidéo bannière et administration des avatars. */
.row-wrap .scroll-left {
  left: calc(-1 * clamp(18px, 4vw, 58px)) !important;
  right: auto !important;
}
.row-wrap .scroll-right {
  right: calc(-1 * clamp(18px, 4vw, 58px)) !important;
  left: auto !important;
}
.row-wrap .scroll-left::before { content: "‹"; }
.row-wrap .scroll-right::before { content: "›"; }
.row-wrap .scroll-btn {
  font-size: 0 !important;
}
.row-wrap .scroll-btn::before {
  font-size: 36px;
  line-height: 1;
  font-weight: 300;
}
.modal-video-layer {
  pointer-events: none;
}
.modal-video-frame {
  inset: -8% !important;
  width: 116% !important;
  height: 116% !important;
  overflow: hidden;
  pointer-events: none;
}
.modal-video-frame iframe {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  width: 100% !important;
  height: 100% !important;
  min-width: 100% !important;
  min-height: 100% !important;
  transform: translate(-50%, -50%) scale(1.12) !important;
  pointer-events: none !important;
}
.modal-video-mute {
  pointer-events: auto;
  user-select: none;
}
.modal-video-layer.active .modal-video-mute {
  display: grid;
}
.avatar-admin-layout {
  display: grid;
  grid-template-columns: minmax(280px, .8fr) minmax(0, 1.5fr);
  gap: 22px;
  align-items: start;
}
.avatar-admin-column {
  min-width: 0;
  display: grid;
  gap: 18px;
}
.avatar-admin-column.wide {
  min-width: 0;
}
.compact-admin-hero {
  min-height: 180px;
}
.compact-panel-head {
  margin-bottom: 0;
}
.avatar-admin-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-items: end;
  padding: 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.08);
}
.avatar-admin-form .wide,
.avatar-admin-edit-grid .wide {
  grid-column: 1 / -1;
}
.avatar-admin-form .checkbox,
.avatar-admin-edit-grid .checkbox {
  min-height: 44px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.avatar-admin-form .checkbox input,
.avatar-admin-edit-grid .checkbox input {
  width: auto;
}
.avatar-admin-list,
.avatar-admin-avatar-grid {
  display: grid;
  gap: 14px;
}
.avatar-admin-card,
.avatar-admin-avatar-card {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}
.avatar-admin-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}
.avatar-admin-category-block {
  display: grid;
  gap: 12px;
  padding-top: 4px;
}
.avatar-admin-category-block h3 {
  margin: 0;
  font-size: 20px;
}
.avatar-admin-avatar-card {
  grid-template-columns: 110px minmax(0, 1fr);
  align-items: start;
}
.avatar-admin-avatar-card form:last-child {
  grid-column: 2;
}
.avatar-admin-preview {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  overflow: hidden;
  background: #161616;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 16px 38px rgba(0,0,0,.28);
}
.avatar-admin-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 980px) {
  .avatar-admin-layout,
  .avatar-admin-avatar-card {
    grid-template-columns: 1fr;
  }
  .avatar-admin-avatar-card form:last-child {
    grid-column: auto;
  }
  .avatar-admin-form,
  .avatar-admin-edit-grid {
    grid-template-columns: 1fr;
  }
}


/* v26: hover long animé dans la carte, sans ouverture de preview grand format. */
.card-hover-media {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
  border-radius: inherit;
  background: #000;
  transition: opacity .28s ease, filter .28s ease;
  filter: saturate(1.05) contrast(1.04);
}
.card-hover-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.72));
  z-index: 2;
  pointer-events: none;
}
.card-hover-media.active {
  opacity: 1;
}
.card-hover-slide {
  position: absolute;
  inset: 0;
  display: block;
  opacity: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1.035);
  transition: opacity .55s ease, transform 2.4s ease;
  will-change: opacity, transform;
}
.card-hover-slide.active {
  opacity: 1;
  transform: scale(1.085);
}
.card-hover-media iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 140%;
  height: 140%;
  min-width: 140%;
  min-height: 140%;
  border: 0;
  transform: translate(-50%, -50%) scale(1.08);
  pointer-events: none;
}
.card .title,
.card .badge,
.card .play-mini,
.rank-poster .title {
  z-index: 5;
}
.card.is-hover-media {
  background-image: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.78)), var(--image), linear-gradient(135deg, var(--a), var(--b));
}
.card.is-hover-media .rank-num {
  z-index: 3;
}

/* v26: le lien Avatars du panel admin est un accès direct et reste visuellement cohérent. */
.admin-tab-direct span::after {
  content: "↗";
  margin-left: 7px;
  font-size: 11px;
  opacity: .62;
}


/* v28: mini-preview screenshot transition plus douce, comme la bannière principale. */
.card-hover-media {
  transition: opacity .38s ease, filter .38s ease;
}
.card-hover-slide {
  opacity: 0;
  transform: scale(1.025);
  transition: opacity .9s cubic-bezier(.22,.61,.36,1), transform 3.2s cubic-bezier(.22,.61,.36,1);
}
.card-hover-slide.active {
  opacity: 1;
  transform: scale(1.09);
}

/* v30: gestion avatars en deux niveaux : catégories puis page dédiée. */
.avatar-categories-home,
.avatar-category-editor-page {
  display: grid;
  gap: 22px;
}
.avatar-category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 16px;
}
.avatar-category-tile {
  min-height: 158px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 8px;
  padding: 18px;
  border-radius: 22px;
  color: #fff;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 0%, rgba(229,9,20,.32), transparent 34%),
    linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.11);
  box-shadow: 0 20px 60px rgba(0,0,0,.24);
  transition: transform .22s ease, border-color .22s ease, background .22s ease;
}
.avatar-category-tile::after {
  content: '›';
  position: absolute;
  top: 20px;
  right: 20px;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 28px;
  line-height: 1;
}
.avatar-category-tile:hover {
  transform: translateY(-4px);
  border-color: rgba(255,255,255,.22);
  background:
    radial-gradient(circle at 20% 0%, rgba(229,9,20,.45), transparent 38%),
    linear-gradient(145deg, rgba(255,255,255,.105), rgba(255,255,255,.035));
}
.avatar-category-tile strong {
  font-size: 24px;
  letter-spacing: -.03em;
}
.avatar-category-tile span,
.avatar-category-tile small {
  color: rgba(255,255,255,.72);
}
.avatar-category-status {
  position: absolute;
  top: 18px;
  left: 18px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.avatar-category-status.enabled {
  color: #cffff1;
  background: rgba(31, 191, 117, .15);
  border: 1px solid rgba(31, 191, 117, .28);
}
.avatar-category-status.disabled {
  color: rgba(255,255,255,.72);
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
}
.avatar-create-category {
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.035);
  overflow: hidden;
}
.avatar-create-category summary {
  cursor: pointer;
  padding: 18px 20px;
  font-weight: 800;
  list-style: none;
}
.avatar-create-category summary::-webkit-details-marker {
  display: none;
}
.avatar-create-category .avatar-admin-form {
  margin: 0 18px 18px;
}
.avatar-editor-topbar {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}
.avatar-editor-topbar h2 {
  margin: 0;
  font-size: clamp(28px, 4vw, 48px);
  letter-spacing: -.05em;
}
.avatar-category-editor-grid {
  display: grid;
  grid-template-columns: minmax(260px, .78fr) minmax(0, 1.3fr);
  gap: 20px;
  align-items: start;
}
.avatar-editor-card {
  display: grid;
  gap: 16px;
  padding: 18px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}
.avatar-editor-card h3 {
  margin: 0;
}
.avatar-admin-form.single-column {
  grid-template-columns: 1fr;
}
.danger-zone {
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.avatar-editor-list-card {
  padding: 20px;
}
.avatar-admin-avatar-grid-clean {
  gap: 16px;
}
.avatar-admin-avatar-card-clean {
  grid-template-columns: 120px minmax(0, 1fr) auto;
  align-items: start;
}
.avatar-admin-avatar-card-clean form:last-child {
  grid-column: auto;
}
.subtle-empty {
  padding: 28px;
  border-radius: 18px;
  background: rgba(255,255,255,.035);
  border: 1px dashed rgba(255,255,255,.16);
  color: rgba(255,255,255,.66);
}
@media (max-width: 1100px) {
  .avatar-category-editor-grid,
  .avatar-admin-avatar-card-clean {
    grid-template-columns: 1fr;
  }
}

/* v32 — lecture: typographie anti-veuve + lecture vocale */
.reader-text {
  text-wrap: pretty;
  hyphens: none;
  overflow-wrap: normal;
  word-break: normal;
}
.reader-text p,
.reader-text li,
.reader-text blockquote,
.reader-text h2,
.reader-text h3 {
  text-wrap: pretty;
}
.reader-title-row {
  gap: 18px;
  align-items: flex-start;
}
.reader-title-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  margin-left: auto;
}
.reader-voice-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(12px);
}

.reader-voice-controls.is-loading {
  opacity: .86;
  cursor: wait;
}
.reader-voice-controls.is-loading .reader-voice-toggle {
  pointer-events: none;
}
.reader-voice-controls[data-voice-mode="ai"]::before {
  content: "IA";
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: rgba(229,9,20,.22);
  color: #fff;
  font-size: 9px;
  font-weight: 1000;
  letter-spacing: .08em;
  box-shadow: inset 0 0 0 1px rgba(229,9,20,.35);
}
.reader-voice-controls.is-speaking {
  border-color: rgba(229,9,20,.55);
  box-shadow: 0 0 0 1px rgba(229,9,20,.18), 0 12px 40px rgba(229,9,20,.1);
}
.reader-voice-rate {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 8px;
  color: rgba(255,255,255,.72);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  white-space: nowrap;
}
.reader-voice-rate input {
  width: 76px;
  accent-color: var(--brand);
}
.reader-voice-unsupported {
  max-width: 260px;
  color: rgba(255,255,255,.62);
  font-size: 12px;
  line-height: 1.35;
}
@media (max-width: 900px) {
  .reader-title-row {
    flex-direction: column;
  }
  .reader-title-actions {
    justify-content: flex-start;
    margin-left: 0;
  }
}
@media (max-width: 640px) {
  .reader-voice-controls {
    width: 100%;
    justify-content: space-between;
    border-radius: 16px;
  }
  .reader-title-actions {
    width: 100%;
  }
}

/* v36 — progression lecture, marque-page et reprise */
.continue-reading-section .section-head h2::before {
  content: "▶";
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  margin-right: 10px;
  border-radius: 999px;
  background: rgba(229,9,20,.95);
  color: #fff;
  font-size: 10px;
  vertical-align: 2px;
}
.continue-card .continue-meta {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 5;
  display: grid;
  gap: 7px;
  color: rgba(255,255,255,.86);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .03em;
  text-transform: uppercase;
  pointer-events: none;
}
.continue-card .continue-meta i,
.reader-progress-bar {
  display: block;
  height: 4px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
}
.continue-card .continue-meta b,
.reader-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand);
  box-shadow: 0 0 18px rgba(229,9,20,.28);
}
.chapter-episode-copy em {
  display: inline-flex;
  width: fit-content;
  margin-top: 2px;
  padding: 3px 7px;
  border-radius: 999px;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.chapter-status-done {
  color: #fff;
  background: rgba(30,185,84,.28);
  box-shadow: inset 0 0 0 1px rgba(30,185,84,.35);
}
.chapter-status-progress {
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.1);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.12);
}
.reader-bookmark-toggle {
  border-color: rgba(255,255,255,.18);
}
.reader-bookmark-toggle.is-bookmarked {
  color: #fff;
  border-color: rgba(229,9,20,.58);
  background: rgba(229,9,20,.22);
}
.chapter-completion-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 42px;
  padding: 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.035));
  box-shadow: 0 22px 60px rgba(0,0,0,.18);
}
.chapter-completion-card h3 {
  margin: 4px 0 6px;
  font-size: clamp(22px,3vw,34px);
  letter-spacing: -.03em;
}
.chapter-completion-card p {
  margin: 0;
  color: var(--muted);
}
.chapter-completion-kicker {
  color: rgba(255,255,255,.62);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.chapter-completion-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  color: #fff;
  font-weight: 950;
  background: rgba(30,185,84,.22);
  box-shadow: inset 0 0 0 1px rgba(30,185,84,.45);
}
.reader-progress-lock {
  display: grid;
  gap: 10px;
}
.reader-progress-lock .reader-progress-bar {
  height: 7px;
}
@media (max-width: 760px) {
  .chapter-completion-card {
    align-items: stretch;
    flex-direction: column;
  }
  .chapter-completion-card .btn,
  .chapter-completion-card form {
    width: 100%;
  }
}

/* v37 — lecture: un seul scroll global + marque-page placé dans le texte */
.reader-page .reader-content {
  max-height: none;
  overflow: visible;
}
.reader-page .reader-text-bookmark-enabled {
  position: relative;
}
.reader-bookmark-summary {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  max-width: 360px;
  padding: 5px 7px 5px 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.62);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025);
}
.reader-bookmark-summary.has-bookmark {
  border-color: rgba(229,9,20,.42);
  background: rgba(229,9,20,.13);
  color: #fff;
}
.reader-bookmark-summary small {
  max-width: 220px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: .02em;
}
.reader-bookmark-jump,
.reader-bookmark-remove,
.reader-inline-bookmark-card button,
.reader-selection-bookmark-popover button {
  border: 0;
  color: inherit;
  font: inherit;
  cursor: pointer;
}
.reader-bookmark-jump {
  display: grid;
  gap: 1px;
  min-width: 0;
  max-width: 270px;
  padding: 0 3px;
  background: transparent;
  text-align: left;
}
.reader-bookmark-jump span {
  color: rgba(255,255,255,.58);
  font-size: 9px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.reader-bookmark-jump strong {
  overflow: hidden;
  color: #fff;
  font-size: 12px;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.reader-bookmark-remove {
  display: inline-grid;
  place-items: center;
  width: 27px;
  height: 27px;
  flex: 0 0 auto;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: rgba(255,255,255,.82);
  font-size: 18px;
  line-height: 1;
}
.reader-bookmark-remove:hover,
.reader-inline-bookmark-card button:hover,
.reader-selection-bookmark-popover button:hover {
  background: rgba(229,9,20,.88);
  color: #fff;
}
.reader-inline-bookmark-marker {
  position: absolute;
  left: -46px;
  z-index: 8;
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid rgba(229,9,20,.58);
  border-radius: 999px;
  background: rgba(12,12,14,.92);
  color: #fff;
  cursor: pointer;
  box-shadow: 0 14px 34px rgba(0,0,0,.34), 0 0 0 6px rgba(229,9,20,.08);
  transform: translateY(-50%);
}
.reader-inline-bookmark-marker span {
  color: var(--brand);
  font-size: 18px;
  font-weight: 950;
  line-height: 1;
}
.reader-inline-bookmark-marker:hover {
  background: rgba(229,9,20,.95);
  border-color: rgba(255,255,255,.3);
}
.reader-inline-bookmark-marker:hover span {
  color: #fff;
}
.reader-inline-bookmark-card {
  position: absolute;
  left: -4px;
  z-index: 9;
  width: min(320px, 84vw);
  padding: 12px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  background: rgba(16,16,18,.98);
  box-shadow: 0 24px 70px rgba(0,0,0,.5);
  backdrop-filter: blur(14px);
}
.reader-inline-bookmark-card strong {
  display: block;
  margin-bottom: 5px;
  color: #fff;
  font-family: var(--font-ui, inherit);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.reader-inline-bookmark-card p {
  margin: 0 0 10px;
  color: rgba(255,255,255,.76);
  font-family: var(--font-ui, inherit);
  font-size: 13px;
  line-height: 1.35;
}
.reader-inline-bookmark-card button {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.1);
  color: #fff;
  font-family: var(--font-ui, inherit);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.reader-selection-bookmark-popover {
  position: fixed;
  z-index: 120;
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.45));
}
.reader-selection-bookmark-popover button {
  padding: 10px 13px;
  border-radius: 999px;
  background: rgba(229,9,20,.96);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.reader-selection-bookmark-popover button:disabled {
  opacity: .7;
  cursor: wait;
}
@media (max-width: 1180px) {
  .reader-inline-bookmark-marker {
    left: -36px;
  }
}
@media (max-width: 760px) {
  .reader-inline-bookmark-marker {
    left: -8px;
    transform: translate(-100%, -50%);
  }
  .reader-bookmark-summary {
    width: 100%;
    max-width: none;
  }
  .reader-bookmark-jump {
    max-width: none;
  }
}

/* v38 — lecture: sélection sans menu navigateur + colonnes latérales professionnelles */
.reader-page .reader-shell {
  align-items: start;
}
.reader-page .reader-sidebar,
.reader-page .music-panel {
  max-height: calc(100vh - 106px);
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.24) transparent;
  padding-right: 5px;
}
.reader-page .reader-sidebar::-webkit-scrollbar,
.reader-page .music-panel::-webkit-scrollbar {
  width: 6px;
}
.reader-page .reader-sidebar::-webkit-scrollbar-track,
.reader-page .music-panel::-webkit-scrollbar-track {
  background: transparent;
}
.reader-page .reader-sidebar::-webkit-scrollbar-thumb,
.reader-page .music-panel::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(255,255,255,.22);
}
.reader-page .reader-sidebar::-webkit-scrollbar-thumb:hover,
.reader-page .music-panel::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,.34);
}
.reader-page .reader-content {
  overflow: visible;
}
.reader-page .reader-text-bookmark-enabled {
  -webkit-touch-callout: none;
}
.reader-page.panels-collapsed .reader-sidebar,
.reader-page.panels-collapsed .music-panel {
  overflow: visible;
  max-height: none;
}
@media (max-width: 1180px) {
  .reader-page .reader-sidebar,
  .reader-page .music-panel {
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }
}

/* v39 — lecture : marque-page sans sélection native + colonnes latérales aérées */
.reader-page .reader-shell {
  gap: clamp(30px, 3vw, 48px);
  max-width: 1780px;
  align-items: start;
}
.reader-page .reader-sidebar,
.reader-page .music-panel {
  gap: 18px;
  border: 1px solid rgba(255,255,255,.11);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(20,20,24,.86), rgba(10,10,12,.74));
  box-shadow: 0 24px 70px rgba(0,0,0,.28);
  backdrop-filter: blur(16px);
}
.reader-page .reader-sidebar {
  padding: 58px 16px 18px;
}
.reader-page .music-panel {
  padding: 18px 16px;
}
.reader-page .reader-sidebar > *,
.reader-page .music-panel > * {
  min-width: 0;
  position: relative;
  z-index: 1;
}
.reader-page .reader-cover {
  width: 100%;
  min-height: 128px;
  margin: 0 0 6px;
  flex: none;
  border-radius: 14px;
  box-shadow: inset 0 -60px 90px rgba(0,0,0,.44), 0 16px 34px rgba(0,0,0,.32);
}
.reader-page .reader-sidebar h1 {
  margin-top: 2px;
  font-size: clamp(22px, 1.9vw, 30px);
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.reader-page .reader-sidebar p {
  margin: 0;
}
.reader-page .reader-tags {
  gap: 9px;
  padding-top: 2px;
}
.reader-page .chapter-nav.episode-nav {
  gap: 10px;
  padding-top: 4px;
}
.reader-page .chapter-nav.episode-nav a.chapter-episode-link {
  gap: 12px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255,255,255,.055);
}
.reader-page .chapter-episode-thumb {
  border-radius: 10px;
}
.reader-page .chapter-episode-copy strong {
  line-height: 1.3;
}
.reader-page .reader-content {
  border-radius: 20px;
  padding: clamp(28px, 4vw, 58px);
}
.reader-page .reader-text-bookmark-enabled {
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
}
.reader-bookmark-place {
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(255,255,255,.09);
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .01em;
  cursor: pointer;
  transition: border-color .18s ease, background .18s ease, transform .18s ease;
}
.reader-bookmark-place:hover,
.reader-bookmark-place.is-active {
  border-color: rgba(229,9,20,.55);
  background: rgba(229,9,20,.22);
  transform: translateY(-1px);
}
.reader-bookmark-place:disabled {
  opacity: .55;
  cursor: wait;
  transform: none;
}
.reader-bookmark-placement-active {
  cursor: crosshair;
}
.reader-bookmark-placement-active * {
  cursor: crosshair !important;
}
.reader-bookmark-placement-guide {
  position: absolute;
  left: -64px;
  z-index: 9;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 0;
  padding: 0;
  background: transparent;
  color: #fff;
  pointer-events: none;
  transform: translateY(-50%);
}
.reader-bookmark-placement-guide span {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--brand);
  box-shadow: 0 0 0 8px rgba(229,9,20,.13), 0 14px 32px rgba(0,0,0,.45);
  font-weight: 950;
}
.reader-bookmark-placement-guide em {
  display: inline-flex;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  background: rgba(12,12,14,.92);
  color: rgba(255,255,255,.86);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}
.reader-selection-bookmark-popover {
  display: none !important;
}
@media (max-width: 1180px) {
  .reader-page .reader-shell {
    gap: 22px;
  }
  .reader-page .reader-sidebar,
  .reader-page .music-panel {
    padding: 18px;
  }
  .reader-page .reader-sidebar {
    padding-top: 54px;
  }
}
@media (max-width: 760px) {
  .reader-bookmark-placement-guide {
    left: 8px;
  }
  .reader-bookmark-placement-guide em {
    display: none;
  }
}

/* v40 — lecture : panneaux latéraux premium sans gros encadré + marque-page au survol de ligne */
.reader-page .reader-shell {
  grid-template-columns: minmax(245px, 285px) minmax(0, 1060px) minmax(250px, 310px);
  gap: clamp(34px, 3.8vw, 62px);
  max-width: 1840px;
}
.reader-page .reader-sidebar,
.reader-page .music-panel {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  padding: 4px 6px 28px 0 !important;
  scrollbar-gutter: stable;
}
.reader-page .reader-sidebar::before,
.reader-page .music-panel::before {
  content: none !important;
}
.reader-page .reader-cover {
  min-height: 142px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: inset 0 -70px 110px rgba(0,0,0,.52), 0 24px 60px rgba(0,0,0,.36);
  overflow: hidden;
}
.reader-page .reader-sidebar h1 {
  margin: 4px 0 0;
  font-size: clamp(24px, 2vw, 34px);
  line-height: 1.02;
  letter-spacing: -.045em;
}
.reader-page .reader-sidebar p {
  color: rgba(255,255,255,.62);
  font-size: 13px;
  line-height: 1.55;
}
.reader-page .reader-tags {
  display: grid;
  gap: 8px;
  margin: 2px 0 8px;
}
.reader-page .reader-tags span {
  width: fit-content;
  max-width: 100%;
  border: 0;
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(255,255,255,.075);
  color: rgba(255,255,255,.78);
  font-size: 12px;
  line-height: 1.25;
}
.reader-page .chapter-nav.episode-nav {
  position: relative;
  gap: 9px;
  padding: 14px 0 0;
  margin-top: 2px;
}
.reader-page .chapter-nav.episode-nav::before,
.reader-page .music-panel h2::after {
  content: '';
  display: block;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,255,255,.18), rgba(255,255,255,0));
}
.reader-page .chapter-nav.episode-nav::before {
  position: absolute;
  inset: 0 0 auto;
}
.reader-page .chapter-nav.episode-nav a.chapter-episode-link {
  border: 0;
  border-radius: 16px;
  padding: 9px;
  background: rgba(255,255,255,.045);
  color: rgba(255,255,255,.82);
  box-shadow: none;
  transition: transform .18s ease, background .18s ease, color .18s ease;
}
.reader-page .chapter-nav.episode-nav a.chapter-episode-link:hover {
  transform: translateX(3px);
  background: rgba(255,255,255,.09);
  color: #fff;
}
.reader-page .chapter-nav.episode-nav a.chapter-episode-link.active {
  background: linear-gradient(135deg, rgba(255,255,255,.16), rgba(255,255,255,.065));
  color: #fff;
  box-shadow: inset 3px 0 0 var(--brand);
}
.reader-page .chapter-episode-thumb {
  width: 74px;
  min-width: 74px;
  border-radius: 12px;
  box-shadow: 0 14px 28px rgba(0,0,0,.26);
}
.reader-page .chapter-episode-copy small {
  color: rgba(255,255,255,.48);
  font-size: 10px;
  letter-spacing: .14em;
}
.reader-page .chapter-episode-copy strong {
  color: inherit;
  font-size: 13px;
  line-height: 1.25;
}
.reader-page .chapter-episode-copy em {
  width: fit-content;
  margin-top: 4px;
  border-radius: 999px;
  padding: 3px 7px;
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.62);
  font-size: 10px;
}
.reader-page .music-panel {
  padding-left: 4px !important;
}
.reader-page .music-panel h2 {
  display: grid;
  gap: 12px;
  margin: 0 0 4px;
  color: rgba(255,255,255,.9);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.reader-page .music-panel .muted-note {
  border-radius: 16px;
  padding: 14px;
  background: rgba(255,255,255,.045);
}
.reader-page .music-cue {
  border: 0;
  border-radius: 18px;
  padding: 14px;
  background: rgba(255,255,255,.055);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.reader-page .music-cue:hover {
  background: rgba(255,255,255,.08);
}
.reader-page .reader-content {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(17,17,20,.96), rgba(11,11,13,.98));
  box-shadow: 0 34px 100px rgba(0,0,0,.38);
}
.reader-page .reader-text-hover-bookmarks {
  position: relative;
  overflow: visible;
  -webkit-user-select: none;
  user-select: none;
}
.reader-line-bookmark-hover,
.reader-inline-bookmark-marker.saved-bookmark-marker {
  position: absolute;
  left: -62px;
  z-index: 12;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 999px;
  background: rgba(18,18,20,.82);
  color: rgba(255,255,255,.9);
  box-shadow: 0 18px 38px rgba(0,0,0,.38);
  backdrop-filter: blur(14px);
  cursor: pointer;
  transform: translateY(-50%) scale(.96);
  opacity: .72;
  transition: opacity .16s ease, transform .16s ease, background .16s ease, border-color .16s ease;
}
.reader-line-bookmark-hover[hidden],
.reader-inline-bookmark-marker.saved-bookmark-marker[hidden] {
  display: none !important;
}
.reader-line-bookmark-hover:hover,
.reader-inline-bookmark-marker.saved-bookmark-marker:hover {
  opacity: 1;
  transform: translateY(-50%) scale(1.04);
  border-color: rgba(229,9,20,.55);
  background: rgba(229,9,20,.92);
}
.reader-line-bookmark-hover span,
.reader-inline-bookmark-marker.saved-bookmark-marker span {
  display: block;
  font-size: 21px;
  line-height: 1;
  transform: translateY(-1px);
}
.reader-line-bookmark-hover.is-remove {
  opacity: 1;
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.16);
}
.reader-line-bookmark-hover.is-remove span::after,
.reader-inline-bookmark-marker.saved-bookmark-marker span::after {
  content: '×';
  position: absolute;
  right: -7px;
  top: -8px;
  display: grid;
  place-items: center;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: var(--brand);
  color: #fff;
  font-size: 12px;
  font-weight: 950;
}
.reader-inline-bookmark-marker.saved-bookmark-marker {
  background: var(--brand);
  border-color: rgba(255,255,255,.24);
  opacity: 1;
}
.reader-bookmark-place,
.reader-bookmark-placement-guide {
  display: none !important;
}
.reader-bookmark-summary small {
  max-width: 260px;
}
@media (max-width: 1180px) {
  .reader-page .reader-shell {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .reader-page .reader-sidebar,
  .reader-page .music-panel {
    padding: 0 !important;
  }
  .reader-line-bookmark-hover,
  .reader-inline-bookmark-marker.saved-bookmark-marker {
    left: 8px;
  }
}


/* v41 — lecture : bannière rectangulaire + marque-page SVG premium */
.reader-page .reader-cover {
  border-radius: 0 !important;
}
.reader-page .reader-title-row {
  align-items: flex-start;
  gap: clamp(18px, 2.4vw, 34px);
}
.reader-heading-block {
  min-width: 0;
  display: grid;
  gap: 12px;
}
.reader-heading-block h2 {
  margin: 0;
}
.reader-title-actions {
  align-items: flex-start;
}
.reader-bookmark-summary {
  width: fit-content;
  max-width: min(100%, 360px);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 0;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.reader-bookmark-summary[hidden] {
  display: none !important;
}
.reader-bookmark-jump {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 7px 12px 7px 10px;
  background: linear-gradient(135deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  color: rgba(255,255,255,.88);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .01em;
  line-height: 1;
  box-shadow: 0 14px 34px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(14px);
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease, color .18s ease;
}
.reader-bookmark-jump:hover,
.reader-bookmark-jump:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(229,9,20,.45);
  background: linear-gradient(135deg, rgba(229,9,20,.92), rgba(151,6,13,.88));
  color: #fff;
}
.reader-bookmark-jump svg,
.reader-bookmark-remove + svg {
  flex: 0 0 auto;
}
.reader-bookmark-jump svg {
  width: 16px;
  height: 16px;
  fill: rgba(255,255,255,.08);
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.reader-bookmark-jump span {
  white-space: nowrap;
}
.reader-bookmark-jump strong {
  display: none !important;
}
.reader-bookmark-remove {
  width: 30px;
  height: 30px;
  min-width: 30px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.72);
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: background .18s ease, color .18s ease, border-color .18s ease, transform .18s ease;
}
.reader-bookmark-remove:hover,
.reader-bookmark-remove:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.24);
  background: rgba(255,255,255,.12);
  color: #fff;
}
.reader-line-bookmark-hover,
.reader-inline-bookmark-marker.saved-bookmark-marker {
  width: 38px;
  height: 38px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(16,16,18,.78);
  color: rgba(255,255,255,.88);
}
.reader-line-bookmark-hover svg,
.reader-inline-bookmark-marker.saved-bookmark-marker svg {
  width: 19px;
  height: 19px;
  fill: rgba(255,255,255,.055);
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,.26));
}
.reader-line-bookmark-hover:hover,
.reader-line-bookmark-hover:focus-visible {
  border-color: rgba(229,9,20,.55);
  background: rgba(229,9,20,.92);
  color: #fff;
}
.reader-inline-bookmark-marker.saved-bookmark-marker {
  border-color: rgba(255,255,255,.20);
  background: linear-gradient(135deg, var(--brand), #9f0710);
  color: #fff;
}
.reader-inline-bookmark-marker.saved-bookmark-marker svg {
  fill: rgba(255,255,255,.22);
}
.reader-line-bookmark-hover.is-remove::after,
.reader-inline-bookmark-marker.saved-bookmark-marker::after {
  content: '×';
  position: absolute;
  right: -7px;
  top: -7px;
  display: grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border-radius: 999px;
  background: #fff;
  color: #111;
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 6px 14px rgba(0,0,0,.28);
}
.reader-line-bookmark-hover span,
.reader-inline-bookmark-marker.saved-bookmark-marker span,
.reader-line-bookmark-hover span::after,
.reader-inline-bookmark-marker.saved-bookmark-marker span::after {
  content: none !important;
  display: none !important;
}
.reader-bookmark-summary small,
.reader-bookmark-placement-guide,
.reader-bookmark-place {
  display: none !important;
}
@media (max-width: 760px) {
  .reader-bookmark-jump span {
    max-width: 170px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}

/* v42: polish client interactions, header and brand identity. */
body:not(.admin-page) {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
body:not(.admin-page) input,
body:not(.admin-page) textarea,
body:not(.admin-page) select,
body:not(.admin-page) option,
body:not(.admin-page) [contenteditable="true"],
body:not(.admin-page) .allow-text-select {
  -webkit-user-select: text;
  -moz-user-select: text;
  -ms-user-select: text;
  user-select: text;
}

.brand-link {
  align-items: center;
  line-height: 1;
  flex-shrink: 0;
}
.headflix-logo {
  gap: 10px;
  letter-spacing: -0.045em;
  transform: perspective(520px) rotateX(0deg);
}
.headflix-logo-mark {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: .95em;
  height: 1.12em;
  color: #fff;
  border-radius: .18em;
  background: linear-gradient(145deg, #ff4650 0%, #e50914 42%, #8f050b 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), inset 0 -10px 18px rgba(0,0,0,.22), 0 10px 28px rgba(229,9,20,.22);
  overflow: hidden;
  transform: skewX(-3deg);
}
.headflix-logo-mark::before,
.headflix-logo-mark::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 36%;
  border-radius: .18em;
  background: linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0) 32%, rgba(0,0,0,.22));
  pointer-events: none;
}
.headflix-logo-mark::before { left: 0; }
.headflix-logo-mark::after { right: 0; }
.headflix-logo-mark span {
  position: relative;
  z-index: 1;
  font-size: .78em;
  font-weight: 1000;
  letter-spacing: -.08em;
  line-height: 1;
  text-shadow: 0 2px 8px rgba(0,0,0,.34);
  transform: scaleX(.96);
}
.headflix-logo-word {
  position: relative;
  display: inline-block;
  color: var(--brand);
  text-shadow: 0 0 22px rgba(229, 9, 20, 0.18), 0 1px 0 rgba(255,255,255,.06);
  transform: scaleY(1.05);
}
.headflix-logo-word::after {
  content: "";
  position: absolute;
  left: 3%;
  right: 3%;
  bottom: -.16em;
  height: .12em;
  border-radius: 999px;
  background: radial-gradient(ellipse at center, rgba(229,9,20,.48), transparent 68%);
  opacity: .48;
}
.logo-small .headflix-logo-mark { width: .9em; height: 1.08em; border-radius: .2em; }
.logo-small .headflix-logo-word::after { display: none; }

.navlinks {
  align-items: center;
}
.navlinks a,
.reader-header nav > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 8px 11px;
  border-radius: 999px;
  line-height: 1;
  font-weight: 780;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,0);
  border: 1px solid rgba(255,255,255,0);
  transition: color .18s ease, background .18s ease, border-color .18s ease, transform .18s ease;
}
.navlinks a:hover,
.reader-header nav > a:hover {
  color: #fff;
  background: rgba(255,255,255,.075);
  border-color: rgba(255,255,255,.11);
  transform: translateY(-1px);
}
.reader-header nav {
  align-items: center;
}
.reader-header-actions,
.reader-header-actions nav {
  min-height: 38px;
}
.reader-header .brand-link,
.topbar .brand-link,
.profile-topbar .brand-link {
  min-height: 42px;
}

/* v43: header proche plateforme streaming, logo wordmark et actions à droite. */
.topbar,
.profile-topbar {
  min-height: 68px;
  padding: 0 clamp(26px, 3.9vw, 64px);
  background: linear-gradient(180deg, rgba(0,0,0,.96) 0%, rgba(0,0,0,.72) 62%, rgba(0,0,0,0) 100%);
}
.topbar.scrolled,
.profile-topbar.scrolled {
  background: #050505;
  border-bottom: 0;
  box-shadow: 0 1px 0 rgba(255,255,255,.035);
  backdrop-filter: none;
}
.leftnav { gap: clamp(22px, 2.3vw, 38px); }
.rightnav-netflix { gap: 21px; }

.logo.headflix-logo {
  display: inline-flex;
  align-items: center;
  color: #e50914;
  font-family: Impact, Haettenschweiler, "Arial Black", "Bebas Neue", "Oswald", sans-serif;
  font-size: clamp(32px, 3vw, 42px);
  font-weight: 900;
  line-height: .84;
  letter-spacing: .015em;
  text-shadow: none;
  filter: drop-shadow(0 0 10px rgba(229,9,20,.08));
  transform: scaleX(.9) scaleY(1.08);
  transform-origin: left center;
}
.logo.logo-small {
  font-size: 30px;
}
.headflix-logo-word {
  display: inline-block;
  color: #e50914;
  transform: perspective(220px) rotateX(4deg);
  transform-origin: center bottom;
  text-shadow: none;
}
.headflix-logo-word::after { display: none !important; }
.headflix-logo-mark { display: none !important; }

.navlinks-netflix {
  display: flex;
  align-items: center;
  gap: clamp(18px, 1.3vw, 27px);
  font-size: 14px;
  font-weight: 650;
  letter-spacing: -.01em;
  white-space: nowrap;
  color: rgba(255,255,255,.92);
}
.navlinks-netflix a,
.reader-header .navlinks-netflix a,
.reader-header nav.navlinks-netflix > a {
  min-height: 68px;
  padding: 0;
  border: 0;
  border-radius: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: rgba(255,255,255,.88);
  opacity: 1;
  font-weight: 650;
  transform: none;
  transition: color .18s ease, opacity .18s ease;
}
.navlinks-netflix a:first-child,
.reader-header .navlinks-netflix a:first-child {
  color: #fff;
  font-weight: 780;
}
.navlinks-netflix a:hover,
.reader-header .navlinks-netflix a:hover,
.reader-header nav.navlinks-netflix > a:hover {
  color: rgba(255,255,255,.62);
  background: transparent;
  border-color: transparent;
  transform: none;
}

.header-icon-btn {
  position: relative;
  width: 25px;
  height: 25px;
  display: inline-grid;
  place-items: center;
  color: #fff;
  border: 0;
  background: transparent;
  padding: 0;
  cursor: pointer;
  opacity: .98;
  transition: opacity .18s ease, transform .18s ease;
}
.header-icon-btn:hover,
.header-icon-btn:focus-visible {
  opacity: .7;
  transform: translateY(-1px);
  outline: none;
}
.header-icon-btn svg {
  width: 25px;
  height: 25px;
  display: block;
  fill: currentColor;
}
.kids-link {
  color: rgba(255,255,255,.92);
  font-size: 14px;
  font-weight: 760;
  line-height: 1;
  white-space: nowrap;
  transition: color .18s ease;
}
.kids-link:hover { color: rgba(255,255,255,.65); }
.notification-badge {
  position: absolute;
  top: -7px;
  right: -8px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #e50914;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 0 0 2px #050505;
}
.topbar .avatar,
.profile-topbar .avatar,
.header-avatar,
.reader-header .header-avatar {
  width: 32px;
  height: 32px;
  border-radius: 4px;
  border: 0;
  background: #262626;
  overflow: hidden;
  box-shadow: none;
}
.topbar .avatar-link:hover,
.topbar .avatar-link:focus-visible,
.profile-topbar .avatar-link:hover,
.profile-topbar .avatar-link:focus-visible,
.reader-header .header-avatar:hover,
.reader-header .header-avatar:focus-visible {
  transform: none;
  box-shadow: none;
  border-color: transparent;
}
.topbar .account-menu,
.profile-topbar .account-menu,
.reader-header .account-menu {
  padding-right: 17px;
}
.topbar .account-menu::after,
.profile-topbar .account-menu::after,
.reader-header .account-menu::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  margin-top: -2px;
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #fff;
  opacity: .95;
  pointer-events: none;
  transition: transform .18s ease;
}
.topbar .account-menu.open::after,
.profile-topbar .account-menu.open::after,
.reader-header .account-menu.open::after {
  transform: rotate(180deg);
}
.account-dropdown {
  top: calc(100% + 15px);
  border-radius: 2px;
  background: rgba(0,0,0,.92);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 12px 35px rgba(0,0,0,.72);
}
.account-dropdown::before {
  background: rgba(0,0,0,.92);
}

.reader-header {
  min-height: 64px;
  padding: 0 clamp(26px, 3.9vw, 64px);
  background: #050505;
  border-bottom: 0;
  box-shadow: 0 1px 0 rgba(255,255,255,.045);
  backdrop-filter: none;
}
.reader-header-actions {
  display: flex;
  align-items: center;
  gap: 21px;
}
.reader-header .brand-link,
.topbar .brand-link,
.profile-topbar .brand-link {
  min-height: 68px;
}
.reader-header .brand-link { min-height: 64px; }
.reader-navlinks { gap: 22px; }
.reader-navlinks a { min-height: 64px !important; }

@media (max-width: 1080px) {
  .navlinks-netflix a:nth-child(n+4) { display: none; }
  .kids-link { display: none; }
}
@media (max-width: 760px) {
  .topbar, .profile-topbar { min-height: 60px; padding-inline: 18px; }
  .logo.headflix-logo { font-size: 29px; }
  .navlinks-netflix { gap: 15px; font-size: 13px; }
  .navlinks-netflix a:nth-child(n+3) { display: none; }
  .header-bell-btn { display: none; }
  .topbar .brand-link, .profile-topbar .brand-link { min-height: 60px; }
}


/* v44: logo arc, recherche fonctionnelle et notifications. */
.logo.headflix-logo {
  display: inline-flex;
  align-items: center;
  color: #e50914;
  font-family: Impact, Haettenschweiler, "Arial Black", "Bebas Neue", "Oswald", sans-serif;
  font-size: clamp(34px, 3.2vw, 47px);
  font-weight: 1000;
  line-height: .82;
  letter-spacing: -.035em;
  text-shadow: none;
  filter: drop-shadow(0 0 8px rgba(229,9,20,.08));
  transform: scaleX(.82) scaleY(1.08);
  transform-origin: left center;
}
.logo.logo-small { font-size: 31px; }
.headflix-logo-word {
  display: inline-flex !important;
  align-items: flex-end;
  gap: .005em;
  color: #e50914;
  transform: perspective(420px) rotateX(5deg);
  transform-origin: center bottom;
}
.headflix-logo-letter {
  display: inline-block;
  transform: translateY(var(--curve, 0px)) skewY(var(--skew, 0deg));
  transform-origin: center bottom;
}
.headflix-logo-word::after,
.headflix-logo-mark { display: none !important; }

.header-search-form {
  position: relative;
  display: inline-flex;
  align-items: center;
  height: 34px;
  border: 1px solid transparent;
  background: transparent;
  transition: width .18s ease, background .18s ease, border-color .18s ease;
}
.header-search-form input {
  width: 0;
  opacity: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: #fff;
  outline: none;
  font-size: 14px;
  transition: width .18s ease, opacity .18s ease, padding .18s ease;
}
.header-search-form.active {
  border-color: rgba(255,255,255,.75);
  background: rgba(0,0,0,.78);
  padding-right: 10px;
}
.header-search-form.active input {
  width: min(250px, 22vw);
  opacity: 1;
  padding-left: 9px;
}
.header-search-form input::placeholder { color: rgba(255,255,255,.62); }

.notification-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.notification-dropdown {
  position: absolute;
  top: calc(100% + 16px);
  right: -14px;
  width: min(380px, 88vw);
  max-height: 70vh;
  overflow-y: auto;
  background: rgba(0,0,0,.94);
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 18px 55px rgba(0,0,0,.72);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-8px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 90;
}
.notification-menu.open .notification-dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.notification-dropdown::before {
  content: "";
  position: absolute;
  right: 20px;
  top: -8px;
  width: 14px;
  height: 14px;
  background: rgba(0,0,0,.94);
  border-left: 1px solid rgba(255,255,255,.16);
  border-top: 1px solid rgba(255,255,255,.16);
  transform: rotate(45deg);
}
.notification-dropdown-head {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  background: rgba(0,0,0,.96);
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.notification-dropdown-head strong { font-size: 16px; }
.notification-dropdown-head button {
  border: 0;
  background: transparent;
  color: rgba(255,255,255,.72);
  cursor: pointer;
  font-weight: 750;
}
.notification-dropdown-head button:hover { color: #fff; }
.notification-item {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr);
  gap: 11px;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  color: #fff;
  text-decoration: none;
  transition: background .16s ease;
}
.notification-item:hover { background: rgba(255,255,255,.075); }
.notification-item strong { display: block; font-size: 14px; margin-bottom: 4px; }
.notification-item small { display: block; color: rgba(255,255,255,.66); line-height: 1.35; }
.notification-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-top: 5px;
  background: transparent;
}
.notification-item.unread .notification-dot { background: #e50914; box-shadow: 0 0 14px rgba(229,9,20,.65); }
.notification-empty { padding: 22px 18px; color: rgba(255,255,255,.58); }

.search-shell {
  min-height: 100vh;
  padding: 118px clamp(22px, 4vw, 70px) 80px;
  background: #050505;
}
.search-hero h1 { margin: 8px 0 26px; font-size: clamp(34px, 5vw, 68px); }
.search-main-form {
  display: flex;
  gap: 14px;
  max-width: 720px;
}
.search-main-form input {
  flex: 1;
  min-height: 52px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  color: #fff;
  border-radius: 2px;
  padding: 0 16px;
  font-size: 17px;
}
.search-results-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 24px 14px;
}
.search-card { min-height: 132px; cursor: pointer; }
.notification-admin-form { max-width: 820px; display: grid; gap: 16px; }
.notification-admin-form textarea { min-height: 150px; }

@media (max-width: 900px) {
  .navlinks-netflix a:nth-child(n+4) { display: none; }
  .header-search-form.active input { width: 160px; }
}

/* v48: logo image utilisateur transparent forcé dans header et footer. */
.logo.headflix-logo {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: clamp(142px, 11vw, 198px) !important;
  height: 42px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  color: transparent !important;
  font-size: 0 !important;
  line-height: 0 !important;
  letter-spacing: 0 !important;
  text-shadow: none !important;
  transform: none !important;
  overflow: visible !important;
}
.logo.headflix-logo.logo-small {
  width: clamp(126px, 9vw, 168px) !important;
  height: 36px !important;
}
.headflix-logo-img {
  display: block !important;
  height: 100% !important;
  width: auto !important;
  max-width: 100% !important;
  object-fit: contain !important;
  object-position: left center !important;
  background: transparent !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
  pointer-events: none !important;
}
.headflix-logo-word,
.headflix-logo-letter,
.headflix-logo-mark { display: none !important; }
.footer .logo.headflix-logo.logo-small {
  width: clamp(138px, 10vw, 185px) !important;
  height: 40px !important;
}
@media (max-width: 760px) {
  .logo.headflix-logo { width: 126px !important; height: 36px !important; }
  .logo.headflix-logo.logo-small { width: 116px !important; height: 33px !important; }
}

/* v49 — Hero homepage media: screenshots/video administrés pour le titre conseillé */
.hero.has-dynamic-media::before {
  background:
    linear-gradient(90deg, rgba(0,0,0,.98), rgba(0,0,0,.82) 28%, rgba(0,0,0,.24) 62%, rgba(0,0,0,.88)),
    linear-gradient(0deg, var(--bg), rgba(0,0,0,.08) 44%, rgba(0,0,0,.58));
}
.hero-media {
  position: absolute;
  inset: 0;
  z-index: -4;
  overflow: hidden;
  background:
    var(--hero-image, linear-gradient(135deg, #161616, #030303)),
    linear-gradient(135deg, #181818, #020202);
  background-size: cover;
  background-position: center;
  pointer-events: none;
}
.hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 68% 30%, rgba(229, 9, 20, .16), transparent 32%),
    linear-gradient(90deg, rgba(0,0,0,.18), transparent 48%, rgba(0,0,0,.28));
  pointer-events: none;
}
.hero-media-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.055);
  transition: opacity 1200ms ease, transform 7200ms ease;
  will-change: opacity, transform;
}
.hero-media-slide.active {
  opacity: 1;
  transform: scale(1.01);
}
.hero-video {
  position: absolute;
  left: 50%;
  top: 50%;
  width: max(100vw, 177.78vh);
  height: max(56.25vw, 100vh);
  transform: translate(-50%, -50%) scale(1.08);
  border: 0;
  opacity: .72;
  filter: saturate(1.08) contrast(1.05);
  pointer-events: none;
}
.hero.has-hero-video .hero-media {
  background-image: var(--hero-image, linear-gradient(135deg, #161616, #030303));
}
@media (max-width: 760px) {
  .hero-video { opacity: .55; transform: translate(-50%, -50%) scale(1.2); }
  .hero.has-dynamic-media::before {
    background:
      linear-gradient(90deg, rgba(0,0,0,.98), rgba(0,0,0,.84) 56%, rgba(0,0,0,.72)),
      linear-gradient(0deg, var(--bg), rgba(0,0,0,.15) 48%, rgba(0,0,0,.6));
  }
}

/* v50 : les grands titres de la bannière principale restent sur une seule ligne.
   La taille est ajustée automatiquement par JS via --hero-title-size. */
.hero-content.hero-featured {
  max-width: min(1040px, calc(100vw - 96px));
}
.hero h1.hero-title-fit {
  display: block;
  width: max-content;
  max-width: calc(100vw - 96px);
  white-space: nowrap;
  overflow: visible;
  font-size: var(--hero-title-size, clamp(44px, 8.5vw, 104px));
  line-height: .9;
}
.hero h1.hero-title-fit.hero-title-tight {
  letter-spacing: -0.075em;
}

@media (max-width: 760px) {
  .hero-content.hero-featured {
    max-width: calc(100vw - 44px);
  }
  .hero h1.hero-title-fit {
    max-width: calc(100vw - 44px);
    letter-spacing: -0.07em;
  }
}

/* v51 — Ma liste, page détail premium, badges et progression */
.navlinks a.active,
.navlinks-netflix a.active {
    color: #fff;
    font-weight: 700;
}

.card-status-stack {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 8;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 5px;
    pointer-events: none;
}

.card-status {
    display: inline-flex;
    align-items: center;
    max-width: 150px;
    border-radius: 999px;
    padding: 4px 8px;
    background: rgba(0,0,0,.68);
    color: #fff;
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .04em;
    text-transform: uppercase;
    box-shadow: 0 8px 20px rgba(0,0,0,.35);
    backdrop-filter: blur(8px);
}

.card-status.status-new { background: rgba(229,9,20,.92); }
.card-status.status-progress { background: rgba(32,118,255,.86); }
.card-status.status-finished { background: rgba(27,170,92,.86); }
.card-status.status-list { background: rgba(255,255,255,.18); border: 1px solid rgba(255,255,255,.24); }

.card-progress-line {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 10px;
    z-index: 9;
    height: 4px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255,255,255,.22);
    pointer-events: none;
}

.card-progress-line b {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #e50914;
}

.my-list-toggle.in-list,
.my-list-toggle[data-in-list="1"] {
    border-color: rgba(255,255,255,.45);
    background: rgba(255,255,255,.18);
    color: #fff;
}

.my-list-toggle:disabled {
    opacity: .65;
    cursor: wait;
}

.detail-page,
.my-list-page {
    background: #050505;
    color: #fff;
    min-height: 100vh;
}

.detail-shell {
    width: min(1560px, 100%);
    margin: 0 auto;
    padding: 78px 4vw 80px;
}

.detail-hero {
    position: relative;
    min-height: clamp(560px, 68vh, 760px);
    overflow: hidden;
    border-radius: 0 0 34px 34px;
    background:
        linear-gradient(90deg, rgba(5,5,5,.98) 0%, rgba(5,5,5,.82) 34%, rgba(5,5,5,.30) 68%, rgba(5,5,5,.88) 100%),
        linear-gradient(0deg, #050505 0%, rgba(5,5,5,0) 45%),
        var(--detail-image, linear-gradient(135deg, var(--a, #200122), var(--b, #6f0000)));
    background-size: cover;
    background-position: center;
    box-shadow: inset 0 -180px 160px rgba(5,5,5,.92), 0 24px 80px rgba(0,0,0,.48);
}

.detail-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 72% 20%, rgba(229,9,20,.18), transparent 36%), linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.78));
    pointer-events: none;
}

.detail-hero-video,
.detail-screenshot-reel,
.detail-screenshot-reel .hero-media-slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.detail-hero-video {
    transform: scale(1.14);
    opacity: .46;
    border: 0;
    pointer-events: none;
}

.detail-screenshot-reel .hero-media-slide {
    background-size: cover;
    background-position: center;
    opacity: 0;
    transition: opacity 900ms ease;
}

.detail-screenshot-reel .hero-media-slide.active { opacity: .52; }

.detail-hero-copy {
    position: relative;
    z-index: 2;
    width: min(760px, 94%);
    padding: clamp(110px, 18vh, 190px) 0 80px clamp(24px, 4vw, 72px);
}

.detail-hero-copy h1 {
    margin: 8px 0 16px;
    font-size: clamp(46px, 7vw, 118px);
    line-height: .86;
    letter-spacing: -.07em;
    text-transform: uppercase;
    max-width: 12ch;
    text-wrap: balance;
}

.detail-slogan {
    max-width: 760px;
    margin: 0 0 18px;
    color: rgba(255,255,255,.88);
    font-size: clamp(18px, 2vw, 27px);
    line-height: 1.25;
    font-weight: 700;
}

.detail-meta {
    flex-wrap: wrap;
    gap: 10px;
    margin: 18px 0 24px;
}

.detail-actions {
    margin-top: 24px;
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.detail-progress-box {
    width: min(420px, 100%);
    margin-top: 24px;
    padding: 16px 18px;
    border: 1px solid rgba(255,255,255,.12);
    border-radius: 18px;
    background: rgba(0,0,0,.42);
    backdrop-filter: blur(16px);
}

.detail-progress-box span,
.detail-progress-box strong {
    display: block;
}

.detail-progress-box span {
    color: rgba(255,255,255,.62);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.detail-progress-box strong {
    margin-top: 4px;
    font-size: 18px;
}

.detail-progress-box i {
    display: block;
    height: 5px;
    margin-top: 12px;
    overflow: hidden;
    border-radius: 999px;
    background: rgba(255,255,255,.18);
}

.detail-progress-box b {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #e50914;
}

.detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, .65fr);
    gap: 22px;
    margin: 34px 0;
}

.detail-panel {
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 24px;
    background: rgba(255,255,255,.045);
    box-shadow: 0 20px 60px rgba(0,0,0,.26);
    padding: clamp(22px, 3vw, 34px);
}

.detail-panel h2,
.detail-section h2 {
    margin: 0 0 14px;
    font-size: clamp(24px, 2.5vw, 38px);
    letter-spacing: -.035em;
}

.detail-synopsis-panel p {
    margin: 0;
    max-width: 90ch;
    color: rgba(255,255,255,.78);
    font-size: 18px;
    line-height: 1.65;
}

.detail-info-panel {
    display: grid;
    gap: 16px;
}

.detail-info-panel p {
    margin: 0;
    display: grid;
    gap: 5px;
}

.detail-info-panel span {
    color: rgba(255,255,255,.45);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .08em;
}

.detail-info-panel strong {
    color: rgba(255,255,255,.88);
    font-size: 15px;
    line-height: 1.45;
}

.detail-section {
    margin-top: 38px;
}

.detail-episode-list {
    display: grid;
    gap: 12px;
}

.detail-episode {
    display: grid;
    grid-template-columns: 52px 150px minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    min-height: 102px;
    padding: 12px 16px;
    border-radius: 18px;
    color: #fff;
    text-decoration: none;
    background: rgba(255,255,255,.055);
    border: 1px solid rgba(255,255,255,.08);
    transition: background .18s ease, transform .18s ease, border-color .18s ease;
}

.detail-episode:hover {
    transform: translateY(-2px);
    background: rgba(255,255,255,.095);
    border-color: rgba(255,255,255,.18);
}

.detail-episode-number {
    color: rgba(255,255,255,.34);
    font-size: 24px;
    font-weight: 900;
    letter-spacing: -.04em;
    text-align: center;
}

.detail-episode-thumb {
    display: block;
    height: 80px;
    border-radius: 12px;
    background: linear-gradient(135deg, #2a0610, #0d0d0d), var(--episode-image);
    background-size: cover;
    background-position: center;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.1);
}

.detail-episode-copy {
    display: grid;
    gap: 7px;
}

.detail-episode-copy strong {
    font-size: 18px;
}

.detail-episode-copy small {
    color: rgba(255,255,255,.52);
    font-size: 13px;
}

.detail-episode-play {
    border-radius: 999px;
    padding: 10px 14px;
    background: rgba(255,255,255,.12);
    color: rgba(255,255,255,.86);
    font-weight: 800;
    font-size: 13px;
}

.my-list-shell {
    padding-top: 110px;
}

.my-list-hero p {
    color: rgba(255,255,255,.68);
    max-width: 760px;
}

.my-list-empty h2 {
    margin: 0 0 8px;
}

.my-list-grid .card[data-in-my-list="0"] {
    opacity: .74;
}

@media (max-width: 900px) {
    .detail-shell { padding-left: 0; padding-right: 0; }
    .detail-hero { border-radius: 0 0 24px 24px; min-height: 620px; }
    .detail-hero-copy { padding-left: 24px; padding-right: 20px; }
    .detail-grid { grid-template-columns: 1fr; padding: 0 20px; }
    .detail-section { padding: 0 20px; }
    .detail-episode { grid-template-columns: 42px 92px minmax(0, 1fr); }
    .detail-episode-play { display: none; }
}

@media (max-width: 560px) {
    .detail-hero-copy h1 { font-size: clamp(38px, 14vw, 70px); }
    .detail-episode { grid-template-columns: 1fr; }
    .detail-episode-number { text-align: left; }
    .detail-episode-thumb { height: 140px; }
}

/* v52 — corrections badges, page détail pleine largeur et vignettes épisodes */
.card > .badge,
.plan-ribbon {
    display: none !important;
}

.card-status.status-soon {
    background: rgba(245,158,11,.96);
    color: #120800;
}

.modal-actions-top {
    margin: 18px 0 18px;
}

.detail-shell {
    width: 100%;
    max-width: none;
    padding-left: 0;
    padding-right: 0;
}

.detail-hero {
    border-radius: 0;
}

.detail-grid,
.detail-section {
    width: min(1720px, calc(100% - 64px));
    margin-left: auto;
    margin-right: auto;
}

.detail-actions-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin: 0 0 26px;
    padding: 18px;
    border: 1px solid rgba(255,255,255,.1);
    border-radius: 22px;
    background: rgba(255,255,255,.045);
    box-shadow: 0 18px 55px rgba(0,0,0,.26);
}

.detail-episodes-section {
    scroll-margin-top: 96px;
}

.detail-screenshot-reel {
    background: var(--detail-image, linear-gradient(135deg, #161616, #030303));
    background-size: cover;
    background-position: center;
}

.detail-screenshot-reel .hero-media-slide {
    opacity: 0;
    transform: scale(1.045);
    transition: opacity 1000ms ease, transform 7600ms ease;
}

.detail-screenshot-reel .hero-media-slide.active {
    opacity: .72;
    transform: scale(1.015);
}

.detail-episode-thumb {
    background-image:
        linear-gradient(90deg, rgba(0,0,0,.05), rgba(0,0,0,.38)),
        var(--episode-image, linear-gradient(135deg, #2a0610, #0d0d0d));
    background-size: cover;
    background-position: center;
}

@media (max-width: 900px) {
    .detail-grid,
    .detail-section {
        width: calc(100% - 40px);
        padding-left: 0;
        padding-right: 0;
    }

    .detail-actions-toolbar {
        padding: 14px;
    }
}

/* v53 — page détail : titre forcé sur une ligne, bannière screenshot propre, badges harmonisés */
.detail-hero-copy h1.hero-title-fit,
.detail-hero-copy h1.detail-title-fit {
    display: block;
    width: max-content;
    max-width: min(100%, calc(100vw - 48px));
    white-space: nowrap;
    text-wrap: nowrap;
    font-size: var(--hero-title-size, clamp(44px, 7vw, 118px));
    line-height: .86;
}

.detail-hero-copy h1.hero-title-tight {
    letter-spacing: -.082em;
}

.detail-hero.has-screenshot-reel {
    background:
        linear-gradient(90deg, rgba(5,5,5,.98) 0%, rgba(5,5,5,.82) 34%, rgba(5,5,5,.30) 68%, rgba(5,5,5,.88) 100%),
        linear-gradient(0deg, #050505 0%, rgba(5,5,5,0) 45%),
        linear-gradient(135deg, var(--a, #200122), var(--b, #6f0000));
}

.detail-screenshot-reel {
    background: #050505 !important;
    isolation: isolate;
}

.detail-screenshot-reel .hero-media-slide {
    opacity: 0;
    transform: scale(1.045);
    transition: opacity 900ms ease, transform 7600ms ease;
    will-change: opacity, transform;
}

.detail-screenshot-reel .hero-media-slide.active {
    opacity: .76;
    transform: scale(1.015);
}

.card-status.status-soon {
    background: rgba(229,9,20,.92) !important;
    color: #fff !important;
}

.card-status.status-progress {
    background: rgba(32,118,255,.88) !important;
    color: #fff !important;
}

@media (max-width: 560px) {
    .detail-hero-copy h1.hero-title-fit,
    .detail-hero-copy h1.detail-title-fit {
        max-width: calc(100vw - 40px);
        font-size: var(--hero-title-size, clamp(30px, 13vw, 70px));
    }
}

/* v53 — mode lecture immersion */
.reader-immersion-toggle {
    border-color: rgba(229,9,20,.42);
    color: #fff;
}

.reader-page.reader-immersive {
    background:
        radial-gradient(circle at 50% 0%, rgba(229,9,20,.11), transparent 34%),
        linear-gradient(180deg, #050505 0%, #020202 100%);
}

.reader-page.reader-immersive .reader-header,
.reader-page.reader-immersive .reader-sidebar,
.reader-page.reader-immersive .music-panel,
.reader-page.reader-immersive .reader-panel-icon,
.reader-page.reader-immersive .reader-recommendation,
.reader-page.reader-immersive .chapter-completion-card {
    display: none !important;
}

.reader-page.reader-immersive .reader-shell {
    display: block;
    max-width: none;
    padding: clamp(18px, 3vw, 42px) clamp(18px, 6vw, 96px) 110px;
}

.reader-page.reader-immersive .reader-content {
    width: min(1080px, 100%);
    margin: 0 auto;
    max-height: none;
    overflow: visible;
    padding: clamp(26px, 5vw, 76px) clamp(18px, 5vw, 82px);
    border: 0;
    border-radius: 28px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.018)),
        rgba(8,8,9,.88);
    box-shadow: 0 30px 110px rgba(0,0,0,.52);
}

.reader-page.reader-immersive .reader-title-row {
    position: sticky;
    top: 0;
    z-index: 18;
    align-items: center;
    margin: calc(-1 * clamp(26px, 5vw, 76px)) calc(-1 * clamp(18px, 5vw, 82px)) 34px;
    padding: 18px clamp(18px, 5vw, 82px);
    border-bottom: 1px solid rgba(255,255,255,.08);
    background: rgba(5,5,5,.86);
    backdrop-filter: blur(18px);
    border-radius: 28px 28px 0 0;
}

.reader-page.reader-immersive .reader-title-row h2 {
    font-size: clamp(25px, 3.8vw, 44px);
}

.reader-page.reader-immersive .reader-text {
    max-width: 880px;
    margin: 0 auto;
    font-size: clamp(21px, 1.7vw, 25px);
    line-height: 2.05;
}

.reader-page.reader-immersive .reader-text p {
    margin-bottom: 1.38em;
}

.reader-page.reader-immersive .reader-immersion-toggle {
    background: #fff;
    color: #050505;
    border-color: #fff;
}

.reader-page.reader-immersive .bottom-music-player {
    z-index: 80;
}

@media (max-width: 760px) {
    .reader-page.reader-immersive .reader-shell {
        padding: 0 0 96px;
    }

    .reader-page.reader-immersive .reader-content {
        width: 100%;
        border-radius: 0;
        padding: 72px 22px 44px;
    }

    .reader-page.reader-immersive .reader-title-row {
        margin: -72px -22px 28px;
        padding: 14px 18px;
        border-radius: 0;
        flex-direction: column;
        align-items: flex-start;
    }
}

/* v55 — publication brouillon/publier + cartes admin chapitres */
.chapter-compact-admin-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
}
.chapter-compact-link {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}
.chapter-admin-state,
.chapter-admin-status-pill {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  margin-top: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.chapter-admin-state.published,
.chapter-admin-status-pill.published {
  color: #d1fae5;
  background: rgba(16,185,129,.18);
  border: 1px solid rgba(16,185,129,.35);
}
.chapter-admin-state.draft,
.chapter-admin-status-pill.draft {
  color: #fff;
  background: rgba(229,9,20,.22);
  border: 1px solid rgba(229,9,20,.5);
}
.chapter-publish-mini,
.publish-btn {
  background: #e50914;
  border-color: #e50914;
  color: #fff;
  font-weight: 900;
}
.chapter-publish-mini {
  border: 0;
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
  white-space: nowrap;
}
.chapter-publish-mini:hover,
.publish-btn:hover {
  filter: brightness(1.08);
}
@media (max-width: 720px) {
  .chapter-compact-admin-card,
  .chapter-compact-link {
    grid-template-columns: 1fr;
  }
  .chapter-publish-mini {
    justify-self: start;
  }
}

/* v56 — refonte admin : organisation plus professionnelle, moins d'arrondis, style Netflix-like plus strict. */
body.admin-page {
  --admin-bg: #050505;
  --admin-surface: #101010;
  --admin-surface-2: #151515;
  --admin-surface-3: #1b1b1b;
  --admin-line: rgba(255,255,255,.105);
  --admin-line-strong: rgba(255,255,255,.18);
  --admin-red: #e50914;
  --admin-red-soft: rgba(229,9,20,.16);
  --admin-radius: 4px;
  background:
    radial-gradient(circle at 18% 0%, rgba(229,9,20,.13), transparent 28%),
    linear-gradient(180deg, #060606 0%, #090909 44%, #050505 100%);
  color: #f5f5f5;
}

body.admin-page .admin-header {
  min-height: 68px;
  padding: 12px clamp(18px, 3.4vw, 42px);
  background: rgba(5,5,5,.96);
  border-bottom: 1px solid rgba(255,255,255,.095);
  box-shadow: 0 18px 42px rgba(0,0,0,.42);
  backdrop-filter: blur(16px);
}
body.admin-page .admin-header nav {
  align-items: center;
  gap: 18px;
}
body.admin-page .admin-header nav > a {
  color: rgba(255,255,255,.78);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .01em;
  text-transform: uppercase;
}
body.admin-page .admin-header nav > a:hover { color: #fff; }
body.admin-page .brand-link .headflix-logo-img { max-height: 34px; }

body.admin-page .admin-shell,
body.admin-page .editor-shell,
body.admin-page .chapter-page-shell {
  max-width: 1680px;
  padding-left: clamp(18px, 3.3vw, 52px);
  padding-right: clamp(18px, 3.3vw, 52px);
}
body.admin-page .admin-hero,
body.admin-page .editor-hero,
body.admin-page .chapter-edit-topbar {
  border-bottom: 1px solid rgba(255,255,255,.11);
  padding-bottom: 22px;
  margin-bottom: 24px;
}
body.admin-page .admin-hero h1,
body.admin-page .editor-hero h1,
body.admin-page .chapter-edit-topbar h1 {
  font-size: clamp(32px, 3.5vw, 54px);
  letter-spacing: -.055em;
}
body.admin-page .admin-hero p:not(.eyebrow),
body.admin-page .editor-hero p:not(.eyebrow),
body.admin-page .chapter-edit-topbar p:not(.eyebrow) {
  color: rgba(255,255,255,.62);
}

body.admin-page .admin-dashboard-grid {
  display: grid;
  grid-template-columns: 286px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
body.admin-page .admin-main-area {
  min-width: 0;
  display: grid;
  gap: 22px;
}
body.admin-page .admin-sidebar-menu {
  position: sticky;
  top: 86px;
  display: grid;
  gap: 16px;
  padding: 16px;
  min-height: calc(100vh - 118px);
  border: 1px solid var(--admin-line);
  border-radius: var(--admin-radius);
  background: linear-gradient(180deg, rgba(18,18,18,.96), rgba(9,9,9,.96));
  box-shadow: 0 26px 60px rgba(0,0,0,.36);
}
body.admin-page .admin-sidebar-title {
  display: grid;
  gap: 4px;
  padding: 4px 2px 16px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
body.admin-page .admin-sidebar-title span,
body.admin-page .admin-menu-label {
  color: rgba(255,255,255,.42);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}
body.admin-page .admin-sidebar-title strong {
  font-size: 18px;
  letter-spacing: -.03em;
}

body.admin-page .admin-dashboard-grid .admin-tabs {
  position: static;
  display: grid;
  gap: 6px;
  overflow: visible;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
body.admin-page .admin-dashboard-grid .admin-menu-label {
  display: block;
  margin: 14px 8px 4px;
}
body.admin-page .admin-dashboard-grid .admin-tab {
  justify-content: flex-start;
  width: 100%;
  min-height: 42px;
  padding: 0 12px;
  border-radius: var(--admin-radius);
  border-left: 3px solid transparent;
  background: rgba(255,255,255,.035);
  color: rgba(255,255,255,.74);
  box-shadow: none;
}
body.admin-page .admin-dashboard-grid .admin-tab::before { display: none; }
body.admin-page .admin-dashboard-grid .admin-tab:hover {
  transform: none;
  background: rgba(255,255,255,.07);
  color: #fff;
}
body.admin-page .admin-dashboard-grid .admin-tab.active {
  border-left-color: var(--admin-red);
  background: linear-gradient(90deg, rgba(229,9,20,.22), rgba(255,255,255,.055));
  color: #fff;
  box-shadow: inset 0 0 0 1px rgba(229,9,20,.18);
}

/* Les sous-pages gardent un menu horizontal, mais en version plus carrée et sobre. */
body.admin-page > .admin-shell > .admin-tabs:not(.admin-dashboard-grid .admin-tabs) {
  top: 70px;
  gap: 6px;
  padding: 6px;
  border-radius: var(--admin-radius);
  background: rgba(12,12,12,.92);
  box-shadow: none;
}
body.admin-page > .admin-shell > .admin-tabs:not(.admin-dashboard-grid .admin-tabs) .admin-tab {
  border-radius: var(--admin-radius);
  min-height: 38px;
  padding: 0 14px;
}
body.admin-page > .admin-shell > .admin-tabs:not(.admin-dashboard-grid .admin-tabs) .admin-tab::before { display: none; }
body.admin-page > .admin-shell > .admin-tabs:not(.admin-dashboard-grid .admin-tabs) .admin-tab.active {
  background: #e50914;
  box-shadow: none;
}

body.admin-page .admin-panel,
body.admin-page .admin-subpanel,
body.admin-page .section-admin-card,
body.admin-page .admin-search-form,
body.admin-page .empty-panel,
body.admin-page .user-result-card,
body.admin-page .avatar-admin-form,
body.admin-page .avatar-admin-card,
body.admin-page .avatar-admin-avatar-card,
body.admin-page .avatar-admin-avatar-card-clean,
body.admin-page .avatar-admin-column,
body.admin-page .chapter-compact-admin-card,
body.admin-page .screenshot-editor,
body.admin-page details.item-editor,
body.admin-page details.user-editor,
body.admin-page .permission-box,
body.admin-page .rich-editor,
body.admin-page .editor-main-form,
body.admin-page .chapter-editor-workspace,
body.admin-page .chapter-music-studio {
  border-radius: var(--admin-radius) !important;
  border-color: var(--admin-line);
  background: linear-gradient(180deg, rgba(21,21,21,.96), rgba(13,13,13,.96));
  box-shadow: 0 18px 42px rgba(0,0,0,.28);
}
body.admin-page .admin-panel {
  padding: 22px;
}
body.admin-page .panel-head {
  padding-bottom: 15px;
  border-bottom: 1px solid rgba(255,255,255,.095);
}
body.admin-page .panel-head h2 {
  letter-spacing: -.035em;
}
body.admin-page .panel-head .muted-note,
body.admin-page .muted-note {
  color: rgba(255,255,255,.56);
}

body.admin-page input,
body.admin-page textarea,
body.admin-page select,
body.admin-page .btn,
body.admin-page .danger-link,
body.admin-page .tile-delete,
body.admin-page .chapter-publish-mini,
body.admin-page .status-pill,
body.admin-page .chapter-admin-state,
body.admin-page .chapter-admin-status-pill,
body.admin-page .catalog-card,
body.admin-page .catalog-poster,
body.admin-page .item-preview,
body.admin-page .item-preview.mini,
body.admin-page .screenshot-editor img,
body.admin-page .user-result-avatar,
body.admin-page .avatar-admin-preview,
body.admin-page .editor-hero-preview,
body.admin-page .chapter-compact-thumb {
  border-radius: var(--admin-radius) !important;
}
body.admin-page input,
body.admin-page textarea,
body.admin-page select {
  background: #080808;
  border-color: rgba(255,255,255,.145);
}
body.admin-page input:focus,
body.admin-page textarea:focus,
body.admin-page select:focus {
  outline: 2px solid rgba(229,9,20,.45);
  border-color: rgba(229,9,20,.85);
}
body.admin-page .btn,
body.admin-page .danger-link,
body.admin-page .chapter-publish-mini {
  text-transform: uppercase;
  letter-spacing: .045em;
  font-size: 12px;
  font-weight: 950;
}
body.admin-page .btn:hover,
body.admin-page .danger-link:hover,
body.admin-page .chapter-publish-mini:hover {
  transform: none;
  filter: brightness(1.08);
}
body.admin-page .btn-primary,
body.admin-page .publish-btn,
body.admin-page .chapter-publish-mini {
  background: #e50914;
  border-color: #e50914;
  color: #fff;
}
body.admin-page .btn-ghost {
  background: rgba(255,255,255,.12);
  color: #fff;
}
body.admin-page .btn-danger.soft,
body.admin-page .danger-link {
  background: rgba(229,9,20,.12);
  border-color: rgba(229,9,20,.46);
  color: #ffccd0;
}

body.admin-page .stat-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}
body.admin-page .stat-grid article {
  padding: 18px;
  border-radius: var(--admin-radius);
  border: 1px solid var(--admin-line);
  background: linear-gradient(180deg, #181818, #0d0d0d);
  box-shadow: none;
}
body.admin-page .stat-grid strong {
  font-size: clamp(28px, 3vw, 42px);
  color: #fff;
}
body.admin-page .stat-grid span {
  color: rgba(255,255,255,.52);
  text-transform: uppercase;
  font-weight: 850;
  letter-spacing: .08em;
}
body.admin-page .admin-quick-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
body.admin-page .admin-quick-card {
  display: grid;
  gap: 7px;
  min-height: 142px;
  padding: 18px;
  color: #fff;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.105);
  border-left: 3px solid rgba(229,9,20,.72);
  border-radius: var(--admin-radius);
  background: linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.028));
  transition: background .18s ease, border-color .18s ease;
}
body.admin-page .admin-quick-card:hover {
  background: linear-gradient(135deg, rgba(229,9,20,.18), rgba(255,255,255,.045));
  border-color: rgba(229,9,20,.45);
}
body.admin-page .admin-quick-card span {
  color: #e50914;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}
body.admin-page .admin-quick-card strong {
  font-size: 18px;
  letter-spacing: -.025em;
}
body.admin-page .admin-quick-card small {
  color: rgba(255,255,255,.6);
  line-height: 1.45;
}

body.admin-page .catalog-grid {
  gap: 12px;
}
body.admin-page .catalog-tile,
body.admin-page .catalog-card {
  border-radius: var(--admin-radius) !important;
}
body.admin-page .catalog-card {
  border: 1px solid rgba(255,255,255,.105);
  background: #0a0a0a;
}
body.admin-page .catalog-card:hover {
  transform: none;
  border-color: rgba(229,9,20,.45);
}
body.admin-page .catalog-edit-cta {
  background: rgba(229,9,20,.95);
  color: #fff;
  border-radius: var(--admin-radius);
}

body.admin-page .section-admin-list,
body.admin-page .user-search-results,
body.admin-page .avatar-admin-list,
body.admin-page .avatar-admin-avatar-grid,
body.admin-page .screenshot-editor-list,
body.admin-page .chapter-compact-list {
  gap: 10px;
}
body.admin-page .section-admin-card-head,
body.admin-page .avatar-admin-category-block h3 {
  border-bottom: 1px solid rgba(255,255,255,.085);
  padding-bottom: 10px;
}
body.admin-page .user-result-card:hover {
  transform: none;
  border-color: rgba(229,9,20,.38);
}

@media (max-width: 1180px) {
  body.admin-page .admin-dashboard-grid {
    grid-template-columns: 1fr;
  }
  body.admin-page .admin-sidebar-menu {
    position: static;
    min-height: 0;
  }
  body.admin-page .admin-dashboard-grid .admin-tabs {
    display: flex;
    flex-wrap: wrap;
  }
  body.admin-page .admin-dashboard-grid .admin-menu-label,
  body.admin-page .admin-sidebar-title {
    width: 100%;
  }
  body.admin-page .admin-dashboard-grid .admin-tab {
    width: auto;
  }
  body.admin-page .stat-grid,
  body.admin-page .admin-quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 760px) {
  body.admin-page .admin-header {
    flex-wrap: wrap;
  }
  body.admin-page .stat-grid,
  body.admin-page .admin-quick-grid {
    grid-template-columns: 1fr;
  }
  body.admin-page .panel-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* v57 — admin edition cleanup, pro episode slots, one-save screenshots */
body.admin-page .editor-layout {
  gap: 16px;
}
body.admin-page .editor-main-form .admin-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
body.admin-page .editor-main-form .panel-head {
  position: sticky;
  top: 72px;
  z-index: 8;
  background: linear-gradient(180deg, rgba(21,21,21,.98), rgba(13,13,13,.96));
}
body.admin-page .admin-episode-grid {
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  align-items: stretch;
}
body.admin-page .chapter-compact-admin-card {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  padding: 12px;
  align-items: stretch;
  min-height: 118px;
}
body.admin-page .chapter-compact-link {
  grid-template-columns: 118px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-width: 0;
}
body.admin-page .chapter-compact-copy {
  align-content: center;
  min-width: 0;
}
body.admin-page .chapter-compact-copy strong,
body.admin-page .chapter-episode-copy strong {
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  font-size: clamp(13px, 1.35vw, 16px);
  line-height: 1.18;
  letter-spacing: -.015em;
}
body.admin-page .chapter-card-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: 92px;
}
body.admin-page .chapter-publish-mini {
  border-radius: 4px !important;
  padding: 9px 12px;
  align-self: center;
}
body.admin-page .chapter-add-slot {
  display: grid !important;
  grid-template-columns: 118px minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 118px;
  border-style: dashed !important;
  border-color: rgba(229,9,20,.48) !important;
  background: linear-gradient(135deg, rgba(229,9,20,.14), rgba(255,255,255,.035)) !important;
  color: #fff;
  text-decoration: none;
}
body.admin-page .chapter-add-slot:hover {
  border-color: rgba(229,9,20,.9) !important;
  background: linear-gradient(135deg, rgba(229,9,20,.22), rgba(255,255,255,.055)) !important;
}
body.admin-page .chapter-add-plus {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid rgba(255,255,255,.16);
  border-radius: 4px !important;
  background: rgba(0,0,0,.38);
  color: #e50914;
  font-size: 44px;
  font-weight: 300;
  line-height: 1;
}
body.admin-page .chapter-add-slot small {
  color: rgba(255,255,255,.58);
  line-height: 1.35;
}
body.admin-page .screenshot-save-with-main {
  display: grid;
  gap: 12px;
}
body.admin-page .screenshot-save-with-main .muted-note {
  margin: 0;
  padding: 10px 12px;
  border-left: 3px solid rgba(229,9,20,.75);
  background: rgba(255,255,255,.045);
}
body.admin-page .chapter-editor-commandbar {
  align-items: start;
}
body.admin-page .chapter-meta-fields {
  grid-template-columns: minmax(240px, 1.4fr) 90px minmax(220px, 1fr) minmax(180px, .8fr) auto auto;
  align-items: end;
}
body.admin-page .chapter-editor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
  align-items: end;
}
body.admin-page .chapter-editor-actions .publish-btn {
  position: static !important;
  transform: none !important;
  border-radius: 4px !important;
}
body.admin-page .chapter-edit-topbar h1 {
  max-width: min(980px, 70vw);
  overflow-wrap: anywhere;
  line-height: 1.05;
}
body.admin-page .chapter-music-disabled {
  min-height: 180px;
  opacity: .82;
}
body.admin-page .compact-add-chapter {
  display: none !important;
}
body.admin-page .permission-box,
body.admin-page input,
body.admin-page textarea,
body.admin-page select,
body.admin-page .btn,
body.admin-page .danger-link,
body.admin-page .tile-delete,
body.admin-page .admin-panel,
body.admin-page .admin-subpanel,
body.admin-page .chapter-compact-admin-card,
body.admin-page .chapter-add-slot,
body.admin-page .screenshot-chip,
body.admin-page .chapter-editor-workspace,
body.admin-page .chapter-music-studio {
  border-radius: 4px !important;
}
@media (max-width: 980px) {
  body.admin-page .admin-episode-grid {
    grid-template-columns: 1fr;
  }
  body.admin-page .chapter-meta-fields {
    grid-template-columns: 1fr 96px;
  }
  body.admin-page .chapter-editor-actions {
    justify-content: flex-start;
  }
  body.admin-page .chapter-edit-topbar h1 {
    max-width: none;
  }
}
@media (max-width: 620px) {
  body.admin-page .chapter-compact-admin-card,
  body.admin-page .chapter-add-slot,
  body.admin-page .chapter-compact-link {
    grid-template-columns: 1fr !important;
  }
  body.admin-page .chapter-card-actions {
    justify-content: flex-start;
  }
}

/* v58 — admin éditorial plus sobre + notifications flottantes */
.flash {
  position: fixed !important;
  left: clamp(16px, 2.2vw, 30px) !important;
  bottom: calc(18px + (var(--toast-index, 0) * 64px)) !important;
  z-index: 9999 !important;
  width: min(420px, calc(100vw - 32px)) !important;
  margin: 0 !important;
  padding: 13px 16px !important;
  border-radius: 6px !important;
  border: 1px solid rgba(70, 210, 110, .42) !important;
  background: rgba(16, 30, 19, .96) !important;
  color: #eaffee !important;
  box-shadow: 0 18px 50px rgba(0,0,0,.5) !important;
  transform: translate3d(-18px, 14px, 0) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity .22s ease, transform .22s ease !important;
}
.flash.is-visible {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
}
.flash.is-hiding {
  opacity: 0 !important;
  transform: translate3d(-18px, 14px, 0) !important;
}
.flash.flash-error,
.flash.error {
  border-color: rgba(229, 9, 20, .58) !important;
  background: rgba(42, 7, 10, .96) !important;
  color: #ffe5e7 !important;
}
.form-error {
  position: static !important;
  margin: 16px 0 !important;
  opacity: 1 !important;
  transform: none !important;
}
body.admin-page .muted-note {
  line-height: 1.35;
}
body.admin-page .genre-picker {
  padding: 16px;
}
body.admin-page .genre-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
body.admin-page .genre-chip-option {
  display: inline-flex;
  align-items: center;
  width: auto;
  gap: 0;
  cursor: pointer;
}
body.admin-page .genre-chip-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
body.admin-page .genre-chip-option span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 8px 12px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 4px;
  background: rgba(255,255,255,.045);
  color: #d8d8d8;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .01em;
  transition: background .18s ease, border-color .18s ease, color .18s ease;
}
body.admin-page .genre-chip-option input:checked + span {
  border-color: rgba(229,9,20,.72);
  background: rgba(229,9,20,.18);
  color: #fff;
}
body.admin-page .genre-chip-option:hover span {
  border-color: rgba(255,255,255,.28);
  background: rgba(255,255,255,.075);
}
body.admin-page .editor-main-form label input[type="file"] {
  min-height: 46px;
}
body.admin-page form[data-autosubmit-media].is-uploading {
  opacity: .66;
  pointer-events: none;
}
body.admin-page form[data-autosubmit-media].is-uploading::after {
  content: 'Upload en cours…';
  display: inline-flex;
  margin-top: 10px;
  color: #fff;
  font-weight: 800;
  font-size: 12px;
}
body.admin-page .screenshot-chip div {
  display: grid;
  gap: 8px;
}
body.admin-page .screenshot-chip label {
  font-size: 12px;
}
body.admin-page .chapter-compact-copy strong {
  word-break: normal;
  overflow-wrap: anywhere;
}
body.admin-page .chapter-card-actions {
  align-self: center;
}
@media (max-width: 680px) {
  .flash {
    left: 12px !important;
    bottom: calc(12px + (var(--toast-index, 0) * 70px)) !important;
    width: calc(100vw - 24px) !important;
  }
  body.admin-page .genre-chip-grid {
    gap: 7px;
  }
}

/* v59 — admin ergonomie, validation sans rebond, édition épisode premium */
body.admin-page {
  scroll-behavior: auto;
}
body.admin-page .admin-action-cluster,
body.admin-page .chapter-v59-actions,
body.admin-page .chapter-v59-statusline {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
body.admin-page .editor-savebar {
  position: sticky;
  top: 72px;
  z-index: 20;
  margin: -22px -22px 22px;
  padding: 18px 22px;
  background: rgba(15,15,17,.96);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(14px);
}
body.admin-page .visibility-switch {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-height: 38px;
  margin: 0;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  cursor: pointer;
  user-select: none;
  color: rgba(255,255,255,.86);
  font-size: .82rem;
  font-weight: 750;
  letter-spacing: .02em;
  text-transform: uppercase;
}
body.admin-page .visibility-switch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
body.admin-page .visibility-track {
  position: relative;
  width: 44px;
  height: 22px;
  border-radius: 99px;
  background: rgba(255,255,255,.14);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  transition: background .18s ease, box-shadow .18s ease;
}
body.admin-page .visibility-track::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #e5e5e5;
  transition: transform .18s ease, background .18s ease;
}
body.admin-page .visibility-switch input:checked + .visibility-track {
  background: #e50914;
  box-shadow: 0 0 0 1px rgba(229,9,20,.65), 0 0 22px rgba(229,9,20,.22);
}
body.admin-page .visibility-switch input:checked + .visibility-track::after {
  transform: translateX(22px);
  background: #fff;
}
body.admin-page .visibility-label {
  min-width: 62px;
}
body.admin-page .btn.is-loading,
body.admin-page .danger-link.is-loading {
  opacity: .55;
  pointer-events: none;
}

body.admin-page .chapter-page-shell-v59 {
  width: min(1760px, calc(100vw - 48px));
  max-width: none;
  padding: 34px 0 80px;
}
body.admin-page .chapter-edit-topbar-v59 {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
body.admin-page .chapter-v59-titleblock h1 {
  max-width: 980px;
  margin: 6px 0 8px;
  line-height: .96;
  letter-spacing: -.055em;
  font-size: clamp(2.35rem, 4.8vw, 5.6rem);
  white-space: normal;
  overflow-wrap: anywhere;
}
body.admin-page .chapter-switcher-v59 {
  min-width: min(420px, 100%);
}
body.admin-page .chapter-switcher-v59 label {
  gap: 8px;
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: .08em;
}
body.admin-page .chapter-switcher-v59 select {
  min-height: 42px;
  border-radius: 3px;
}
body.admin-page .chapter-v59-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 18px;
  align-items: start;
}
body.admin-page .chapter-v59-primary,
body.admin-page .chapter-v59-sidebar .admin-panel {
  border-radius: 4px;
  background: #101012;
  box-shadow: 0 24px 70px rgba(0,0,0,.32);
}
body.admin-page .chapter-v59-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
body.admin-page .chapter-v59-savebar {
  position: sticky;
  top: 72px;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: -22px -22px 0;
  padding: 16px 22px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(16,16,18,.96);
  backdrop-filter: blur(16px);
}
body.admin-page .chapter-v59-meta-panel {
  display: grid;
  grid-template-columns: minmax(260px, 34%) minmax(0, 1fr);
  gap: 18px;
  align-items: stretch;
}
body.admin-page .chapter-v59-image-panel {
  min-height: 250px;
}
body.admin-page .chapter-v59-image-preview {
  width: 100%;
  min-height: 100%;
  height: 100%;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.10);
  background-image: linear-gradient(135deg, rgba(229,9,20,.20), rgba(0,0,0,.50)), var(--episode-image);
  background-size: cover;
  background-position: center;
  overflow: hidden;
}
body.admin-page .chapter-v59-image-preview.is-empty {
  background: linear-gradient(135deg, rgba(229,9,20,.18), rgba(255,255,255,.03));
}
body.admin-page .chapter-v59-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-content: start;
}
body.admin-page .chapter-v59-fields .wide {
  grid-column: 1 / -1;
}
body.admin-page .chapter-v59-fields label,
body.admin-page .chapter-v59-sidebar label,
body.admin-page .music-cue-editor label {
  color: rgba(255,255,255,.62);
  text-transform: uppercase;
  font-size: .72rem;
  letter-spacing: .07em;
  font-weight: 800;
}
body.admin-page .chapter-v59-fields input,
body.admin-page .chapter-v59-sidebar input,
body.admin-page .chapter-v59-sidebar textarea,
body.admin-page .chapter-v59-fields select {
  margin-top: 7px;
  border-radius: 3px;
  border-color: rgba(255,255,255,.11);
  background: rgba(0,0,0,.30);
}
body.admin-page .chapter-v59-editor-card {
  padding: 0;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.09);
  overflow: hidden;
  background: #09090a;
}
body.admin-page .chapter-v59-editor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
body.admin-page .chapter-v59-editor-head h2 {
  margin: 0;
  font-size: 1rem;
  letter-spacing: .02em;
}
body.admin-page .chapter-v59-toolbar {
  position: sticky;
  top: 137px;
  z-index: 24;
  margin: 0;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(12,12,13,.98);
  backdrop-filter: blur(12px);
}
body.admin-page .chapter-v59-toolbar button {
  border-radius: 3px;
  background: rgba(255,255,255,.07);
}
body.admin-page .chapter-v59-rich-editor {
  min-height: 72vh;
  padding: clamp(28px, 4vw, 56px);
  font-size: clamp(1.03rem, 1.2vw, 1.22rem);
  line-height: 1.86;
  color: rgba(255,255,255,.90);
  background:
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px) 0 0 / 56px 56px,
    #080809;
  outline: none;
}
body.admin-page .chapter-v59-rich-editor:focus {
  box-shadow: inset 0 0 0 1px rgba(229,9,20,.35);
}
body.admin-page .chapter-v59-sidebar {
  position: sticky;
  top: 92px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  max-height: calc(100vh - 112px);
  overflow: auto;
  scrollbar-width: thin;
}
body.admin-page .chapter-v59-sidebar .admin-panel {
  padding: 18px;
}
body.admin-page .chapter-v59-sidebar .panel-head.slim {
  margin: 0 0 14px;
  padding: 0 0 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
body.admin-page .chapter-v59-sidebar .panel-head.slim h2 {
  margin: 0;
  font-size: 1rem;
}
body.admin-page .chapter-v59-sidebar .admin-subpanel,
body.admin-page .chapter-v59-sidebar .music-cue-editor {
  border-radius: 3px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.08);
}
body.admin-page .chapter-v59-sidebar h3 {
  margin: 0 0 12px;
  font-size: .92rem;
}
body.admin-page .btn-small {
  min-height: 34px;
  padding: 8px 12px;
  font-size: .78rem;
}
body.admin-page .file-field input[type="file"] {
  cursor: pointer;
}
@media (max-width: 1180px) {
  body.admin-page .chapter-v59-layout {
    grid-template-columns: 1fr;
  }
  body.admin-page .chapter-v59-sidebar {
    position: static;
    max-height: none;
    overflow: visible;
  }
}
@media (max-width: 760px) {
  body.admin-page .chapter-page-shell-v59 {
    width: min(100% - 24px, 1000px);
    padding-top: 20px;
  }
  body.admin-page .chapter-edit-topbar-v59,
  body.admin-page .chapter-v59-savebar,
  body.admin-page .editor-savebar {
    position: static;
    flex-direction: column;
    align-items: stretch;
  }
  body.admin-page .chapter-v59-meta-panel,
  body.admin-page .chapter-v59-fields {
    grid-template-columns: 1fr;
  }
  body.admin-page .chapter-v59-toolbar {
    position: static;
  }
}

/* v60 — éditeur épisode premium : barre type document, image 16:9, musique pro */
body.admin-page.chapter-edit-page .chapter-v59-layout {
  grid-template-columns: minmax(0, 1fr) minmax(420px, 460px);
}
body.admin-page.chapter-edit-page .chapter-v59-meta-panel {
  grid-template-columns: minmax(340px, 42%) minmax(0, 1fr);
  align-items: start;
}
body.admin-page.chapter-edit-page .chapter-v59-image-panel {
  min-height: 0;
}
body.admin-page.chapter-edit-page .chapter-v59-image-preview {
  aspect-ratio: 16 / 9;
  height: auto;
  min-height: 0;
  background-image: var(--episode-image);
  background-size: cover;
  background-position: center;
  background-color: #050505;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 18px 45px rgba(0,0,0,.35);
}
body.admin-page.chapter-edit-page .chapter-v59-image-preview::before,
body.admin-page.chapter-edit-page .chapter-image-preview::before {
  content: none !important;
  display: none !important;
}
body.admin-page.chapter-edit-page .chapter-v59-image-preview.is-empty {
  background: #141416;
  border: 1px dashed rgba(255,255,255,.18);
}
body.admin-page.chapter-edit-page .chapter-v59-image-preview.is-empty::after {
  content: '16:9';
  display: grid;
  place-items: center;
  height: 100%;
  color: rgba(255,255,255,.38);
  font-weight: 850;
  letter-spacing: .12em;
}
body.admin-page.chapter-edit-page .chapter-doc-editor-card {
  overflow: visible;
  border: 1px solid rgba(255,255,255,.08);
  background: #060607;
}
body.admin-page.chapter-edit-page .chapter-doc-editor-head {
  background: #111113;
}
body.admin-page.chapter-edit-page .chapter-doc-editor-head > div {
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}
body.admin-page.chapter-edit-page .editor-word-count {
  margin: 0;
  color: rgba(255,255,255,.44);
  font-size: .78rem;
  font-weight: 650;
}
body.admin-page.chapter-edit-page .chapter-doc-toolbar {
  position: sticky;
  top: calc(72px + var(--chapter-savebar-height, 72px));
  z-index: 55;
  display: flex;
  align-items: center;
  gap: 0;
  flex-wrap: nowrap;
  overflow-x: auto;
  margin: 0;
  padding: 7px 10px;
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(0,0,0,.45);
  background: #e8eaed;
  color: #202124;
  box-shadow: 0 12px 28px rgba(0,0,0,.25);
  backdrop-filter: none;
}
body.admin-page.chapter-edit-page .doc-toolbar-group {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0 8px;
  border-right: 1px solid rgba(60,64,67,.22);
  white-space: nowrap;
}
body.admin-page.chapter-edit-page .doc-toolbar-group:first-child {
  padding-left: 0;
}
body.admin-page.chapter-edit-page .doc-toolbar-group:last-child {
  border-right: 0;
  padding-right: 0;
}
body.admin-page.chapter-edit-page .doc-toolbar-select {
  height: 32px;
  min-width: 116px;
  border: 1px solid transparent;
  border-radius: 3px;
  padding: 0 26px 0 8px;
  background: transparent;
  color: #202124;
  font-size: .84rem;
  font-weight: 550;
  outline: none;
}
body.admin-page.chapter-edit-page .doc-toolbar-select:hover,
body.admin-page.chapter-edit-page .doc-toolbar-select:focus {
  border-color: rgba(60,64,67,.26);
  background: rgba(255,255,255,.72);
}
body.admin-page.chapter-edit-page .doc-toolbar-size {
  min-width: 92px;
}
body.admin-page.chapter-edit-page .chapter-doc-toolbar .doc-tool,
body.admin-page.chapter-edit-page .chapter-doc-toolbar button.doc-tool {
  display: inline-grid;
  place-items: center;
  width: 32px;
  height: 32px;
  min-width: 32px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 3px;
  background: transparent;
  color: #202124;
  font-size: .86rem;
  font-weight: 750;
  line-height: 1;
  cursor: pointer;
}
body.admin-page.chapter-edit-page .chapter-doc-toolbar .doc-tool:hover,
body.admin-page.chapter-edit-page .chapter-doc-toolbar button.doc-tool:hover {
  border-color: rgba(60,64,67,.18);
  background: rgba(60,64,67,.10);
}
body.admin-page.chapter-edit-page .tool-underline {
  text-decoration: underline;
  text-underline-offset: 3px;
}
body.admin-page.chapter-edit-page .doc-color-tool {
  position: relative;
  display: inline-grid !important;
  place-items: center;
  width: 34px;
  height: 32px;
  min-height: 32px;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 3px;
  color: #202124 !important;
  font-size: .86rem !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  cursor: pointer;
}
body.admin-page.chapter-edit-page .doc-color-tool:hover {
  background: rgba(60,64,67,.10);
}
body.admin-page.chapter-edit-page .doc-color-tool span::after {
  content: '';
  display: block;
  width: 17px;
  height: 2px;
  margin-top: 1px;
  background: #e50914;
}
body.admin-page.chapter-edit-page .doc-color-tool input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}
body.admin-page.chapter-edit-page .chapter-doc-paper {
  padding: clamp(22px, 3vw, 42px);
  background: radial-gradient(circle at 50% 0, rgba(255,255,255,.04), transparent 42%), #0b0b0d;
}
body.admin-page.chapter-edit-page .chapter-doc-rich-editor {
  width: min(980px, 100%);
  min-height: 82vh;
  margin: 0 auto;
  padding: clamp(34px, 5vw, 72px);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 2px;
  background: #111113;
  box-shadow: 0 28px 80px rgba(0,0,0,.42);
  line-height: 1.85;
}
body.admin-page.chapter-edit-page .chapter-doc-rich-editor h2,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor h3 {
  line-height: 1.18;
  margin: 1.6em 0 .65em;
}
body.admin-page.chapter-edit-page .chapter-doc-rich-editor blockquote {
  margin: 1.25em 0;
  padding: .8em 1.1em;
  border-left: 3px solid #e50914;
  background: rgba(229,9,20,.08);
  color: rgba(255,255,255,.84);
}
body.admin-page.chapter-edit-page .chapter-doc-rich-editor a {
  color: #7db7ff;
}

body.admin-page.chapter-edit-page .chapter-music-pro {
  padding: 0 !important;
  overflow: hidden;
}
body.admin-page.chapter-edit-page .music-pro-head {
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 !important;
  padding: 18px 18px 14px !important;
  background: rgba(16,16,18,.96);
  backdrop-filter: blur(12px);
}
body.admin-page.chapter-edit-page .music-pro-head .eyebrow {
  margin: 0 0 4px;
  color: #e50914;
}
body.admin-page.chapter-edit-page .music-pro-head h2 {
  margin: 0;
  letter-spacing: -.02em;
}
body.admin-page.chapter-edit-page .music-count-pill {
  display: inline-grid;
  place-items: center;
  min-width: 34px;
  height: 28px;
  padding: 0 10px;
  background: #e50914;
  color: #fff;
  font-weight: 900;
  font-size: .8rem;
}
body.admin-page.chapter-edit-page .music-pro-form,
body.admin-page.chapter-edit-page .music-pro-list {
  margin: 16px 18px 18px;
}
body.admin-page.chapter-edit-page .music-form-title-row,
body.admin-page.chapter-edit-page .music-cue-topline,
body.admin-page.chapter-edit-page .music-cue-actions,
body.admin-page.chapter-edit-page .music-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
body.admin-page.chapter-edit-page .music-form-actions {
  margin-top: 14px;
}
body.admin-page.chapter-edit-page .music-pro-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
body.admin-page.chapter-edit-page .music-pro-grid .wide {
  grid-column: 1 / -1;
}
body.admin-page.chapter-edit-page .music-file-drop {
  display: block !important;
  padding: 12px !important;
  border: 1px dashed rgba(255,255,255,.18);
  background: rgba(0,0,0,.22);
}
body.admin-page.chapter-edit-page .music-mini-toggle {
  display: inline-flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 34px;
  margin: 0 !important;
  padding: 7px 10px !important;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.76) !important;
  font-size: .7rem !important;
  font-weight: 850 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}
body.admin-page.chapter-edit-page .music-mini-toggle input {
  width: auto;
  margin: 0;
  accent-color: #e50914;
}
body.admin-page.chapter-edit-page .music-pro-cue {
  padding: 14px !important;
  margin-bottom: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025)) !important;
}
body.admin-page.chapter-edit-page .music-cue-main-title {
  min-width: 0;
}
body.admin-page.chapter-edit-page .music-cue-main-title strong {
  display: block;
  margin-top: 3px;
  color: #fff;
  line-height: 1.25;
  overflow-wrap: anywhere;
}
body.admin-page.chapter-edit-page .music-visibility-switch {
  flex: 0 0 auto;
  padding: 6px 8px;
}
body.admin-page.chapter-edit-page .music-preview-audio {
  display: block;
  width: 100%;
  height: 34px;
  margin: 12px 0;
  filter: grayscale(1) contrast(1.1);
}
body.admin-page.chapter-edit-page .music-external-link {
  display: inline-flex;
  margin: 10px 0 12px;
  color: #fff;
  font-size: .78rem;
  font-weight: 800;
  text-decoration: none;
  border-bottom: 1px solid rgba(229,9,20,.75);
}
body.admin-page.chapter-edit-page .music-timecode-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
body.admin-page.chapter-edit-page .music-cue-actions {
  justify-content: flex-end;
  padding-top: 12px;
}
@media (max-width: 1180px) {
  body.admin-page.chapter-edit-page .chapter-v59-layout,
  body.admin-page.chapter-edit-page .chapter-v59-meta-panel {
    grid-template-columns: 1fr;
  }
  body.admin-page.chapter-edit-page .chapter-doc-toolbar {
    top: calc(72px + var(--chapter-savebar-height, 72px));
  }
}
@media (max-width: 760px) {
  body.admin-page.chapter-edit-page .chapter-doc-toolbar {
    position: sticky;
    top: 0;
  }
  body.admin-page.chapter-edit-page .doc-toolbar-select {
    min-width: 104px;
  }
  body.admin-page.chapter-edit-page .chapter-doc-paper {
    padding: 14px;
  }
  body.admin-page.chapter-edit-page .chapter-doc-rich-editor {
    padding: 24px 18px;
  }
  body.admin-page.chapter-edit-page .music-pro-grid {
    grid-template-columns: 1fr;
  }
}

/* v61 — correction empilement sticky édition épisode */
body.admin-page.chapter-edit-page .chapter-v59-savebar {
  z-index: 70;
}
body.admin-page.chapter-edit-page .chapter-doc-toolbar {
  z-index: 60;
  top: calc(72px + var(--chapter-savebar-height, 72px));
}
@media (max-width: 760px) {
  body.admin-page.chapter-edit-page .chapter-doc-toolbar {
    top: 0;
  }
}


/* v62 - stabilité éditeur épisode : pas de police parasite au collage */
body.admin-page.chapter-edit-page .chapter-doc-rich-editor,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor p,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor div,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor span,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor li {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif !important;
}
body.admin-page.chapter-edit-page .chapter-doc-rich-editor strong,
body.admin-page.chapter-edit-page .chapter-doc-rich-editor b {
  font-weight: 800;
}


/* v64 — saisons admin */
body.admin-page .admin-seasons-panel {
  display: grid;
  gap: 18px;
}
body.admin-page .admin-seasons-panel > .panel-head {
  align-items: center;
  gap: 18px;
}
body.admin-page .season-create-inline {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-left: auto;
}
body.admin-page .season-create-inline input,
body.admin-page .season-title-input,
body.admin-page .season-order-input,
body.admin-page .episode-season-form select {
  border-radius: 4px !important;
  background: #101010;
  border: 1px solid rgba(255,255,255,.14);
  color: #fff;
}
body.admin-page .season-create-inline input {
  min-width: 220px;
  height: 38px;
  padding: 0 12px;
}
body.admin-page .season-admin-list {
  display: grid;
  gap: 8px;
}
body.admin-page .season-admin-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 88px auto auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
}
body.admin-page .season-title-input,
body.admin-page .season-order-input {
  height: 38px;
  padding: 0 10px;
}
body.admin-page .season-list-actions {
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}
body.admin-page .season-episode-groups {
  display: grid;
  gap: 22px;
}
body.admin-page .season-episode-group {
  display: grid;
  gap: 12px;
}
body.admin-page .season-group-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
body.admin-page .season-group-head h3 {
  margin: 3px 0 0;
  font-size: 22px;
  letter-spacing: -.03em;
}
body.admin-page .episode-admin-actions {
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  min-width: 130px;
}
body.admin-page .episode-season-form select {
  width: 100%;
  height: 34px;
  padding: 0 9px;
  font-size: 12px;
  font-weight: 700;
}
body.admin-page .chapter-compact-admin-card.is-updated {
  box-shadow: 0 0 0 1px rgba(229,9,20,.7), 0 18px 40px rgba(0,0,0,.32);
}
body.admin-page .empty-panel.compact {
  min-height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px;
}
@media (max-width: 840px) {
  body.admin-page .season-admin-row {
    grid-template-columns: 1fr;
  }
  body.admin-page .season-create-inline {
    width: 100%;
    margin-left: 0;
  }
  body.admin-page .season-create-inline input {
    min-width: 0;
    flex: 1;
  }
}

/* v64 — saisons côté détail */
.detail-season-list {
  display: grid;
  gap: 22px;
}
.detail-season-block {
  display: grid;
  gap: 12px;
}
.detail-season-head {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 0 0 6px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}
.detail-season-head span {
  color: #aaa;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.detail-season-head h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(19px, 2vw, 28px);
  letter-spacing: -.04em;
}


/* v65 — catalogue Netflix-like, modal épisodes par saison, admin production plus propre */
.card:not(.rank-card)::after {
  content: attr(data-title) !important;
  white-space: normal !important;
  padding: 10px 13px 12px !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  line-height: 1.25 !important;
}
.card[style*="--image"] > .title,
.card[style*="--image"] .rank-poster > .title {
  display: none !important;
}
.card:not([style*="--image"]) > .title,
.card:not([style*="--image"]) .rank-poster > .title {
  display: block;
}
.card.is-hover-media::after {
  content: attr(data-title) !important;
}

.modal-card {
  width: min(980px, calc(100vw - 40px)) !important;
  border-radius: 8px !important;
  background: #141414 !important;
}
.modal-visual {
  height: min(58vh, 560px) !important;
}
.modal-body {
  margin-top: -142px !important;
  padding-bottom: 44px !important;
}
.modal-title {
  max-width: 720px !important;
  font-size: clamp(40px, 6vw, 76px) !important;
  line-height: .9 !important;
}
.modal-actions-top {
  margin: 18px 0 26px !important;
}
.netflix-modal-episodes-head {
  margin-top: 10px;
  padding-top: 8px;
}
.modal-season-select {
  min-width: 150px;
  border: 1px solid rgba(255,255,255,.32);
  border-radius: 3px;
  background: #242424;
  color: #fff;
  padding: 10px 36px 10px 13px;
  font-size: 14px;
  font-weight: 850;
}
.modal-season-panel { display: none; }
.modal-season-panel.active { display: grid; gap: 0; }
.netflix-modal-episode {
  grid-template-columns: 46px 150px minmax(0, 1fr) !important;
  min-height: 104px;
  border-width: 0 0 1px 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 16px 0 !important;
}
.netflix-modal-episode:hover,
.netflix-modal-episode:focus-visible {
  background: rgba(255,255,255,.075) !important;
  transform: none !important;
}
.modal-episode-index {
  color: #d3d3d3;
  font-size: 24px;
  font-weight: 650;
  text-align: center;
}
.netflix-modal-episode .modal-episode-thumb {
  border-radius: 3px !important;
}
.netflix-modal-episode .modal-episode-copy {
  align-content: center;
  gap: 7px;
}
.netflix-modal-episode .modal-episode-copy strong {
  font-size: 16px;
  line-height: 1.25;
}
.netflix-modal-episode .modal-episode-copy small {
  order: -1;
  color: #aaa;
  font-size: 12px;
}

.admin-production-panel {
  padding: 0;
  overflow: hidden;
}
.production-panel-head {
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.production-create-season {
  display: flex;
  align-items: center;
  gap: 8px;
}
.production-create-season input {
  min-width: 210px;
}
.production-admin-layout {
  display: grid;
  grid-template-columns: minmax(260px, 330px) minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
}
.season-control-rail {
  padding: 22px;
  border-right: 1px solid rgba(255,255,255,.1);
  background: rgba(0,0,0,.24);
}
.rail-title-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}
.rail-title-row h3 {
  margin: 0;
  font-size: 16px;
}
.rail-title-row span {
  color: #a6a6ac;
  font-size: 12px;
  font-weight: 850;
}
.season-admin-list-pro {
  display: grid;
  gap: 10px;
}
.season-admin-row-pro {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 56px;
  gap: 10px;
  align-items: center;
  padding: 13px !important;
  border-radius: 4px !important;
  background: rgba(255,255,255,.045) !important;
  border: 1px solid rgba(255,255,255,.095) !important;
}
.season-row-main {
  min-width: 0;
  display: grid;
  gap: 5px;
}
.season-title-input {
  width: 100%;
  min-width: 0;
  font-weight: 900;
}
.season-row-meta,
.season-group-count {
  color: #a7a7ad;
  font-size: 12px;
  font-weight: 750;
}
.season-order-input {
  width: 56px !important;
  min-width: 0 !important;
  text-align: center;
}
.season-admin-row-pro .visibility-switch,
.season-admin-row-pro .season-state,
.season-admin-row-pro .season-publish-btn {
  grid-column: 1 / -1;
  justify-self: start;
}
.season-admin-row-pro .season-publish-btn {
  justify-self: stretch;
}
.episode-production-board {
  display: grid;
  gap: 18px;
  padding: 22px;
  min-width: 0;
}
.season-episode-group-pro {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 4px;
  overflow: hidden;
  background: rgba(255,255,255,.025);
}
.season-group-head-pro {
  padding: 16px 18px;
  border-bottom: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.035);
}
.season-group-head-pro h3 {
  margin: 2px 0 0;
  font-size: 22px;
  letter-spacing: -.03em;
}
.season-group-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: wrap;
}
.admin-episode-list-pro {
  display: grid;
  gap: 0 !important;
  padding: 0 !important;
}
.episode-admin-row-pro {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(180px, 260px);
  gap: 14px;
  align-items: center;
  min-height: 104px;
  padding: 14px 16px !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.09) !important;
  border-radius: 0 !important;
  background: transparent !important;
}
.episode-admin-row-pro:hover {
  background: rgba(255,255,255,.045) !important;
}
.episode-admin-link {
  display: grid !important;
  grid-template-columns: 150px minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: center;
  min-width: 0;
}
.episode-admin-copy {
  min-width: 0;
}
.episode-admin-copy strong {
  display: -webkit-box !important;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  white-space: normal !important;
  line-height: 1.2 !important;
  font-size: clamp(15px, 1.35vw, 19px) !important;
}
.episode-admin-actions-pro {
  display: flex !important;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}
.episode-season-form {
  min-width: 0;
  flex: 1 1 150px;
}
.episode-season-select {
  width: 100%;
  min-width: 0;
  max-width: 220px;
  border-radius: 3px;
  background: #1f1f22;
  color: #fff;
  border: 1px solid rgba(255,255,255,.16);
  padding: 9px 30px 9px 10px;
  font-size: 13px;
  font-weight: 850;
}
.episode-add-slot-pro {
  margin: 0 !important;
  border: 1px dashed rgba(255,255,255,.2) !important;
  border-width: 1px 0 0 !important;
  border-radius: 0 !important;
  background: rgba(255,255,255,.025) !important;
}
.episode-add-slot-pro:hover {
  background: rgba(229,9,20,.08) !important;
}
@media (max-width: 980px) {
  .production-admin-layout { grid-template-columns: 1fr; }
  .season-control-rail { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.1); }
  .episode-admin-row-pro { grid-template-columns: 1fr; }
  .episode-admin-actions-pro { justify-content: flex-start; }
}
@media (max-width: 720px) {
  .netflix-modal-episode { grid-template-columns: 34px 112px minmax(0, 1fr) !important; }
  .modal-season-select { width: 100%; }
  .production-panel-head, .season-group-head-pro { align-items: flex-start; }
  .production-create-season { width: 100%; }
  .production-create-season input { min-width: 0; width: 100%; }
  .episode-admin-link { grid-template-columns: 112px minmax(0, 1fr) !important; }
}

/* v66 — admin seasons/episodes professional reflow */
body.admin-page .admin-tabs .admin-tab[href*="item-create"] { display: none !important; }
.production-v66 { overflow: visible; }
.production-v66 .production-panel-head { align-items: center; gap: 18px; }
.production-v66 .production-create-season { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.production-v66 .production-create-season input { min-width: 260px; }
.production-publish-bar {
  display: flex; justify-content: space-between; align-items: center; gap: 14px;
  padding: 14px 18px; border: 1px solid rgba(255,255,255,.10); background: linear-gradient(90deg, rgba(229,9,20,.12), rgba(255,255,255,.025));
  margin: 0 0 18px; border-radius: 4px;
}
.production-publish-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.production-v66-layout { display: grid; grid-template-columns: minmax(260px, 320px) minmax(0,1fr); gap: 22px; align-items: start; }
.season-control-rail-v66 { position: sticky; top: 92px; border-right: 1px solid rgba(255,255,255,.08); padding-right: 18px; max-height: calc(100vh - 120px); overflow: auto; }
.season-admin-row-v66 { display: grid; grid-template-columns: minmax(0,1fr) 58px; gap: 10px; padding: 14px; border-radius: 4px; background: #111; border: 1px solid rgba(255,255,255,.10); }
.season-admin-row-v66 .visibility-switch,
.season-admin-row-v66 .chapter-admin-state,
.season-admin-row-v66 .season-publish-btn { grid-column: 1 / -1; justify-self: start; }
.season-admin-row-v66 .season-publish-btn { justify-self: stretch; }
.episode-production-board-v66 { min-width: 0; display: grid; gap: 18px; }
.season-episode-group-v66 { border-radius: 4px; background: #101010; border: 1px solid rgba(255,255,255,.12); overflow: hidden; }
.season-episode-group-v66 .season-group-head { padding: 18px 20px; border-bottom: 1px solid rgba(255,255,255,.10); background: linear-gradient(180deg,#1b1b1b,#121212); }
.season-group-actions { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; }
.episode-list-table-v66 { display: grid; }
.episode-row-v66 {
  display: grid; grid-template-columns: 34px minmax(360px,1fr) minmax(190px,240px) minmax(110px,140px);
  gap: 16px; align-items: center; padding: 16px 18px; border-bottom: 1px solid rgba(255,255,255,.08); min-height: 104px;
}
.episode-row-v66:last-child { border-bottom: 0; }
.episode-row-v66:hover { background: rgba(255,255,255,.035); }
.episode-select-cell { display: flex; align-items: center; justify-content: center; }
.episode-main-cell { display: grid; grid-template-columns: 164px minmax(0,1fr); gap: 16px; align-items: center; color: inherit; min-width: 0; }
.episode-thumb-v66 { width: 164px; aspect-ratio: 16/9; display: block; background: #1a1a1a var(--episode-image) center/cover no-repeat; border: 1px solid rgba(255,255,255,.10); border-radius: 3px; }
.episode-title-v66 { min-width: 0; display: grid; gap: 5px; }
.episode-title-v66 strong { display: block; white-space: normal; overflow-wrap: anywhere; line-height: 1.12; font-size: clamp(15px, 1vw, 18px); max-width: 100%; }
.episode-controls-v66 { display: grid; gap: 9px; }
.episode-controls-v66 label { color: #aeb0b8; font-size: 11px; text-transform: uppercase; letter-spacing: .06em; display: grid; gap: 5px; }
.episode-controls-v66 select { width: 100%; min-width: 0; background: #090909; border: 1px solid rgba(255,255,255,.18); border-radius: 3px; color: #fff; padding: 9px 10px; font-weight: 700; }
.episode-status-actions-v66 { display: grid; justify-items: end; gap: 9px; }
.episode-status-actions-v66 .chapter-publish-mini { position: static !important; transform: none !important; inset: auto !important; width: auto; min-width: 92px; }
.episode-add-row-v66 { grid-template-columns: 54px minmax(0,1fr); color: #fff; background: linear-gradient(110deg,rgba(229,9,20,.18),rgba(255,255,255,.025)); text-decoration: none; border: 1px dashed rgba(229,9,20,.55); margin: 12px 18px 18px; min-height: 84px; }
.episode-add-row-v66 .chapter-add-plus { width: 48px; height: 48px; font-size: 30px; display: grid; place-items: center; border: 1px solid rgba(255,255,255,.18); border-radius: 3px; color: #e50914; }
.chapter-compact-card.episode-admin-row-pro { min-width: 0; }
.chapter-compact-copy strong { white-space: normal !important; overflow: visible !important; text-overflow: clip !important; overflow-wrap: anywhere; }
@media (max-width: 1180px) {
  .production-v66-layout { grid-template-columns: 1fr; }
  .season-control-rail-v66 { position: static; max-height: none; border-right: 0; padding-right: 0; }
  .episode-row-v66 { grid-template-columns: 30px minmax(260px,1fr); }
  .episode-controls-v66, .episode-status-actions-v66 { grid-column: 2; justify-items: start; }
  .episode-main-cell { grid-template-columns: 140px minmax(0,1fr); }
  .episode-thumb-v66 { width: 140px; }
}
@media (max-width: 720px) {
  .production-v66 .production-panel-head, .production-publish-bar { align-items: stretch; flex-direction: column; }
  .production-v66 .production-create-season { margin-left: 0; width: 100%; }
  .production-v66 .production-create-season input { min-width: 0; width: 100%; }
  .episode-row-v66 { grid-template-columns: 1fr; }
  .episode-select-cell, .episode-controls-v66, .episode-status-actions-v66 { grid-column: 1; justify-items: start; }
  .episode-main-cell { grid-template-columns: 1fr; }
  .episode-thumb-v66 { width: 100%; }
}

/* v70 — admin item editor: seasons as compact collapsible groups */
.production-v70-layout {
  display: block !important;
}
.production-v70-layout .episode-production-board-v66 {
  width: 100%;
  padding: 18px !important;
  gap: 14px;
}
.production-v70-layout .season-control-rail,
.production-v70-layout .season-control-rail-v66 {
  display: none !important;
}
.season-episode-group-v70 {
  border-radius: 3px !important;
  overflow: hidden;
  background: #0f0f0f !important;
  border-color: rgba(255,255,255,.13) !important;
}
.season-group-head-v70 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 72px;
  padding: 14px 18px !important;
}
.season-toggle-v70 {
  appearance: none;
  border: 0;
  background: transparent;
  color: #fff;
  padding: 0;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  flex: 1 1 auto;
}
.season-chevron-v70 {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(255,255,255,.045);
  font-size: 24px;
  line-height: 1;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.season-episode-group-v70:not(.is-collapsed) .season-chevron-v70 {
  transform: rotate(90deg);
  background: rgba(229,9,20,.14);
  border-color: rgba(229,9,20,.42);
}
.season-toggle-copy-v70 {
  display: grid;
  gap: 3px;
  min-width: 0;
}
.season-toggle-copy-v70 strong {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: clamp(18px, 1.8vw, 24px);
  letter-spacing: -.035em;
}
.season-group-actions-v70 {
  flex: 0 0 auto;
  justify-content: flex-end;
}
.season-episode-group-v70.is-collapsed .season-body-v70 {
  display: none !important;
}
.season-body-v70 {
  display: grid;
}
.season-episode-group-v70.is-collapsed .season-group-head-v70 {
  border-bottom: 0 !important;
}
.production-v70-layout .episode-row-v66 {
  grid-template-columns: 34px minmax(0, 1fr) minmax(170px, 220px) minmax(100px, 128px) !important;
  gap: 14px !important;
  align-items: center !important;
}
.production-v70-layout .episode-main-cell {
  min-width: 0 !important;
  grid-template-columns: minmax(120px, 168px) minmax(0, 1fr) !important;
}
.production-v70-layout .episode-title-v66 strong {
  overflow-wrap: anywhere;
  word-break: normal;
  line-height: 1.16;
}
.production-v70-layout .episode-controls-v66 {
  min-width: 0;
  max-width: 220px;
}
.production-v70-layout .episode-controls-v66 select {
  max-width: 100%;
  height: 38px;
}
.production-v70-layout .episode-status-actions-v66 {
  min-width: 0;
}
.production-v70-layout .episode-add-row-v66 {
  grid-template-columns: 54px minmax(0, 1fr) !important;
}
@media (max-width: 1180px) {
  .production-v70-layout .episode-row-v66 {
    grid-template-columns: 30px minmax(0,1fr) !important;
  }
  .production-v70-layout .episode-controls-v66,
  .production-v70-layout .episode-status-actions-v66 {
    grid-column: 2;
    justify-items: start;
    max-width: 320px;
  }
}
@media (max-width: 760px) {
  .season-group-head-v70,
  .season-group-actions-v70 {
    align-items: stretch;
    flex-direction: column;
  }
  .season-group-actions-v70 {
    width: 100%;
  }
  .season-group-actions-v70 .btn {
    width: 100%;
  }
  .production-v70-layout .episode-row-v66 {
    grid-template-columns: 1fr !important;
  }
  .production-v70-layout .episode-select-cell,
  .production-v70-layout .episode-controls-v66,
  .production-v70-layout .episode-status-actions-v66 {
    grid-column: 1;
  }
  .production-v70-layout .episode-main-cell {
    grid-template-columns: 1fr !important;
  }
  .production-v70-layout .episode-thumb-v66 {
    width: 100%;
  }
}

/* v71 — admin item seasons full-width collapsible headers */
body.admin-page #chapters.admin-production-panel,
body.admin-page #chapters .production-v70-layout,
body.admin-page #chapters .episode-production-board,
body.admin-page #chapters .episode-production-board-v66,
body.admin-page #chapters .season-episode-group,
body.admin-page #chapters .season-episode-group-v70,
body.admin-page #chapters .season-body-v70,
body.admin-page #chapters .episode-list-table-v66 {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}
body.admin-page #chapters .production-v70-layout {
  display: block !important;
  padding: 0 !important;
}
body.admin-page #chapters .episode-production-board-v66 {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-items: stretch !important;
  align-items: stretch !important;
  padding: 22px !important;
  gap: 18px !important;
}
body.admin-page #chapters .season-episode-group-v70 {
  display: block !important;
  margin: 0 !important;
  background: #101010 !important;
  border: 1px solid rgba(255,255,255,.13) !important;
  border-radius: 3px !important;
  overflow: hidden !important;
}
body.admin-page #chapters .season-group-head-v70 {
  width: 100% !important;
  box-sizing: border-box !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 18px !important;
  min-height: 74px !important;
  padding: 16px 20px !important;
  cursor: pointer !important;
  user-select: none !important;
  background: linear-gradient(180deg, #1c1c1c 0%, #121212 100%) !important;
  border-bottom: 1px solid rgba(255,255,255,.10) !important;
}
body.admin-page #chapters .season-group-head-v70:hover {
  background: linear-gradient(180deg, #222 0%, #141414 100%) !important;
}
body.admin-page #chapters .season-group-head-v70:focus-visible {
  outline: 2px solid rgba(229,9,20,.78) !important;
  outline-offset: -2px !important;
}
body.admin-page #chapters .season-toggle-v70 {
  pointer-events: none !important;
  width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
body.admin-page #chapters .season-toggle-copy-v70 {
  min-width: 0 !important;
}
body.admin-page #chapters .season-toggle-copy-v70 strong {
  max-width: 100% !important;
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;
  line-height: 1.12 !important;
}
body.admin-page #chapters .season-group-actions-v70 {
  justify-self: end !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}
body.admin-page #chapters .season-group-actions-v70,
body.admin-page #chapters .season-group-actions-v70 * {
  cursor: auto !important;
}
body.admin-page #chapters .season-episode-group-v70.is-collapsed .season-body-v70 {
  display: none !important;
}
body.admin-page #chapters .season-episode-group-v70:not(.is-collapsed) .season-body-v70 {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
}
body.admin-page #chapters .season-episode-group-v70.is-collapsed .season-group-head-v70 {
  border-bottom: 0 !important;
}
body.admin-page #chapters .season-episode-group-v70:not(.is-collapsed) .season-chevron-v70 {
  transform: rotate(90deg) !important;
  background: rgba(229,9,20,.14) !important;
  border-color: rgba(229,9,20,.42) !important;
}
body.admin-page #chapters .episode-row-v66 {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: 40px minmax(380px, 1.4fr) minmax(220px, 300px) minmax(120px, 170px) !important;
  gap: 18px !important;
  align-items: center !important;
}
body.admin-page #chapters .episode-main-cell {
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: minmax(150px, 190px) minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: center !important;
}
body.admin-page #chapters .episode-thumb-v66 {
  width: 100% !important;
  max-width: 190px !important;
  aspect-ratio: 16 / 9 !important;
}
body.admin-page #chapters .episode-title-v66 strong {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  line-height: 1.18 !important;
}
body.admin-page #chapters .episode-controls-v66 {
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 8px !important;
}
body.admin-page #chapters .episode-controls-v66 label {
  min-width: 0 !important;
}
body.admin-page #chapters .episode-controls-v66 select {
  width: 100% !important;
  max-width: none !important;
}
body.admin-page #chapters .episode-status-actions-v66 {
  justify-items: end !important;
}
body.admin-page #chapters .episode-add-row-v66 {
  width: auto !important;
  margin: 14px 18px 18px !important;
}
@media (max-width: 1220px) {
  body.admin-page #chapters .episode-row-v66 {
    grid-template-columns: 36px minmax(0,1fr) !important;
  }
  body.admin-page #chapters .episode-controls-v66,
  body.admin-page #chapters .episode-status-actions-v66 {
    grid-column: 2 !important;
    justify-items: start !important;
    max-width: 360px !important;
  }
}
@media (max-width: 820px) {
  body.admin-page #chapters .season-group-head-v70 {
    grid-template-columns: minmax(0,1fr) !important;
  }
  body.admin-page #chapters .season-group-actions-v70 {
    justify-self: stretch !important;
    justify-content: flex-start !important;
  }
  body.admin-page #chapters .episode-row-v66 {
    grid-template-columns: 1fr !important;
  }
  body.admin-page #chapters .episode-select-cell,
  body.admin-page #chapters .episode-controls-v66,
  body.admin-page #chapters .episode-status-actions-v66 {
    grid-column: 1 !important;
  }
  body.admin-page #chapters .episode-main-cell {
    grid-template-columns: 1fr !important;
  }
  body.admin-page #chapters .episode-thumb-v66 {
    max-width: none !important;
  }
}

/* v72 — admin œuvre: saisons repliables fiables + switch publication */
body.admin-page #chapters .season-group-head-v70 {
  cursor: pointer !important;
}
body.admin-page #chapters .season-group-head-v70 * {
  user-select: none;
}
body.admin-page #chapters .season-group-actions-v70,
body.admin-page #chapters .season-group-actions-v70 * {
  user-select: auto;
}
body.admin-page #chapters .season-episode-group-v70:not(.is-collapsed) .season-body-v70 {
  display: grid !important;
}
body.admin-page #chapters .season-episode-group-v70:not(.is-collapsed) .season-chevron-v70 {
  transform: rotate(90deg);
}
body.admin-page .editor-savebar .visibility-switch {
  min-width: 142px;
}
body.admin-page .editor-savebar .visibility-label {
  min-width: 76px;
  text-align: left;
}

/* v74 - season delete action */
.season-delete-button-v74 {
    background: rgba(229, 9, 20, .12) !important;
    border-color: rgba(229, 9, 20, .36) !important;
    color: #fff !important;
}
.season-delete-button-v74:hover,
.season-delete-button-v74:focus-visible {
    background: rgba(229, 9, 20, .24) !important;
    border-color: rgba(229, 9, 20, .58) !important;
}

/* v75 - images catalogue : toujours cadrées dans les cartes, sans répétition */
.card,
.rank-card,
.catalog-poster,
.item-preview,
.editor-hero-preview,
.reader-cover,
.modal-visual,
.detail-hero,
.detail-screenshot-reel,
.detail-screenshot-reel .hero-media-slide,
.detail-episode-thumb,
.episode-thumb-v66,
.episode-card-thumb,
.chapter-episode-thumb,
.reader-page .reader-cover {
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    background-clip: padding-box;
}

.card,
.catalog-poster,
.item-preview,
.editor-hero-preview,
.reader-cover,
.modal-visual,
.detail-episode-thumb,
.episode-thumb-v66,
.episode-card-thumb,
.chapter-episode-thumb {
    min-width: 0;
    min-height: 0;
}

/* v76 - connexion : rester connecté */
.remember-line {
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  margin-top: -2px;
  color: #f1f1f1;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
}

.remember-line input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  flex: 0 0 auto;
  accent-color: var(--brand);
}

.auth-switch {
  margin: 18px 0 0;
  text-align: center;
}

.auth-switch a {
  font-weight: 900;
}

/* v78 — Lecteur optimisé, streaming vidéo adapté à la lecture */
body.reader-page-v78 {
  --reader-bg: #050505;
  --reader-panel: rgba(18,18,20,.72);
  --reader-panel-strong: rgba(23,23,26,.92);
  --reader-line: rgba(255,255,255,.10);
  --reader-soft: rgba(255,255,255,.64);
  --reader-muted: rgba(255,255,255,.48);
  --reader-red: #e50914;
  --reader-radius: 22px;
  background: #050505;
  color: #fff;
  min-height: 100vh;
}

body.reader-page-v78 .reader-header-v78 {
  position: sticky;
  top: 0;
  z-index: 60;
  height: 68px;
  padding: 0 clamp(18px, 3.2vw, 54px);
  background: linear-gradient(180deg, rgba(5,5,5,.96), rgba(5,5,5,.78));
  border-bottom: 1px solid rgba(255,255,255,.055);
  backdrop-filter: blur(16px);
}

body.reader-page-v78 .reader-shell-v78 {
  display: block !important;
  width: min(1840px, 100%);
  max-width: none;
  margin: 0 auto;
  padding: 0 clamp(18px, 3.2vw, 54px) 92px;
}

body.reader-page-v78 .reader-hero-v78 {
  position: relative;
  min-height: clamp(320px, 42vh, 520px);
  margin: 0 calc(clamp(18px, 3.2vw, 54px) * -1) 0;
  padding: clamp(110px, 15vh, 165px) clamp(18px, 3.2vw, 54px) 54px;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(5,5,5,.98) 0%, rgba(5,5,5,.76) 42%, rgba(5,5,5,.26) 70%, rgba(5,5,5,.94) 100%),
    linear-gradient(0deg, #050505 0%, rgba(5,5,5,.18) 44%, rgba(5,5,5,.48) 100%),
    var(--reader-image, var(--image, linear-gradient(135deg, var(--a, #1a1a1d), var(--b, #37060a))));
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

body.reader-page-v78 .reader-hero-v78::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 48%;
  background: linear-gradient(180deg, transparent, #050505 88%);
  pointer-events: none;
}

body.reader-page-v78 .reader-hero-copy-v78 {
  position: relative;
  z-index: 2;
  width: min(900px, 92vw);
}

body.reader-page-v78 .reader-kicker-v78,
body.reader-page-v78 .reader-panel-label-v78 {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: rgba(255,255,255,.72);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

body.reader-page-v78 .reader-kicker-v78::before,
body.reader-page-v78 .reader-panel-label-v78::before {
  content: "";
  width: 24px;
  height: 3px;
  border-radius: 999px;
  background: var(--reader-red);
  box-shadow: 0 0 20px rgba(229,9,20,.65);
}

body.reader-page-v78 .reader-hero-copy-v78 h1 {
  margin: 14px 0 0;
  max-width: 980px;
  font-size: clamp(44px, 6.4vw, 104px);
  line-height: .86;
  letter-spacing: -.07em;
  text-transform: uppercase;
  text-wrap: balance;
}

body.reader-page-v78 .reader-episode-title-v78 {
  max-width: 720px;
  margin: 20px 0 0;
  color: rgba(255,255,255,.82);
  font-size: clamp(18px, 1.65vw, 26px);
  line-height: 1.34;
  font-weight: 750;
}

body.reader-page-v78 .reader-meta-v78 {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 22px;
}

body.reader-page-v78 .reader-meta-v78 span,
body.reader-page-v78 .recommendation-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  border: 1px solid rgba(255,255,255,.13);
  border-radius: 999px;
  padding: 0 12px;
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.82);
  font-size: 12px;
  font-weight: 900;
}

body.reader-page-v78 .reader-episode-strip-v78 {
  position: relative;
  z-index: 5;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(250px, 320px);
  gap: 14px;
  margin: -38px 0 34px;
  padding: 0 0 12px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}

body.reader-page-v78 .reader-episode-card-v78 {
  scroll-snap-align: start;
  min-width: 0;
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 9px;
  background: rgba(16,16,18,.88);
  color: #fff;
  text-decoration: none;
  box-shadow: 0 20px 48px rgba(0,0,0,.30);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

body.reader-page-v78 .reader-episode-card-v78:hover,
body.reader-page-v78 .reader-episode-card-v78.active {
  transform: translateY(-2px);
  border-color: rgba(229,9,20,.48);
  background: rgba(28,28,31,.94);
}

body.reader-page-v78 .reader-episode-thumb-v78 {
  display: block;
  aspect-ratio: 16 / 9;
  border-radius: 11px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.35)),
    var(--episode-image, linear-gradient(135deg, #25070b, #151515));
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

body.reader-page-v78 .reader-episode-copy-v78 {
  min-width: 0;
  display: grid;
  gap: 3px;
}

body.reader-page-v78 .reader-episode-copy-v78 small {
  color: rgba(255,255,255,.48);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.reader-page-v78 .reader-episode-copy-v78 strong {
  overflow: hidden;
  color: #fff;
  font-size: 14px;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.reader-page-v78 .reader-episode-copy-v78 em {
  color: rgba(255,255,255,.55);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

body.reader-page-v78 .reader-stage-v78 {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 820px) minmax(220px, 300px);
  gap: clamp(22px, 3vw, 46px);
  align-items: start;
}

body.reader-page-v78 .reader-left-v78,
body.reader-page-v78 .reader-right-v78 {
  position: sticky;
  top: 92px;
  display: grid;
  gap: 16px;
}

body.reader-page-v78 .reader-progress-card-v78,
body.reader-page-v78 .reader-side-card-v78 {
  border: 1px solid var(--reader-line);
  border-radius: var(--reader-radius);
  padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.03));
  box-shadow: 0 22px 54px rgba(0,0,0,.24);
}

body.reader-page-v78 .reader-progress-card-v78 strong,
body.reader-page-v78 .recommendation-score-v78 {
  display: block;
  margin-top: 10px;
  color: #fff;
  font-size: 34px;
  line-height: .9;
  letter-spacing: -.04em;
}

body.reader-page-v78 .reader-progress-bar {
  height: 6px;
  margin: 15px 0 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
}

body.reader-page-v78 .reader-progress-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--reader-red);
  box-shadow: 0 0 22px rgba(229,9,20,.6);
}

body.reader-page-v78 .reader-progress-card-v78 p,
body.reader-page-v78 .reader-side-card-v78 p {
  color: var(--reader-soft);
  font-size: 13px;
  line-height: 1.55;
}

body.reader-page-v78 .reader-document-v78 {
  min-width: 0;
  border: 1px solid rgba(255,255,255,.085);
  border-radius: 28px;
  padding: clamp(24px, 4vw, 58px);
  background:
    radial-gradient(circle at top left, rgba(229,9,20,.055), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.022));
  box-shadow: 0 30px 90px rgba(0,0,0,.34);
}

body.reader-page-v78 .reader-document-head-v78 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 22px;
  padding-bottom: 26px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}

body.reader-page-v78 .reader-document-head-v78 h2 {
  margin: 10px 0 0;
  max-width: 680px;
  color: #fff;
  font-size: clamp(30px, 4vw, 54px);
  line-height: .96;
  letter-spacing: -.055em;
}

body.reader-page-v78 .reader-document-actions-v78 {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

body.reader-page-v78 .reader-bookmark-summary {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

body.reader-page-v78 .reader-bookmark-summary[hidden],
body.reader-page-v78 .reader-bookmark-summary [hidden] {
  display: none !important;
}

body.reader-page-v78 .reader-bookmark-jump,
body.reader-page-v78 .reader-bookmark-remove,
body.reader-page-v78 .mini-control {
  border-radius: 999px;
}

body.reader-page-v78 .reader-voice-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

body.reader-page-v78 .reader-voice-rate {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.58);
  font-size: 11px;
  font-weight: 900;
}

body.reader-page-v78 .reader-voice-rate input {
  width: 86px;
  padding: 0;
}

body.reader-page-v78 .reader-text-v78 {
  max-width: 760px;
  margin: 34px auto 0;
  color: rgba(255,255,255,.88);
  font-size: clamp(18px, 1.28vw, 21px);
  line-height: 1.9;
  letter-spacing: .003em;
  text-wrap: pretty;
}

body.reader-page-v78 .reader-text-v78 p {
  margin: 0 0 1.35em;
}

body.reader-page-v78 .reader-text-v78 h1,
body.reader-page-v78 .reader-text-v78 h2,
body.reader-page-v78 .reader-text-v78 h3 {
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.03em;
}

body.reader-page-v78 .reader-text-v78 blockquote {
  margin: 1.8em 0;
  border-left: 3px solid var(--reader-red);
  padding: .2em 0 .2em 1em;
  color: rgba(255,255,255,.75);
}

body.reader-page-v78 .reader-music-list-v78 {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}

body.reader-page-v78 .music-cue.music-cue-jump {
  border-radius: 16px;
  border-color: rgba(255,255,255,.105);
  background: rgba(255,255,255,.052);
}

body.reader-page-v78 .music-cue-label {
  color: rgba(255,255,255,.46);
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.reader-page-v78 .vote-actions-v78 {
  display: grid;
  gap: 9px;
  margin-top: 14px;
}

body.reader-page-v78 .reader-next-card-v78 {
  display: grid;
  gap: 10px;
}

body.reader-page-v78 .full-width {
  width: 100%;
  justify-content: center;
}

body.reader-page-v78 .chapter-completion-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  border-radius: 999px;
  padding: 0 13px;
  background: rgba(86,209,109,.13);
  color: #baffc8;
  font-size: 12px;
  font-weight: 950;
}

body.reader-page-v78 .reader-panel-icon,
body.reader-page-v78 .reader-immersion-toggle,
body.reader-page-v78 [data-reader-immersion-toggle] {
  display: none !important;
}

@media (max-width: 1240px) {
  body.reader-page-v78 .reader-stage-v78 {
    grid-template-columns: minmax(0, 1fr);
  }

  body.reader-page-v78 .reader-left-v78,
  body.reader-page-v78 .reader-right-v78 {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.reader-page-v78 .reader-document-v78 {
    order: -1;
  }
}

@media (max-width: 760px) {
  body.reader-page-v78 .reader-header-v78 {
    height: auto;
    min-height: 62px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  body.reader-page-v78 .reader-navlinks {
    display: none;
  }

  body.reader-page-v78 .reader-shell-v78 {
    padding-inline: 14px;
    padding-bottom: 72px;
  }

  body.reader-page-v78 .reader-hero-v78 {
    margin-inline: -14px;
    min-height: 310px;
    padding: 100px 14px 48px;
  }

  body.reader-page-v78 .reader-hero-copy-v78 h1 {
    font-size: clamp(40px, 15vw, 68px);
  }

  body.reader-page-v78 .reader-episode-strip-v78 {
    grid-auto-columns: minmax(230px, 78vw);
  }

  body.reader-page-v78 .reader-left-v78,
  body.reader-page-v78 .reader-right-v78 {
    grid-template-columns: 1fr;
  }

  body.reader-page-v78 .reader-document-v78 {
    border-radius: 20px;
    padding: 22px 18px;
  }

  body.reader-page-v78 .reader-document-head-v78 {
    display: grid;
  }

  body.reader-page-v78 .reader-document-actions-v78 {
    justify-content: flex-start;
  }

  body.reader-page-v78 .reader-text-v78 {
    font-size: 18px;
    line-height: 1.82;
  }
}

/* v79 — Lecteur plus sobre, plus large, moins arrondi */
body.reader-page-v79 {
  background: #050505 !important;
}

body.reader-page-v79 .reader-header-v79 {
  border-radius: 0 !important;
}

body.reader-page-v79 .reader-shell-v79 {
  width: min(1600px, 100%) !important;
  padding: 0 clamp(18px, 3.2vw, 54px) 86px !important;
}

body.reader-page-v79 .reader-hero-v79 {
  min-height: clamp(280px, 34vh, 430px) !important;
  padding-top: clamp(96px, 12vh, 135px) !important;
  padding-bottom: 42px !important;
  border-radius: 0 !important;
}

body.reader-page-v79 .reader-hero-copy-v79 h1 {
  font-size: clamp(38px, 5.5vw, 82px) !important;
}

body.reader-page-v79 .reader-episode-title-v78 {
  margin-top: 14px !important;
  font-size: clamp(17px, 1.4vw, 22px) !important;
}

body.reader-page-v79 .reader-meta-v79 {
  margin-top: 16px !important;
}

body.reader-page-v79 .reader-meta-v79 span {
  border-radius: 4px !important;
  min-height: 28px !important;
  padding: 0 10px !important;
  background: rgba(255,255,255,.055) !important;
}

body.reader-page-v79 .reader-episode-strip-v79 {
  position: relative;
  z-index: 5;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(265px, 345px);
  gap: 12px;
  margin: -28px 0 22px;
  padding: 0 0 13px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
  scrollbar-color: rgba(229,9,20,.72) rgba(255,255,255,.08);
}

body.reader-page-v79 .reader-episode-strip-v79::-webkit-scrollbar {
  height: 7px;
}

body.reader-page-v79 .reader-episode-strip-v79::-webkit-scrollbar-track {
  background: rgba(255,255,255,.07);
  border-radius: 999px;
}

body.reader-page-v79 .reader-episode-strip-v79::-webkit-scrollbar-thumb {
  background: linear-gradient(90deg, rgba(229,9,20,.95), rgba(180,0,8,.95));
  border-radius: 999px;
}

body.reader-page-v79 .reader-episode-line-v79 {
  scroll-snap-align: start;
  min-width: 0;
  display: grid;
  grid-template-columns: 122px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #fff;
  text-decoration: none;
  transition: transform .18s ease, opacity .18s ease;
}

body.reader-page-v79 .reader-episode-line-v79:hover,
body.reader-page-v79 .reader-episode-line-v79.active {
  transform: translateY(-2px);
}

body.reader-page-v79 .reader-episode-line-v79.active .reader-episode-thumb-v79 {
  outline: 2px solid rgba(229,9,20,.75);
  outline-offset: 2px;
}

body.reader-page-v79 .reader-episode-thumb-v79 {
  display: block;
  aspect-ratio: 16 / 9;
  border-radius: 4px;
  background:
    linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.25)),
    var(--episode-image, linear-gradient(135deg, #25070b, #151515));
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  box-shadow: 0 10px 26px rgba(0,0,0,.28);
}

body.reader-page-v79 .reader-episode-copy-v79 {
  min-width: 0;
  display: grid;
  gap: 3px;
}

body.reader-page-v79 .reader-episode-copy-v79 small {
  color: rgba(255,255,255,.48);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.reader-page-v79 .reader-episode-copy-v79 strong {
  overflow: hidden;
  color: #fff;
  font-size: 14px;
  line-height: 1.22;
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.reader-page-v79 .reader-episode-copy-v79 em {
  color: rgba(255,255,255,.55);
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

body.reader-page-v79 .reader-document-v79 {
  width: min(1120px, 100%) !important;
  margin: 0 auto !important;
  border-radius: 6px !important;
  padding: clamp(24px, 4vw, 54px) clamp(22px, 4.8vw, 74px) !important;
  background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.018)) !important;
  border: 1px solid rgba(255,255,255,.075) !important;
  box-shadow: 0 24px 75px rgba(0,0,0,.24) !important;
}

body.reader-page-v79 .reader-document-head-v79 {
  display: flex !important;
  justify-content: space-between !important;
  gap: 20px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid rgba(255,255,255,.085) !important;
}

body.reader-page-v79 .reader-document-head-v79 h2 {
  max-width: 780px !important;
  font-size: clamp(28px, 3.7vw, 48px) !important;
}

body.reader-page-v79 .reader-document-actions-v79 {
  gap: 8px !important;
}

body.reader-page-v79 .reader-bookmark-jump,
body.reader-page-v79 .reader-bookmark-remove,
body.reader-page-v79 .mini-control,
body.reader-page-v79 .btn,
body.reader-page-v79 input,
body.reader-page-v79 select,
body.reader-page-v79 textarea {
  border-radius: 4px !important;
}

body.reader-page-v79 .reader-voice-rate {
  display: none !important;
}

body.reader-page-v79 .reader-text-v79 {
  max-width: 940px !important;
  margin: 30px auto 0 !important;
  font-size: clamp(18px, 1.35vw, 22px) !important;
  line-height: 1.88 !important;
  color: rgba(255,255,255,.88) !important;
}

body.reader-page-v79 .reader-end-v79 {
  max-width: 940px;
  margin: 54px auto 0;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.09);
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
}

body.reader-page-v79 .reader-end-progress-v79 {
  min-width: min(360px, 100%);
}

body.reader-page-v79 .reader-end-progress-v79 span {
  display: block;
  color: rgba(255,255,255,.45);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.reader-page-v79 .reader-end-progress-v79 strong {
  display: block;
  margin: 8px 0 10px;
  font-size: 28px;
  line-height: 1;
}

body.reader-page-v79 .reader-end-progress-v79 small {
  color: rgba(255,255,255,.52);
  font-weight: 800;
}

body.reader-page-v79 .reader-progress-bar {
  height: 5px !important;
  margin: 0 0 9px !important;
  border-radius: 999px !important;
}

body.reader-page-v79 .reader-after-v79 {
  max-width: 940px;
  margin: 28px auto 0;
  padding: 18px 0 0;
  border-top: 1px solid rgba(255,255,255,.06);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

body.reader-page-v79 .reader-recommend-v79 {
  display: grid;
  gap: 4px;
}

body.reader-page-v79 .reader-recommend-v79 strong {
  font-size: 18px;
}

body.reader-page-v79 .reader-recommend-v79 span {
  color: rgba(255,255,255,.52);
  font-size: 13px;
}

body.reader-page-v79 .vote-actions-v79 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

body.reader-page-v79 .reader-music-v79 {
  max-width: 940px;
  margin: 36px auto 0;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,.08);
}

body.reader-page-v79 .reader-music-v79 h2 {
  margin: 0 0 14px;
  font-size: 20px;
}

body.reader-page-v79 .music-cue.music-cue-jump {
  border-radius: 5px !important;
  background: rgba(255,255,255,.035) !important;
  box-shadow: none !important;
}

body.reader-page-v79 .reader-left-v78,
body.reader-page-v79 .reader-right-v78,
body.reader-page-v79 .reader-stage-v78,
body.reader-page-v79 .reader-progress-card-v78,
body.reader-page-v79 .reader-side-card-v78 {
  display: none !important;
}

body.reader-page-v79 .reader-backtop-v79 {
  position: fixed;
  right: clamp(18px, 2.4vw, 34px);
  bottom: clamp(18px, 2.4vw, 34px);
  z-index: 70;
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 4px;
  background: rgba(12,12,14,.88);
  color: #fff;
  font-size: 22px;
  font-weight: 900;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity .18s ease, transform .18s ease, background .18s ease, border-color .18s ease;
  backdrop-filter: blur(12px);
}

body.reader-page-v79 .reader-backtop-v79.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

body.reader-page-v79 .reader-backtop-v79:hover {
  background: rgba(229,9,20,.86);
  border-color: rgba(229,9,20,.9);
}

body.reader-page-v79 .reader-panel-icon,
body.reader-page-v79 .reader-immersion-toggle,
body.reader-page-v79 [data-reader-immersion-toggle] {
  display: none !important;
}

@media (max-width: 900px) {
  body.reader-page-v79 .reader-document-v79 {
    padding: 22px 18px !important;
  }

  body.reader-page-v79 .reader-document-head-v79,
  body.reader-page-v79 .reader-end-v79,
  body.reader-page-v79 .reader-after-v79 {
    display: grid !important;
  }

  body.reader-page-v79 .reader-text-v79 {
    font-size: 18px !important;
    line-height: 1.82 !important;
  }
}

@media (max-width: 760px) {
  body.reader-page-v79 .reader-shell-v79 {
    padding-inline: 14px !important;
  }

  body.reader-page-v79 .reader-hero-v79 {
    margin-inline: -14px !important;
    min-height: 285px !important;
    padding: 96px 14px 40px !important;
  }

  body.reader-page-v79 .reader-episode-strip-v79 {
    grid-auto-columns: minmax(260px, 82vw);
    margin-top: -22px;
  }

  body.reader-page-v79 .reader-episode-line-v79 {
    grid-template-columns: 112px minmax(0, 1fr);
  }
}

/* v80 — lecteur pleine largeur, épisodes non coupés, contrôles audio complets */
body.reader-page-v79 .reader-shell-v79 {
  width: 100% !important;
  max-width: none !important;
  padding-inline: clamp(18px, 3vw, 48px) !important;
}

body.reader-page-v79 .reader-document-v79 {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding-inline: clamp(28px, 6vw, 110px) !important;
}

body.reader-page-v79 .reader-text-v79,
body.reader-page-v79 .reader-end-v79,
body.reader-page-v79 .reader-after-v79,
body.reader-page-v79 .reader-music-v79 {
  max-width: 1180px !important;
}

body.reader-page-v79 .reader-document-head-v79 {
  max-width: 1180px;
  margin-inline: auto;
}

body.reader-page-v79 .reader-episode-strip-v79 {
  padding-top: 7px !important;
  padding-bottom: 14px !important;
  overflow-y: visible !important;
}

body.reader-page-v79 .reader-episode-line-v79:hover,
body.reader-page-v79 .reader-episode-line-v79.active {
  transform: none !important;
}

body.reader-page-v79 .reader-episode-line-v79.active .reader-episode-thumb-v79 {
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(229,9,20,.86), 0 10px 26px rgba(0,0,0,.28) !important;
}

body.reader-page-v79 .reader-episode-line-v79:hover .reader-episode-thumb-v79 {
  box-shadow: 0 0 0 1px rgba(255,255,255,.30), 0 10px 26px rgba(0,0,0,.28) !important;
}

body.reader-page-v79 .reader-episode-copy-v79 {
  justify-content: center;
}

body.reader-page-v79 .reader-voice-controls-v80 {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

body.reader-page-v79 .reader-voice-slider-v80 {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: rgba(255,255,255,.58) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}

body.reader-page-v79 .reader-voice-slider-v80 input[type="range"] {
  width: 92px !important;
  height: 4px !important;
  padding: 0 !important;
  accent-color: var(--reader-red) !important;
}

body.reader-page-v79 .reader-voice-rate {
  display: inline-flex !important;
}

body.reader-page-v79 .reader-voice-volume {
  display: inline-flex !important;
}

@media (max-width: 900px) {
  body.reader-page-v79 .reader-document-v79 {
    padding-inline: 18px !important;
  }

  body.reader-page-v79 .reader-text-v79,
  body.reader-page-v79 .reader-end-v79,
  body.reader-page-v79 .reader-after-v79,
  body.reader-page-v79 .reader-music-v79 {
    max-width: none !important;
  }

  body.reader-page-v79 .reader-document-head-v79 {
    max-width: none !important;
  }
}

/* v81 — lecteur : contrôles audio contenus, épisodes alignés, titres complets */
body.reader-page-v79 .reader-document-head-v79 {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px !important;
}

body.reader-page-v79 .reader-document-actions-v79 {
  width: 100% !important;
  min-width: 0 !important;
  justify-content: flex-start !important;
  align-items: center !important;
  overflow: hidden !important;
}

body.reader-page-v79 .reader-voice-controls-v80 {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: grid !important;
  grid-template-columns: auto auto minmax(150px, 220px) minmax(150px, 220px) !important;
  align-items: center !important;
  gap: 10px 12px !important;
}

body.reader-page-v79 .reader-voice-controls-v80 .mini-control {
  white-space: nowrap !important;
}

body.reader-page-v79 .reader-voice-slider-v80 {
  min-width: 0 !important;
  width: 100% !important;
}

body.reader-page-v79 .reader-voice-slider-v80 input[type="range"] {
  width: 100% !important;
  min-width: 0 !important;
}

body.reader-page-v79 .reader-episode-strip-v79 {
  grid-auto-columns: minmax(300px, 390px) !important;
  gap: 14px !important;
  padding: 8px 6px 16px 6px !important;
  overflow-y: hidden !important;
}

body.reader-page-v79 .reader-episode-line-v79 {
  width: 100% !important;
  min-width: 0 !important;
  grid-template-columns: 126px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: center !important;
  padding: 0 !important;
  transform: none !important;
}

body.reader-page-v79 .reader-episode-line-v79:hover,
body.reader-page-v79 .reader-episode-line-v79.active {
  transform: none !important;
}

body.reader-page-v79 .reader-episode-thumb-v79 {
  width: 126px !important;
  max-width: 126px !important;
  min-width: 126px !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.24) !important;
}

body.reader-page-v79 .reader-episode-line-v79.active .reader-episode-thumb-v79 {
  box-shadow: inset 0 0 0 2px rgba(229,9,20,.92), 0 10px 24px rgba(0,0,0,.24) !important;
}

body.reader-page-v79 .reader-episode-line-v79:hover .reader-episode-thumb-v79 {
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.34), 0 10px 24px rgba(0,0,0,.24) !important;
}

body.reader-page-v79 .reader-episode-copy-v79 {
  min-width: 0 !important;
  align-self: center !important;
  justify-content: center !important;
}

body.reader-page-v79 .reader-episode-copy-v79 strong {
  overflow: visible !important;
  white-space: normal !important;
  text-overflow: clip !important;
  display: block !important;
  font-size: clamp(12px, .9vw, 14px) !important;
  line-height: 1.25 !important;
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
}

@media (max-width: 980px) {
  body.reader-page-v79 .reader-voice-controls-v80 {
    grid-template-columns: auto auto !important;
  }

  body.reader-page-v79 .reader-voice-slider-v80 {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  body.reader-page-v79 .reader-episode-strip-v79 {
    grid-auto-columns: minmax(280px, 86vw) !important;
  }

  body.reader-page-v79 .reader-episode-line-v79 {
    grid-template-columns: 112px minmax(0, 1fr) !important;
  }

  body.reader-page-v79 .reader-episode-thumb-v79 {
    width: 112px !important;
    max-width: 112px !important;
    min-width: 112px !important;
  }
}

/* v82 — hotfix admin catalogue : les affiches gardent une hauteur visible */
body.admin-page .catalog-poster {
  display: block !important;
  width: 100% !important;
  min-height: 150px !important;
  height: 150px !important;
  aspect-ratio: 16 / 9 !important;
  background-image:
    linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.82)),
    var(--image),
    linear-gradient(135deg, var(--a), var(--b)) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

body.admin-page .catalog-link-card .catalog-poster {
  flex: none !important;
}

body.admin-page .item-preview {
  min-height: 116px !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

body.admin-page .editor-hero-preview {
  min-height: 230px !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

/* v83 — admin catalogue séparé publiés / non publiés */
body.admin-page .catalog-admin-groups {
  display: grid;
  gap: 26px;
}

body.admin-page .catalog-admin-group {
  display: grid;
  gap: 14px;
}

body.admin-page .catalog-admin-group + .catalog-admin-group {
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,.09);
}

body.admin-page .catalog-admin-group-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
}

body.admin-page .catalog-admin-group-head h3 {
  margin: 0;
  color: #fff;
  font-size: 22px;
  letter-spacing: -.035em;
}

body.admin-page .catalog-admin-group-head p {
  margin: 5px 0 0;
  color: rgba(255,255,255,.52);
  font-size: 13px;
}

body.admin-page .catalog-admin-group-head > span {
  flex: none;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(255,255,255,.055);
  color: rgba(255,255,255,.76);
  font-size: 12px;
  font-weight: 900;
}

body.admin-page .catalog-admin-group-unpublished .catalog-card {
  border-color: rgba(255,255,255,.08);
  background: rgba(255,255,255,.035);
}

body.admin-page .catalog-admin-group-unpublished .catalog-poster {
  opacity: .74;
  filter: saturate(.7) brightness(.82);
}

body.admin-page .catalog-admin-group-unpublished .catalog-info::after {
  content: "Non publié";
  width: fit-content;
  margin-top: 5px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.64);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

body.admin-page .catalog-admin-group-published .catalog-info::after {
  content: "Publié";
  width: fit-content;
  margin-top: 5px;
  border: 1px solid rgba(86,209,109,.24);
  border-radius: 999px;
  padding: 4px 8px;
  background: rgba(86,209,109,.08);
  color: #aaf2b8;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* v86 — flèches catalogue plus stables et non bloquantes */
.row-wrap.at-start .scroll-left,
.row-wrap.at-end .scroll-right,
.row-wrap:not(.is-scrollable) .scroll-btn,
.row-wrap .scroll-btn:disabled {
  opacity: 0 !important;
  pointer-events: none !important;
}

.row-wrap.is-scrollable:hover .scroll-btn:not(:disabled),
.row-wrap.is-scrollable .scroll-btn:focus-visible {
  opacity: .88 !important;
}

.row-wrap .scroll-btn {
  width: 40px !important;
  max-width: 40px !important;
  background: linear-gradient(90deg, rgba(5,5,5,.78), rgba(5,5,5,.36)) !important;
}

.row-wrap .scroll-right {
  background: linear-gradient(270deg, rgba(5,5,5,.78), rgba(5,5,5,.36)) !important;
}

.row-wrap .scroll-btn:hover {
  opacity: 1 !important;
  background-color: rgba(20,20,20,.88) !important;
}

/* Sécurité : les cartes restent cliquables au milieu du rail. */
.row-wrap .row {
  scroll-behavior: smooth;
}

/* v88 — audio IA uploadé manuellement : aucune génération serveur */
.reader-voice-controls-v87 .mini-control:disabled {
  opacity: .45 !important;
  cursor: not-allowed !important;
  filter: grayscale(.35);
}

.chapter-admin-status-pill.tts {
  border-color: rgba(255,255,255,.14);
}

.reader-voice-controls-v87 {
  grid-template-columns: auto auto auto minmax(150px, 220px) minmax(150px, 220px) !important;
}

.reader-voice-controls-v87 .reader-browser-voice-toggle {
  background: rgba(255,255,255,.11);
}

.reader-voice-controls-v87 .reader-voice-toggle:not(:disabled) {
  border-color: rgba(229,9,20,.52);
  background: rgba(229,9,20,.18);
  color: #fff;
}

@media (max-width: 1120px) {
  body.reader-page-v79 .reader-voice-controls-v87 {
    grid-template-columns: auto auto auto !important;
  }

  body.reader-page-v79 .reader-voice-controls-v87 .reader-voice-slider-v80 {
    grid-column: 1 / -1;
  }
}

@media (max-width: 640px) {
  body.reader-page-v79 .reader-voice-controls-v87 {
    grid-template-columns: 1fr !important;
  }
}


/* v88 — panneau upload audio IA */
.chapter-ai-audio-panel {
  display: grid;
  gap: 14px;
}
.ai-audio-upload-card {
  display: grid;
  gap: 14px;
}
.ai-audio-upload-form {
  display: grid;
  gap: 12px;
}
.ai-audio-preview {
  width: 100%;
  min-height: 42px;
}
.ai-audio-delete-form {
  display: flex;
  justify-content: flex-end;
}
.ai-audio-upload-shortcut {
  white-space: nowrap;
}
.empty-panel.compact,
.muted-note.compact {
  margin: 0;
}
