/* Pro Gallery viewer — Mon Carnet
 * Branding par tenant/galerie via CSS variables (brand-primary, brand-accent, brand-logo).
 * Esthétique de base : papier crème + encre profonde + accent personnalisable.
 */
:root {
  --pg-bg: #fafaf7;
  --pg-paper: #ffffff;
  --pg-ink: #1a1814;
  --pg-ink-soft: #6b665e;
  --pg-line: #e5e1d7;
  --pg-primary: #a16f3a;
  --pg-on-primary: #ffffff; /* texte lisible sur --pg-primary ; recalculé en JS selon la marque */
  --pg-accent: #1a1814;
  --pg-radius: 4px;
  --pg-serif: "Cormorant Garamond", Georgia, serif;
  --pg-sans: "Inter", system-ui, -apple-system, sans-serif;
  /* Design tokens "Onyx & Ivoire" (premium) */
  --c-void: #0a0a0a;
  --c-void-soft: #14110e;
  --c-cream: #faf9f6;
  --c-line: #e8e4dc;
  --c-gold: #9c6b32;
  --c-gold-light: #c49a5a;
  --ease-enter: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-exit:  cubic-bezier(0.4, 0, 0.2, 1);
  --ease-expo:  cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 280ms;
  --dur-mid:  500ms;
  --dur-slow: 800ms;
  --dur-kb:   22s;
}
::selection { background: var(--pg-primary); color: #fff; }
::-moz-selection { background: var(--pg-primary); color: #fff; }
html { scrollbar-width: thin; scrollbar-color: rgba(0,0,0,0.25) transparent; }
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.18); border-radius: 999px; }
::-webkit-scrollbar-track { background: transparent; }
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--pg-bg);
  color: var(--pg-ink);
  font-family: var(--pg-sans);
  font-size: 16px;
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden; /* évite scroll horizontal parasite sur mobile */
  transition: background 320ms ease;
}
/* ===== TEMPLATES COULEUR (8 presets nommés) =====
 * Chaque template définit un set complet de tokens CSS harmonisés.
 * Priorité sur le mode dark/light auto (les color pickers libres restent
 * actifs si template = null ou "custom"). */

body[data-template="or-dore"] {
  --pg-bg: #faf9f6;
  --pg-paper: #ffffff;
  --pg-ink: #1a1814;
  --pg-ink-soft: #6b665e;
  --pg-line: #c8c4ba; /* WCAG: 1.65:1 vs bg (was #e5e1d7 = 1.24) */
  --pg-primary: #a16f3a;
  --pg-accent: #c49a5a;
}
body[data-template="champagne"] {
  --pg-bg: #f8f3ea;
  --pg-paper: #fdfaf3;
  --pg-ink: #2c241a;
  --pg-ink-soft: #7a6a55;
  --pg-line: #c8baa8; /* WCAG: 1.72:1 vs bg (was #e8dccc = 1.22) */
  --pg-primary: #8a6520; /* WCAG: 4.79:1 vs bg (was #a07830 = 3.64 — FAIL small text) */
  --pg-accent: #c49a5a;
}
body[data-template="sauge"] {
  --pg-bg: #e8eae0;
  --pg-paper: #f3f4ee;
  --pg-ink: #2b3526;
  --pg-ink-soft: #5a6653;
  --pg-line: #adb5a4; /* WCAG: 1.74:1 vs bg (was #ccd0c4 = 1.29) */
  --pg-primary: #4d5c42; /* WCAG: 5.91:1 vs bg (was #6b7b5e = 3.74 — FAIL small text) */
  --pg-accent: #4e5f42;
}
body[data-template="bordeaux"] {
  --pg-bg: #f5ecec;
  --pg-paper: #fdfafa;
  --pg-ink: #3b1015;
  --pg-ink-soft: #7a4a51;
  --pg-line: #c8b8b8; /* WCAG: 1.64:1 vs bg (was #e0cfd0 = 1.29) */
  --pg-primary: #6f1f2e;
  --pg-accent: #a03040;
}
body[data-template="marine"] {
  --pg-bg: #e8edf3;
  --pg-paper: #f5f7fa;
  --pg-ink: #0e1a2e;
  --pg-ink-soft: #4a5a74;
  --pg-line: #a8b5c8; /* WCAG: 1.76:1 vs bg (was #c8d2e0 = 1.30) */
  --pg-primary: #1f3a5f;
  --pg-accent: #2a4d7a;
}
body[data-template="rose-poudre"] {
  --pg-bg: #faf3f3;
  --pg-paper: #fffafa;
  --pg-ink: #3a2b2b;
  --pg-ink-soft: #7a6060;
  --pg-line: #c8b0b0; /* WCAG: 1.86:1 vs bg (was #e8d8d8 = 1.26) */
  --pg-primary: #8a3a3a; /* WCAG: 6.98:1 vs bg (was #b06060 = 4.09 — FAIL small text) */
  --pg-accent: #b06b6b;
}
body[data-template="charbon"] {
  --pg-bg: #1a1814;
  --pg-paper: #252220;
  --pg-ink: #faf9f6;
  --pg-ink-soft: #c8c3bc;
  --pg-line: rgba(255,255,255,0.20); /* WCAG: ~1.88:1 vs bg (was 0.10 = 1.34) */
  --pg-primary: #c49a5a;
  --pg-accent: #a07c3d;
}
body[data-template="ivoire"] {
  --pg-bg: #f5f0e8;
  --pg-paper: #fdf9f2;
  --pg-ink: #2e2720;
  --pg-ink-soft: #706858; /* WCAG: 4.86:1 vs bg (was #7a7060 = 4.29 — FAIL) */
  --pg-line: #c5bcaa; /* WCAG: 1.66:1 vs bg (was #e0d8c8 = 1.25) */
  --pg-primary: #8a6b35;
  --pg-accent: #c4a86a;
}

/* Les templates dark héritent des styles dark (fav, overlays...) */
body[data-template="charbon"] .pg-tile-fav { background: rgba(0,0,0,0.5); color: rgba(255,255,255,0.9); }
body[data-template="charbon"] .pg-tile-fav.active { background: var(--pg-primary); color: #fff; }
body[data-template="charbon"][data-theme="premium"] {
  --paper: var(--pg-bg);
  --tech: rgba(255,255,255,0.06);
  --ink: #faf9f6;
  --ink-soft: #d4d0c8;
  --ink-muted: #a39e95;
  --line: rgba(255,255,255,0.20); /* WCAG: ~1.88:1 vs dark bg (was 0.12) */
}
/* Toolbar premium sur charbon : fond sombre + texte clair */
body[data-template="charbon"][data-theme="premium"] .pg-actions {
  background: rgba(20, 18, 14, 0.94);
}
/* Sticky CTA sur charbon : contraste minimal avec fond sombre */
body[data-template="charbon"] .pg-fav-cta {
  background: rgba(250, 249, 246, 0.12);
  border-top: 1px solid rgba(255,255,255,0.15);
}
/* Bouton CTA charbon: white on gold #c49a5a = 2.59:1 FAIL — texte sombre à la place */
body[data-template="charbon"] .pg-fav-cta-btn {
  color: #1a1814;
}
/* Toolbar buttons hover charbon : évite fond clair sur fond clair */
body[data-template="charbon"][data-theme="premium"] .pg-actions button:hover {
  background: rgba(255,255,255,0.14);
  color: #fff;
}
/* Filter banner charbon : teinte or invisible sur sombre */
body[data-template="charbon"] .pg-filter-banner {
  background: rgba(196,154,90,0.10);
  border-bottom-color: var(--pg-line);
}
/* Chapitres actif charbon : eviter fond clair + texte blanc = invisible */
body[data-template="charbon"] .pg-chapters button.active {
  background: var(--pg-primary);
  color: #fff;
  border-color: var(--pg-primary);
}
body[data-bg="dark"] .pg-chapters button.active {
  background: var(--pg-primary);
  color: #fff;
  border-color: var(--pg-primary);
}
/* Bundle banner charbon : fond clair (--pg-ink=cream) + texte white = invisible */
body[data-template="charbon"] .pg-bundle-banner,
body[data-bg="dark"] .pg-bundle-banner {
  background: rgba(250,249,246,0.95);
  color: #1a1814;
}
body[data-template="charbon"] .pg-bundle-close,
body[data-bg="dark"] .pg-bundle-close {
  color: #1a1814;
}
/* pg-search-input hardcodé #fff — doit s'adapter au template */
body[data-template="charbon"] .pg-search-input {
  background: rgba(255,255,255,0.08);
  color: var(--pg-ink);
  border-color: var(--pg-line);
}
body[data-template="charbon"] .pg-search-input::placeholder { color: var(--pg-ink-soft); }

/* Mode dark auto quand le photographe choisit un fond sombre — l'encre passe
   en clair pour préserver le contraste sans micro-réglages. */
body[data-bg="dark"] {
  --pg-ink: #faf9f6;
  --pg-ink-soft: #b6b1a8;
  --pg-line: rgba(255,255,255,0.20); /* WCAG: ~1.88:1 vs dark bg (was 0.10) */
  --pg-paper: rgba(255,255,255,0.04);
  color: var(--pg-ink);
}
body[data-bg="dark"] .pg-tile-fav { background: rgba(0,0,0,0.5); color: rgba(255,255,255,0.9); }
body[data-bg="dark"] .pg-tile-fav.active { background: var(--pg-primary); color: #fff; }
body[data-bg="dark"][data-theme="premium"] {
  --paper: var(--pg-bg);
  --tech: rgba(255,255,255,0.06);
  --ink: #faf9f6;
  --ink-soft: #d4d0c8;
  --ink-muted: #a39e95;
  --line: rgba(255,255,255,0.20); /* WCAG: ~1.88:1 vs dark bg (was 0.12) */
}
/* data-bg="dark" : même corrections toolbar + CTA que charbon */
body[data-bg="dark"][data-theme="premium"] .pg-actions {
  background: rgba(20, 18, 14, 0.94);
}
body[data-bg="dark"][data-theme="premium"] .pg-actions button:hover {
  background: rgba(255,255,255,0.14);
  color: #fff;
}
body[data-bg="dark"] .pg-fav-cta {
  background: rgba(250, 249, 246, 0.12);
  border-top: 1px solid rgba(255,255,255,0.15);
}
body[data-bg="dark"] .pg-fav-cta-btn { color: #1a1814; }
body[data-bg="dark"] .pg-search-input {
  background: rgba(255,255,255,0.08);
  color: var(--pg-ink);
  border-color: var(--pg-line);
}
body[data-bg="dark"] .pg-search-input::placeholder { color: var(--pg-ink-soft); }
body[data-bg="dark"] .pg-filter-banner {
  background: rgba(196,154,90,0.10);
  border-bottom-color: var(--pg-line);
}
body.pg-loading #pg-app { opacity: 0; }
#pg-app { transition: opacity .4s ease; }
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; }

/* Boot screen */
#pg-boot {
  position: fixed; inset: 0; display: grid; place-items: center;
  background: var(--pg-bg); z-index: 9999; transition: opacity .4s ease;
}
#pg-boot.hide { opacity: 0; pointer-events: none; }
.pg-boot-mark {
  width: 32px; height: 32px; border-radius: 50%;
  border: 2px solid var(--pg-line); border-top-color: var(--pg-primary);
  animation: pg-spin .8s linear infinite;
}
@keyframes pg-spin { to { transform: rotate(360deg); } }

/* === LOGIN === */
.pg-login {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
}
.pg-login-card {
  background: var(--pg-paper); padding: 56px 48px;
  border-radius: var(--pg-radius); border: 1px solid var(--pg-line);
  max-width: 420px; width: 100%; text-align: center;
}
.pg-login-card .pg-brand {
  height: 48px; margin-bottom: 24px;
  background: center/contain no-repeat;
}
.pg-login-card .pg-title {
  font-family: var(--pg-serif); font-weight: 400; font-style: italic;
  font-size: 32px; margin: 0 0 8px;
}
.pg-login-card .pg-subtitle {
  color: var(--pg-ink-soft); margin: 0 0 32px; font-size: 15px;
}
.pg-login-form { display: flex; flex-direction: column; gap: 12px; text-align: left; }
.pg-login-form label {
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--pg-ink-soft);
}
.pg-login-form input {
  padding: 14px 16px; border: 1px solid var(--pg-line);
  background: var(--pg-bg); color: var(--pg-ink);
  border-radius: var(--pg-radius); font-size: 16px;
}
.pg-login-form input:focus {
  outline: 2px solid var(--pg-primary); outline-offset: 1px; border-color: var(--pg-primary);
}
.pg-login-form button {
  background: var(--pg-ink); color: var(--pg-paper);
  border: 0; padding: 14px; border-radius: var(--pg-radius);
  font-size: 15px; letter-spacing: 0.04em; margin-top: 12px;
}
.pg-login-form button:hover { background: var(--pg-primary); color: var(--pg-on-primary); }
.pg-error {
  color: #b94a4a; font-size: 14px; margin-top: 8px;
}

/* === GALLERY === */
.pg-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--pg-bg); border-bottom: 1px solid var(--pg-line);
  padding: 16px 24px;
  display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px;
}
.pg-header .pg-brand {
  height: 36px; width: 80px; background: left center/contain no-repeat;
}
.pg-title-block { text-align: center; }
.pg-title-block .pg-title {
  font-family: var(--pg-serif); font-weight: 400; font-style: italic;
  font-size: 22px; margin: 0; color: var(--pg-ink);
}
.pg-title-block .pg-subtitle {
  font-size: 12px; color: var(--pg-ink-soft); margin: 2px 0 0;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.pg-actions { display: flex; gap: 8px; }
.pg-actions button {
  background: var(--pg-paper); border: 1px solid var(--pg-line);
  padding: 8px 14px; border-radius: 999px;
  font-size: 14px; display: inline-flex; align-items: center; gap: 6px;
}
.pg-actions button:hover { border-color: var(--pg-primary); }
.pg-actions button:focus-visible { outline: 2px solid var(--pg-primary); outline-offset: 2px; }
.pg-actions .ico { color: var(--pg-primary); font-size: 16px; }
.pg-face-btn.active { background: var(--pg-primary); color: white; border-color: var(--pg-primary); }
.pg-proofing-btn { background: var(--pg-primary); color: white; border-color: var(--pg-primary); }
.pg-proofing-btn:hover { filter: brightness(1.08); }
.pg-download-btn { padding: 8px 14px; }
.pg-lb-download {
  background: rgba(255,255,255,0.08); color: white;
  border: 0; padding: 10px 20px; border-radius: 999px;
  font-size: 14px;
}
.pg-lb-download:hover { background: rgba(255,255,255,0.18); }

.pg-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  padding: 24px;
  max-width: 1600px; margin: 0 auto;
}

.pg-group-banner {
  max-width: 1600px; margin: 16px auto 0;
  padding: 14px 24px;
  background: var(--pg-paper); border: 1px solid var(--pg-line);
  border-left: 4px solid var(--pg-primary); border-radius: 6px;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 14px;
}
.pg-group-banner.reached { border-left-color: #4a8b6b; background: rgba(74, 139, 107, 0.06); }
.pg-group-banner strong { color: var(--pg-primary); }
.pg-group-banner .pg-bar {
  flex: 1; max-width: 200px; height: 6px; border-radius: 3px;
  background: var(--pg-line); overflow: hidden; margin: 0 16px;
}
.pg-group-banner .pg-bar > span {
  display: block; height: 100%; background: var(--pg-primary);
  transition: width .4s ease;
}
@media (min-width: 1024px) {
  .pg-grid { grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); }
}

.pg-tile {
  position: relative; cursor: pointer;
  background: center/cover no-repeat #ddd;
  border-radius: var(--pg-radius);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}
.pg-tile:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.08); }
.pg-tile-img {
  width: 100%; height: auto; display: block;
  opacity: 0; transition: opacity .4s ease;
  /* v103 — Bloque long-press iOS/Android "Enregistrer l'image" qui sauvait
     le webp basse qualité. -webkit-touch-callout désactive le menu natif
     sans bloquer le clic (vs pointer-events: none qui empêche les events). */
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
}
.pg-tile { -webkit-touch-callout: none; -webkit-user-select: none; user-select: none; }
.pg-tile-img.loaded { opacity: 1; }
.pg-tile-fav {
  position: absolute; top: 8px; right: 8px;
  background: rgba(255,255,255,0.92); border: 0;
  width: 36px; height: 36px; border-radius: 50%;
  display: grid; place-items: center; font-size: 18px;
  color: var(--pg-ink-soft);
  opacity: 0; transition: opacity .2s ease;
}
.pg-tile:hover .pg-tile-fav, .pg-tile-fav.active { opacity: 1; }
.pg-tile-fav.active { color: var(--pg-primary); background: white; }

.pg-footer {
  padding: 32px 24px;
  text-align: center;
  color: var(--pg-ink-soft); font-size: 13px;
  border-top: 1px solid var(--pg-line);
  display: flex; justify-content: space-between; max-width: 1600px; margin: 0 auto;
}
.pg-credit {
  font-family: var(--pg-serif); font-style: italic;
}

/* === LIGHTBOX immersive (refonte 2026-05-10) === */
.pg-lb {
  position: fixed; inset: 0; z-index: 200;
  background: var(--pg-accent, #0a0a0a);
  display: grid; grid-template-rows: auto 1fr auto;
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-mid, 500ms) var(--ease-enter);
  overflow: hidden;
}
.pg-lb.open { opacity: 1; pointer-events: auto; }
/* Backdrop : photo courante en bg ultra-flou, brightness baissé. */
.pg-lb-bg-blur {
  position: absolute; inset: -8%;
  background-size: cover; background-position: center;
  background-repeat: no-repeat;
  filter: blur(48px) brightness(0.32) saturate(0.85);
  opacity: 0; transform: scale(1.08);
  transition: opacity 700ms var(--ease-enter), background-image 0ms;
  z-index: 0; pointer-events: none;
}
.pg-lb.open .pg-lb-bg-blur { opacity: 1; }
/* Topbar : compteur centré + close à droite */
.pg-lb-topbar {
  position: relative; z-index: 5;
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 22px 28px;
  color: rgba(255,255,255,0.82);
}
.pg-lb-pos {
  grid-column: 2;
  font-family: var(--pg-sans);
  font-size: 11px; letter-spacing: 0.36em; text-transform: uppercase;
  font-variant-numeric: tabular-nums;
  opacity: 0.7;
}
.pg-lb-close {
  grid-column: 3; justify-self: end;
  background: transparent; color: rgba(255,255,255,0.7);
  border: 0; width: 40px; height: 40px;
  display: grid; place-items: center;
  cursor: pointer; transition: color 200ms var(--ease-enter), transform 200ms var(--ease-enter);
}
.pg-lb-close:hover { color: #fff; transform: rotate(90deg); }
.pg-lb-prev, .pg-lb-next {
  position: absolute; top: 50%; transform: translateY(-50%);
  z-index: 5;
  background: transparent; color: rgba(255,255,255,0.65);
  border: 0; width: 56px; height: 56px;
  display: grid; place-items: center;
  cursor: pointer; transition: color 200ms var(--ease-enter), background 200ms var(--ease-enter);
}
.pg-lb-prev:hover, .pg-lb-next:hover {
  color: #fff;
  background: rgba(255,255,255,0.04);
}
.pg-lb-prev { left: 16px; }
.pg-lb-next { right: 16px; }
.pg-lb-prev svg, .pg-lb-next svg { width: 28px; height: 28px; }
.pg-lb-close svg, .pg-lb-topbar [data-icon] svg { width: 20px; height: 20px; }
/* Stage : crossfade double-buffer comme slideshow */
.pg-lb-stage {
  position: relative; z-index: 2;
  width: 100%; height: 100%;
  display: block;
  overflow: hidden;
  padding: 8px 88px;
}
.pg-lb-img {
  position: absolute; top: 8px; left: 88px; right: 88px; bottom: 8px;
  width: calc(100% - 176px); height: calc(100% - 16px);
  object-fit: contain;
  user-select: none; -webkit-user-drag: none;
  /* v103 — Bloque long-press save-image en lightbox. */
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  opacity: 0;
  transition: opacity 450ms var(--ease-enter);
}
.pg-lb-img.show { opacity: 1; }
.pg-lb-bottom {
  position: relative; z-index: 5;
  display: flex; justify-content: center; align-items: center; gap: 18px;
  padding: 22px 28px calc(22px + env(safe-area-inset-bottom));
  color: rgba(255,255,255,0.85);
}
.pg-lb-fav, .pg-lb-cart, .pg-lb-download {
  background: transparent; color: rgba(255,255,255,0.88);
  border: 1px solid rgba(255,255,255,0.18);
  padding: 11px 22px; border-radius: 0;
  font-size: 10px; font-family: var(--pg-sans);
  letter-spacing: 0.28em; text-transform: uppercase; font-weight: 500;
  display: inline-flex; align-items: center; gap: 10px;
  cursor: pointer;
  transition: border-color 220ms var(--ease-enter), background 220ms var(--ease-enter), color 220ms var(--ease-enter);
}
.pg-lb-fav:hover, .pg-lb-cart:hover, .pg-lb-download:hover {
  border-color: rgba(255,255,255,0.6);
  background: rgba(255,255,255,0.05);
  color: #fff;
}
.pg-lb-fav.active {
  border-color: var(--c-gold-light, var(--pg-primary, #c49a5a));
  background: transparent;
  color: var(--c-gold-light, var(--pg-primary, #c49a5a));
}
.pg-lb-fav.active svg { fill: currentColor; }
.pg-lb-cart {
  border-color: var(--c-gold-light, var(--pg-primary, #c49a5a));
  color: var(--c-gold-light, var(--pg-primary, #c49a5a));
}
.pg-lb-cart:hover {
  background: var(--c-gold-light, var(--pg-primary, #c49a5a));
  color: var(--pg-accent, #0a0a0a);
}
.pg-lb-bottom svg { width: 16px; height: 16px; }
@media (max-width: 720px) {
  /* Topbar : safe-area iOS pour le notch + croix garantie visible/cliquable. */
  .pg-lb-topbar {
    padding: calc(12px + env(safe-area-inset-top)) 16px 12px;
  }
  .pg-lb-close {
    width: 44px; height: 44px;
    background: rgba(0,0,0,0.35);
    border-radius: 50%;
    color: #fff;
  }
  .pg-lb-close:hover { transform: none; }
  .pg-lb-pos { font-size: 10px; letter-spacing: 0.28em; }
  /* Stage : moins de padding latéral, image bien centrée. */
  .pg-lb-stage { padding: 8px 12px; }
  .pg-lb-img {
    left: 12px; right: 12px; top: 4px; bottom: 4px;
    width: calc(100% - 24px); height: calc(100% - 8px);
  }
  /* Flèches plus petites, plus discrètes, posées sur fond léger. */
  .pg-lb-prev { left: 6px; } .pg-lb-next { right: 6px; }
  .pg-lb-prev, .pg-lb-next {
    width: 40px; height: 40px;
    background: rgba(0,0,0,0.35);
    border-radius: 50%;
    color: #fff;
  }
  .pg-lb-prev svg, .pg-lb-next svg { width: 22px; height: 22px; }
  /* Bottom : 3 boutons qui débordaient. Wrap + texte raccourci + plus petits. */
  .pg-lb-bottom {
    flex-wrap: wrap;
    gap: 8px;
    padding: 12px 12px calc(12px + env(safe-area-inset-bottom));
  }
  .pg-lb-fav, .pg-lb-cart, .pg-lb-download {
    padding: 9px 14px;
    font-size: 10px;
    letter-spacing: 0.18em;
    gap: 6px;
    flex: 1 1 auto;
    min-width: 0;
    justify-content: center;
  }
  .pg-lb-fav span, .pg-lb-cart span, .pg-lb-download span {
    /* Si certains labels sont trop longs, ellipsis plutôt que retour ligne. */
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  }
  .pg-lb-bottom svg { width: 14px; height: 14px; }
  /* Watermark studio discret sous les boutons (pas par-dessus). */
  .pg-lb-watermark { font-size: 10px; opacity: 0.5; }
}
/* Très petits écrans : 1 bouton par ligne pour ne plus rien rogner. */
@media (max-width: 380px) {
  .pg-lb-fav, .pg-lb-cart, .pg-lb-download { flex-basis: 100%; }
}

/* Toolbar Imprimer/Similaires/Avec moi/Commenter masquée sur mobile :
   les 4 actions ne tenaient ni en flex ni en grille sans tronquer les labels.
   Les actions essentielles (favoris, HD, ajouter au panier) restent dans
   .pg-lb-bottom. Sur mobile on déclenche les autres via un menu compact `⋯`
   ajouté dans le topbar à gauche du compteur. */
@media (max-width: 720px) {
  .pg-lb-tools { display: none !important; }
  /* Bouton menu compact "⋯" à gauche du compteur (injecté par JS). */
  .pg-lb-more {
    grid-column: 1; justify-self: start;
    background: rgba(0,0,0,0.35);
    color: #fff;
    border: 0;
    width: 40px; height: 40px;
    border-radius: 50%;
    display: grid; place-items: center;
    cursor: pointer;
    font-size: 18px; line-height: 1;
  }
  /* Menu déroulant des actions secondaires (Imprimer/Similaires/Avec moi/Comm.). */
  .pg-lb-more-menu {
    position: absolute;
    top: calc(56px + env(safe-area-inset-top));
    left: 12px;
    z-index: 6;
    background: rgba(15,12,10,0.96);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 6px;
    display: none;
    flex-direction: column;
    min-width: 180px;
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  }
  .pg-lb-more-menu.open { display: flex; }
  .pg-lb-more-menu button {
    appearance: none;
    background: transparent; color: #fff;
    border: 0;
    text-align: left;
    padding: 12px 14px;
    font: 500 13px/1.1 var(--pg-sans);
    letter-spacing: 0.06em;
    display: flex; align-items: center; gap: 12px;
    cursor: pointer;
    border-radius: 6px;
  }
  .pg-lb-more-menu button:hover, .pg-lb-more-menu button:active {
    background: rgba(255,255,255,0.08);
  }
  .pg-lb-more-menu .pg-ic svg { width: 16px; height: 16px; }
}

/* === CART DRAWER === */
.pg-cart-drawer {
  position: fixed; inset: 0; z-index: 250;
  background: rgba(20, 18, 16, 0.5);
  display: grid; justify-items: end;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.pg-cart-drawer.open { opacity: 1; pointer-events: auto; }
.pg-cart-panel {
  width: 100%; max-width: 420px; height: 100%;
  background: var(--pg-paper);
  padding: 24px; display: grid; grid-template-rows: auto auto 1fr auto;
  gap: 16px; overflow-y: auto;
  transform: translateX(20px); transition: transform .25s ease;
}
.pg-cart-drawer.open .pg-cart-panel { transform: translateX(0); }
.pg-cart-close {
  position: absolute; top: 16px; right: 16px;
  background: none; border: 0; font-size: 28px; line-height: 1;
  color: var(--pg-ink-soft); cursor: pointer;
}
.pg-cart-panel h2 {
  font-family: var(--pg-serif); font-style: italic; font-weight: 400;
  font-size: 28px; margin: 0;
}
.pg-cart-items {
  display: flex; flex-direction: column; gap: 12px;
  border-top: 1px solid var(--pg-line); padding-top: 16px;
}
.pg-cart-row {
  display: grid; grid-template-columns: 56px 1fr auto auto; gap: 12px; align-items: center;
}
.pg-cart-row .thumb {
  width: 56px; height: 56px; background: center/cover no-repeat #ddd;
  border-radius: 4px;
}
.pg-cart-row .label { font-size: 14px; }
.pg-cart-row .price { font-size: 14px; color: var(--pg-ink-soft); }
.pg-cart-row .del {
  background: none; border: 0; color: var(--pg-ink-soft);
  cursor: pointer; padding: 4px 8px;
  display: grid; place-items: center;
}
.pg-cart-row .del svg { width: 14px; height: 14px; }
.pg-cart-row .del:hover { color: var(--pg-primary); }
.pg-cart-qty { color: var(--pg-ink-soft); }
.pg-cart-foot { border-top: 1px solid var(--pg-line); padding-top: 16px; }
.pg-cart-total {
  font-size: 18px; font-weight: 500; margin-bottom: 12px; text-align: right;
}
.pg-cart-email {
  width: 100%; padding: 12px 14px; border: 1px solid var(--pg-line);
  background: var(--pg-bg); border-radius: var(--pg-radius);
  font-size: 15px; margin-bottom: 12px;
}
.pg-cart-checkout {
  width: 100%; padding: 14px; background: var(--pg-primary); color: white;
  border: 0; border-radius: var(--pg-radius); font-size: 15px;
  cursor: pointer;
}
.pg-cart-checkout:hover { filter: brightness(1.08); }
.pg-cart-checkout:disabled { opacity: 0.5; cursor: wait; }
.pg-cart-error { color: #b94a4a; font-size: 13px; margin: 8px 0 0; }
.pg-cart-fine { color: var(--pg-ink-soft); font-size: 12px; margin: 8px 0 0; text-align: center; }

/* ===== Séparateurs de chapitres (entre les photos) ===== */
.pg-chapter-divider {
  grid-column: 1 / -1;
  /* CSS columns : force pleine largeur du container colonnes */
  column-span: all;
  -webkit-column-span: all;
  display: flex; align-items: center; justify-content: center;
  padding: clamp(48px, 8vh, 120px) clamp(20px, 4vw, 80px);
  opacity: 0; transform: translateY(20px);
  transition: opacity 1.2s var(--ease-enter), transform 1.2s var(--ease-enter);
  transition-delay: 80ms;
  /* Évite que break-inside: avoid du tile parent ne soit hérité */
  break-inside: auto;
}
.pg-chapter-divider.is-visible { opacity: 1; transform: translateY(0); }
.pg-chapter-divider-inner {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 18px;
  max-width: 720px; width: 100%;
}
.pg-chapter-eyebrow {
  font-family: var(--pg-sans);
  font-size: 11px; letter-spacing: 0.42em; text-transform: uppercase;
  font-weight: 500;
  color: var(--pg-primary);
  display: inline-flex; align-items: center; gap: 14px;
}
.pg-chapter-eyebrow::before, .pg-chapter-eyebrow::after {
  content: ""; display: inline-block; width: 32px; height: 1px;
  background: currentColor; opacity: 0.5;
}
.pg-chapter-name {
  font-family: var(--pg-serif);
  font-style: italic; font-weight: 300;
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  line-height: 1;
  margin: 0;
  color: var(--pg-ink);
  letter-spacing: -0.01em;
}
.pg-chapter-rule {
  display: block; width: 56px; height: 1px;
  background: var(--pg-primary);
  opacity: 0.6;
  margin-top: 6px;
}
@media (max-width: 720px) {
  .pg-chapter-divider { padding: clamp(36px, 6vh, 80px) 20px; }
  .pg-chapter-eyebrow { font-size: 10px; letter-spacing: 0.32em; }
  .pg-chapter-eyebrow::before, .pg-chapter-eyebrow::after { width: 22px; }
}

/* === MODE CINÉMA — scroll-snapped fullscreen === */
.pg-cinema {
  position: fixed; inset: 0; z-index: 340;
  background: var(--pg-accent, #0a0a0a);
  opacity: 0; pointer-events: none;
  transition: opacity 500ms var(--ease-enter);
}
.pg-cinema.open { opacity: 1; pointer-events: auto; }
.pg-cinema-scroll {
  position: absolute; inset: 0;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
}
.pg-cinema-scroll::-webkit-scrollbar { display: none; }
.pg-cinema-slide {
  scroll-snap-align: start;
  scroll-snap-stop: always;
  width: 100%; height: 100vh; height: 100dvh;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  box-sizing: border-box;
  overflow: hidden;
}
.pg-cinema-slide img {
  display: block;
  width: auto; height: auto;
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  opacity: 0;
  transition: opacity 700ms var(--ease-enter);
}
.pg-cinema-slide img[src] { opacity: 1; }
@media (max-width: 720px) {
  .pg-cinema-slide { padding: 12px; }
}
.pg-cinema-close {
  position: fixed; top: 22px; right: 28px; z-index: 5;
  background: transparent; color: rgba(255,255,255,0.6);
  border: 0; width: 40px; height: 40px;
  display: grid; place-items: center; cursor: pointer;
  transition: color 200ms var(--ease-enter), transform 200ms var(--ease-enter), opacity 600ms;
}
.pg-cinema-close svg { width: 22px; height: 22px; }
.pg-cinema-close:hover { color: #fff; transform: rotate(90deg); }
.pg-cinema-pos {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 5;
  color: rgba(255,255,255,0.55);
  font-family: var(--pg-sans);
  font-size: 10px; letter-spacing: 0.42em; text-transform: uppercase;
  font-variant-numeric: tabular-nums;
}
.pg-cinema-hint {
  position: fixed; top: 32px; left: 50%; transform: translateX(-50%);
  z-index: 5;
  color: rgba(255,255,255,0.55);
  font-family: var(--pg-serif); font-style: italic;
  font-size: 14px; letter-spacing: 0.04em;
  pointer-events: none;
  opacity: 1; transition: opacity 1.2s var(--ease-enter);
  text-align: center;
}
.pg-cinema-hint.fade-out { opacity: 0; }
@media (max-width: 720px) {
  .pg-cinema-slide { padding: 12px; }
  .pg-cinema-hint { font-size: 12px; top: 20px; padding: 0 20px; }
}

/* === SLIDESHOW === */
.pg-slideshow {
  position: fixed; inset: 0; z-index: 320;
  background: #000;
  display: grid; grid-template-rows: 1fr auto;
  opacity: 0; pointer-events: none;
  transition: opacity .4s ease;
}
.pg-slideshow.open { opacity: 1; pointer-events: auto; }
.pg-ss-stage {
  position: relative; width: 100%; height: 100%; overflow: hidden;
}
.pg-ss-stage img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: contain;
  opacity: 0;
  transition: opacity 1.4s var(--ease-enter), transform 7s cubic-bezier(0.25, 0.1, 0.25, 1);
  transform: scale(1.06);
  transform-origin: center;
}
.pg-ss-stage img.show {
  opacity: 1;
  transform: scale(1);
}
.pg-ss-close {
  position: absolute; top: 24px; right: 24px;
  background: transparent; color: rgba(255,255,255,0.7);
  border: 0; width: 44px; height: 44px;
  display: grid; place-items: center;
  cursor: pointer; z-index: 10;
  transition: color 200ms var(--ease-enter), transform 200ms var(--ease-enter);
}
.pg-ss-close svg { width: 20px; height: 20px; }
.pg-ss-close:hover { color: #fff; transform: rotate(90deg); }
.pg-ss-controls {
  display: flex; align-items: center; justify-content: center; gap: 24px;
  padding: 16px; color: rgba(255,255,255,0.85);
  background: linear-gradient(transparent, rgba(0,0,0,0.6));
}
.pg-ss-controls button {
  background: transparent; color: rgba(255,255,255,0.75);
  border: 0; width: 44px; height: 44px;
  display: grid; place-items: center;
  cursor: pointer;
  transition: color 200ms var(--ease-enter), background 200ms var(--ease-enter);
}
.pg-ss-controls button svg { width: 22px; height: 22px; }
.pg-ss-controls button:hover { color: #fff; background: rgba(255,255,255,0.06); }
.pg-ss-pos {
  font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase;
  font-variant-numeric: tabular-nums; opacity: 0.55;
  margin-left: 12px;
}

/* === GENERIC MODAL (proofing, etc.) === */
.pg-modal {
  position: fixed; inset: 0; z-index: 280;
  background: rgba(20, 18, 16, 0.65);
  display: grid; place-items: center;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.pg-modal.open { opacity: 1; pointer-events: auto; }
.pg-modal-card {
  position: relative; background: var(--pg-paper);
  padding: 32px 28px; border-radius: 8px;
  max-width: 480px; width: 90%;
}
.pg-modal-card h2 {
  font-family: var(--pg-serif); font-style: italic; font-weight: 400;
  font-size: 28px; margin: 0 0 12px;
}
.pg-modal-close {
  position: absolute; top: 12px; right: 12px;
  background: none; border: 0; font-size: 24px; color: var(--pg-ink-soft); cursor: pointer;
}
.pg-proofing-form { display: flex; flex-direction: column; gap: 12px; }
.pg-proofing-form label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 13px; color: var(--pg-ink-soft);
}
.pg-proofing-form input, .pg-proofing-form textarea {
  padding: 12px 14px; border: 1px solid var(--pg-line);
  background: var(--pg-bg); border-radius: var(--pg-radius);
  font-size: 15px; font-family: inherit;
}
.pg-proofing-form button {
  background: var(--pg-primary); color: white; border: 0;
  padding: 14px; border-radius: var(--pg-radius);
  font-size: 15px; cursor: pointer; margin-top: 12px;
}
.pg-proofing-hint { font-size: 12px; color: var(--pg-ink-soft); margin: 8px 0 0; text-align: center; }
.pg-proofing-count { color: var(--pg-ink-soft); margin: 0 0 20px; }

/* === BUNDLE SUGGESTION BANNER === */
.pg-bundle-banner {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 220; max-width: 560px; width: calc(100% - 48px);
  background: var(--pg-ink); color: white;
  padding: 14px 20px; border-radius: 999px;
  display: flex; align-items: center; gap: 12px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.18);
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease, transform .25s ease;
  transform: translateX(-50%) translateY(20px);
}
.pg-bundle-banner.open {
  opacity: 1; pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.pg-bundle-text { flex: 1; font-size: 14px; }
.pg-bundle-cta {
  background: var(--pg-primary); color: white; border: 0;
  padding: 8px 16px; border-radius: 999px;
  font-size: 13px; cursor: pointer; white-space: nowrap;
}
.pg-bundle-cta:hover { filter: brightness(1.08); }
.pg-bundle-close {
  background: none; border: 0; color: white;
  font-size: 18px; cursor: pointer; opacity: 0.6;
}

/* === FACE MATCH MODAL === */
.pg-face-modal {
  position: fixed; inset: 0; z-index: 300;
  background: rgba(20, 18, 16, 0.85);
  display: grid; place-items: center;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
.pg-face-modal.open { opacity: 1; pointer-events: auto; }
.pg-face-card {
  position: relative;
  background: var(--pg-paper); border-radius: 8px;
  padding: 32px 28px; max-width: 480px; width: 90%;
  text-align: center;
}
.pg-face-card h2 {
  font-family: var(--pg-serif); font-style: italic; font-weight: 400;
  font-size: 28px; margin: 0 0 12px;
}
.pg-face-card p { color: var(--pg-ink-soft); margin: 0 0 24px; font-size: 14px; }
.pg-face-close {
  position: absolute; top: 12px; right: 12px;
  background: none; border: 0; font-size: 24px; color: var(--pg-ink-soft); cursor: pointer;
}
.pg-face-actions {
  display: flex; gap: 12px; justify-content: center; margin-bottom: 16px;
}
.pg-face-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 12px 20px; border: 1px solid var(--pg-line);
  background: var(--pg-bg); border-radius: 6px;
  cursor: pointer; font-size: 14px;
}
.pg-face-btn:hover { border-color: var(--pg-primary); }
.pg-face-stage {
  margin: 16px 0; max-height: 400px; overflow: hidden;
  border-radius: 6px;
}
.pg-face-stage img, .pg-face-stage video {
  max-width: 100%; max-height: 360px; display: block; margin: 0 auto;
  border-radius: 6px;
}
.pg-face-status {
  font-size: 14px; color: var(--pg-ink-soft); min-height: 22px;
}

/* === SUCCESS PAGE === */
.pg-success {
  min-height: 100vh; display: grid; place-items: center; padding: 24px;
}
.pg-success-card {
  text-align: center; max-width: 440px; padding: 56px 40px;
  background: var(--pg-paper); border: 1px solid var(--pg-line);
  border-radius: var(--pg-radius);
}
.pg-success-mark {
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(74, 139, 107, 0.10); color: #4a8b6b;
  display: grid; place-items: center;
  margin: 0 auto 20px;
}
.pg-success-mark svg { width: 32px; height: 32px; stroke-width: 1.5; }
.pg-proofing-done { text-align: center; padding: 24px 0; }
.pg-proofing-check {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(156, 107, 50, 0.08); color: var(--pg-primary, #9c6b32);
  display: grid; place-items: center; margin: 0 auto 16px;
}
.pg-proofing-check svg { width: 28px; height: 28px; }
.pg-success-card h1 {
  font-family: var(--pg-serif); font-style: italic; font-weight: 400;
  font-size: 36px; margin: 0 0 12px;
}
.pg-success-amount {
  font-size: 18px; color: var(--pg-primary); margin: 16px 0;
}
.pg-back-btn {
  display: inline-block; margin-top: 16px;
  padding: 12px 24px; background: var(--pg-ink); color: white;
  text-decoration: none; border-radius: var(--pg-radius); font-size: 14px;
}

/* === Sprint 1 Pic-Time 2.0 === */

/* Bandeau lancement -X% sticky en haut. */
.pg-launch-banner {
  position: sticky; top: 0; z-index: 40; /* z-40 sous pg-header z-50 pour éviter overlap */
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 10px 16px;
  background: linear-gradient(90deg, var(--pg-primary), color-mix(in srgb, var(--pg-primary) 70%, #000));
  color: #fff;
  font-family: var(--pg-sans); font-size: 13px; letter-spacing: 0.06em;
  text-transform: uppercase;
}
.pg-launch-banner[hidden] { display: none; }
.pg-launch-label { opacity: 1; } /* was 0.85 = 3:1 FAIL on primary bg */
.pg-launch-pct { font-size: 16px; letter-spacing: 0.04em; }
.pg-launch-count { opacity: 1; font-variant-numeric: tabular-nums; } /* was 0.85 = 3:1 FAIL */
@media (max-width: 480px) {
  .pg-launch-banner { font-size: 11px; padding: 8px 12px; gap: 8px; flex-wrap: wrap; }
  .pg-launch-pct { font-size: 14px; }
}

/* Sticky CTA "Commander mes N favoris". */
/* v84 — FAB favoris : pill flottante bottom-right (au lieu de l'ancienne
   barre 100% width qui masquait le contenu mobile). Plus discret, premium,
   ne chevauche pas la galerie. Apparaît dès 1 favori. */
.pg-fav-cta {
  position: fixed; bottom: max(20px, env(safe-area-inset-bottom));
  right: max(20px, env(safe-area-inset-right));
  z-index: 60;
  display: inline-flex; align-items: center; gap: 12px;
  padding: 12px 18px 12px 20px;
  background: var(--pg-primary, #a16f3a);
  color: #fff;
  border-radius: 999px;
  box-shadow: 0 12px 28px rgba(26, 24, 20, 0.28), 0 4px 10px rgba(26, 24, 20, 0.18);
  font-family: var(--pg-sans); font-size: 14px; font-weight: 500;
  letter-spacing: 0.02em;
  cursor: default;
  animation: pg-cta-in 320ms cubic-bezier(.18,.89,.32,1.28);
  border: 0;
  text-decoration: none;
}
.pg-fav-cta[hidden] { display: none; }
@keyframes pg-cta-in {
  from { transform: translateY(120%) scale(0.85); opacity: 0; }
  to { transform: translateY(0) scale(1); opacity: 1; }
}
.pg-fav-cta-text {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; opacity: 0.96;
}
.pg-fav-cta-text::before {
  content: "♥"; font-size: 15px; line-height: 1;
}
.pg-fav-cta-badge {
  background: rgba(255, 255, 255, 0.22); color: #fff;
  padding: 2px 9px; border-radius: 999px; font-size: 11.5px; font-weight: 700;
  letter-spacing: 0.04em;
}
.pg-fav-cta-badge[hidden] { display: none; }
.pg-fav-cta-btn {
  background: rgba(255, 255, 255, 0.96); color: var(--pg-primary, #a16f3a);
  border: 0; padding: 8px 16px; border-radius: 999px; cursor: pointer;
  font-family: inherit; font-size: 12.5px; font-weight: 700;
  letter-spacing: 0.04em; text-transform: uppercase;
  transition: transform .15s, box-shadow .2s;
}
.pg-fav-cta-btn:hover { transform: scale(1.03); box-shadow: 0 4px 12px rgba(0,0,0,0.12); }
.pg-fav-cta-btn:active { transform: scale(0.97); }
@media (max-width: 480px) {
  .pg-fav-cta {
    bottom: max(16px, env(safe-area-inset-bottom));
    right: 16px; left: 16px;
    justify-content: space-between;
    padding: 12px 16px;
  }
  .pg-fav-cta-btn { padding: 9px 14px; }
}
body[data-bg="dark"] .pg-fav-cta {
  background: rgba(255, 255, 255, 0.96); color: #1a1814;
}
body[data-bg="dark"] .pg-fav-cta-btn {
  background: #1a1814; color: #fff;
}
body[data-bg="dark"] .pg-fav-cta-badge {
  background: rgba(26, 24, 20, 0.12); color: #1a1814;
}

/* v80 — CTA Avis Google. Couleur or, discret, sous la galerie. */
/* Bulle flottante "Laisser un avis Google" : suit le scroll, sur toutes les
   galeries (gérée par review_enabled côté serveur). Discrète mais classe. */
.pg-review-cta {
  position: fixed; bottom: 22px; right: 22px; z-index: 90;
  display: flex; align-items: center; gap: 10px;
  max-width: 258px; margin: 0;
  padding: 9px 15px;
  /* Verre dépoli sombre : contraste garanti sur n'importe quelle photo de fond. */
  background: rgba(24, 22, 19, 0.55);
  -webkit-backdrop-filter: blur(14px) saturate(1.3);
  backdrop-filter: blur(14px) saturate(1.3);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  text-decoration: none;
  color: #fff;
  font-family: var(--pg-sans);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.28);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity .35s ease, visibility .35s ease, transform .18s ease, box-shadow .18s ease;
}
/* Révélée seulement une fois scrollé dans les photos (classe posée en JS). */
.pg-review-cta.pg-review-cta--show { opacity: 1; visibility: visible; pointer-events: auto; }
.pg-review-cta[hidden] { display: none; }
.pg-review-cta:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.36); }
.pg-review-cta__stars { font-size: 13px; color: #e7c281; letter-spacing: 1.5px; flex-shrink: 0; }
.pg-review-cta__text { flex: 1; display: flex; flex-direction: column; gap: 1px; line-height: 1.2; min-width: 0; }
.pg-review-cta__title { font-weight: 600; font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pg-review-cta__sub { font-size: 10.5px; color: rgba(255, 255, 255, 0.66); white-space: nowrap; }
.pg-review-cta__arrow { font-size: 16px; color: rgba(255, 255, 255, 0.8); font-weight: 300; flex-shrink: 0; }
/* Fallback navigateurs sans backdrop-filter : fond plus opaque. */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .pg-review-cta { background: rgba(24, 22, 19, 0.86); }
}
@media (max-width: 480px) {
  .pg-review-cta { bottom: calc(14px + env(safe-area-inset-bottom)); right: 12px; left: auto; max-width: calc(100vw - 24px); padding: 8px 14px; gap: 9px; }
  .pg-review-cta__stars { font-size: 12px; letter-spacing: 1px; }
  .pg-review-cta__title { font-size: 12.5px; }
  .pg-review-cta__sub { font-size: 10px; }
}
@media (prefers-reduced-motion: reduce) { .pg-review-cta { animation: none; } }

/* Coupon dans le panneau panier. */
.pg-cart-coupon { margin: 12px 0 8px; padding-top: 12px; border-top: 1px solid var(--pg-line); }
.pg-cart-coupon label { font-size: 13px; color: var(--pg-ink); }
.pg-coupon-row { display: flex; gap: 8px; margin-top: 6px; }
.pg-cart-coupon-input {
  flex: 1; padding: 10px 12px; border: 1px solid var(--pg-line); border-radius: var(--pg-radius);
  font-family: inherit; font-size: 14px; text-transform: uppercase;
}
.pg-cart-coupon-apply {
  padding: 10px 16px; background: var(--pg-ink); color: #fff;
  border: 0; border-radius: var(--pg-radius); cursor: pointer;
  font-family: inherit; font-size: 13px;
}
.pg-cart-coupon-msg { display: block; margin-top: 6px; font-size: 12px; }
.pg-cart-coupon-msg.ok { color: #4a8b6b; }
.pg-cart-coupon-msg.err { color: #b04545; }

/* Breakdown remises au-dessus du total. */
.pg-cart-breakdown { margin: 12px 0; }
.pg-cart-breakdown:empty { display: none; }
.pg-cart-breakdown-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 4px 0; font-size: 13px;
}
.pg-cart-breakdown-row span.muted, .pg-cart-breakdown-row strong.muted { color: #7a7066; }
.pg-cart-breakdown-row strong { color: var(--pg-primary); }

/* Évite que le sticky CTA cache la dernière ligne de photos. */
.pg-grid { padding-bottom: 80px; }

/* === Sprint 2 Pic-Time 2.0 === */

/* Bandeau chapitres / albums sticky sous le header. */
.pg-chapters {
  display: flex; gap: 8px; padding: 12px 16px;
  overflow-x: auto;
  background: var(--pg-paper); border-bottom: 1px solid var(--pg-line);
  position: sticky; top: 0; z-index: 30;
  scrollbar-width: thin;
}
.pg-chapters[hidden] { display: none; }
.pg-chapters button {
  flex-shrink: 0;
  padding: 8px 16px;
  background: transparent;
  border: 1px solid var(--pg-line);
  border-radius: 999px;
  cursor: pointer;
  font-family: inherit; font-size: 13px;
  color: var(--pg-ink);
  display: inline-flex; align-items: center; gap: 6px;
  transition: all 160ms ease;
}
.pg-chapters button:hover { border-color: var(--pg-primary); }
.pg-chapters button.active { background: var(--pg-ink); color: #fff; border-color: var(--pg-ink); }
.pg-chapters button span {
  font-size: 11px; opacity: 0.6;
  background: rgba(255,255,255,0.1); padding: 1px 6px; border-radius: 999px;
}
.pg-chapters .pg-ch-num {
  font-family: var(--pg-serif); font-style: italic;
  font-size: 13px; margin-right: 10px;
  color: var(--pg-primary, #9c6b32);
  letter-spacing: 0.04em;
}
.pg-chapters button.active span { opacity: 0.9; }

/* Sprint 5 — barre de recherche sémantique IA. */
.pg-search {
  display: flex; gap: 8px; padding: 12px 16px;
  background: var(--pg-paper); border-bottom: 1px solid var(--pg-line);
  position: sticky; top: 44px; z-index: 25;
}
.pg-search[hidden] { display: none; }
.pg-search-input {
  flex: 1; padding: 10px 14px; border: 1px solid var(--pg-line); border-radius: 999px;
  font-family: inherit; font-size: 14px; background: #fff;
}
.pg-search-input:focus { outline: 2px solid var(--pg-primary); outline-offset: 2px; }
.pg-search-btn {
  background: var(--pg-ink); color: #fff;
  border: 0; padding: 10px 20px; border-radius: 999px; cursor: pointer;
  font-family: inherit; font-size: 13px;
}
.pg-search-clear {
  background: transparent; color: #7a7066; border: 1px solid var(--pg-line);
  width: 36px; height: 36px; border-radius: 50%; cursor: pointer; font-size: 18px;
  align-self: center;
}

/* Bandeau filtre actif (au-dessus de la grille quand on filtre similaires/with-me). */
.pg-filter-banner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; margin: 0;
  background: rgba(161, 111, 58, 0.08);
  border-bottom: 1px solid var(--pg-line);
  font-size: 13px; color: var(--pg-ink);
}
.pg-filter-banner button {
  background: var(--pg-primary); color: #fff;
  border: 0; padding: 6px 12px; border-radius: 4px; cursor: pointer;
  font-family: inherit; font-size: 12px;
}

/* Slideshow contrôles audio + fullscreen (hérite des styles .pg-ss-controls button) */

/* Lightbox v2 — EXIF + tools + comment box. */
.pg-lb-meta {
  position: absolute; bottom: 100px; left: 50%; transform: translateX(-50%);
  z-index: 4;
  color: rgba(255,255,255,0.72);
  padding: 8px 22px;
  font-family: var(--pg-serif); font-style: italic;
  font-size: 15px; font-weight: 300;
  letter-spacing: 0.02em;
  pointer-events: none;
  display: flex; align-items: center; gap: 14px;
  text-shadow: 0 1px 6px rgba(0,0,0,0.6);
}
.pg-lb-meta em { font-style: italic; }
.pg-lb-meta .pg-exif-cam {
  font-family: var(--pg-sans); font-style: normal;
  font-size: 10px; letter-spacing: 0.24em; text-transform: uppercase;
  font-weight: 500; opacity: 0.65;
}
.pg-lb-meta .pg-exif-u {
  font-family: var(--pg-sans); font-style: normal;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  opacity: 0.55; margin-left: 2px;
}
.pg-lb-meta .pg-exif-sep {
  display: inline-block; width: 1px; height: 12px;
  background: rgba(255,255,255,0.25);
}
/* Watermark studio bottom-right, opacité 18% pour signature discrète. */
.pg-lb-watermark {
  position: absolute; bottom: 96px; right: 28px;
  z-index: 4;
  font-family: var(--pg-serif); font-style: italic;
  font-size: 14px; color: rgba(255,255,255,0.62); /* was 0.42 = 3.7:1 FAIL 14px */
  letter-spacing: 0.06em;
  pointer-events: none;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6);
}
.pg-lb-watermark[hidden] { display: none; }
@media (max-width: 720px) {
  /* Sur mobile, la signature studio chevauchait le bouton HD (positionnée à
     bottom:84px right:12px, mais le bottom mesure ~180px avec 3 boutons +
     wrap). Caché : la signature reste imprimée sur les previews côté serveur
     (watermark sharp) si activé, donc pas de perte d'attribution. */
  .pg-lb-watermark { display: none !important; }
  .pg-lb-meta { font-size: 13px; padding: 6px 14px; }
}
/* Zoom double-tap : scale 2.2 + transform-origin défini dynamiquement. */
.pg-lb-stage.is-zoomed {
  transform: scale(2.2);
  cursor: zoom-out;
  transition: transform 450ms var(--ease-enter);
}
.pg-lb-stage {
  transition: transform 350ms var(--ease-enter);
  cursor: zoom-in;
}
.pg-lb-meta[hidden] { display: none; }

.pg-lb-tools {
  position: absolute; top: 72px; left: 50%; transform: translateX(-50%);
  z-index: 5;
  display: flex; gap: 4px;
  background: rgba(0,0,0,0.35); padding: 4px;
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.08);
}
.pg-lb-tools[hidden] { display: none; }
.pg-lb-tools button {
  background: transparent; color: rgba(255,255,255,0.82);
  border: 0; padding: 8px 14px; border-radius: 0; cursor: pointer;
  font-family: var(--pg-sans); font-size: 10px;
  letter-spacing: 0.24em; text-transform: uppercase; font-weight: 500;
  display: inline-flex; align-items: center; gap: 8px;
  transition: color 200ms var(--ease-enter), background 200ms var(--ease-enter);
}
.pg-lb-tools button:hover { background: rgba(255,255,255,0.08); color: #fff; }
.pg-lb-tools button svg { width: 14px; height: 14px; }

.pg-lb-comment-box {
  position: absolute; bottom: 100px; left: 50%; transform: translateX(-50%);
  background: rgba(255,255,255,0.97); color: var(--pg-ink);
  padding: 16px; border-radius: var(--pg-radius);
  width: min(440px, calc(100% - 32px));
  box-shadow: 0 18px 60px rgba(0,0,0,0.5);
}
.pg-lb-comment-box[hidden] { display: none; }
.pg-lb-comment-input {
  width: 100%; min-height: 80px; padding: 10px 12px;
  border: 1px solid var(--pg-line); border-radius: 6px;
  font-family: inherit; font-size: 14px; resize: vertical;
}
.pg-lb-comment-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 8px; }
.pg-lb-comment-cancel, .pg-lb-comment-save {
  border: 0; padding: 8px 16px; border-radius: 4px; cursor: pointer;
  font-family: inherit; font-size: 13px;
}
.pg-lb-comment-cancel { background: transparent; color: #7a7066; }
.pg-lb-comment-save { background: var(--pg-ink); color: #fff; }
.pg-lb-comment-status { display: block; margin-top: 6px; font-size: 12px; color: #4a8b6b; }
.pg-lb-comment-status.err { color: #b04545; }

/* Sprint 3 — panneau "Imprimer cette photo" dans la lightbox. */
.pg-lb-shop-panel {
  position: absolute; top: 16px; right: 16px;
  width: min(320px, calc(100% - 32px));
  max-height: 70vh; overflow-y: auto;
  background: rgba(255,255,255,0.97); color: var(--pg-ink);
  border-radius: var(--pg-radius);
  box-shadow: 0 18px 60px rgba(0,0,0,0.5);
  padding: 12px;
}
.pg-lb-shop-panel[hidden] { display: none; }
.pg-lb-shop-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 10px; margin-bottom: 8px;
  border-bottom: 1px solid var(--pg-line);
}
.pg-lb-shop-head strong { font-family: var(--pg-serif); font-style: italic; font-weight: 400; font-size: 18px; }
.pg-lb-shop-close {
  background: transparent; border: 0; cursor: pointer;
  font-size: 22px; line-height: 1; color: #7a7066;
}
.pg-lb-shop-list { display: grid; gap: 6px; }
.pg-lb-shop-item {
  display: grid; grid-template-columns: 1fr auto auto;
  align-items: center; gap: 10px;
  padding: 10px 12px;
  background: transparent; color: var(--pg-ink);
  border: 1px solid var(--pg-line); border-radius: 6px;
  cursor: pointer; font-family: inherit; font-size: 13px;
  text-align: left;
  transition: border-color 140ms ease;
}
.pg-lb-shop-item:hover { border-color: var(--pg-primary); }
.pg-lb-shop-item:disabled { opacity: 0.55; cursor: default; }
.pg-lb-shop-label { font-weight: 500; }
.pg-lb-shop-price { font-variant-numeric: tabular-nums; color: var(--pg-primary); font-weight: 600; }
.pg-lb-shop-add {
  background: var(--pg-ink); color: #fff;
  padding: 4px 10px; border-radius: 999px; font-size: 11px;
}

/* Mode kiosk (présentation, sans aucune UI). */
body.pg-kiosk { background: #000; color: #fff; }
body.pg-kiosk #pg-app { display: none; }
.pg-kiosk-splash {
  position: fixed; inset: 0; display: grid; place-items: center;
  background: #000; color: #fff; z-index: 100;
}
.pg-kiosk-splash-card { text-align: center; padding: 40px; }
.pg-kiosk-start {
  background: var(--pg-primary); color: #fff;
  border: 0; padding: 14px 28px; border-radius: 999px; cursor: pointer;
  font-family: inherit; font-size: 14px; letter-spacing: 0.06em;
}
.pg-kiosk-start:hover { filter: brightness(1.1); }

@media (max-width: 720px) {
  .pg-header { grid-template-columns: auto 1fr; }
  .pg-actions { grid-column: 1 / -1; justify-content: center; }
  .pg-title-block .pg-title { font-size: 18px; }
  .pg-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 6px; padding: 8px; padding-bottom: 100px; }
}

/* ==============================================================
   PREMIUM THEME (default) — refonte 2026-05-10 v6 (COPIE EXACTE Jays)
   Origine : /root/jays-ultimate-gallery/public/css/main.css l.5-28, 380-485, 1066-1230.
   Adapté minimalement : préfixé body[data-theme="premium"] où conflit, classes pg-* renommées en .hero/.gallery/.masonry/.photo.
   ============================================================== */
body[data-theme="premium"] {
  --bg: #ffffff;
  --paper: #fafaf7;
  --tech: #f5f5f5;
  --ink: #111111;
  --ink-soft: #2a2a2a;
  --ink-muted: #6b6b6b;
  --ink-faint: #a0a0a0;
  --line: #ebebeb;
  --serif: 'Cormorant Garamond', 'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --ease:     cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --gutter:   clamp(8px,  1.2vw, 18px);
  --page-pad: clamp(20px, 4vw,   64px);
  background: var(--paper);
  font-family: var(--sans);
  color: var(--ink);
}
body[data-theme="premium"][data-gap="tight"]    { --gutter: 4px; }
body[data-theme="premium"][data-gap="standard"] { --gutter: 12px; }
body[data-theme="premium"][data-gap="airy"]     { --gutter: 22px; }
body[data-theme="premium"][data-gap="luxe"]     { --gutter: 38px; }
body[data-theme="premium"][data-gap="lavish"]   { --gutter: 54px; }

/* On masque bannière promo et search bar en premium pour rester sobre */
body[data-theme="premium"] .pg-launch-banner,
body[data-theme="premium"] .pg-search { display: none !important; }
/* Bouton Top 20 (auto-pick) masqué côté client (toujours actif admin). */
body[data-theme="premium"] .pg-autopick-btn { display: none !important; }

/* On cache complètement les éléments du header centré actuel — le hero les remplace —
   mais on garde le header au DOM (sinon .pg-actions enfant fixed serait masqué). */
body[data-theme="premium"] .pg-header {
  position: static; background: transparent; border: 0;
  padding: 0; margin: 0; display: block;
}
body[data-theme="premium"] .pg-header > .pg-brand,
body[data-theme="premium"] .pg-header > .pg-title-block { display: none; }

/* ===== HERO (copie exacte Jays main.css l.1066-1199) ===== */
.hero {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 100vh; width: 100%;
  overflow: hidden;
  background: #0a0a0a;
  margin: 0;
  z-index: 1;
}
.hero__spacer { height: 100vh; width: 100%; pointer-events: none; }
/* Wrapper EXT : parallax zoom contrôlé par JS au scroll. */
.hero__bg {
  position: absolute;
  inset: -4%;
  transform: scale(1.08);
  will-change: transform;
  transition: transform 2s var(--ease-expo);
  overflow: hidden;
}
.hero.is-ready .hero__bg { transform: scale(1); }
/* Wrapper INT : ken-burns infini, indépendant du parallax JS. */
.hero__bg-inner {
  position: absolute; inset: -2%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  will-change: transform;
  animation: heroKenBurns 24s ease-in-out 2.2s infinite alternate;
  transform-origin: 50% 50%;
}
@keyframes heroKenBurns {
  from { transform: scale(1) translate3d(0, 0, 0); }
  to   { transform: scale(1.12) translate3d(-1.4%, -1%, 0); }
}
@media (prefers-reduced-motion: reduce) {
  .hero__bg-inner { animation: none; }
}
/* v62 — Living Cover : vidéo animée en boucle superposée au fond statique */
.hero__video {
  position: absolute; inset: -4%;
  width: 108%; height: 108%;
  object-fit: cover; object-position: center;
  opacity: 0;
  transition: opacity 1.2s var(--ease-enter);
  pointer-events: none;
  z-index: 1;
  /* Anti-pixelisation upscaling : sharpen + smooth interpolation, contrast subtil. */
  image-rendering: high-quality;
  -webkit-backface-visibility: hidden;
  filter: contrast(1.03) saturate(1.05);
  transform: translateZ(0); /* GPU compositing */
}
.hero__video.is-ready { opacity: 1; }
.hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom,
    rgba(0,0,0,0.35) 0%,
    rgba(0,0,0,0.12) 35%,
    rgba(0,0,0,0.25) 75%,
    rgba(0,0,0,0.55) 100%);
  pointer-events: none;
}
.hero__content {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; justify-content: center;
  padding: 0 clamp(32px, 8vw, 120px);
  color: #fff;
  max-width: 68vw;
  text-shadow: 0 1px 3px rgba(0,0,0,0.55), 0 2px 16px rgba(0,0,0,0.40);
  will-change: transform, opacity;
}
@media (max-width: 640px) { .hero__content { max-width: none; padding: 0 24px; } }

.hero__eyebrow {
  font-size: 11px; letter-spacing: 0.42em;
  text-transform: uppercase; font-weight: 500;
  display: inline-flex; align-items: center; gap: 14px;
  opacity: 0; transform: translateY(14px);
  transition: opacity 1s 0.25s var(--ease-expo), transform 1s 0.25s var(--ease-expo);
}
.hero__eyebrow::before {
  content: ""; display: inline-block; width: 32px; height: 1px;
  background: rgba(255,255,255,0.7);
}
.hero__title {
  font-family: var(--serif);
  font-size: clamp(48px, 8vw, 124px);
  line-height: 1.0; font-weight: 300;
  font-style: italic;
  letter-spacing: -0.005em;
  text-transform: none;
  max-width: 14ch;
  margin: 22px 0 0;
  opacity: 0; transform: translateY(24px);
  transition: opacity 1.4s 0.45s var(--ease-expo), transform 1.4s 0.45s var(--ease-expo);
}
.hero__title em {
  font-style: italic; font-family: var(--serif);
  font-weight: 400;
  letter-spacing: 0;
  color: var(--c-gold-light, var(--pg-primary, #c49a5a));
  font-size: 0.85em;
  padding: 0 0.05em;
}
.hero__subtitle {
  font-size: clamp(14px, 1.3vw, 17px);
  font-weight: 300; margin-top: 22px;
  letter-spacing: 0.06em;
  max-width: 40ch;
  opacity: 0; transform: translateY(14px);
  transition: opacity 1s 0.7s var(--ease), transform 1s 0.7s var(--ease);
}
.hero__divider {
  width: 54px; height: 1px;
  background: rgba(255,255,255,0.78);
  margin: 36px 0 20px;
  transform: scaleX(0); transform-origin: left center;
  transition: transform 1s 0.9s var(--ease);
}
.hero__photo-count {
  font-size: 10px; letter-spacing: 0.32em;
  text-transform: uppercase; font-weight: 500;
  font-variant-numeric: tabular-nums;
  opacity: 0; transform: translateY(10px);
  transition: opacity 1s 1.05s var(--ease), transform 1s 1.05s var(--ease);
}
.hero.is-ready .hero__eyebrow,
.hero.is-ready .hero__title,
.hero.is-ready .hero__subtitle,
.hero.is-ready .hero__photo-count {
  opacity: 1; transform: translateY(0);
}
.hero.is-ready .hero__divider { transform: scaleX(1); }

.hero__scroll {
  position: absolute;
  bottom: 36px; left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.85);
  background: none; border: 0; padding: 10px;
  opacity: 0; cursor: pointer;
  transition: opacity 1.4s 1.3s var(--ease), color 0.3s;
}
.hero__scroll svg { width: 28px; height: 28px; display: block; }
.hero__scroll:hover { color: #fff; }
.hero.is-ready .hero__scroll { opacity: 1; animation: heroBounce 2.4s ease-in-out 1.8s infinite; }
@keyframes heroBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(9px); }
}

/* ===== TOOLBAR (Jays main.css l.413-466 adapté pg-actions) ===== */
body[data-theme="premium"] .pg-actions {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: rgba(250, 250, 247, 0.92);
  backdrop-filter: saturate(1.2) blur(12px);
  -webkit-backdrop-filter: saturate(1.2) blur(12px);
  color: var(--ink);
  box-shadow: 0 1px 0 rgba(0,0,0,0.05);
  transform: translateY(-110%);
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  padding: 14px var(--page-pad);
  display: flex; align-items: center; justify-content: center;
  gap: clamp(10px, 2vw, 18px);
  flex-wrap: wrap;
}
body[data-theme="premium"] .pg-actions.is-solid { transform: translateY(0); }

/* v70 — Nav chapters : cachée tant que le hero n'est pas dépassé (~70vh).
   Empêche la barre blanche de couper le hero plein écran. */
body[data-theme="premium"] .pg-chapters {
  position: fixed; top: 56px; left: 0; right: 0;
  z-index: 45;
  background: rgba(250, 250, 247, 0.92);
  backdrop-filter: saturate(1.2) blur(12px);
  -webkit-backdrop-filter: saturate(1.2) blur(12px);
  box-shadow: 0 1px 0 rgba(0,0,0,0.05);
  transform: translateY(calc(-100% - 56px));
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  margin: 0;
}
body[data-theme="premium"] .pg-chapters.is-solid { transform: translateY(0); }
body[data-theme="premium"] .pg-actions button {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 14px;
  border: 1px solid var(--ink);
  font-size: 10px; letter-spacing: 0.24em;
  text-transform: uppercase; font-weight: 500;
  color: var(--ink);
  background: transparent;
  border-radius: 0;
  transition: background 0.2s var(--ease), color 0.2s var(--ease);
  font-family: var(--sans);
}
body[data-theme="premium"] .pg-actions button:hover { background: var(--ink); color: #fff; }
body[data-theme="premium"] .pg-actions .ico { font-size: 13px; letter-spacing: 0; }
body[data-theme="premium"] .pg-actions .pg-ic { display: inline-flex; align-items: center; }
body[data-theme="premium"] .pg-actions .pg-ic svg { width: 14px; height: 14px; }
body[data-theme="premium"] .pg-fav-btn.active .pg-ic svg { fill: currentColor; }
/* Mobile : toolbar compacte en icônes seules + 1 ligne scrollable horizontale */
@media (max-width: 720px) {
  body[data-theme="premium"] .pg-actions {
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: center;
    padding: 10px 14px;
    gap: 6px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  body[data-theme="premium"] .pg-actions::-webkit-scrollbar { display: none; }
  /* Si trop de boutons (≥6) → flex-start pour que le scroll horizontal montre
     le 1er bouton, sinon le centrage masque le début sous l'overflow. */
  body[data-theme="premium"] .pg-actions:has(> :nth-child(6)) { justify-content: flex-start; }
  body[data-theme="premium"] .pg-actions button {
    flex-shrink: 0;
    width: 42px; height: 42px;
    padding: 0;
    justify-content: center;
    gap: 0;
  }
  body[data-theme="premium"] .pg-actions .pg-lbl,
  body[data-theme="premium"] .pg-actions .lbl,
  body[data-theme="premium"] .pg-actions .cnt {
    display: none;
  }
  body[data-theme="premium"] .pg-actions .pg-ic svg { width: 18px; height: 18px; }
  /* Exception : compteur favoris/panier reste visible en pill compact */
  body[data-theme="premium"] .pg-fav-btn .cnt,
  body[data-theme="premium"] .pg-cart-btn .cnt {
    display: inline-flex;
    align-items: center; justify-content: center;
    position: absolute;
    top: -4px; right: -4px;
    min-width: 16px; height: 16px; padding: 0 4px;
    background: var(--pg-primary, #9c6b32); color: #fff;
    border-radius: 999px;
    font-size: 9px; font-weight: 600;
    letter-spacing: 0;
  }
  body[data-theme="premium"] .pg-fav-btn,
  body[data-theme="premium"] .pg-cart-btn { position: relative; }
  /* Mobile : "Valider ma sélection" devient un check icône carré 42×42
     comme les autres (uniformité visuelle). Le CTA réel est un pill flottant
     bottom-right qui apparaît quand l'invité a des favoris (voir .pg-proofing-fab). */
  body[data-theme="premium"] .pg-proofing-btn {
    width: 42px; height: 42px; padding: 0;
    border-color: var(--pg-primary, #9c6b32);
    color: var(--pg-primary, #9c6b32);
    flex-direction: row;
    gap: 0;
  }
  body[data-theme="premium"] .pg-proofing-btn .pg-ic { display: inline-flex; }
  body[data-theme="premium"] .pg-proofing-btn .pg-ic svg { width: 18px; height: 18px; }
  body[data-theme="premium"] .pg-proofing-btn .pg-lbl {
    display: none;
    font-size: 8px;
    letter-spacing: 0.16em;
    line-height: 1.15;
    max-width: 70px;
    text-align: center;
    white-space: normal;
  }
  body[data-theme="premium"] .pg-proofing-btn:hover {
    background: var(--pg-primary, #9c6b32);
    color: #fff;
  }
}
/* Bouton "Ma sélection" + bouton "Story Insta" — mise en avant or */
body[data-theme="premium"] .pg-fav-page-btn,
body[data-theme="premium"] .pg-story-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 14px;
  border: 1px solid var(--pg-primary, #9c6b32);
  font-size: 10px; letter-spacing: 0.24em;
  text-transform: uppercase; font-weight: 500;
  color: var(--pg-primary, #9c6b32);
  background: transparent;
  cursor: pointer;
  transition: background 0.2s var(--ease-enter), color 0.2s var(--ease-enter);
  font-family: var(--sans);
}
body[data-theme="premium"] .pg-fav-page-btn:hover,
body[data-theme="premium"] .pg-story-btn:hover {
  background: var(--pg-primary, #9c6b32); color: #fff;
}
body[data-theme="premium"] .pg-fav-page-btn svg,
body[data-theme="premium"] .pg-story-btn svg { width: 14px; height: 14px; }
body[data-theme="premium"] .pg-story-btn:disabled { opacity: 0.5; cursor: wait; }

/* ===== GALERIE / MASONRY (Jays main.css l.469-485) ===== */
body[data-theme="premium"] .pg-grid {
  position: relative;
  z-index: 2;
  background: var(--paper);
  padding: clamp(72px, 10vh, 140px) var(--page-pad) clamp(80px, 10vh, 140px);
  display: block;
  max-width: 100%;
  margin: 0;
}
/* Chaque chapitre = une section indépendante avec son propre masonry JS.
   Les dividers chapitre sont en flow normal AU-DESSUS des sections, jamais
   superposés aux tiles. */
body[data-theme="premium"] .pg-section {
  position: relative;
  display: block;
  width: 100%;
}
body[data-theme="premium"] .pg-tile {
  position: absolute;
  background: var(--tech);
  overflow: hidden;
  cursor: zoom-in;
  border-radius: 0;
  isolation: isolate;
  transform: translateZ(0);
}
body[data-theme="premium"] .pg-tile {
  /* v90 — Reveal accéléré : 800→350ms, stagger 55→18ms × max 6 (au lieu de 24).
     La 1ère photo visible en 350ms, la dernière en max 458ms total. */
  opacity: 0; transform: translate3d(0, 8px, 0);
  transition: opacity 350ms var(--ease-enter), transform 350ms var(--ease-enter);
  transition-delay: calc(var(--i, 0) * 18ms);
}
body[data-theme="premium"] .pg-tile.is-visible {
  opacity: 1; transform: translate3d(0, 0, 0);
}
body[data-theme="premium"] .pg-tile-img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0;
  /* Fade-in image 0.9s → 0.25s : la photo apparaît dès que le pixel arrive. */
  transition: opacity 0.25s var(--ease-enter);
  transform: translateZ(0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  will-change: transform, opacity;
  transform-origin: center center;
}
body[data-theme="premium"] .pg-tile.loaded .pg-tile-img { opacity: 1; }
/* Hover ken-burns lent desktop only — sensation cinéma sans agitation tactile */
@media (min-width: 900px) and (hover: hover) {
  body[data-theme="premium"] .pg-tile-img {
    transition: opacity 0.9s var(--ease-enter), transform 4.5s var(--ease-expo);
  }
  body[data-theme="premium"] .pg-tile:hover .pg-tile-img {
    transform: translateZ(0) scale(1.07);
  }
  body[data-theme="premium"] .pg-tile::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 55%, rgba(0,0,0,0.32) 100%);
    opacity: 0; transition: opacity 600ms var(--ease-enter);
    pointer-events: none;
    transform: translateZ(0);
  }
  body[data-theme="premium"] .pg-tile:hover::after { opacity: 1; }
}

/* Icônes favoris : carré sobre + SVG heart */
body[data-theme="premium"] .pg-tile-fav {
  width: 38px; height: 38px;
  top: 10px; right: 10px;
  /* v90 — Rond + couleurs Mon Carnet (cognac) au lieu du carré blanc neutre. */
  background: rgba(26, 24, 20, 0.55);
  border-radius: 50%;
  color: #fff;
  box-shadow: 0 2px 10px rgba(0,0,0,0.25);
  opacity: 0;
  transition: opacity 320ms var(--ease-enter), transform 220ms var(--ease-enter), color 220ms var(--ease-enter), background 220ms var(--ease-enter);
  z-index: 3;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
body[data-theme="premium"] .pg-tile-fav svg { width: 18px; height: 18px; }
body[data-theme="premium"] .pg-tile:hover .pg-tile-fav,
body[data-theme="premium"] .pg-tile-fav.active { opacity: 1; }
body[data-theme="premium"] .pg-tile-fav:hover {
  transform: scale(1.08);
  background: rgba(161, 111, 58, 0.85);
}
body[data-theme="premium"] .pg-tile-fav.active {
  background: var(--pg-primary, #a16f3a);
  color: #fff;
}
body[data-theme="premium"] .pg-tile-fav.active svg { fill: currentColor; }

/* Footer */
body[data-theme="premium"] .pg-footer {
  position: relative; z-index: 2;
  padding: 80px var(--page-pad) 120px;
  background: var(--paper);
  flex-direction: column; gap: 14px; max-width: 100%;
  border-top: 1px solid var(--line);
  text-align: center; justify-content: center;
}
body[data-theme="premium"] .pg-credit {
  font-family: var(--serif); font-style: italic;
  font-size: clamp(22px, 3vw, 32px); opacity: 0.65;
  font-weight: 300;
  letter-spacing: 0.01em;
  position: relative;
}
body[data-theme="premium"] .pg-credit::before,
body[data-theme="premium"] .pg-credit::after {
  content: ""; display: inline-block;
  width: 48px; height: 1px;
  background: var(--line); vertical-align: middle;
  margin: 0 22px;
  opacity: 0.6;
}
body[data-theme="premium"] .pg-photo-count {
  font-size: 10px; letter-spacing: 0.42em;
  text-transform: uppercase; opacity: 0.42;
  font-variant-numeric: tabular-nums;
}
/* v90 — Logo studio dans le footer, sous le nom (signature de fin de scroll).
   Hauteur fixe 64px, ratio préservé via background-size:contain, opacity
   réduite pour rester subtil sans écraser la signature italique. */
body[data-theme="premium"] .pg-credit-logo {
  width: 100%;
  max-width: 220px;
  height: 64px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  margin: 6px auto 0;
  opacity: 0.85;
  filter: saturate(0.9);
}
@media (max-width: 720px) {
  body[data-theme="premium"] .pg-credit-logo { max-width: 160px; height: 48px; }
}
/* Mode classique (non-premium) : logo plus discret en ligne. */
.pg-credit-logo {
  width: 100%;
  max-width: 160px;
  height: 48px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  margin: 8px auto 0;
  opacity: 0.8;
}

/* ===== LAYOUT — JUSTIFIED (Flickr / Google Photos) =====
 * Les sections deviennent des blocs positionnés-absolus calculés par JS.
 * Le reste (overflow, border-radius) suit les règles .pg-tile existantes. */
body[data-layout="justified"] .pg-section { position: relative; }
body[data-layout="justified"] .pg-tile {
  position: absolute;
  border-radius: 2px;
  overflow: hidden;
  transform: none !important; /* pas de hover translateY ici */
  transition: box-shadow .25s ease, opacity .4s ease;
}
body[data-layout="justified"] .pg-tile:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,0.14);
  z-index: 1;
}
body[data-layout="justified"] .pg-tile .pg-tile-img {
  width: 100%; height: 100%; object-fit: cover;
}

/* ===== LAYOUT — ÉDITORIAL MAGAZINE =====
 * Blocs A/B/C/D rotatifs, tout positionné en absolu par JS.
 * Les tiles couvrent leur espace au centre (object-fit: cover). */
body[data-layout="editorial"] .pg-section { position: relative; }
body[data-layout="editorial"] .pg-tile {
  position: absolute;
  overflow: hidden;
  border-radius: 0;
  transition: transform .3s var(--ease-enter), box-shadow .3s ease;
}
body[data-layout="editorial"] .pg-tile:hover {
  transform: scale(1.012);
  box-shadow: 0 12px 40px rgba(0,0,0,0.18);
  z-index: 2;
}
body[data-layout="editorial"] .pg-tile .pg-tile-img {
  width: 100%; height: 100%; object-fit: cover;
}
/* Séparateur chapitre éditorial : filet gras + chiffre pleine largeur */
body[data-layout="editorial"] .pg-chapter-divider {
  border-top: 3px solid var(--pg-ink);
  margin: 48px 0 0;
  padding-top: 20px;
}

/* ===== LAYOUT — POLAROID SCRAPBOOK =====
 * Même masonry que Carnet mais chaque tile mimique un tirage polaroid :
 * fond blanc, padding, ombre douce, rotation légère aléatoire. */
body[data-layout="polaroid"] .pg-tile {
  background: #fff;
  padding: 12px 12px 40px;
  box-shadow: 0 3px 12px rgba(0,0,0,0.12), 0 1px 3px rgba(0,0,0,0.08);
  border-radius: 1px;
  transform: rotate(var(--rot, 0deg));
  transition: transform .28s var(--ease-enter), box-shadow .28s ease;
  /* L'image est à l'intérieur du padding — on ne veut pas overflow:hidden global */
  overflow: visible;
}
body[data-layout="polaroid"] .pg-tile:hover {
  transform: rotate(0deg) scale(1.03);
  box-shadow: 0 16px 48px rgba(0,0,0,0.22), 0 4px 12px rgba(0,0,0,0.10);
  z-index: 5;
}
body[data-layout="polaroid"] .pg-tile .pg-tile-img {
  display: block; width: 100%; height: 100%;
  object-fit: cover;
  /* L'image occupe tout l'espace intérieur, le padding blanc crée l'effet tirage */
}
/* Override : le fav doit rester à l'intérieur du cadre blanc */
body[data-layout="polaroid"] .pg-tile .pg-tile-fav {
  top: 16px; right: 16px;
}
/* Séparateur chapitre Polaroid : ruban washi-tape + nom en script */
body[data-layout="polaroid"] .pg-chapter-divider {
  position: relative;
  margin: 48px 0 16px;
  overflow: visible;
}
body[data-layout="polaroid"] .pg-chapter-divider .pg-chapter-divider-inner {
  position: relative; z-index: 1;
}
body[data-layout="polaroid"] .pg-chapter-divider::before {
  content: "";
  position: absolute;
  inset: 8px -24px;
  background: repeating-linear-gradient(
    105deg,
    rgba(255,220,160,0.72) 0px,
    rgba(255,235,190,0.80) 6px,
    rgba(255,210,130,0.60) 12px
  );
  border-radius: 2px;
  transform: rotate(-0.6deg);
  z-index: 0;
}
body[data-layout="polaroid"] .pg-chapter-eyebrow { display: none; }
body[data-layout="polaroid"] .pg-chapter-name {
  font-family: "Brush Script MT", "Segoe Script", "Dancing Script", cursive;
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 400;
  font-style: normal;
  color: var(--pg-ink);
  text-shadow: 1px 1px 0 rgba(255,255,255,0.6);
  margin: 0;
}
body[data-layout="polaroid"] .pg-chapter-rule { display: none; }

/* Mobile (Jays main.css l.1319-1332) */
@media (max-width: 640px) {
  /* v105 — Hero plein écran iPhone : 100svh (small viewport height, exclut
     la barre d'adresse rétractable) au lieu de 75vh qui laissait dépasser
     la section Films sous le hero (UX dégueu). dvh fallback pour Safari < 15.4. */
  .hero__spacer { height: 100vh; height: 100svh; min-height: 480px; }
  .hero { height: 100vh; height: 100svh; min-height: 480px; }
  .hero__eyebrow { font-size: 10px; letter-spacing: 0.28em; }
  .hero__title { font-size: clamp(36px, 9vw, 56px); margin-top: 14px; max-width: 14ch; }
  .hero__subtitle { font-size: 13px; margin-top: 14px; }
  .hero__divider { width: 40px; margin: 14px 0 8px; }
  .hero__photo-count { font-size: 9px; letter-spacing: 0.25em; }
  .hero__content { padding: 0 clamp(20px, 4vw, 60px); }
  .hero__scroll { bottom: 14px; padding: 6px; }
}

/* ===== v70 — SECTION FILMS centrée, prestige éditorial ===== */
.pg-films {
  width: 100%;
  /* Marges en padding (incluses dans le bg) pour éviter les bandes
     transparentes qui laisseraient voir le hero entre les sections. */
  margin: 0;
  padding: clamp(72px, 10vh, 140px) clamp(24px, 5vw, 64px) clamp(36px, 6vw, 64px);
  box-sizing: border-box;
  /* z-index > 1 requis : le hero est position:fixed z-index:1 et peint PAR-DESSUS
     les éléments non-positionnés. Sans position+z-index la section Films serait
     cachée sous le hero lors du scroll. Le pg-grid a z-index:2 pour la même raison. */
  position: relative;
  z-index: 3;
  background: var(--paper, #fafaf7);
}
/* Quand films est présent, on collapse le padding-top de la grid pour
   éviter une bande blanche surchargée entre les deux. */
body[data-theme="premium"] .pg-films + .pg-grid {
  padding-top: 0;
}
.pg-films__eyebrow {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  margin: 0 auto clamp(20px, 3vw, 36px);
  max-width: 1400px;
}
.pg-films__line {
  flex: 0 1 80px; height: 1px;
  background: linear-gradient(90deg, transparent, currentColor 50%, transparent);
  opacity: 0.35;
}
.pg-films__label {
  font: 400 11px/1 var(--ui, sans-serif);
  letter-spacing: 0.45em;
  text-transform: uppercase;
  color: var(--ink, #1a1814);
  opacity: 0.75;
}
.pg-films__grid {
  display: grid; gap: clamp(16px, 2vw, 28px);
  margin: 0 auto;
}
/* v102 — Sous-titre chapter dans la section Films. Style cohérent avec
   les dividers de chapters photos. */
.pg-films__chapter {
  font: italic 500 clamp(20px, 2.4vw, 32px)/1.2 var(--serif, "Fraunces", serif);
  color: var(--ink, #1a1814);
  text-align: center;
  margin: clamp(16px, 2vw, 28px) auto 6px;
  letter-spacing: 0.01em;
}
.pg-films__chapter:first-of-type { margin-top: 8px; }
/* 1 film → centré max 880px */
.pg-films[data-count="1"] .pg-films__grid {
  grid-template-columns: 1fr;
  max-width: 880px;
}
/* 2 films → côte à côte centrés */
.pg-films[data-count="2"] .pg-films__grid {
  grid-template-columns: 1fr 1fr;
  max-width: 1280px;
}
/* 3+ films → grille 3 col centrée */
.pg-films[data-count="3"] .pg-films__grid,
.pg-films[data-count="4"] .pg-films__grid {
  grid-template-columns: repeat(3, 1fr);
  max-width: 1400px;
}
/* Mobile : tout en colonne + padding-top réduit (évitait un grand blanc
   après le hero quand 1+ vidéo en attente de chargement poster). */
@media (max-width: 780px) {
  .pg-films[data-count="2"] .pg-films__grid,
  .pg-films[data-count="3"] .pg-films__grid,
  .pg-films[data-count="4"] .pg-films__grid {
    grid-template-columns: 1fr;
  }
  .pg-films { padding: clamp(28px, 5vh, 56px) clamp(16px, 4vw, 24px) clamp(20px, 4vw, 36px); }
  .pg-films__eyebrow { margin-bottom: 14px; }
}
.pg-films .pg-tile--video {
  /* Reset des hacks masonry (absolute + height JS + opacity 0 du premium) —
     ici grid normale, tiles visibles immédiatement. */
  position: relative !important;
  top: auto !important; left: auto !important; right: auto !important;
  width: 100% !important; height: auto !important;
  /* Aspect 16:9 forcé pour uniformité (les portraits sont coverés). */
  aspect-ratio: 16 / 9 !important;
  /* Override de body[data-theme="premium"] .pg-tile { opacity: 0; transform } */
  opacity: 1 !important;
  transform: none !important;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 18px 60px rgba(0,0,0,.12), 0 4px 14px rgba(0,0,0,.06);
  transition: box-shadow .4s ease;
}
.pg-films .pg-tile--video:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 28px 80px rgba(0,0,0,.18), 0 8px 24px rgba(0,0,0,.08);
}

/* ===== v66 — TUILES VIDÉO + MODE CINÉMA ===== */
.hero__video--native { z-index: 1; opacity: 0; transition: opacity 1.4s ease; }
.hero__video--native.is-ready { opacity: 1; }

/* v104 — Hero vidéo paysage 16:9 visible ENTIÈRE sur mobile (au lieu de
   crop cover qui coupait les côtés). object-fit:contain + fond ambiant
   reproduisant la vidéo elle-même en blur (style Apple TV / YouTube).
   Le titre couple monte en haut pour ne pas couvrir la vidéo. */
@media (max-width: 780px) {
  .hero__video--native {
    inset: 0;
    width: 100%; height: 100%;
    object-fit: contain;
    background: #0a0908;
  }
  /* Fond ambiant sous la vidéo en contain (cognac + ink). On NE TOUCHE PAS
     position:fixed du .hero (sinon il perd sa hauteur 75vh et le contenu
     suivant remonte par-dessus). */
  #pg-hero {
    background:
      radial-gradient(circle at 30% 20%, rgba(161,111,58,.18), transparent 60%),
      radial-gradient(circle at 70% 80%, rgba(26,24,20,.85), #0a0908 70%);
  }
  .hero__overlay {
    background: linear-gradient(to bottom,
      rgba(0,0,0,0.65) 0%,
      rgba(0,0,0,0.15) 25%,
      rgba(0,0,0,0.15) 75%,
      rgba(0,0,0,0.65) 100%);
  }
  /* Titre/sous-titre relogés top + bottom pour ne pas masquer la vidéo. */
  .hero__content {
    justify-content: space-between;
    padding: clamp(24px, 5vh, 48px) 24px;
  }
}
.hero__cta-cinema {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 22px; padding: 10px 22px;
  background: rgba(255,255,255,.12); color: #fff;
  border: 1px solid rgba(255,255,255,.55); border-radius: 999px;
  font: 600 12px/1 var(--ui, sans-serif); letter-spacing: 0.15em; text-transform: uppercase;
  cursor: pointer; backdrop-filter: blur(8px);
  transition: background .25s ease, transform .2s ease;
}
.hero__cta-cinema:hover { background: rgba(255,255,255,.22); transform: translateY(-1px); }

/* Tuile vidéo (feature = span 2 colonnes) */
.pg-tile--video {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  background: #0c0b09;
  isolation: isolate;
}
.pg-tile-video__poster {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover;
  transition: opacity .35s ease, transform .8s ease;
  z-index: 1;
}
.pg-tile-video__inline {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: 0; z-index: 2;
  transition: opacity .5s ease;
  pointer-events: none;
}
.pg-tile--video.is-playing .pg-tile-video__inline { opacity: 1; }
.pg-tile--video.is-playing .pg-tile-video__poster { opacity: 0; }
.pg-tile-video__scrub {
  position: absolute; inset: 0; z-index: 3;
  background-repeat: no-repeat;
  background-size: 1000% 100%;
  opacity: 0; transition: opacity .25s ease;
  pointer-events: none;
}
.pg-tile--video:hover .pg-tile-video__scrub { opacity: 1; }
.pg-tile-video__overlay {
  position: absolute; inset: 0; z-index: 4;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 14px 18px;
  background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 60%, rgba(0,0,0,.55) 100%);
  pointer-events: none;
}
.pg-tile-video__play {
  width: 64px; height: 64px; margin: auto;
  display: grid; place-items: center;
  background: rgba(255,255,255,.92); color: #1a1814;
  border-radius: 50%;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  transition: transform .25s ease, background .25s ease;
}
.pg-tile-video__play svg { width: 28px; height: 28px; margin-left: 3px; }
.pg-tile--video:hover .pg-tile-video__play { transform: scale(1.08); background: #fff; }
.pg-tile-video__title {
  position: absolute; left: 18px; top: 14px;
  color: #fff; font: 600 13px/1.3 var(--ui, sans-serif);
  text-shadow: 0 2px 8px rgba(0,0,0,.55); max-width: 70%;
}
.pg-tile-video__duration {
  position: absolute; right: 14px; bottom: 12px;
  padding: 3px 10px; border-radius: 4px;
  background: rgba(0,0,0,.7); color: #fff;
  font: 600 11px/1 var(--ui, sans-serif); letter-spacing: 0.05em;
  backdrop-filter: blur(4px);
}

/* Mode CINÉMA plein écran */
body.pg-vcinema-open { overflow: hidden; }
.pg-vcinema {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(8, 7, 5, 0.98);
  display: grid;
  grid-template-columns: 1fr;
  animation: pgVCinemaIn .35s ease;
}
.pg-vcinema:has(.pg-vcinema__rail) {
  grid-template-columns: 1fr 320px;
}
@keyframes pgVCinemaIn { from { opacity: 0; } to { opacity: 1; } }
.pg-vcinema__stage {
  position: relative;
  display: grid; place-items: center;
  padding: 28px;
}
.pg-vcinema__video {
  max-width: 100%; max-height: 100%; width: 100%; height: auto;
  background: #000;
  box-shadow: 0 20px 80px rgba(0,0,0,.7);
  border-radius: 6px;
}
.pg-vcinema__close {
  position: absolute; top: 18px; right: 18px;
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: rgba(0,0,0,.55); color: #fff;
  border: 1px solid rgba(255,255,255,.25); border-radius: 50%;
  cursor: pointer; backdrop-filter: blur(8px);
  transition: background .2s ease, transform .2s ease;
  z-index: 2;
}
.pg-vcinema__close svg { width: 18px; height: 18px; }
.pg-vcinema__close:hover { background: rgba(255,255,255,.18); transform: rotate(90deg); }
.pg-vcinema__title {
  position: absolute; left: 0; right: 0; top: 18px;
  text-align: center; pointer-events: none;
  color: #fff; font: 500 14px/1.4 var(--ui, sans-serif); letter-spacing: 0.1em;
  text-shadow: 0 2px 8px rgba(0,0,0,.7);
}
.pg-vcinema__rail {
  background: rgba(20, 17, 14, 0.96);
  border-left: 1px solid rgba(255,255,255,.07);
  padding: 28px 22px;
  overflow-y: auto;
  color: #f5f0e8;
}
.pg-vcinema__rail h4 {
  font: 600 11px/1 var(--ui, sans-serif); letter-spacing: 0.25em;
  text-transform: uppercase; color: rgba(245,240,232,.55);
  margin: 0 0 18px;
}
.pg-vcinema__rail ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.pg-vcinema__rail button {
  display: flex; align-items: baseline; gap: 12px;
  width: 100%; padding: 10px 12px;
  background: transparent; color: #f5f0e8;
  border: 1px solid transparent; border-radius: 8px;
  font: 500 14px/1.4 var(--ui, sans-serif);
  text-align: left; cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}
.pg-vcinema__rail button:hover { background: rgba(255,255,255,.04); }
.pg-vcinema__rail button.is-active { background: rgba(161,111,58,.18); border-color: rgba(161,111,58,.55); }
.pg-vcinema__rail-t {
  font-variant-numeric: tabular-nums;
  font-size: 12px; color: rgba(245,240,232,.55); min-width: 42px;
}
@media (max-width: 780px) {
  .pg-vcinema:has(.pg-vcinema__rail) { grid-template-columns: 1fr; grid-template-rows: 1fr auto; }
  .pg-vcinema__rail { max-height: 40vh; border-left: none; border-top: 1px solid rgba(255,255,255,.07); }
}
.pg-vcinema__actions {
  position: absolute; left: 0; right: 0; bottom: 22px;
  display: flex; justify-content: center; gap: 12px;
  pointer-events: none;
}
.pg-vcinema__dl {
  pointer-events: auto;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px;
  background: var(--primary, #a16f3a); color: #fff;
  border: none; border-radius: 999px;
  font: 600 13px/1 var(--ui, sans-serif); letter-spacing: 0.1em;
  cursor: pointer; text-decoration: none;
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
  transition: transform .2s ease, background .2s ease;
}
.pg-vcinema__dl:hover { background: #b97e3f; transform: translateY(-2px); }
.pg-vcinema__dl svg { width: 14px; height: 14px; }
/* v69 — Live banner sticky */
#pg-live-banner {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 10000;
  background: linear-gradient(90deg, #e53935 0%, #c62828 100%);
  color: #fff; border: none; cursor: pointer;
  padding: 12px 18px;
  font: 600 13px/1.3 var(--ui, sans-serif); letter-spacing: 0.05em;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  box-shadow: 0 4px 14px rgba(0,0,0,.25);
  animation: liveBannerIn .4s ease;
}
@keyframes liveBannerIn { from { transform: translateY(-100%); } to { transform: translateY(0); } }
.pg-live-dot { display: inline-block; width: 10px; height: 10px; background: #fff; border-radius: 50%; animation: livePulse 1.2s ease-in-out infinite; }
@keyframes livePulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: .4; transform: scale(.8); } }
.pg-vcinema--live .pg-vcinema__title { color: #fff; }

/* ===== v70 — CTA Valider sticky bottom mobile ===== */
.pg-proofing-fab {
  position: fixed;
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 180;
  padding: 14px 24px;
  background: var(--pg-primary, #9c6b32);
  color: #fff;
  border: 0;
  border-radius: 999px;
  font: 600 13px/1 var(--pg-sans, "Inter", sans-serif);
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.32), 0 4px 10px rgba(0,0,0,0.18);
  cursor: pointer;
  transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1), background 200ms;
  white-space: nowrap;
  max-width: calc(100vw - 32px);
}
.pg-proofing-fab.is-visible { transform: translateX(-50%) translateY(0); }
.pg-proofing-fab:active { background: var(--pg-ink, #1a1814); }
.pg-proofing-fab .pg-proofing-fab-count {
  background: rgba(255,255,255,0.18);
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 12px;
  font-variant-numeric: tabular-nums;
}
.pg-proofing-fab svg { width: 16px; height: 16px; }
/* Caché sur desktop, l'invité a déjà le bouton dans la topbar. */
@media (min-width: 721px) { .pg-proofing-fab { display: none !important; } }

/* === v86 — Themes Pic-Time killer (preset + shape + palette) === */
/* Les CSS vars --pg-bg/--pg-ink/--pg-primary/--pg-muted/--pg-shape-radius/etc.
   sont injectées sur <body> par app.js depuis state.meta.themeV86.cssVars.
   On les consomme ici pour overrides ciblés sans tout refactorer. */
body[data-shape="rect"]    { --pg-shape-radius: 0; }
body[data-shape="rounded"] { --pg-shape-radius: 8px; }
body[data-shape="pill"]    { --pg-shape-radius: 999px; }

/* Boutons / inputs respectent shape global */
body[data-shape] .pg-fav-cta,
body[data-shape] .pg-fav-cta-btn,
body[data-shape] .pg-cart-btn,
body[data-shape] .pg-fav-btn,
body[data-shape] .pg-download-btn,
body[data-shape] .pg-proofing-btn,
body[data-shape] .pg-autopick-btn,
body[data-shape] .pg-slideshow-btn,
body[data-shape] .pg-cinema-btn,
body[data-shape] .pg-face-btn,
body[data-shape] .pg-search-input,
body[data-shape] .pg-search-btn {
  border-radius: var(--pg-shape-radius) !important;
}

/* Préfixe palette : couleurs accent et fond galerie quand themeV86 actif */
body[data-preset] {
  background-color: var(--pg-bg, #faf6f0);
  color: var(--pg-ink, #1a1814);
  font-family: var(--pg-font-sans, 'Inter', -apple-system, sans-serif);
}
body[data-preset] .pg-title,
body[data-preset] .pg-subtitle,
body[data-preset] h1, body[data-preset] h2, body[data-preset] h3 {
  font-family: var(--pg-font-serif, 'Fraunces', Georgia, serif);
  font-weight: var(--pg-cover-weight, 400);
  letter-spacing: var(--pg-cover-spacing, 0.02em);
}
body[data-preset="editorial"] .pg-title { font-style: italic; }
body[data-preset] .pg-fav-cta { background: var(--pg-primary, #a16f3a); }
body[data-preset] .pg-cart-btn .cnt,
body[data-preset] .pg-fav-btn .cnt { background: var(--pg-primary); }
