﻿/* Classes de base conservées (utilisées par mariage.html, photobooth.html) */

.photobooth-specs {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.spec {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-md);
  padding: 1rem;
}

.spec strong {
  color: var(--color-red-dark);
  display: block;
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1;
}

@media (max-width: 900px) {
  .photobooth-specs {
    grid-template-columns: 1fr;
  }
}


/* Karvirec v3 - système photo/film cohérent */
:root {
  --photo-paper: #f3eee5;
  --photo-ink: #11100e;
  --photo-muted: #71685d;
  --photo-line: rgba(17, 16, 14, 0.18);
  --photo-gold: #9a6f3f;
  --photo-night: #10100f;
  --photo-cream: #fff8ec;
}

body {
  background: var(--photo-paper);
  color: var(--photo-ink);
}

.site-header {
  background: rgba(243, 238, 229, 0.94);
  border-bottom: 1px solid var(--photo-line);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}

.booking-bar {
  background: #e7ded2;
  color: var(--photo-ink);
}

.kv-cursor {
  border: 1px solid rgba(154, 111, 63, 0.55);
  border-radius: 50%;
  height: 34px;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transform: translate3d(-50%, -50%, 0);
  transition: opacity 180ms ease, width 220ms ease, height 220ms ease, border-color 220ms ease;
  width: 34px;
  z-index: 200;
}

.kv-cursor.is-visible {
  opacity: 1;
}

.kv-cursor.is-active {
  border-color: rgba(255, 248, 236, 0.95);
  height: 58px;
  width: 58px;
}

.photo-hero {
  padding: 1.2rem 20px 0;
}

.photo-hero__stage {
  background: var(--photo-night);
  color: var(--photo-cream);
  min-height: calc(100vh - 124px);
  min-height: calc(100dvh - 124px);
  overflow: hidden;
  position: relative;
}

.photo-hero__slide {
  inset: 0;
  margin: 0;
  opacity: 0;
  position: absolute;
  transform: scale(1.04);
  transition: opacity 1200ms ease, transform 5500ms ease;
}

.photo-hero__slide.is-active {
  opacity: 1;
  transform: scale(1);
}

.photo-hero__slide img {
  filter: brightness(0.62) contrast(1.08) saturate(0.96);
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.photo-hero__shade {
  background:
    radial-gradient(circle at 68% 30%, rgba(196, 141, 78, 0.38), transparent 34%),
    linear-gradient(90deg, rgba(0, 0, 0, 0.48), transparent 46%, rgba(0, 0, 0, 0.35)),
    linear-gradient(0deg, rgba(0, 0, 0, 0.72), transparent 46%);
  inset: 0;
  position: absolute;
  z-index: 2;
}

.photo-hero__grain {
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.18) 0 1px, transparent 1px),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,.12) 0 1px, transparent 1px);
  background-size: 14px 14px, 19px 19px;
  inset: 0;
  mix-blend-mode: soft-light;
  opacity: 0.22;
  pointer-events: none;
  position: absolute;
  z-index: 3;
  animation: grain-drift 7s steps(6) infinite;
}

.photo-hero__reticle {
  border: 1px solid rgba(255, 248, 236, 0.5);
  inset: 30px;
  pointer-events: none;
  position: absolute;
  z-index: 4;
}

.photo-hero__reticle::before,
.photo-hero__reticle::after {
  background: rgba(255, 248, 236, 0.23);
  content: "";
  position: absolute;
}

.photo-hero__reticle::before {
  height: 1px;
  left: 0;
  top: 50%;
  width: 100%;
}

.photo-hero__reticle::after {
  height: 100%;
  left: 50%;
  top: 0;
  width: 1px;
}

.photo-hero__copy {
  bottom: clamp(2rem, 5vw, 5rem);
  display: grid;
  gap: 1rem;
  left: clamp(1.5rem, 5vw, 5rem);
  max-width: 900px;
  position: absolute;
  z-index: 5;
}

.photo-hero__overline,
.photo-index {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.photo-hero__overline {
  color: rgba(255, 248, 236, 0.76);
}

.photo-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(3rem, 5.5vw, 5.5rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 0.92;
}

.photo-hero h1 span {
  display: block;
}

.photo-hero__copy p:not(.photo-hero__overline) {
  color: rgba(255, 248, 236, 0.86);
  font-size: clamp(1.22rem, 2vw, 1.7rem);
  max-width: 680px;
}

.photo-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.6rem;
}

.button-ghost-light {
  border-color: rgba(255, 248, 236, 0.7);
  color: var(--photo-cream);
}

.button-ghost-light:hover {
  background: var(--photo-cream);
  color: var(--photo-ink);
}

.photo-hero__status {
  align-items: center;
  bottom: clamp(1.5rem, 3vw, 3rem);
  display: flex;
  gap: 0.7rem;
  position: absolute;
  right: clamp(1.5rem, 4vw, 4rem);
  z-index: 5;
}

.photo-hero__status span {
  color: rgba(255, 248, 236, 0.72);
  font-size: 0.75rem;
  font-weight: 900;
}

.photo-hero__status span:nth-child(2) {
  background: rgba(255, 248, 236, 0.55);
  height: 1px;
  overflow: hidden;
  position: relative;
  width: 84px;
}

.photo-hero__status span:nth-child(2)::before {
  animation: hero-progress 5.5s linear infinite;
  background: var(--photo-cream);
  content: "";
  inset: 0;
  position: absolute;
  transform-origin: left;
}

.photo-intro,
.photo-services,
.photo-closing {
  padding: clamp(2.5rem, 4vw, 4rem) 20px;
}

.photo-intro__grid {
  border-bottom: 1px solid var(--photo-line);
  display: grid;
  gap: clamp(1.5rem, 4vw, 4.5rem);
  grid-template-columns: minmax(80px, 0.18fr) minmax(0, 1.08fr) minmax(280px, 0.44fr);
  padding-bottom: clamp(5rem, 9vw, 9rem);
}

.photo-index {
  color: var(--photo-muted);
}

.photo-intro h2,
.photo-closing h2 {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4.5vw, 4.2rem);
  font-weight: 400;
  letter-spacing: -0.04em;
  line-height: 0.96;
}

.photo-intro p:last-child {
  color: var(--photo-muted);
  font-size: 1.22rem;
  line-height: 1.65;
}

.photo-services__grid {
  align-items: stretch;
  display: grid;
  gap: clamp(2rem, 6vw, 6rem);
  grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1fr);
}

.photo-services__preview {
  align-self: start;
  background: #17130f;
  min-height: 640px;
  overflow: hidden;
  position: sticky;
  top: 116px;
}

.photo-services__preview img {
  filter: brightness(0.82) contrast(1.06) saturate(0.94);
  height: 100%;
  object-fit: cover;
  transition: opacity 260ms ease, transform 900ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 100%;
}

.photo-services__preview.is-switching img {
  opacity: 0.35;
  transform: scale(1.04);
}

.photo-services__list {
  display: grid;
}

.photo-services__list > .photo-index {
  border-bottom: 1px solid var(--photo-line);
  padding-bottom: 1rem;
}

.photo-service {
  align-items: center;
  border-bottom: 1px solid var(--photo-line);
  color: var(--photo-ink);
  display: grid;
  gap: 1.4rem;
  grid-template-columns: 52px minmax(0, 0.82fr) minmax(220px, 0.58fr);
  min-height: 132px;
  padding: 1.3rem 0;
  text-decoration: none;
  transition: color 240ms ease, transform 240ms ease;
}

.photo-service span {
  color: var(--photo-muted);
  font-size: 0.86rem;
  font-weight: 700;
}

.photo-service strong {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 5.8vw, 5.8rem);
  font-weight: 400;
  letter-spacing: -0.055em;
  line-height: 0.9;
}

.photo-service em {
  color: var(--photo-muted);
  font-style: normal;
  line-height: 1.5;
}

.photo-service:hover,
.photo-service.is-active {
  color: var(--photo-gold);
  transform: translateX(10px);
}

.film-strip {
  overflow: hidden;
  padding: 1rem 0 clamp(5rem, 9vw, 9rem);
}

.film-strip__track {
  animation: film-roll 34s linear infinite;
  display: flex;
  gap: 1rem;
  width: max-content;
}

.film-strip:hover .film-strip__track {
  animation-play-state: paused;
}

.film-strip figure {
  background: #15120f;
  color: var(--photo-cream);
  flex: 0 0 clamp(260px, 30vw, 440px);
  margin: 0;
  overflow: hidden;
  position: relative;
}

.film-strip img {
  aspect-ratio: 4 / 5;
  filter: brightness(0.82) contrast(1.04) saturate(0.9);
  object-fit: cover;
  transition: transform 700ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 100%;
}

.film-strip figure:hover img {
  transform: scale(1.05);
}

.film-strip figcaption {
  bottom: 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  left: 0.85rem;
  letter-spacing: 0.14em;
  position: absolute;
  text-transform: uppercase;
}

.photo-closing {
  background: var(--photo-night);
  color: var(--photo-cream);
}

.photo-closing__inner {
  align-items: end;
  display: grid;
  gap: clamp(1rem, 2vw, 2rem);
  grid-template-columns: minmax(80px, 0.18fr) minmax(0, 1fr) auto;
}

.photo-closing .button-primary {
  background: var(--photo-cream);
  color: var(--photo-ink);
}

@keyframes hero-progress {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

@keyframes grain-drift {
  0% {
    transform: translate3d(0, 0, 0);
  }
  33% {
    transform: translate3d(2%, -1%, 0);
  }
  66% {
    transform: translate3d(-1%, 2%, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes film-roll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-50% - 0.5rem));
  }
}

@media (max-width: 1000px) {
  .photo-intro__grid,
  .photo-services__grid,
  .photo-closing__inner {
    grid-template-columns: 1fr;
  }

  .photo-services__preview {
    min-height: auto;
    position: relative;
    top: auto;
  }

  .photo-services__preview img {
    aspect-ratio: 16 / 10;
    height: auto;
  }

  .photo-service {
    grid-template-columns: 46px 1fr;
  }

  .photo-service em {
    grid-column: 2;
  }
}

@media (pointer: coarse) {
  .kv-cursor { display: none !important; }
}

@media (max-width: 640px) {
  .kv-cursor {
    display: none;
  }

  .photo-hero {
    padding-left: 0;
    padding-right: 0;
  }

  .photo-hero__stage {
    min-height: 82vh;
    min-height: 82dvh;
  }

  .photo-hero__reticle {
    inset: 14px;
  }

  .photo-hero__copy {
    bottom: 6rem;
    left: 1rem;
    right: 1rem;
  }

  .photo-hero h1 {
    font-size: clamp(2rem, 8vw, 3.2rem);
  }

  .photo-hero__status {
    display: none;
  }

  .photo-service {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .photo-service em {
    grid-column: auto;
  }
}

/* Karvirec v4 - accueil plus photographique, cohérent et animé */
:root {
  --photo-signal: #aa3832;
  --photo-sage: #405f58;
  --photo-blue: #1f2c3f;
}

.home-page {
  --hero-x: 58%;
  --hero-y: 38%;
  --scroll-progress: 0;
  background:
    linear-gradient(90deg, rgba(17, 16, 14, 0.055) 1px, transparent 1px),
    linear-gradient(180deg, rgba(17, 16, 14, 0.045) 1px, transparent 1px),
    var(--photo-paper);
  background-size: 64px 64px;
  overflow-x: hidden;
}

.home-page::before {
  background: linear-gradient(90deg, var(--photo-signal), var(--photo-sage), var(--photo-gold));
  content: "";
  height: 2px;
  left: 0;
  position: fixed;
  top: 0;
  transform: scaleX(var(--scroll-progress));
  transform-origin: left;
  width: 100%;
  z-index: 300;
}

.home-page .site-header {
  background: rgba(17, 16, 14, 0.18);
  border-bottom-color: rgba(255, 248, 236, 0.14);
  color: var(--photo-cream);
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
}

.home-page .site-header.is-scrolled {
  background: rgba(243, 238, 229, 0.94);
  border-bottom-color: var(--photo-line);
  color: var(--photo-ink);
}

.home-page .site-header:not(.is-scrolled) .booking-bar {
  background: rgba(255, 248, 236, 0.08);
  color: rgba(255, 248, 236, 0.78);
}

.home-page .site-header:not(.is-scrolled) .brand-mark,
.home-page .site-header:not(.is-scrolled) .primary-nav a {
  color: var(--photo-cream);
}

.home-page .site-header:not(.is-scrolled) .brand-subtitle,
.home-page .site-header:not(.is-scrolled) .primary-nav a:not(.is-active) {
  color: rgba(255, 248, 236, 0.68);
}

.home-page .site-header:not(.is-scrolled) .primary-nav a:hover,
.home-page .site-header:not(.is-scrolled) .primary-nav a.is-active {
  border-color: var(--photo-cream);
  color: var(--photo-cream);
}

.home-page .site-header:not(.is-scrolled) .nav-toggle {
  border-color: rgba(255, 248, 236, 0.42);
  color: var(--photo-cream);
}

.home-page.is-camera-captured .site-header {
  background: rgba(17, 16, 14, 0.035);
  border-bottom-color: rgba(255, 255, 255, 0.1);
  box-shadow: none;
  color: rgba(255, 255, 255, 0.72);
}

.home-page.is-camera-captured .site-header .booking-bar {
  background: rgba(17, 16, 14, 0.04);
  color: rgba(255, 255, 255, 0.54);
}

.home-page.is-camera-captured .site-header .brand-mark,
.home-page.is-camera-captured .site-header .primary-nav a {
  color: rgba(255, 255, 255, 0.72);
}

.home-page.is-camera-captured .site-header .brand-subtitle,
.home-page.is-camera-captured .site-header .primary-nav a:not(.is-active) {
  color: rgba(255, 255, 255, 0.52);
}

.home-page .photo-hero {
  padding: 0;
}

.home-page .photo-hero__stage {
  min-height: 100vh;
  min-height: 100dvh;
}

.photo-hero__stage::before {
  background:
    radial-gradient(circle at var(--hero-x) var(--hero-y), rgba(255, 248, 236, 0.26), transparent 0 12%, rgba(255, 248, 236, 0.08) 22%, transparent 38%),
    radial-gradient(circle at calc(var(--hero-x) + 12%) calc(var(--hero-y) + 8%), rgba(64, 95, 88, 0.42), transparent 28%),
    radial-gradient(circle at calc(var(--hero-x) - 22%) calc(var(--hero-y) + 18%), rgba(170, 56, 50, 0.22), transparent 30%);
  content: "";
  inset: 0;
  mix-blend-mode: screen;
  opacity: 0.72;
  pointer-events: none;
  position: absolute;
  transition: background-position 220ms ease;
  z-index: 3;
}

.home-page .photo-hero__slide {
  transform: scale(1.08) translate3d(-1%, 0, 0);
  transition: opacity 1200ms ease;
}

.home-page .photo-hero__slide.is-active {
  animation: cinematic-drift 5.5s linear both;
  transform: scale(1.02);
}

.home-page .photo-hero__slide img {
  filter: brightness(0.52) contrast(1.14) saturate(0.9);
}

.home-page .photo-hero__shade {
  background:
    linear-gradient(90deg, rgba(8, 9, 10, 0.76), rgba(8, 9, 10, 0.22) 47%, rgba(8, 9, 10, 0.62)),
    linear-gradient(0deg, rgba(8, 9, 10, 0.86), transparent 52%),
    linear-gradient(180deg, rgba(8, 9, 10, 0.78), transparent 30%);
  z-index: 2;
}

.photo-hero__lens {
  border: 1px solid rgba(255, 248, 236, 0.22);
  border-radius: 50%;
  height: clamp(260px, 38vw, 620px);
  left: var(--hero-x);
  pointer-events: none;
  position: absolute;
  top: var(--hero-y);
  transform: translate(-50%, -50%);
  width: clamp(260px, 38vw, 620px);
  z-index: 4;
}

.photo-hero__lens::before,
.photo-hero__lens::after {
  border: 1px solid rgba(255, 248, 236, 0.13);
  border-radius: inherit;
  content: "";
  inset: 10%;
  position: absolute;
}

.photo-hero__lens::after {
  animation: lens-spin 18s linear infinite;
  border-color: transparent rgba(255, 248, 236, 0.32) transparent rgba(170, 56, 50, 0.28);
  inset: 24%;
}

.photo-hero__scan {
  background: linear-gradient(180deg, transparent, rgba(255, 248, 236, 0.36), transparent);
  height: 20%;
  inset: auto 30px 14%;
  opacity: 0.18;
  pointer-events: none;
  position: absolute;
  z-index: 5;
  animation: scan-pass 6.5s ease-in-out infinite;
}

.home-page .photo-hero__reticle {
  border-color: rgba(255, 248, 236, 0.34);
  inset: clamp(90px, 10vw, 110px) clamp(16px, 3vw, 46px) clamp(16px, 3vw, 46px);
  z-index: 6;
}

.home-page .photo-hero__reticle::before,
.home-page .photo-hero__reticle::after {
  opacity: 0.68;
}

.home-page .photo-hero__copy {
  bottom: clamp(2.4rem, 6vw, 6.2rem);
  color: var(--photo-cream);
  gap: 1.05rem;
  z-index: 7;
}

.home-page .photo-hero__copy[data-reveal] {
  opacity: 1;
  transform: none;
}

.home-page .photo-hero h1 {
  letter-spacing: -0.07em;
  text-shadow: 0 22px 70px rgba(0, 0, 0, 0.42);
}

.home-page .photo-hero h1 span {
  animation: hero-title-rise 900ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.home-page .photo-hero h1 span:nth-child(2) {
  animation-delay: 110ms;
}

.home-page .photo-hero h1 span:nth-child(3) {
  animation-delay: 220ms;
}

.home-page .photo-hero__actions .button {
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  white-space: normal;
}

.photo-hero__meta {
  color: rgba(255, 248, 236, 0.62);
  display: grid;
  font-size: 0.72rem;
  font-weight: 700;
  gap: 0.55rem;
  letter-spacing: 0.14em;
  position: absolute;
  right: clamp(1.5rem, 4vw, 4rem);
  text-transform: uppercase;
  top: clamp(8.3rem, 10vw, 9.7rem);
  z-index: 7;
}

.photo-hero__meta span:last-child {
  color: var(--photo-signal);
}

.photo-marquee {
  background: var(--photo-night);
  border-bottom: 1px solid rgba(255, 248, 236, 0.12);
  border-top: 1px solid rgba(255, 248, 236, 0.12);
  color: var(--photo-cream);
  overflow: hidden;
  padding: 0.9rem 0;
}

.photo-marquee__track {
  animation: marquee-flow 24s linear infinite;
  display: flex;
  gap: 2rem;
  width: max-content;
}

.photo-marquee__track span {
  align-items: center;
  display: inline-flex;
  font-size: clamp(1.4rem, 3vw, 3.2rem);
  font-family: var(--font-display);
  gap: 2rem;
  line-height: 1;
  opacity: 0.92;
  white-space: nowrap;
}

.photo-marquee__track span::after {
  background: var(--photo-signal);
  border-radius: 50%;
  content: "";
  height: 8px;
  width: 8px;
}

.home-page .photo-intro {
  background: var(--photo-paper);
  padding-bottom: clamp(2rem, 3vw, 3rem);
}

.home-page .photo-intro__grid {
  align-items: center;
  border-bottom: 0;
  gap: clamp(2rem, 7vw, 7rem);
  grid-template-columns: minmax(0, 0.86fr) minmax(360px, 0.8fr);
  padding-bottom: 0;
}

.photo-intro__copy {
  display: grid;
  gap: clamp(1rem, 2.6vw, 2.2rem);
}

.home-page .photo-intro h2,
.photo-gallery__head h2,
.photo-sequence__line,
.home-page .photo-closing h2 {
  letter-spacing: -0.06em;
}

.home-page .photo-intro p:last-child {
  max-width: 640px;
}

.contact-sheet {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: 1.08fr 0.72fr;
  position: relative;
}

.contact-sheet::before {
  background:
    linear-gradient(90deg, rgba(17, 16, 14, 0.18) 1px, transparent 1px),
    linear-gradient(180deg, rgba(17, 16, 14, 0.18) 1px, transparent 1px);
  background-size: 22px 22px;
  content: "";
  inset: -7% -8% 12% 24%;
  opacity: 0.26;
  position: absolute;
}

.contact-sheet__frame {
  background: #17130f;
  color: var(--photo-cream);
  margin: 0;
  overflow: hidden;
  position: relative;
  transform-style: preserve-3d;
}

.contact-sheet__frame.is-large {
  grid-row: span 2;
}

.contact-sheet__frame.is-dark {
  align-self: end;
}

.contact-sheet__frame img {
  aspect-ratio: 4 / 5;
  filter: brightness(0.78) contrast(1.08) saturate(0.92);
  height: 100%;
  object-fit: cover;
  transition: transform 900ms cubic-bezier(0.16, 1, 0.3, 1), filter 700ms ease;
  width: 100%;
}

.contact-sheet__frame:not(.is-large) img {
  aspect-ratio: 1 / 1;
}

.contact-sheet__frame:hover img,
.contact-sheet__frame.is-tilting img {
  filter: brightness(0.9) contrast(1.05) saturate(1);
  transform: scale(1.045);
}

.contact-sheet__frame figcaption {
  bottom: 0.8rem;
  font-size: 0.68rem;
  font-weight: 700;
  left: 0.85rem;
  letter-spacing: 0.13em;
  position: absolute;
  text-transform: uppercase;
  z-index: 2;
}

.contact-sheet__frame::after,
.photo-services__preview::after,
.film-strip figure::after,
.photo-closing::after {
  background:
    linear-gradient(90deg, rgba(255, 248, 236, 0.34) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255, 248, 236, 0.2) 1px, transparent 1px);
  background-size: 36px 36px;
  content: "";
  inset: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  transition: opacity 260ms ease;
}

.contact-sheet__frame:hover::after,
.photo-services__preview:hover::after,
.film-strip figure:hover::after {
  opacity: 0.22;
}

.photo-sequence {
  background: var(--photo-night);
  color: var(--photo-cream);
  overflow: hidden;
  padding: clamp(2.5rem, 4vw, 4rem) 20px;
  position: relative;
}

.photo-sequence::before {
  background:
    radial-gradient(circle at 18% 22%, rgba(170, 56, 50, 0.3), transparent 25%),
    radial-gradient(circle at 88% 72%, rgba(64, 95, 88, 0.42), transparent 26%),
    linear-gradient(90deg, rgba(255, 248, 236, 0.08) 1px, transparent 1px);
  background-size: auto, auto, 76px 76px;
  content: "";
  inset: 0;
  opacity: 0.78;
  position: absolute;
}

.photo-sequence__inner {
  display: grid;
  gap: clamp(0.6rem, 1vw, 1rem);
  position: relative;
  z-index: 1;
}

.photo-sequence__inner--split {
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.5fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
}

.photo-sequence__text {
  display: grid;
  gap: clamp(0.6rem, 1vw, 1rem);
}

.photo-sequence__frame {
  background: #15120f;
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 248, 236, 0.12);
}

.photo-sequence__frame img {
  width: 100%;
  display: block;
  filter: brightness(0.85) contrast(1.06) saturate(0.94);
}

@media (max-width: 900px) {
  .photo-sequence__inner--split {
    grid-template-columns: 1fr;
  }
}

.photo-sequence__line {
  display: grid;
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.5vw, 3.2rem);
  font-weight: 400;
  grid-template-columns: 1fr 1fr;
  gap: 0.3rem 2rem;
  line-height: 1;
}

.photo-sequence__line span {
  transform-origin: left;
  transition: color 260ms ease, transform 260ms ease;
}

.photo-sequence__line span:nth-child(even) {
  text-align: right;
}

.photo-sequence__line span:hover {
  color: var(--photo-signal);
  transform: translateX(0.18em);
}

.photo-sequence__inner > p:last-child {
  color: rgba(255, 248, 236, 0.68);
  font-size: 1.22rem;
  line-height: 1.6;
  max-width: 640px;
}

.home-page .photo-services {
  background: linear-gradient(180deg, var(--photo-paper), #ece4d9);
}

.home-page .photo-services__grid {
  align-items: start;
}

.home-page .photo-services__preview {
  border: 1px solid rgba(17, 16, 14, 0.16);
  box-shadow: 0 36px 90px rgba(17, 16, 14, 0.16);
  min-height: min(70vh, 760px);
  min-height: min(70dvh, 760px);
}

.home-page .photo-services__preview img {
  transform-origin: center;
}

.home-page .photo-services__preview span {
  background: rgba(17, 16, 14, 0.72);
  color: rgba(255, 248, 236, 0.82);
  font-size: 0.68rem;
  font-weight: 700;
  left: 1rem;
  letter-spacing: 0.14em;
  padding: 0.4rem 0.55rem;
  position: absolute;
  text-transform: uppercase;
  top: 1rem;
  z-index: 3;
}

.home-page .photo-service {
  min-height: 150px;
  position: relative;
}

.home-page .photo-service::before {
  background: var(--photo-signal);
  content: "";
  height: 100%;
  left: -1.2rem;
  opacity: 0;
  position: absolute;
  top: 0;
  transform: scaleY(0);
  transform-origin: center;
  transition: opacity 240ms ease, transform 360ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 3px;
}

.home-page .photo-service:hover::before,
.home-page .photo-service.is-active::before {
  opacity: 1;
  transform: scaleY(1);
}

.home-page .photo-service:hover,
.home-page .photo-service.is-active {
  color: var(--photo-signal);
}

.photo-gallery {
  background: var(--photo-night);
  color: var(--photo-cream);
  overflow: hidden;
  padding: clamp(2.5rem, 4vw, 4rem) 0;
}

.photo-gallery__head {
  display: grid;
  gap: 1rem;
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
  padding: 0 20px;
}

.photo-gallery__head h2 {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.8vw, 3.4rem);
  font-weight: 400;
  line-height: 1;
  max-width: 780px;
}

.photo-gallery .film-strip {
  padding: 0;
}

.photo-gallery .film-strip__track {
  animation-duration: 38s;
}

.photo-gallery .film-strip figure {
  border: 1px solid rgba(255, 248, 236, 0.12);
  box-shadow: 0 32px 70px rgba(0, 0, 0, 0.34);
  transform-style: preserve-3d;
}

.photo-gallery .film-strip img {
  filter: brightness(0.76) contrast(1.1) saturate(0.92);
}

.testimonial-section {
  background: var(--photo-night);
  color: var(--photo-cream);
  padding: clamp(3rem, 5vw, 5rem) 20px;
}

.testimonial-section__inner {
  display: grid;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  max-width: 800px;
}

.testimonial-carousel {
  height: 260px;
  position: relative;
  overflow: hidden;
}

.testimonial-card {
  border: none;
  margin: 0;
  padding: 0;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  opacity: 0;
  transform: translate3d(-80px, 30px, 0) scale(0.82);
  will-change: transform, opacity;
}

.testimonial-card.is-entering {
  animation: testi-enter 1.4s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

.testimonial-card.is-active {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.testimonial-card.is-exiting {
  animation: testi-exit 1.2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes testi-enter {
  from {
    opacity: 0;
    transform: translate3d(-80px, 30px, 0) scale(0.82);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@keyframes testi-exit {
  from {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }
  to {
    opacity: 0;
    transform: translate3d(100px, -20px, 0) scale(0.85);
  }
}

.testimonial__open {
  color: rgba(170, 56, 50, 0.5);
  display: block;
  font-family: var(--font-display);
  font-size: clamp(5rem, 10vw, 8rem);
  line-height: 0.6;
  margin-bottom: 0.2rem;
}

.testimonial__text {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-style: italic;
  line-height: 1.35;
}

.testimonial__author {
  align-items: center;
  display: flex;
  gap: 1rem;
  margin-top: clamp(1.2rem, 2vw, 1.8rem);
}

.testimonial__line {
  background: rgba(170, 56, 50, 0.6);
  display: block;
  height: 1px;
  width: 40px;
}

.testimonial__author strong {
  color: var(--photo-cream);
  display: block;
  font-size: 1rem;
  font-weight: 700;
}

.testimonial__author span:last-child {
  color: rgba(255, 248, 236, 0.5);
  font-size: 0.85rem;
}

.home-page .photo-closing {
  min-height: auto;
  overflow: hidden;
  padding: clamp(2rem, 3vw, 3rem) 20px;
  position: relative;
}

.photo-closing__back {
  inset: 0;
  position: absolute;
}

.photo-closing__back img {
  filter: brightness(0.28) contrast(1.18) saturate(0.9);
  height: 100%;
  object-fit: cover;
  transform: scale(1.04);
  width: 100%;
}

.home-page .photo-closing::before {
  background:
    radial-gradient(circle at 74% 26%, rgba(170, 56, 50, 0.26), transparent 30%),
    linear-gradient(90deg, rgba(16, 16, 15, 0.86), rgba(16, 16, 15, 0.48));
  content: "";
  inset: 0;
  position: absolute;
  z-index: 1;
}

.home-page .photo-closing::after {
  opacity: 0.13;
  z-index: 2;
}

.home-page .photo-closing__inner {
  align-items: start;
  grid-template-columns: 1fr;
  justify-items: start;
  min-height: auto;
  position: relative;
  z-index: 3;
}

.home-page .photo-closing h2 {
  font-size: clamp(2rem, 3.8vw, 3.4rem);
}

.home-page [data-reveal] {
  transition-duration: 760ms;
  transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
}

.home-page [data-reveal="clip"] {
  clip-path: inset(0 0 100% 0);
  opacity: 1;
  transform: translateY(0);
  transition: clip-path 760ms cubic-bezier(0.16, 1, 0.3, 1);
}

.home-page [data-reveal="clip"].is-visible {
  clip-path: inset(0 0 0 0);
}

.home-page [data-reveal="image"] {
  clip-path: inset(9% 9% 9% 9%);
  opacity: 0;
  transform: translateY(34px) scale(0.98);
}

.home-page [data-reveal="image"].is-visible {
  clip-path: inset(0 0 0 0);
  opacity: 1;
  transform: translateY(0) scale(1);
}

@keyframes cinematic-drift {
  0% {
    transform: scale(1.08) translate3d(-1.2%, 0, 0);
  }
  100% {
    transform: scale(1.02) translate3d(1.2%, 0, 0);
  }
}

@keyframes lens-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

@keyframes scan-pass {
  0%,
  100% {
    transform: translateY(-120%);
  }
  48%,
  54% {
    transform: translateY(120%);
  }
}

@keyframes hero-title-rise {
  from {
    opacity: 0;
    transform: translateY(0.18em);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes marquee-flow {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-50% - 1rem));
  }
}

@media (max-width: 1000px) {
  .home-page .photo-intro__grid {
    grid-template-columns: 1fr;
  }

  .contact-sheet {
    max-width: 760px;
  }

  .home-page .photo-services__preview {
    min-height: auto;
  }
}

@media (max-width: 900px) {
  .home-page .nav-shell {
    position: relative;
  }

  .home-page .nav-toggle {
    background: var(--photo-cream) !important;
    border-color: var(--photo-cream) !important;
    color: var(--photo-ink) !important;
    display: inline-flex !important;
    flex: 0 0 42px;
    height: 42px;
    margin-left: auto;
    opacity: 1;
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    visibility: visible;
    width: 42px;
    z-index: 90;
  }

  .home-page .primary-nav {
    background: rgba(243, 238, 229, 0.97);
  }

  .home-page .site-header:not(.is-scrolled) .primary-nav a {
    color: var(--photo-ink);
  }

  .photo-hero__meta {
    display: none;
  }
}

@media (max-width: 640px) {
  .home-page .photo-hero__stage {
    min-height: 100vh;
    min-height: 100dvh;
  }

  .home-page .photo-hero__copy {
    bottom: 4.2rem;
    max-width: none;
  }

  .home-page .photo-hero__copy p:not(.photo-hero__overline) {
    font-size: 1rem;
    max-width: 330px;
    overflow-wrap: anywhere;
  }

  .photo-hero__scan,
  .photo-hero__lens {
    display: none;
  }

  .photo-marquee__track {
    animation-duration: 18s;
  }

  .home-page .photo-intro,
  .photo-sequence,
  .home-page .photo-services,
  .photo-gallery,
  .home-page .photo-closing {
    padding-left: 16px;
    padding-right: 16px;
  }

  .contact-sheet {
    grid-template-columns: 1fr;
  }

  .contact-sheet::before {
    inset: -4%;
  }

  .photo-sequence__line span:nth-child(even) {
    justify-self: start;
  }

  .photo-gallery__head {
    padding: 0;
  }
}


/* Karvirec v6 - déclenchement appareil photo sur le hero */
.home-page .photo-hero__stage {
  cursor: crosshair;
  isolation: isolate;
}

.home-page .photo-hero__stage a,
.home-page .photo-hero__stage button {
  cursor: pointer;
}

.home-page .photo-hero__stage.is-captured .photo-hero__slide.is-active {
  animation-play-state: paused;
}

.home-page .photo-hero__stage.is-captured .photo-hero__slide.is-active img {
  filter: brightness(0.72) contrast(1.24) saturate(0.88);
}

.home-page .photo-hero__stage.is-captured .photo-hero__grain,
.home-page .photo-hero__stage.is-captured .photo-hero__scan,
.home-page .photo-hero__stage.is-captured .photo-hero__lens::after {
  animation-play-state: paused;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__status span:nth-child(2)::before,
.home-page .photo-hero__stage.is-captured .photo-hero__status span:nth-child(2)::before {
  animation-play-state: paused;
}

.photo-hero__focus {
  border: 1px solid rgba(255, 248, 236, 0.62);
  height: clamp(86px, 11vw, 160px);
  left: var(--hero-x);
  pointer-events: none;
  position: absolute;
  top: var(--hero-y);
  transform: translate(-50%, -50%);
  transition: left 180ms ease, top 180ms ease, transform 220ms ease, opacity 220ms ease;
  width: clamp(86px, 11vw, 160px);
  z-index: 6;
}

.photo-hero__focus::before,
.photo-hero__focus::after {
  background: rgba(255, 248, 236, 0.48);
  content: "";
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
}

.photo-hero__focus::before {
  height: 1px;
  width: 34%;
}

.photo-hero__focus::after {
  height: 34%;
  width: 1px;
}

.photo-hero__focus {
  animation: focus-breathe 2.8s ease-in-out infinite;
}

.photo-hero__shutter,
.photo-hero__flash {
  inset: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
}

.photo-hero__shutter {
  background: transparent;
  overflow: hidden;
  z-index: 10;
}

.photo-hero__shutter::before,
.photo-hero__shutter::after {
  background: linear-gradient(180deg, rgba(3, 3, 3, 0.96), rgba(13, 12, 11, 0.86));
  content: "";
  height: 52%;
  left: 0;
  opacity: 0;
  position: absolute;
  right: 0;
  transform: translateY(-105%);
  will-change: opacity, transform;
}

.photo-hero__shutter::before {
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
  top: 0;
}

.photo-hero__shutter::after {
  background: linear-gradient(0deg, rgba(3, 3, 3, 0.96), rgba(13, 12, 11, 0.86));
  bottom: 0;
  box-shadow: 0 -18px 42px rgba(0, 0, 0, 0.34);
  transform: translateY(105%);
}

.photo-hero__flash {
  background:
    radial-gradient(circle at var(--hero-x) var(--hero-y), rgba(255, 255, 255, 0.96), rgba(255, 248, 236, 0.48) 20%, transparent 50%),
    rgba(255, 255, 255, 0.3);
  mix-blend-mode: screen;
  z-index: 12;
}

.photo-hero__capture {
  align-items: center;
  border: 1px solid rgba(255, 248, 236, 0.32);
  color: rgba(255, 248, 236, 0.72);
  display: flex;
  font-size: 0.68rem;
  font-weight: 700;
  justify-content: center;
  letter-spacing: 0.14em;
  opacity: 0;
  padding: 0.45rem 0.6rem;
  pointer-events: none;
  position: absolute;
  right: clamp(1.5rem, 4vw, 4rem);
  text-transform: uppercase;
  top: clamp(12rem, 14vw, 14rem);
  transform: translateY(-8px);
  transition: opacity 220ms ease, transform 220ms ease;
  z-index: 13;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__shutter {
  animation: shutter-click 640ms cubic-bezier(0.16, 1, 0.3, 1);
}

.home-page .photo-hero__stage.is-shooting .photo-hero__shutter::before {
  animation: shutter-top 640ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__shutter::after {
  animation: shutter-bottom 640ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__flash {
  animation: camera-flash 540ms cubic-bezier(0.16, 1, 0.3, 1);
}

.home-page .photo-hero__stage.is-shooting .photo-hero__reticle {
  transform: scale(0.985);
  transform-origin: center;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__focus {
  transform: translate(-50%, -50%) scale(0.96);
}

.home-page .photo-hero__stage.is-captured .photo-hero__capture {
  opacity: 1;
  transform: translateY(0);
}

.home-page .photo-hero__stage.is-captured .photo-hero__focus {
  animation: focus-lock 420ms ease both;
  border-color: rgba(255, 248, 236, 0.96);
}

.home-page .photo-hero__stage.is-captured .photo-hero__meta span:last-child {
  color: var(--photo-cream);
}

@keyframes focus-breathe {
  0%,
  100% {
    opacity: 0.46;
    transform: translate(-50%, -50%) scale(1);
  }
  50% {
    opacity: 0.86;
    transform: translate(-50%, -50%) scale(1.05);
  }
}

@keyframes focus-lock {
  0% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.12);
  }
  100% {
    opacity: 0.84;
    transform: translate(-50%, -50%) scale(0.82);
  }
}

@keyframes shutter-click {
  0% {
    opacity: 0;
  }
  16%,
  48% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes shutter-top {
  0% {
    opacity: 0;
    transform: translateY(-105%);
  }
  24%,
  44% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(-105%);
  }
}

@keyframes shutter-bottom {
  0% {
    opacity: 0;
    transform: translateY(105%);
  }
  24%,
  44% {
    opacity: 1;
    transform: translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateY(105%);
  }
}

@keyframes camera-flash {
  0% {
    opacity: 0;
  }
  12% {
    opacity: 1;
  }
  24% {
    opacity: 0.82;
  }
  100% {
    opacity: 0;
  }
}

@media (max-width: 640px) {
  .photo-hero__focus {
    height: 92px;
    opacity: 0.48;
    width: 92px;
  }

  .photo-hero__capture {
    bottom: 1rem;
    right: 1rem;
    top: auto;
  }
}

/* Karvirec v7 - fond vidéo et pause de capture */
.photo-hero__video {
  filter: brightness(0.58) contrast(1.18) saturate(0.88);
  height: 100%;
  inset: 0;
  object-fit: cover;
  object-position: center;
  position: absolute;
  transform: scale(1.03);
  transition: filter 220ms ease, transform 2200ms cubic-bezier(0.16, 1, 0.3, 1);
  width: 100%;
  z-index: 0;
}

.home-page .photo-hero__slide {
  display: none;
}

.home-page .photo-hero__slide.is-active {
  opacity: 0.18;
}

.home-page .photo-hero__slide img {
  opacity: 0.58;
}

.home-page .photo-hero__stage.is-shooting .photo-hero__video,
.home-page .photo-hero__stage.is-captured .photo-hero__video {
  filter: brightness(0.76) contrast(1.2) saturate(0.78);
  transform: scale(1.018);
}

.home-page .photo-hero__stage.is-captured .photo-hero__slide.is-active {
  opacity: 0.08;
}

.home-page .photo-hero__stage.is-captured .photo-hero__scan,
.home-page .photo-hero__stage.is-captured .photo-hero__focus {
  opacity: 0.26;
}

.photo-hero__film-svg {
  transform-origin: center;
}

@media (max-width: 640px) {
  .photo-hero__video {
    object-position: center;
  }

  .home-page .photo-hero__slide.is-active {
    opacity: 0.12;
  }
}

/* Karvirec v8 - capture photo propre */
.home-page .photo-hero__stage::before {
  transition: opacity 360ms ease, background-position 220ms ease;
}

/* Cadre fixe ::after supprimé — remplacé par le cadre absolu dans .photo-hero__stage::after */

.home-page .photo-hero__stage::after {
  border: clamp(8px, 1.2vw, 16px) solid rgba(255, 255, 255, 0.98);
  box-shadow:
    0 24px 80px rgba(0, 0, 0, 0.34),
    inset 0 0 0 1px rgba(17, 16, 14, 0.1);
  content: "";
  inset: clamp(90px, 10vw, 110px) clamp(0.9rem, 2vw, 1.7rem) clamp(0.9rem, 2vw, 1.7rem);
  opacity: 0;
  pointer-events: none;
  position: absolute;
  transform: scale(0.982);
  transition: opacity 260ms ease, transform 620ms cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 11;
}

.home-page .photo-hero__shade,
.home-page .photo-hero__grain,
.home-page .photo-hero__lens,
.home-page .photo-hero__reticle,
.home-page .photo-hero__scan,
.home-page .photo-hero__copy,
.home-page .photo-hero__meta {
  transition:
    opacity 280ms ease,
    transform 520ms cubic-bezier(0.16, 1, 0.3, 1);
}

.home-page .photo-hero__stage.is-shooting .photo-hero__video {
  filter: brightness(0.72) contrast(1.18) saturate(0.9);
  transform: scale(1.018);
}

.home-page .photo-hero__stage.is-captured .photo-hero__video {
  filter: none;
  transform: scale(1);
}

.home-page .photo-hero__stage.is-captured::before,
.home-page .photo-hero__stage.is-captured .photo-hero__shade,
.home-page .photo-hero__stage.is-captured .photo-hero__grain,
.home-page .photo-hero__stage.is-captured .photo-hero__lens,
.home-page .photo-hero__stage.is-captured .photo-hero__reticle,
.home-page .photo-hero__stage.is-captured .photo-hero__scan,
.home-page .photo-hero__stage.is-captured .photo-hero__focus,
.home-page .photo-hero__stage.is-captured .photo-hero__copy,
.home-page .photo-hero__stage.is-captured .photo-hero__meta {
  opacity: 0;
}

.home-page .photo-hero__stage.is-captured::after {
  opacity: 1;
  transform: scale(1);
}

.home-page .photo-hero__stage.is-captured .photo-hero__focus {
  animation: none;
}

.home-page .photo-hero__stage.is-captured .photo-hero__copy {
  pointer-events: none;
  transform: translateY(14px);
}

.home-page .photo-hero__stage.is-captured .photo-hero__capture {
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.98);
  box-shadow: 0 14px 42px rgba(0, 0, 0, 0.22);
  color: #151413;
}

@media (max-width: 640px) {
  .home-page .photo-hero__stage::after {
    border-width: 8px;
    inset: 0.7rem;
  }
}

