/* =============================================================================
   VISUAL QA — Maurice Bardèche ARCHIV
   Contraste, galerie, lightbox, cohérence composants (charge en dernier).
   ============================================================================= */

/* ---------- Tokens lisibilité (thème clair) ---------- */
html[data-theme="light"] {
  --text-muted: #4a524c;
  --text-secondary: #3d423f;
  --lit-ink-muted: #4a524c;
}

html[data-theme="dark"] {
  --text-muted: #b0b5b0;
  --text-secondary: #c5cac5;
}

.ej-military-subtitle,
.ej-subtitle,
.gallery-subtitle,
.ej-leitmotive-subtitle {
  color: var(--text-muted) !important;
  opacity: 1 !important;
}

.ej-source-note,
.ej-gallery-attribution {
  color: var(--text-muted) !important;
  opacity: 0.92 !important;
}

.ej-leitmotive-card-desc,
.ej-drogen-card-desc,
.ej-timeline-title,
.ej-bibliography-description,
p {
  color: var(--text-primary);
}

/* ---------- Boutons & CTA ---------- */
.button.bg-brand,
.hero-section .buttons .button.ej-hero-cta-interview {
  color: var(--bg-card) !important;
}

.hero-section .buttons .button.ej-hero-cta-timeline,
.gallery-more-button,
.ej-link-card-btn {
  color: var(--lead-gray) !important;
  border-color: var(--border-soft) !important;
}

html[data-theme="dark"] .hero-section .buttons .button.ej-hero-cta-timeline,
html[data-theme="dark"] .gallery-more-button,
html[data-theme="dark"] .ej-link-card-btn {
  color: var(--lit-ink) !important;
}

/* ---------- Galerie : grille & ratios portrait ---------- */
.gallery-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1rem, 2vw, 1.5rem) !important;
}

@media (max-width: 968px) {
  .gallery-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 640px) {
  .gallery-grid {
    grid-template-columns: 1fr !important;
    max-width: 28rem;
    margin-left: auto;
    margin-right: auto;
  }
}

.gallery-card {
  position: relative;
  aspect-ratio: 3 / 4 !important;
  cursor: pointer;
  border: 1px solid var(--border-soft) !important;
  background: var(--bg-card) !important;
  transform: none !important;
  box-shadow: none !important;
}

.gallery-card picture {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.gallery-card .gallery-card-image,
.gallery-card picture img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.35s ease, filter 0.35s ease;
}

.gallery-grid .gallery-card:first-child picture img,
.gallery-grid .gallery-card:nth-child(2) picture img {
  object-position: center 15%;
}

/* Overlays décoratifs : ne pas bloquer les clics */
.gallery-card::before,
.gallery-card::after {
  pointer-events: none !important;
  z-index: 2;
}

html[data-theme="light"] .gallery-card::after {
  opacity: 0.35 !important;
  box-shadow: none !important;
  background: linear-gradient(180deg, transparent 55%, rgba(47, 58, 52, 0.12) 100%) !important;
}

@media (hover: hover) and (pointer: fine) {
  .gallery-card:hover {
    transform: none !important;
    border-color: var(--verdigris) !important;
  }

  .gallery-card:hover .gallery-card-image,
  .gallery-card:hover picture img {
    transform: scale(1.015);
  }
}

.gallery-card:focus-visible {
  outline: 2px solid var(--verdigris);
  outline-offset: 3px;
}

/* ---------- Lightbox (plein écran, contrôles fixés au viewport) ---------- */
.gallery-lightbox {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  max-width: none !important;
  max-height: none !important;
  margin: 0 !important;
  z-index: 100050 !important;
  background-color: rgba(23, 26, 23, 0.92) !important;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  padding: 0 !important;
  box-sizing: border-box !important;
}

html[data-theme="light"] .gallery-lightbox {
  background-color: rgba(23, 26, 23, 0.94) !important;
}

.gallery-lightbox.active {
  display: flex !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.gallery-lightbox-content {
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: clamp(3.5rem, 10vh, 5rem) clamp(3.25rem, 8vw, 4.5rem) !important;
  box-sizing: border-box !important;
  pointer-events: none !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  z-index: 100051 !important;
}

.gallery-lightbox-image {
  max-width: min(96vw, 1100px) !important;
  max-height: min(82vh, 820px) !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  border: 1px solid rgba(185, 183, 170, 0.35) !important;
  background: #1a1c1a !important;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.35);
  pointer-events: auto !important;
}

.gallery-lightbox-counter {
  position: fixed !important;
  top: max(0.75rem, env(safe-area-inset-top, 0px)) !important;
  left: max(0.75rem, env(safe-area-inset-left, 0px)) !important;
  right: auto !important;
  color: rgba(245, 242, 234, 0.9) !important;
  font-family: var(--am-mono, "DM Mono", monospace);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  z-index: 100053 !important;
  pointer-events: none !important;
}

.gallery-lightbox-close,
.gallery-lightbox-nav {
  position: fixed !important;
  z-index: 100053 !important;
  background: rgba(47, 58, 52, 0.92) !important;
  border: 1px solid rgba(185, 183, 170, 0.45) !important;
  color: #f5f2ea !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}

.gallery-lightbox-close {
  top: max(0.75rem, env(safe-area-inset-top, 0px)) !important;
  right: max(0.75rem, env(safe-area-inset-right, 0px)) !important;
  left: auto !important;
  transform: none !important;
}

.gallery-lightbox-nav.prev {
  left: max(0.5rem, env(safe-area-inset-left, 0px)) !important;
  right: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.gallery-lightbox-nav.next {
  right: max(0.5rem, env(safe-area-inset-right, 0px)) !important;
  left: auto !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.gallery-lightbox-nav:hover {
  background: var(--verdigris-dark) !important;
  border-color: var(--verdigris) !important;
  color: #f5f2ea !important;
  transform: translateY(-50%) !important;
}

.gallery-lightbox-close:hover {
  background: var(--verdigris-dark) !important;
  border-color: var(--verdigris) !important;
  color: #f5f2ea !important;
  transform: none !important;
}

.gallery-lightbox-close svg,
.gallery-lightbox-nav svg {
  stroke: currentColor !important;
  opacity: 1 !important;
}

@media (max-width: 640px) {
  .gallery-lightbox-content {
    padding: 3.25rem 0.5rem 2.5rem !important;
  }

  .gallery-lightbox-image {
    max-height: 72vh !important;
  }
}

body.archiv-lightbox-open {
  overflow: hidden !important;
}

/* ---------- Bibliographie lightbox ---------- */
.bibliography-lightbox {
  z-index: 100050 !important;
  background-color: rgba(23, 26, 23, 0.92) !important;
}

.bibliography-lightbox-image {
  max-height: min(85vh, 820px) !important;
  object-fit: contain !important;
}

/* ---------- Cartes & sections ---------- */
.ej-leitmotive-card:hover,
.ej-drogen-card:hover,
.ej-link-card:hover {
  transform: none !important;
}

.ej-timeline-year {
  color: var(--verdigris-dark) !important;
}

html[data-theme="dark"] .ej-timeline-year {
  color: var(--lit-accent) !important;
}

.ej-timeline-title {
  color: var(--text-primary) !important;
}

/* ---------- Footer lisible ---------- */
.ej-footer-link a {
  color: rgba(245, 242, 234, 0.92) !important;
}

/* ---------- Citations ---------- */
.mm-citations-section .ej-quote-text {
  color: var(--text-main) !important;
}

html[data-theme="dark"] .mm-citations-section .ej-quote-text {
  color: var(--lit-ink) !important;
}

.mm-citations-section .ej-quote-author {
  color: var(--text-muted) !important;
  opacity: 1 !important;
}

/* ---------- Retour haut : flèche blanche visible (priorité sur cache / ::before) ---------- */
.ej-scroll-to-top {
  z-index: 10050 !important;
  border: 1px solid rgba(255, 255, 255, 0.55) !important;
  background: #2f3a34 !important;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.45);
}

.ej-scroll-to-top::before,
.ej-scroll-to-top::after {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}

.ej-scroll-to-top-icon {
  display: block;
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}

.ej-scroll-to-top-icon path {
  stroke: #ffffff !important;
}

.ej-scroll-to-top.visible {
  opacity: 1 !important;
  visibility: visible !important;
}
