/* =============================================================
   La Récrée Tech — Plateforme app · Design system
   ============================================================= */

:root {
  --rose: #C8395E;
  --rose-light: #E8587A;
  --rose-deep: #A82248;
  --rose-pale: #F0D6D6;
  --ink: #14110D;
  --ink-soft: #4A4540;
  --cream: #FCFAF5;
  --cream-warm: #F5EEDB;
  --tableau: #1F3025;
  --tableau-light: #2D4438;
  --line: rgba(20, 17, 13, 0.10);
  --line-strong: rgba(20, 17, 13, 0.18);
  --grid: rgba(20, 17, 13, 0.05);
  --grid-dark: rgba(252, 250, 245, 0.08);
  --shadow-soft: 0 8px 24px rgba(20, 17, 13, 0.06);
  --shadow-rose: 0 8px 24px rgba(200, 57, 94, 0.25);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; }
body {
  font-family: 'Manrope', system-ui, -apple-system, sans-serif;
  background: var(--cream);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.55;
  min-height: 100vh;
}
a { color: var(--rose); text-decoration: none; }
a:hover { color: var(--rose-deep); }
button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; }

h1, h2, h3, h4 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ink);
}

/* =============================================================
   Auth layout (login · register · reset)
   ============================================================= */

.auth-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background-color: var(--tableau);
  background-image:
    linear-gradient(var(--grid-dark) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-dark) 1px, transparent 1px);
  background-size: 30px 30px;
  color: var(--cream);
}

.auth-header {
  padding: 28px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.auth-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--cream);
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.015em;
  text-decoration: none;
}
.auth-brand em { color: var(--rose-light); font-style: italic; }
.auth-brand-svg { width: 44px; height: 44px; }
.auth-header-link {
  font-family: 'DM Mono', Menlo, monospace;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(252, 250, 245, 0.65);
  text-decoration: none;
}
.auth-header-link:hover { color: var(--rose-light); }

.auth-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 24px 60px;
}

.auth-card {
  background: var(--cream);
  border-radius: 16px;
  padding: clamp(36px, 5vw, 56px) clamp(28px, 4vw, 48px);
  max-width: 440px;
  width: 100%;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.25),
    0 0 0 1px rgba(240, 214, 214, 0.4);
}

.auth-eyebrow {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rose);
  margin-bottom: 14px;
}

.auth-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(28px, 4vw, 38px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin-bottom: 12px;
}
.auth-title em { font-style: italic; color: var(--rose); }

.auth-sub {
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.55;
  margin-bottom: 32px;
}

.auth-field {
  margin-bottom: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.auth-field label {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
}
.auth-field input {
  width: 100%;
  font-family: 'Manrope', sans-serif;
  font-size: 16px;
  padding: 13px 16px;
  background: #fff;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  color: var(--ink);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.auth-field input:focus {
  outline: none;
  border-color: var(--rose);
  box-shadow: 0 0 0 3px rgba(200, 57, 94, 0.12);
}
.auth-field input::placeholder {
  color: var(--ink-soft);
  opacity: 0.55;
}

.auth-row-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 18px 0 24px;
  font-size: 13.5px;
  color: var(--ink-soft);
}
.auth-row-between label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.auth-row-between input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--rose);
  cursor: pointer;
}
.auth-row-between a:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

.auth-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 16px;
  background: var(--rose);
  color: #fff;
  border: 1px solid var(--rose);
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.auth-submit:hover {
  background: var(--rose-deep);
  border-color: var(--rose-deep);
  transform: translateY(-1px);
  box-shadow: var(--shadow-rose);
}

.auth-alert {
  background: var(--rose-pale);
  border: 1px solid rgba(200, 57, 94, 0.35);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 24px;
  font-size: 14px;
  color: var(--rose-deep);
}

.auth-footer-link {
  margin-top: 28px;
  text-align: center;
  font-size: 14px;
  color: var(--ink-soft);
}
.auth-footer-link a {
  color: var(--rose);
  font-weight: 600;
}

.auth-foot {
  padding: 20px 32px;
  text-align: center;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: rgba(252, 250, 245, 0.45);
}

/* =============================================================
   App layout (dashboard authenticated pages)
   ============================================================= */

.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--cream);
}

.app-header {
  background: rgba(252, 250, 245, 0.92);
  backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 50;
}
.app-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 32px;
  max-width: 1280px;
  margin: 0 auto;
}
.app-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--ink);
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.015em;
  text-decoration: none;
}
.app-brand em { color: var(--rose); font-style: italic; }
.app-brand .dot { color: var(--rose); }
.app-brand-svg { width: 40px; height: 40px; }

.app-nav {
  display: flex;
  align-items: center;
  gap: 24px;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
}
.app-nav a {
  color: var(--ink-soft);
  font-weight: 500;
}
.app-nav a:hover { color: var(--rose); }

.app-user {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  color: var(--ink-soft);
}
.app-user strong { color: var(--ink); }

.app-main {
  flex: 1;
  max-width: 1280px;
  margin: 0 auto;
  width: 100%;
  padding: 48px 32px;
}

.app-footer {
  border-top: 1px solid var(--line);
  padding: 24px 32px;
  text-align: center;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

/* =============================================================
   Dashboard
   ============================================================= */

.eyebrow {
  display: inline-block;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rose);
  margin-bottom: 14px;
}

/* User menu — avatar + dropdown placeholder */
.app-user-menu {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 14px 6px 6px;
  border-radius: 999px;
  background: rgba(252, 250, 245, 0.5);
  border: 1px solid var(--line);
  transition: border-color 0.2s, background 0.2s;
}
.app-user-menu:hover {
  border-color: var(--rose);
  background: var(--rose-pale);
}
.app-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--rose);
  color: var(--cream);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.02em;
}
.app-user-name {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}
.app-logout {
  margin-left: 18px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.app-logout:hover { color: var(--rose); }

/* Hero greeting */
.dash-hero { margin-bottom: 48px; }
.dash-hero-caveat {
  display: block;
  font-family: 'Caveat', cursive;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 38px);
  color: var(--rose);
  line-height: 1.1;
  margin-bottom: 8px;
}
.dash-hero-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(36px, 5vw, 52px);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--ink);
  margin: 0 0 14px;
}
.dash-hero-title em { font-style: italic; color: var(--rose); }
.dash-hero-sub {
  font-family: 'Manrope', sans-serif;
  font-size: 17px;
  color: var(--ink-soft);
  max-width: 580px;
  line-height: 1.55;
}

/* Stats row */
.dash-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-bottom: 48px;
}
@media (min-width: 640px) { .dash-stats { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .dash-stats { grid-template-columns: repeat(4, 1fr); } }
.dash-stat {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.dash-stat:hover {
  border-color: rgba(200, 57, 94, 0.3);
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
}
.dash-stat-label {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 10px;
}
.dash-stat-value {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: clamp(30px, 3.4vw, 40px);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1;
  color: var(--rose);
  margin-bottom: 6px;
}
.dash-stat-hint {
  font-family: 'Manrope', sans-serif;
  font-size: 12.5px;
  color: var(--ink-soft);
}

/* Section header */
.dash-section { margin-bottom: 48px; }
.dash-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 16px;
}
.dash-section-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--ink);
  line-height: 1.15;
  margin: 0;
}
.dash-section-title em { font-style: italic; color: var(--rose); }
.dash-section-action {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.dash-section-action:hover { color: var(--rose); }

/* CONTINUE WATCHING — hero Netflix-style */
.dash-continue {
  background-color: var(--tableau);
  background-image:
    linear-gradient(var(--grid-dark) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-dark) 1px, transparent 1px);
  background-size: 30px 30px;
  border-radius: 18px;
  padding: clamp(20px, 2.5vw, 28px);
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  color: var(--cream);
  position: relative;
  overflow: hidden;
}
@media (min-width: 760px) {
  .dash-continue { grid-template-columns: 360px 1fr; align-items: center; }
}
@media (min-width: 1024px) {
  .dash-continue { grid-template-columns: 440px 1fr; gap: 36px; }
}

.dash-continue-thumb {
  position: relative;
  aspect-ratio: 16 / 9;
  width: 100%;
  background-color: var(--tableau-light);
  background-image:
    linear-gradient(var(--grid-dark) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-dark) 1px, transparent 1px);
  background-size: 18px 18px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(232, 88, 122, 0.2);
}
.dash-continue-thumb-play {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--rose);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cream);
  font-size: 22px;
  box-shadow: 0 8px 24px rgba(200, 57, 94, 0.4);
  transition: transform 0.2s, background 0.2s;
}
.dash-continue:hover .dash-continue-thumb-play {
  transform: scale(1.08);
  background: var(--rose-light);
}
.dash-continue-thumb-time {
  position: absolute;
  bottom: 10px;
  right: 10px;
  background: rgba(20, 17, 13, 0.75);
  color: var(--cream);
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 4px;
  letter-spacing: 0.04em;
}

.dash-continue-body { display: flex; flex-direction: column; gap: 14px; }
.dash-continue-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rose-light);
}
.dash-continue h3 {
  font-family: 'Fraunces', serif;
  font-size: clamp(24px, 2.8vw, 32px);
  font-weight: 500;
  color: var(--cream);
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.1;
}
.dash-continue h3 em { font-style: italic; color: var(--rose-light); }
.dash-continue-meta {
  font-size: 14px;
  color: rgba(252, 250, 245, 0.7);
  margin: 0;
}

.dash-progress-bar {
  position: relative;
  height: 6px;
  background: rgba(252, 250, 245, 0.12);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 4px;
}
.dash-progress-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: linear-gradient(90deg, var(--rose), var(--rose-light));
  border-radius: 999px;
}
.dash-progress-meta {
  display: flex;
  justify-content: space-between;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: rgba(252, 250, 245, 0.6);
  letter-spacing: 0.08em;
}
.dash-progress-meta strong { color: var(--rose-light); font-weight: 600; }

.dash-continue-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--rose-light);
  color: var(--ink);
  padding: 14px 26px;
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  justify-self: start;
  align-self: flex-start;
}
.dash-continue-cta:hover {
  background: var(--cream);
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(232, 88, 122, 0.35);
}

/* PROGRESS MAP — parcours visuel modules */
.dash-progress-map {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: clamp(24px, 3vw, 36px);
  overflow-x: auto;
}
.dash-progress-map-title {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 22px;
  display: flex;
  justify-content: space-between;
  gap: 18px;
}
.dash-progress-map-title strong { color: var(--ink); }
.dash-progress-map-title em {
  font-style: normal;
  color: var(--rose);
  font-weight: 600;
}

.map-track {
  display: flex;
  align-items: stretch;
  gap: 0;
  min-width: max-content;
}
.map-node {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  position: relative;
}
.map-node + .map-node { margin-left: 0; }
.map-connector {
  flex: 1;
  height: 3px;
  align-self: center;
  background: var(--rose-pale);
  margin: 0 -2px;
  margin-bottom: 28px;
  min-width: 44px;
}
.map-connector.is-done { background: var(--rose); }

.map-marker {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--rose-pale);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'DM Mono', Menlo, monospace;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink-soft);
  z-index: 1;
  transition: transform 0.2s, background 0.2s, color 0.2s;
  cursor: pointer;
}
.map-marker:hover { transform: scale(1.08); }

.map-marker.is-done {
  background: var(--rose);
  border-color: var(--rose);
  color: var(--cream);
  font-family: 'Fraunces', serif;
  font-size: 22px;
}
.map-marker.is-current {
  border-color: var(--rose);
  color: var(--rose);
  background: var(--rose-pale);
  animation: marker-pulse 2.2s ease-out infinite;
}
@keyframes marker-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(200, 57, 94, 0.45); }
  100% { box-shadow: 0 0 0 16px rgba(200, 57, 94, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .map-marker.is-current { animation: none; box-shadow: 0 0 0 6px rgba(200, 57, 94, 0.18); }
}
.map-marker.is-finale {
  background: var(--rose-deep);
  border-color: var(--rose-deep);
  color: var(--cream);
  font-family: 'Fraunces', serif;
  font-size: 20px;
}

.map-label {
  margin-top: 10px;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-align: center;
}
.map-marker.is-done + .map-label,
.map-marker.is-current + .map-label { color: var(--ink); font-weight: 600; }
.map-pct {
  margin-top: 4px;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--rose);
  font-weight: 600;
  letter-spacing: 0.04em;
}

.dash-progress-map-foot {
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px dashed var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
  flex-wrap: wrap;
  gap: 12px;
}
.dash-progress-map-foot strong { color: var(--rose); font-weight: 600; }
.dash-progress-map-foot a { color: var(--rose); font-weight: 600; }

/* Empty state */
.dash-empty {
  background: #fff;
  border: 1px dashed var(--line-strong);
  border-radius: 14px;
  padding: 48px 32px;
  text-align: center;
}
.dash-empty-icon {
  display: inline-block;
  font-family: 'Fraunces', serif;
  font-size: 28px;
  color: var(--rose-light);
  margin-bottom: 14px;
}
.dash-empty h3 {
  font-family: 'Fraunces', serif;
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 10px;
  color: var(--ink);
}
.dash-empty p {
  font-size: 15px;
  color: var(--ink-soft);
  margin: 0 0 20px;
  max-width: 460px;
  margin-left: auto;
  margin-right: auto;
}
.dash-empty a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--rose);
  color: #fff;
  padding: 12px 22px;
  border-radius: 10px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.2s;
}
.dash-empty a:hover {
  background: var(--rose-deep);
  transform: translateY(-1px);
  box-shadow: var(--shadow-rose);
}

/* Activity timeline */
.dash-activity {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 28px;
}
.dash-activity-item {
  display: flex;
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--line);
}
.dash-activity-item:first-child { border-top: 0; padding-top: 0; }
.dash-activity-item:last-child { padding-bottom: 0; }
.dash-activity-dot {
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--rose);
  margin-top: 6px;
}
.dash-activity-body strong {
  display: block;
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 3px;
}
.dash-activity-body span {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

::selection { background: var(--rose); color: #fff; }
:focus-visible {
  outline: 2px solid var(--rose);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ============================================
   CATALOGUE — Récrée Tech DA
   ============================================ */

/* HERO — tableau-noir billboard */
.cat-hero {
  position: relative;
  margin: 0 0 2.5rem;
  padding: 3.5rem 2rem 3rem;
  background: #1F3025;
  color: #FCFAF5;
  border-radius: 20px;
  overflow: hidden;
  isolation: isolate;
}
.cat-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(252, 250, 245, 0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(252, 250, 245, 0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  background-position: -1px -1px;
  z-index: -1;
}
.cat-hero::before,
.cat-hero::after {
  content: '';
  position: absolute;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(252, 250, 245, 0.4);
  z-index: 0;
}
.cat-hero::before { top: 1rem; left: 1rem; border-right: 0; border-bottom: 0; }
.cat-hero::after { bottom: 1rem; right: 1rem; border-left: 0; border-top: 0; }
.cat-hero-inner { position: relative; max-width: 760px; }
.cat-hero-caveat {
  font-family: 'Caveat', cursive;
  font-size: 2rem;
  color: var(--rose);
  display: inline-block;
  transform: rotate(-2deg);
  margin-bottom: 0.6rem;
}
.cat-hero-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(2.4rem, 5vw, 4rem);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 1rem;
  color: #FCFAF5;
}
.cat-hero-title em {
  font-style: italic;
  color: var(--rose);
}
.cat-hero-sub {
  font-family: 'Manrope', sans-serif;
  font-size: 1.05rem;
  line-height: 1.6;
  color: rgba(252, 250, 245, 0.78);
  margin: 0 0 1.8rem;
  max-width: 560px;
}
.cat-hero-stats {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
}
.cat-hero-stats li {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cat-hero-stats strong {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 2.2rem;
  font-weight: 500;
  color: #FCFAF5;
  line-height: 1;
}
.cat-hero-stats li.is-mine strong { color: var(--rose); }
.cat-hero-stats span {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: rgba(252, 250, 245, 0.55);
  text-transform: uppercase;
}

/* SECTION HEAD */
.cat-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  gap: 1rem;
  flex-wrap: wrap;
}
.cat-section-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 500;
  margin: 0;
  color: var(--ink);
}
.cat-section-title em {
  font-style: italic;
  color: var(--rose);
}
.cat-section-hint {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  text-transform: uppercase;
}

/* GRID */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 1.8rem;
}

/* CARD */
.cat-card {
  background: #fff;
  border: 1px solid #efe9df;
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.cat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 50px -22px rgba(31, 48, 37, 0.28);
  border-color: rgba(200, 57, 94, 0.35);
}
.cat-card.is-enrolled { border-color: rgba(200, 57, 94, 0.55); }
.cat-card.is-vip { border-color: rgba(200, 57, 94, 0.85); box-shadow: 0 0 0 2px rgba(200, 57, 94, 0.08) inset; }

/* CARD COVER */
.cat-card-cover-link { display: block; text-decoration: none; }
.cat-card-cover {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #1F3025;
  overflow: hidden;
}
.cat-card-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.cat-card:hover .cat-card-cover img { transform: scale(1.04); }
.cat-card-cover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(31, 48, 37, 0) 55%, rgba(31, 48, 37, 0.5) 100%);
  pointer-events: none;
}

/* CARD COVER FALLBACK (formation sans image) */
.cat-card-cover-fallback {
  position: absolute;
  inset: 0;
  padding: 1.4rem;
  color: #FCFAF5;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  isolation: isolate;
}
.cat-card-cover-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(252, 250, 245, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(252, 250, 245, 0.06) 1px, transparent 1px);
  background-size: 40px 40px;
  z-index: -1;
}
.cat-card-cover-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--rose);
  text-transform: uppercase;
}
.cat-card-cover-num {
  align-self: center;
  font-family: 'Fraunces', serif;
  font-size: 5rem;
  font-weight: 400;
  line-height: 1;
  color: #FCFAF5;
}
.cat-card-cover-title {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--rose);
  line-height: 1.1;
}
.cat-card-cover-sub {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 0.8rem;
  color: rgba(252, 250, 245, 0.7);
  margin-top: 0.3rem;
}

/* CARD BADGE */
.cat-card-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: var(--rose);
  color: #fff;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.12em;
  padding: 0.4rem 0.7rem;
  border-radius: 99px;
  text-transform: uppercase;
  z-index: 2;
  box-shadow: 0 4px 12px -4px rgba(200, 57, 94, 0.5);
}
.cat-card-badge.is-vip {
  background: #1F3025;
  color: var(--rose);
  border: 1px solid var(--rose);
  box-shadow: 0 4px 12px -4px rgba(31, 48, 37, 0.5);
}

/* CARD BODY */
.cat-card-body {
  padding: 1.4rem 1.4rem 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  flex: 1;
}
.cat-card-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.cat-card-title {
  font-family: 'Fraunces', serif;
  font-size: 1.5rem;
  font-weight: 500;
  margin: 0;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.cat-card-title a {
  color: var(--ink);
  text-decoration: none;
  background-image: linear-gradient(var(--rose), var(--rose));
  background-size: 0 2px;
  background-repeat: no-repeat;
  background-position: 0 100%;
  transition: background-size .25s ease;
}
.cat-card-title a:hover {
  color: var(--rose);
  background-size: 100% 2px;
}
.cat-card-sub {
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--ink-soft);
  margin: 0;
}

/* CARD PROGRESS */
.cat-card-progress {
  margin-top: 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.cat-card-progress-bar {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 8px;
  border: 0;
  border-radius: 99px;
  background: rgba(31, 48, 37, 0.08);
  overflow: hidden;
}
.cat-card-progress-bar::-webkit-progress-bar {
  background: rgba(31, 48, 37, 0.08);
  border-radius: 99px;
}
.cat-card-progress-bar::-webkit-progress-value {
  background: linear-gradient(90deg, var(--rose), #E8587A);
  border-radius: 99px;
  transition: width .25s ease;
}
.cat-card-progress-bar::-moz-progress-bar {
  background: linear-gradient(90deg, var(--rose), #E8587A);
  border-radius: 99px;
}
.cat-card-progress-meta {
  display: flex;
  justify-content: space-between;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--ink-soft);
}
.cat-card-progress-meta strong {
  color: var(--rose);
  font-weight: 600;
}

/* CARD PRICE */
.cat-card-price-row {
  margin-top: 0.6rem;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 0.8rem 1rem;
  background: var(--cream, #FCFAF5);
  border-radius: 10px;
}
.cat-card-price-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.cat-card-price {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 1.3rem;
  font-weight: 500;
  color: var(--ink);
}

/* CARD CTA */
.cat-card-cta {
  margin-top: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.9rem 1.2rem;
  background: var(--ink, #1F3025);
  color: #FCFAF5;
  border-radius: 10px;
  text-decoration: none;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  text-align: center;
  transition: background .15s ease, transform .15s ease;
}
.cat-card-cta:hover {
  background: var(--rose);
  transform: translateY(-1px);
}
.cat-card-cta.is-resume {
  background: var(--rose);
}
.cat-card-cta.is-resume:hover {
  background: #B22F50;
}

/* COMING SOON */
.cat-card.is-coming { opacity: 0.92; }
.cat-card.is-coming .cat-card-cover-fallback { filter: grayscale(0.4); }
.cat-card.is-coming .cat-card-cover::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(31, 48, 37, 0.2) 0%, rgba(31, 48, 37, 0.55) 100%);
  pointer-events: none;
}
.cat-card-badge.is-coming {
  background: #FCFAF5;
  color: var(--ink, #1F3025);
  border: 1px solid #1F3025;
  box-shadow: 0 4px 12px -4px rgba(31, 48, 37, 0.45);
}
.cat-card-coming-row {
  margin-top: 0.6rem;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 0.8rem 1rem;
  background: rgba(31, 48, 37, 0.05);
  border: 1px dashed rgba(31, 48, 37, 0.2);
  border-radius: 10px;
}
.cat-card-coming-label {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  color: var(--ink-soft);
  text-transform: uppercase;
}
.cat-card-coming-date {
  font-family: 'Caveat', cursive;
  font-size: 1.6rem;
  color: var(--rose);
  line-height: 1;
}
.cat-card-cta.is-disabled,
.cat-card-cta[disabled] {
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(31, 48, 37, 0.25);
  cursor: not-allowed;
  font-family: 'Manrope', sans-serif;
}
.cat-card-cta.is-disabled:hover,
.cat-card-cta[disabled]:hover {
  background: rgba(31, 48, 37, 0.04);
  color: var(--ink);
  transform: none;
}

/* Cover wrapper (used when no link, e.g. coming-soon) */
.cat-card-cover-wrapper { display: block; }

/* PROGRAMME FORMATION */
.formation-programme { display: flex; flex-direction: column; gap: 1.2rem; }
.programme-module { background: #fff; border: 1px solid #efe9df; border-radius: 14px; overflow: hidden; }
.programme-module-cover { aspect-ratio: 16 / 6; overflow: hidden; background: #1F3025; }
.programme-module-cover img { width: 100%; height: 100%; object-fit: cover; display: block; }
.programme-module-head { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 1rem; padding: 1rem 1.4rem; background: #FCFAF5; border-bottom: 1px solid #efe9df; }
.programme-module-num { font-family: 'DM Mono', monospace; font-size: 0.9rem; font-weight: 600; color: var(--rose); background: rgba(200, 57, 94, 0.08); padding: 0.4rem 0.7rem; border-radius: 8px; letter-spacing: 0.05em; }
.programme-module-title { font-family: 'Fraunces', serif; font-size: 1.2rem; font-weight: 500; margin: 0; color: var(--ink); }
.programme-module-sub { font-size: 0.85rem; color: var(--ink-soft); margin: 0.2rem 0 0; }
.programme-module-count { font-family: 'DM Mono', monospace; font-size: 11px; letter-spacing: 0.08em; color: var(--ink-soft); text-transform: uppercase; }
.programme-lessons { list-style: none; margin: 0; padding: 0; }
.programme-lesson { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 1rem; padding: 0.85rem 1.4rem; border-bottom: 1px solid #efe9df; transition: background .12s ease; }
.programme-lesson:last-child { border-bottom: 0; }
.programme-lesson:hover { background: rgba(252, 250, 245, 0.5); }
.programme-lesson-mark { width: 28px; height: 28px; border-radius: 50%; background: #FCFAF5; display: inline-flex; align-items: center; justify-content: center; font-family: 'DM Mono', monospace; font-size: 12px; font-weight: 600; color: var(--ink-soft); border: 1px solid #efe9df; }
.programme-lesson.is-done .programme-lesson-mark { background: var(--rose); color: #fff; border-color: var(--rose); }
.programme-lesson-body { display: flex; flex-direction: column; }
.programme-lesson-body strong { font-family: 'Manrope', sans-serif; font-size: 0.95rem; font-weight: 600; color: var(--ink); }
.programme-lesson-body span { font-family: 'DM Mono', monospace; font-size: 11px; color: var(--ink-soft); margin-top: 2px; }
.programme-lesson-cta { color: var(--rose); font-weight: 600; font-size: 0.85rem; text-decoration: none; }
.programme-lesson-cta:hover { text-decoration: underline; }
.programme-lesson-lock { opacity: 0.4; font-size: 1rem; }

/* ============================================
   LECTEUR LEÇON — Cinéma immersif
   ============================================ */
.lp-shell {
  background: var(--cream, #FCFAF5);
  padding-bottom: 90px; /* sticky dock */
}

.lp-cinema {
  max-width: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}

/* TOP STRIP */
.lp-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 0.55rem clamp(1rem, 3vw, 2rem);
  background: #1F3025;
  color: rgba(252, 250, 245, 0.78);
}
.lp-strip-crumbs {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
}
.lp-strip-crumbs a { color: rgba(252, 250, 245, 0.78); text-decoration: none; transition: color .15s ease; }
.lp-strip-crumbs a:hover { color: var(--rose); }
.lp-strip-meta { display: flex; align-items: center; gap: 1rem; }
.lp-strip-chrono {
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #FCFAF5;
  padding: 0.25rem 0.7rem;
  border: 1px solid rgba(252, 250, 245, 0.25);
  border-radius: 4px;
}
.lp-strip-caveat {
  font-family: 'Caveat', cursive;
  font-size: 1.5rem;
  color: var(--rose);
  transform: rotate(-2deg);
  line-height: 1;
}

/* SCREEN — fond clair (cream), même que le reste de la page */
.lp-screen {
  position: relative;
  background: var(--cream, #FCFAF5);
  padding: 1.6rem clamp(1rem, 4vw, 3rem) 2rem;
  isolation: isolate;
  overflow: hidden;
}
.lp-curtain { display: none; }
.lp-screen-grid {
  position: relative;
  z-index: 1;
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(280px, 1fr);
  gap: 1.4rem;
  align-items: start;
}
@media (max-width: 1024px) {
  .lp-screen-grid { grid-template-columns: 1fr; }
}
.lp-screen-bezel {
  position: relative;
  background: #1F3025;
  padding: 10px;
  border-radius: 6px;
  margin: 0;
  box-shadow:
    0 24px 60px -24px rgba(0, 0, 0, 0.7),
    0 0 0 1px rgba(252, 250, 245, 0.05);
  z-index: 1;
}
.lp-screen-bezel::before,
.lp-screen-bezel::after {
  content: '';
  position: absolute;
  width: 18px;
  height: 18px;
  border: 1px solid rgba(252, 250, 245, 0.4);
}
.lp-screen-bezel::before { top: 6px; left: 6px; border-right: 0; border-bottom: 0; }
.lp-screen-bezel::after { bottom: 6px; right: 6px; border-left: 0; border-top: 0; }
.lp-player-frame {
  position: relative;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 2px;
  overflow: hidden;
}
@media (max-width: 720px) {
  .lp-player-frame { aspect-ratio: 16 / 9; }
}
.lp-player-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* RESOURCES SIDEBAR — pretty version */
.lp-resources-side {
  position: relative;
  background: #fff;
  border: 1px solid #efe9df;
  border-radius: 16px;
  padding: 1.4rem 1.3rem 1.4rem;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-height: 0;
  box-shadow: 0 14px 36px -20px rgba(31, 48, 37, 0.2);
  overflow: hidden;
}
.lp-resources-side::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 80px;
  height: 4px;
  background: var(--rose);
  border-bottom-right-radius: 4px;
}
.lp-resources-side-head {
  padding-bottom: 0.9rem;
  border-bottom: 1px dashed rgba(31, 48, 37, 0.18);
}
.lp-resources-side-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--rose);
  text-transform: uppercase;
  font-weight: 600;
}
.lp-resources-side-title {
  font-family: 'Fraunces', serif;
  font-size: 1.35rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0.4rem 0 0;
  line-height: 1.2;
}
.lp-resources-side-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: rgba(200, 57, 94, 0.4) transparent;
}
.lp-resources-side-list::-webkit-scrollbar { width: 6px; }
.lp-resources-side-list::-webkit-scrollbar-thumb { background: rgba(200, 57, 94, 0.4); border-radius: 99px; }

.lp-resource-side a {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.85rem;
  align-items: center;
  padding: 0.85rem 1rem;
  border-radius: 12px;
  text-decoration: none;
  color: var(--ink);
  background: var(--cream, #FCFAF5);
  border: 1px solid #efe9df;
  position: relative;
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.lp-resource-side a::after {
  content: '→';
  font-family: 'Manrope', sans-serif;
  font-size: 1.1rem;
  color: var(--rose);
  font-weight: 600;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .2s ease, transform .2s ease;
}
.lp-resource-side a:hover {
  border-color: var(--rose);
  background: #fff;
  transform: translateY(-2px);
  box-shadow: 0 10px 26px -16px rgba(200, 57, 94, 0.45);
}
.lp-resource-side a:hover::after {
  opacity: 1;
  transform: translateX(0);
}
.lp-resource-side-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #efe9df;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  flex-shrink: 0;
  transition: transform .25s ease;
}
.lp-resource-side a:hover .lp-resource-side-icon { transform: rotate(-6deg); }
.lp-resource-side.is-file .lp-resource-side-icon {
  background: linear-gradient(135deg, rgba(200, 57, 94, 0.18) 0%, rgba(200, 57, 94, 0.06) 100%);
  border-color: rgba(200, 57, 94, 0.35);
}
.lp-resource-side-body { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.lp-resource-side-kind {
  font-family: 'DM Mono', monospace;
  font-size: 9px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 600;
}
.lp-resource-side-body strong {
  font-family: 'Manrope', sans-serif;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.005em;
}
.lp-resource-side-body em {
  display: none; /* arrow hover handles CTA visually */
}

/* HEADLINE under screen */
.lp-headline {
  background: #1F3025;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  padding: 1.8rem clamp(1rem, 4vw, 3rem) 1.8rem;
}
.lp-headline::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(252, 250, 245, 0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(252, 250, 245, 0.04) 1px, transparent 1px);
  background-size: 50px 50px;
  z-index: -1;
}
.lp-headline-mark {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 2.4rem;
  color: var(--rose);
  line-height: 1;
  margin-top: 0.4rem;
}
.lp-headline-body { display: flex; flex-direction: column; gap: 0.3rem; min-width: 0; max-width: 1400px; }
.lp-headline-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(252, 250, 245, 0.55);
}
.lp-headline-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(2rem, 4.5vw, 3.6rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0;
  color: #FCFAF5;
}

/* FLASH */
.lp-flash {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  background: rgba(200, 57, 94, 0.08);
  border-left: 4px solid var(--rose);
  padding: 0.9rem 1.2rem;
  border-radius: 6px;
  margin: 1rem clamp(1rem, 4vw, 3rem);
  max-width: 1100px;
  font-family: 'Manrope', sans-serif;
  font-size: 0.95rem;
  color: var(--ink);
}
@media (min-width: 1200px) {
  .lp-flash { margin-left: max(clamp(1rem, 4vw, 3rem), calc((100% - 1100px) / 2)); margin-right: auto; }
}
.lp-flash-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--rose);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.8rem;
}

/* VELLUM (description) */
.lp-vellum {
  max-width: 1100px;
  margin: 1.6rem auto;
  padding: 2rem clamp(1.4rem, 3vw, 2.4rem);
  background:
    repeating-linear-gradient(180deg, transparent 0 31px, rgba(31, 48, 37, 0.06) 31px 32px),
    #fff;
  border: 1px solid #efe9df;
  border-radius: 14px;
  box-shadow:
    0 12px 32px -16px rgba(31, 48, 37, 0.18),
    0 1px 2px rgba(31, 48, 37, 0.08);
  width: calc(100% - 2 * clamp(1rem, 4vw, 3rem));
  position: relative;
}
.lp-vellum::before {
  content: '';
  position: absolute;
  left: 1.4rem;
  top: 0;
  bottom: 0;
  width: 1px;
  background: rgba(200, 57, 94, 0.3);
}
.lp-vellum-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--rose);
  text-transform: uppercase;
}
.lp-vellum-title {
  font-family: 'Fraunces', serif;
  font-size: 1.5rem;
  font-weight: 500;
  margin: 0.4rem 0 1rem;
  color: var(--ink);
}
.lp-vellum p {
  font-family: 'Manrope', sans-serif;
  color: var(--ink);
  line-height: 1.8;
  font-size: 1.05rem;
  margin: 0;
}

/* CHIPS SECTION */
.lp-chips-section {
  max-width: 1100px;
  margin: 1.4rem auto;
  width: calc(100% - 2 * clamp(1rem, 4vw, 3rem));
}
.lp-chips-head { margin-bottom: 1rem; padding: 0 0.2rem; }
.lp-chips-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--rose);
  text-transform: uppercase;
}
.lp-chips-title {
  font-family: 'Fraunces', serif;
  font-size: 1.5rem;
  font-weight: 500;
  margin: 0.3rem 0 0;
  color: var(--ink);
}
.lp-chips-scroller {
  overflow-x: auto;
  padding-bottom: 0.6rem;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: rgba(200, 57, 94, 0.4) transparent;
}
.lp-chips-scroller::-webkit-scrollbar { height: 8px; }
.lp-chips-scroller::-webkit-scrollbar-thumb { background: rgba(200, 57, 94, 0.4); border-radius: 99px; }
.lp-chips {
  list-style: none;
  margin: 0;
  padding: 0.2rem 0;
  display: flex;
  gap: 0.9rem;
  width: max-content;
}
.lp-chip { scroll-snap-align: start; }
.lp-chip a {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 0.9rem 1.2rem;
  background: #fff;
  border: 1px solid #efe9df;
  border-radius: 99px;
  text-decoration: none;
  color: var(--ink);
  min-width: 280px;
  transition: border-color .15s ease, transform .15s ease, box-shadow .15s ease;
}
.lp-chip a:hover {
  border-color: var(--rose);
  transform: translateY(-2px);
  box-shadow: 0 12px 24px -14px rgba(31, 48, 37, 0.25);
}
.lp-chip.is-file a { background: linear-gradient(90deg, rgba(200, 57, 94, 0.04), #fff 60%); }
.lp-chip-icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--cream, #FCFAF5);
  border: 1px solid #efe9df;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}
.lp-chip.is-file .lp-chip-icon { background: rgba(200, 57, 94, 0.12); border-color: rgba(200, 57, 94, 0.3); }
.lp-chip-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.lp-chip-kind {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.lp-chip-body strong {
  font-family: 'Manrope', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lp-chip-body em {
  font-style: normal;
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--rose);
  text-transform: uppercase;
}

/* BIG JUMP NAV prev/next */
.lp-bigjump {
  max-width: 1100px;
  margin: 2.5rem auto 1rem;
  width: calc(100% - 2 * clamp(1rem, 4vw, 3rem));
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  padding-top: 1.5rem;
  border-top: 1px dashed rgba(31, 48, 37, 0.18);
}
@media (max-width: 720px) { .lp-bigjump { grid-template-columns: 1fr; } }
.lp-bigjump-link {
  display: flex;
  align-items: center;
  gap: 1.1rem;
  padding: 1.2rem 1.4rem;
  background: #fff;
  border: 1px solid #efe9df;
  border-radius: 16px;
  text-decoration: none;
  color: var(--ink);
  position: relative;
  overflow: hidden;
  transition: border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}
.lp-bigjump-link::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(200, 57, 94, 0.04) 0%, transparent 50%);
  opacity: 0;
  transition: opacity .25s ease;
}
.lp-bigjump-link:hover {
  border-color: var(--rose);
  transform: translateY(-3px);
  box-shadow: 0 18px 40px -18px rgba(200, 57, 94, 0.4);
}
.lp-bigjump-link:hover::before { opacity: 1; }
.lp-bigjump-next { text-align: right; flex-direction: row-reverse; }
.lp-bigjump-link span { display: flex; flex-direction: column; gap: 3px; min-width: 0; position: relative; }
.lp-bigjump-link small {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--rose);
  font-weight: 600;
}
.lp-bigjump-link strong {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--ink);
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  letter-spacing: -0.01em;
}
.lp-bigjump-arrow {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--rose);
  font-weight: 600;
  background: rgba(200, 57, 94, 0.1);
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  transition: background .25s ease, transform .25s ease;
}
.lp-bigjump-link:hover .lp-bigjump-arrow {
  background: var(--rose);
  color: #fff;
}
.lp-bigjump-link:not(.lp-bigjump-next):hover .lp-bigjump-arrow { transform: translateX(-4px); }
.lp-bigjump-link.lp-bigjump-next:hover .lp-bigjump-arrow { transform: translateX(4px); }
.lp-bigjump-link.is-disabled { opacity: 0.45; pointer-events: none; }
.lp-bigjump-link.is-disabled strong { font-style: italic; color: var(--ink-soft); }
.lp-bigjump-link.is-disabled .lp-bigjump-arrow { background: rgba(31, 48, 37, 0.08); color: var(--ink-soft); }

/* DOCK STICKY EN BAS */
.lp-dock {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 50;
  background: rgba(31, 48, 37, 0.96);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(252, 250, 245, 0.1);
}
.lp-dock-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0.85rem clamp(1rem, 3vw, 2rem);
  display: flex;
  align-items: center;
  gap: 1.2rem;
  flex-wrap: wrap;
}
.lp-dock-status { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; }
.lp-dock-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 0.9rem;
  border-radius: 99px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: rgba(252, 250, 245, 0.08);
  color: rgba(252, 250, 245, 0.92);
}
.lp-dock-pill.is-done {
  background: var(--rose);
  color: #fff;
  box-shadow: 0 0 16px -2px rgba(200, 57, 94, 0.7);
}
.lp-dock-pill.is-progress {
  background: transparent;
  color: var(--rose);
  border: 1px dashed rgba(200, 57, 94, 0.6);
}
.lp-dock-meta {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: rgba(252, 250, 245, 0.55);
  letter-spacing: 0.05em;
}
.lp-dock-complete { margin-left: auto; }
.lp-dock-complete button {
  background: linear-gradient(135deg, var(--rose) 0%, #E8587A 100%);
  color: #fff;
  border: 0;
  padding: 0.8rem 1.4rem 0.8rem 1.2rem;
  border-radius: 99px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;
  box-shadow:
    0 8px 20px -8px rgba(200, 57, 94, 0.6),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
  position: relative;
  letter-spacing: -0.01em;
}
.lp-dock-complete button > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  font-size: 0.85rem;
}
.lp-dock-complete button:hover {
  transform: translateY(-2px);
  filter: brightness(1.05);
  box-shadow:
    0 12px 28px -10px rgba(200, 57, 94, 0.7),
    inset 0 1px 0 rgba(255, 255, 255, 0.25);
}
.lp-dock-complete button:active { transform: translateY(-1px); }

.lp-dock-drawer-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.75rem 1.1rem;
  border: 1px solid rgba(252, 250, 245, 0.22);
  background: rgba(252, 250, 245, 0.04);
  border-radius: 99px;
  color: #FCFAF5;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, transform .2s ease;
  letter-spacing: -0.005em;
}
.lp-dock-drawer-trigger:hover {
  background: rgba(252, 250, 245, 0.1);
  border-color: var(--rose);
  transform: translateY(-1px);
}
.lp-dock-drawer-count {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
  color: #fff;
  background: var(--rose);
  padding: 3px 9px;
  border-radius: 99px;
  letter-spacing: 0.04em;
  box-shadow: 0 0 12px -2px rgba(200, 57, 94, 0.6);
}
/* hide auto-margin when complete absent */
.lp-dock-status + .lp-dock-drawer-trigger { margin-left: auto; }

/* DRAWER */
.lp-drawer-input { position: absolute; opacity: 0; pointer-events: none; }
.lp-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(13, 24, 20, 0.55);
  opacity: 0;
  pointer-events: none;
  z-index: 60;
  transition: opacity .25s ease;
}
.lp-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(420px, 90vw);
  background: #FCFAF5;
  border-left: 1px solid #efe9df;
  z-index: 70;
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(0.7, 0, 0.3, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -20px 0 50px -10px rgba(13, 24, 20, 0.35);
  overflow-y: auto;
}
.lp-drawer-input:checked ~ .lp-drawer-overlay {
  opacity: 1;
  pointer-events: auto;
}
.lp-drawer-input:checked ~ .lp-drawer { transform: translateX(0); }

.lp-drawer-head {
  padding: 1.5rem 1.4rem 1rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid #efe9df;
}
.lp-drawer-eyebrow {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--rose);
  text-transform: uppercase;
}
.lp-drawer-title {
  font-family: 'Fraunces', serif;
  font-size: 1.4rem;
  font-weight: 500;
  margin: 0.3rem 0 0.3rem;
  color: var(--ink);
  line-height: 1.2;
}
.lp-drawer-meta {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  color: var(--ink-soft);
  margin: 0;
  letter-spacing: 0.05em;
}
.lp-drawer-close {
  cursor: pointer;
  font-family: 'DM Mono', monospace;
  font-size: 1rem;
  color: var(--ink-soft);
  background: var(--cream, #FCFAF5);
  border: 1px solid #efe9df;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color .15s ease, border-color .15s ease;
}
.lp-drawer-close:hover { color: var(--rose); border-color: var(--rose); }

.lp-drawer-progress {
  appearance: none;
  -webkit-appearance: none;
  width: calc(100% - 2.8rem);
  height: 4px;
  border: 0;
  background: rgba(31, 48, 37, 0.08);
  border-radius: 99px;
  margin: 1.2rem 1.4rem 0.4rem;
  overflow: hidden;
}
.lp-drawer-progress::-webkit-progress-bar { background: rgba(31, 48, 37, 0.08); border-radius: 99px; }
.lp-drawer-progress::-webkit-progress-value { background: linear-gradient(90deg, var(--rose), #E8587A); border-radius: 99px; }
.lp-drawer-progress::-moz-progress-bar { background: linear-gradient(90deg, var(--rose), #E8587A); border-radius: 99px; }

.lp-drawer-list {
  list-style: none;
  margin: 0;
  padding: 0.6rem 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.lp-drawer-item a {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 0.8rem;
  align-items: center;
  padding: 0.75rem 0.8rem;
  border-radius: 8px;
  text-decoration: none;
  color: var(--ink);
  transition: background .12s ease;
}
.lp-drawer-item a:hover { background: rgba(31, 48, 37, 0.04); }
.lp-drawer-mark {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--cream, #FCFAF5);
  border: 1px solid #efe9df;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  font-weight: 600;
  color: var(--ink-soft);
  flex-shrink: 0;
}
.lp-drawer-item.is-done .lp-drawer-mark { background: var(--rose); color: #fff; border-color: var(--rose); }
.lp-drawer-item.is-started .lp-drawer-mark { border-color: var(--rose); color: var(--rose); background: rgba(200, 57, 94, 0.08); }
.lp-drawer-item.is-current a {
  background: rgba(200, 57, 94, 0.08);
  border-left: 3px solid var(--rose);
  padding-left: calc(0.8rem - 3px);
}
.lp-drawer-item.is-current .lp-drawer-mark { background: var(--rose); color: #fff; border-color: var(--rose); }
.lp-drawer-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.lp-drawer-text strong {
  font-family: 'Manrope', sans-serif;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.lp-drawer-text em {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  font-style: normal;
  color: var(--ink-soft);
  letter-spacing: 0.05em;
}
.lp-drawer-back {
  margin: 0 1rem 1.4rem;
  display: block;
  text-align: center;
  padding: 0.8rem;
  border: 1px dashed rgba(31, 48, 37, 0.2);
  color: var(--ink-soft);
  text-decoration: none;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 8px;
  transition: color .15s ease, border-color .15s ease;
}
.lp-drawer-back:hover { color: var(--rose); border-color: var(--rose); }

.lp-cinema-footer { margin-bottom: 70px; } /* don't hide behind dock */


/* =============================================================
   Community — Hub Discord
   ============================================================= */

/* Shared CTA */
.comm-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--rose);
  color: var(--cream);
  padding: 16px 30px;
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  box-shadow: var(--shadow-rose);
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
}
.comm-cta:hover {
  background: var(--rose-deep);
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(200, 57, 94, 0.35);
}
.comm-cta span { font-size: 12px; }

/* Hero */
.comm-hero {
  margin-bottom: 64px;
  max-width: 680px;
}
.comm-hero-caveat {
  display: block;
  font-family: 'Caveat', cursive;
  font-weight: 600;
  font-size: clamp(28px, 3vw, 38px);
  color: var(--rose);
  line-height: 1.1;
  margin-bottom: 8px;
}
.comm-hero-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(40px, 5.5vw, 60px);
  font-weight: 400;
  letter-spacing: -0.025em;
  line-height: 1.02;
  color: var(--ink);
  margin: 0 0 18px;
}
.comm-hero-title em { font-style: italic; color: var(--rose); }
.comm-hero-sub {
  font-family: 'Manrope', sans-serif;
  font-size: 18px;
  color: var(--ink-soft);
  line-height: 1.6;
  margin-bottom: 28px;
}
.comm-hero-note {
  display: block;
  margin-top: 16px;
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* Section scaffold */
.comm-section { margin-bottom: 64px; }
.comm-section-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(26px, 3.4vw, 36px);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--ink);
  margin: 0 0 28px;
}
.comm-section-title em { font-style: italic; color: var(--rose); }

/* Channels grid */
.comm-channels {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 640px) { .comm-channels { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 960px) { .comm-channels { grid-template-columns: repeat(4, 1fr); } }
.comm-channel {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 22px 24px;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.comm-channel:hover {
  border-color: rgba(200, 57, 94, 0.3);
  transform: translateY(-2px);
  box-shadow: var(--shadow-soft);
}
.comm-channel-name {
  display: block;
  font-family: 'DM Mono', monospace;
  font-size: 15px;
  font-weight: 500;
  color: var(--rose);
  margin-bottom: 10px;
}
.comm-channel-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-soft);
}

/* Steps */
.comm-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 760px) { .comm-steps { grid-template-columns: repeat(3, 1fr); } }
.comm-step {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 28px 26px;
}
.comm-step-num {
  display: inline-block;
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 34px;
  font-weight: 500;
  color: var(--rose-pale);
  line-height: 1;
  margin-bottom: 14px;
}
.comm-step-title {
  font-family: 'Fraunces', serif;
  font-size: 21px;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 8px;
}
.comm-step-desc {
  font-family: 'Manrope', sans-serif;
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink-soft);
}

/* Rules */
.comm-rules {
  list-style: none;
  display: grid;
  gap: 12px;
  max-width: 720px;
}
.comm-rule {
  position: relative;
  padding: 16px 20px 16px 48px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  font-family: 'Manrope', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink);
}
.comm-rule::before {
  content: "✦";
  position: absolute;
  left: 20px;
  top: 16px;
  color: var(--rose);
  font-size: 14px;
}

/* Wins */
.comm-wins {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 760px) { .comm-wins { grid-template-columns: repeat(3, 1fr); } }
.comm-win {
  background: var(--tableau);
  color: var(--cream);
  border-radius: 16px;
  padding: 28px 26px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.comm-win-quote {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 17px;
  line-height: 1.5;
  margin: 0;
  flex: 1;
}
.comm-win-author {
  font-family: 'Manrope', sans-serif;
  font-size: 13px;
  line-height: 1.4;
  border-top: 1px solid var(--grid-dark);
  padding-top: 14px;
}
.comm-win-author strong {
  display: block;
  color: var(--rose-light);
  font-weight: 600;
  font-size: 14px;
}
.comm-win-author span { color: rgba(252, 250, 245, 0.65); }

/* Outro */
.comm-outro {
  background: var(--cream-warm);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: clamp(36px, 5vw, 56px);
  text-align: center;
  margin-bottom: 24px;
}
.comm-outro-title {
  font-family: 'Fraunces', serif;
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 24px;
}
.comm-outro-title em { font-style: italic; color: var(--rose); }
