@import url('/assets/css/pinapp-a11y-performance.css');
@import url('/assets/css/pp-chatbot.css');
@import url('/assets/css/pinapp-apple-polish.css');
@import url('/assets/css/pp-theme-toggle.css');
/* Pinapp — palette nuit / jour (alignée sauvegarde + .cursorrules), tokens optimisés */
:root {
  --bg: #080d18;
  --surface: #0c1424;
  --bg-card: rgba(255, 255, 255, 0.04);
  --text: #f0f8ff;
  --muted: rgba(240, 248, 255, 0.72);
  --nacre: #e8f4f8;
  /* Tokens « pp » (couche Awwwards / diagnostics) */
  --pp-teal: #00e5b0;
  --pp-violet: #5b4fe8;
  --pp-bg: #050a14;
  --pp-card: var(--bg-card);
  --pp-text: #e8f4f8;
  --pp-muted: rgba(232, 244, 248, 0.5);
  --accent: #00e5b0;
  --accent-2: #b388ff;
  --accent-3: #7fffea;
  --accent-4: #e040fb;
  --accent-rgb: 0, 229, 176;
  --accent-2-rgb: 179, 136, 255;
  --border: rgba(179, 136, 255, 0.08);
  --pp-border: rgba(0, 229, 176, 0.08);
  --card-border: rgba(179, 136, 255, 0.08);
  --separator: rgba(0, 229, 176, 0.06);
  --btn-cta-bg: rgba(91, 60, 180, 0.85);
  --btn-cta-bd: rgba(179, 136, 255, 0.3);
  --chart-warn: #ff7a6a;
  --teal: var(--accent);
  --violet: var(--accent-2);
  --teal-glow: rgba(var(--accent-rgb), 0.12);
  --violet-glow: rgba(var(--accent-2-rgb), 0.12);
  --ray-mid: rgba(var(--accent-rgb), 0.22);
  --ray-mid-2: rgba(var(--accent-2-rgb), 0.2);
  --text-on-accent: #061018;
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --max: 75rem;
  --focus: 0 0 0 0.125rem var(--accent), 0 0 0 0.25rem rgba(var(--accent-rgb), 0.35);
  --glass-radius: 20px;
  --glass-blur: 20px;
  --glass-sat: 180%;
}

html[data-theme='light'] {
  color-scheme: light;
  --bg: #0a2a2e;
  --surface: rgba(10, 60, 65, 0.6);
  --bg-card: rgba(10, 60, 65, 0.6);
  --text: #e8fffd;
  --muted: rgba(232, 255, 253, 0.72);
  --nacre: #e8f4f8;
  --accent: #7fffea;
  --accent-2: #c4b5fd;
  --accent-3: #ffffff;
  --accent-4: #a78bfa;
  --accent-rgb: 127, 255, 234;
  --accent-2-rgb: 196, 181, 253;
  --border: rgba(196, 181, 253, 0.12);
  --card-border: rgba(196, 181, 253, 0.12);
  --separator: rgba(127, 255, 234, 0.08);
  --btn-cta-bg: rgba(109, 40, 217, 0.8);
  --btn-cta-bd: rgba(196, 181, 253, 0.3);
  --chart-warn: #f07167;
  --teal-glow: rgba(var(--accent-rgb), 0.1);
  --violet-glow: rgba(var(--accent-2-rgb), 0.1);
  --ray-mid: rgba(var(--accent-rgb), 0.18);
  --ray-mid-2: rgba(var(--accent-2-rgb), 0.18);
  --text-on-accent: #0a1820;
  --focus: 0 0 0 0.125rem var(--accent), 0 0 0 0.25rem rgba(var(--accent-rgb), 0.35);
  --teal: var(--accent);
  --violet: var(--accent-2);
  --pp-bg: #fafbfe;
  --pp-card: #ffffff;
  --pp-text: #0d1b3e;
  --pp-muted: rgba(13, 27, 62, 0.6);
  --pp-teal: #00b4a6;
  --pp-violet: #5b4fe8;
  --pp-border: rgba(91, 79, 232, 0.15);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: auto;
  overflow-x: hidden;
}

body {
  margin: 0;
  overflow-x: hidden;
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: 1rem;
  line-height: 1.8;
  background: var(--bg);
  color: var(--text);
  transition:
    background-color 0.3s var(--ease),
    color 0.3s var(--ease);
  -webkit-font-smoothing: antialiased;
}

/* Mode jour — océan Avatar 2 : profondeur, bleus, lumière sous-marine */
html[data-theme='light'] body {
  background-color: #0a2a2e;
  background-image:
    radial-gradient(ellipse 125% 85% at 50% -12%, rgba(120, 220, 240, 0.22), transparent 54%),
    radial-gradient(ellipse 90% 55% at 102% 38%, rgba(70, 155, 210, 0.18), transparent 50%),
    radial-gradient(ellipse 70% 48% at -8% 78%, rgba(45, 110, 150, 0.16), transparent 46%),
    linear-gradient(168deg, #0c3640 0%, #0a2a2e 45%, #061f26 100%);
}

#bg-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

.bg-light-veil {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.bg-light-veil__pulse {
  position: absolute;
  width: min(92vw, 56rem);
  height: min(92vw, 56rem);
  border-radius: 50%;
  left: 50%;
  top: -18%;
  transform: translateX(-50%);
  background: radial-gradient(closest-side, rgba(var(--accent-rgb), 0.18), transparent 72%);
  filter: blur(48px);
  mix-blend-mode: screen;
  opacity: 0.5;
  animation: lightPulse 16s ease-in-out infinite;
}

.bg-light-veil__pulse--b {
  top: auto;
  bottom: -28%;
  width: min(110vw, 64rem);
  height: min(110vw, 64rem);
  background: radial-gradient(closest-side, rgba(var(--accent-2-rgb), 0.16), transparent 74%);
  animation-duration: 22s;
  animation-delay: -5s;
}

.bg-light-veil__pulse--c {
  top: 38%;
  left: -12%;
  width: min(70vw, 36rem);
  height: min(70vw, 36rem);
  transform: none;
  background: radial-gradient(closest-side, rgba(var(--accent-rgb), 0.1), transparent 70%);
  animation: lightPulseSide 18s ease-in-out infinite;
  animation-delay: -2s;
}

html[data-theme='light'] .bg-light-veil__pulse {
  mix-blend-mode: screen;
  opacity: 0.52;
  background: radial-gradient(
    closest-side,
    rgba(130, 230, 245, 0.28) 0%,
    rgba(70, 160, 200, 0.14) 42%,
    transparent 72%
  );
  filter: blur(52px);
}

html[data-theme='light'] .bg-light-veil__pulse--b {
  opacity: 0.46;
  background: radial-gradient(
    closest-side,
    rgba(200, 190, 255, 0.22) 0%,
    rgba(90, 130, 195, 0.12) 48%,
    transparent 74%
  );
}

html[data-theme='light'] .bg-light-veil__pulse--c {
  opacity: 0.4;
  background: radial-gradient(
    closest-side,
    rgba(85, 185, 215, 0.24) 0%,
    rgba(40, 100, 140, 0.1) 55%,
    transparent 72%
  );
}

@keyframes lightPulse {
  0%,
  100% {
    transform: translateX(-50%) scale(1);
    opacity: 0.42;
  }
  50% {
    transform: translateX(-50%) scale(1.14);
    opacity: 0.62;
  }
}

@keyframes lightPulseSide {
  0%,
  100% {
    transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.32;
  }
  50% {
    transform: translate3d(4vw, -2vh, 0) scale(1.1);
    opacity: 0.48;
  }
}

.bg-rays {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}

.bg-rays span {
  position: absolute;
  width: 140%;
  height: 1px;
  left: -20%;
  background: linear-gradient(90deg, transparent, var(--ray-mid), transparent);
  opacity: 0.02;
  transform-origin: center;
  transform: rotate(-35deg);
  animation: rayDrift 22s linear infinite;
}

html[data-theme='light'] .bg-rays span {
  background: linear-gradient(
    90deg,
    transparent,
    rgba(120, 210, 235, 0.35),
    rgba(196, 181, 253, 0.28),
    transparent
  );
  opacity: 0.038;
}

.bg-rays span:nth-child(1) {
  top: 18%;
  animation-duration: 20s;
}
.bg-rays span:nth-child(2) {
  top: 48%;
  animation-duration: 30s;
  animation-delay: -6s;
}
.bg-rays span:nth-child(3) {
  top: 72%;
  animation-duration: 25s;
  animation-delay: -12s;
}

.bg-rays span:nth-child(4) {
  top: 32%;
  transform: rotate(-28deg);
  animation-duration: 34s;
  animation-delay: -9s;
  opacity: 0.018;
}

.bg-rays span:nth-child(5) {
  top: 62%;
  transform: rotate(-41deg);
  animation-duration: 28s;
  animation-delay: -15s;
  opacity: 0.016;
}

html[data-theme='light'] .bg-rays span:nth-child(4),
html[data-theme='light'] .bg-rays span:nth-child(5) {
  opacity: 0.05;
}

@keyframes rayDrift {
  0% {
    transform: rotate(-35deg) translateX(-30%);
  }
  100% {
    transform: rotate(-35deg) translateX(30%);
  }
}

img,
video,
iframe {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  touch-action: manipulation;
}

button,
input,
textarea,
select {
  font: inherit;
  color: inherit;
}

button {
  touch-action: manipulation;
  cursor: pointer;
}

:focus-visible {
  outline: none;
  box-shadow: var(--focus);
}

.skip {
  position: absolute;
  left: -9999px;
  top: 0.5rem;
  z-index: 200;
  padding: 0.5rem 1rem;
  background: var(--surface);
  border-radius: 0.25rem;
}

.skip:focus {
  left: 0.5rem;
}

.ellipses {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.ellipses__b {
  position: absolute;
  border-radius: 50%;
  filter: blur(9.375rem);
  opacity: 0.05;
  transition: opacity 0.3s var(--ease);
  animation: breathe1 8s ease-in-out infinite;
}

.ellipses__b--2 {
  animation-name: breathe2;
  animation-duration: 10s;
}

.ellipses__b--3 {
  animation-name: breathe3;
  animation-duration: 12s;
}

@keyframes breathe1 {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.05;
  }
  50% {
    transform: scale(1.08);
    opacity: 0.07;
  }
}

@keyframes breathe2 {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.04;
  }
  50% {
    transform: scale(1.12);
    opacity: 0.06;
  }
}

@keyframes breathe3 {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.03;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.05;
  }
}

html[data-theme='light'] .ellipses__b {
  opacity: 0.08;
}

html[data-theme='light'] .ellipses__b--1 {
  background: radial-gradient(ellipse, rgba(110, 210, 230, 0.42), transparent 72%);
}

html[data-theme='light'] .ellipses__b--2 {
  background: radial-gradient(ellipse, rgba(140, 175, 255, 0.38), transparent 72%);
}

html[data-theme='light'] .ellipses__b--3 {
  background: radial-gradient(ellipse, rgba(100, 200, 215, 0.36), transparent 72%);
}

.ellipses__b--1 {
  width: 37.5rem;
  height: 25rem;
  top: -6rem;
  left: -8rem;
  background: radial-gradient(ellipse, rgba(var(--accent-rgb), 0.35), transparent 70%);
}

.ellipses__b--2 {
  width: 31.25rem;
  height: 18.75rem;
  bottom: -5rem;
  right: -6rem;
  background: radial-gradient(ellipse, rgba(var(--accent-2-rgb), 0.35), transparent 70%);
  filter: blur(7.5rem);
  opacity: 0.04;
}

.ellipses__b--3 {
  width: 18.75rem;
  height: 12.5rem;
  top: 38%;
  right: -4rem;
  background: radial-gradient(ellipse, rgba(var(--accent-rgb), 0.3), transparent 70%);
  filter: blur(6.25rem);
  opacity: 0.03;
}

.page {
  position: relative;
  z-index: 2;
  min-height: 100svh;
}

.wrap {
  width: min(100% - 2rem, var(--max));
  margin-inline: auto;
}

.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  background: transparent;
  border-bottom: 1px solid transparent;
  transition:
    background-color 0.3s var(--ease),
    border-color 0.3s var(--ease);
}

.nav::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--teal), var(--violet), transparent);
  opacity: 0.78;
}

.nav--scrolled {
  background: color-mix(in srgb, var(--surface) 62%, transparent);
  border-bottom-color: var(--card-border);
}

.nav--scrolled::after {
  opacity: 0;
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 0;
  width: min(100% - 2rem, var(--max));
  margin-inline: auto;
}

.nav__logo {
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: 1.0625rem;
  letter-spacing: -0.02em;
  color: var(--text);
  font-weight: 700;
  text-decoration: none;
}

.nav__logo__inc {
  font-weight: 700;
}

.nav__links {
  display: none;
  align-items: center;
  gap: 1.25rem;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 0.875rem;
}

.nav__links a {
  opacity: 0.85;
  border-bottom: 1px solid transparent;
  padding: 0.25rem 0;
  transition:
    opacity 0.2s var(--ease),
    border-color 0.2s var(--ease);
}

.nav__links a:hover,
.nav__links a[aria-current='page'] {
  opacity: 1;
  border-color: color-mix(in srgb, var(--teal) 40%, transparent);
}

.nav__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.nav__toggle {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 0.5rem;
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--bg-card) 75%, transparent);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.nav__toggle-bar {
  display: block;
  width: 1.125rem;
  height: 0.125rem;
  background: var(--text);
  border-radius: 0.125rem;
  position: relative;
  transition: transform 0.25s var(--ease);
}

.nav__toggle-bar::before,
.nav__toggle-bar::after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 0.125rem;
  background: var(--text);
  border-radius: 0.125rem;
  transition: transform 0.25s var(--ease);
}

.nav__toggle-bar::before {
  top: -0.3125rem;
}
.nav__toggle-bar::after {
  top: 0.3125rem;
}

.nav__toggle[aria-expanded='true'] .nav__toggle-bar {
  background: transparent;
}
.nav__toggle[aria-expanded='true'] .nav__toggle-bar::before {
  transform: translateY(0.3125rem) rotate(45deg);
}
.nav__toggle[aria-expanded='true'] .nav__toggle-bar::after {
  transform: translateY(-0.3125rem) rotate(-45deg);
}

.theme-btn {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--teal) 35%, var(--card-border));
  background: color-mix(in srgb, var(--bg-card) 80%, transparent);
  backdrop-filter: blur(16px) saturate(160%);
  -webkit-backdrop-filter: blur(16px) saturate(160%);
  color: var(--teal);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition:
    background-color 0.3s var(--ease),
    border-color 0.3s var(--ease),
    transform 0.2s var(--ease);
}

.theme-btn__icon {
  display: block;
}

html[data-theme='dark'] .theme-btn__icon--sun,
html[data-theme='light'] .theme-btn__icon--moon {
  display: none;
}

.theme-btn:hover {
  transform: scale(1.04);
}

.drawer {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  padding: 0 1rem 1rem;
  animation: slideDown 0.35s var(--ease);
}

.drawer.is-open {
  display: block;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-0.5rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.drawer__panel {
  position: relative;
  isolation: isolate;
  border: 1px solid var(--card-border);
  border-radius: var(--glass-radius);
  background: color-mix(in srgb, var(--bg-card) 88%, transparent);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  padding: 0.75rem;
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.12);
}

.drawer__panel::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.drawer a {
  position: relative;
  z-index: 1;
  display: block;
  padding: 0.75rem 0.5rem;
  border-radius: 0.5rem;
}

.drawer a:hover {
  background: color-mix(in srgb, var(--teal) 8%, transparent);
}

@media (min-width: 62rem) {
  .nav__toggle {
    display: none;
  }
  .nav__links {
    display: flex;
  }
  .drawer {
    display: none !important;
  }
}

.hero {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: min(100svh, 56rem);
  /* Moins d’air sous le hero (évite le « trou » visuel avant la ligne / confiance) */
  padding: 2.5rem 0 0.5rem;
  overflow: hidden;
}

.hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--teal), var(--violet));
  opacity: 0.75;
  z-index: 4;
  pointer-events: none;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(160deg, var(--bg) 0%, var(--surface) 100%);
}

html[data-theme='light'] .hero__bg {
  background: linear-gradient(
    160deg,
    var(--bg) 0%,
    color-mix(in srgb, var(--surface) 75%, var(--bg)) 100%
  );
}

.hero__canvas {
  display: none;
}

.hero__cursor {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  mix-blend-mode: screen;
}

@media (hover: hover) and (pointer: fine) {
  .hero__cursor {
    opacity: 1;
  }
}

.hero__inner {
  position: relative;
  z-index: 2;
  width: min(100% - 2rem, var(--max));
  margin-inline: auto;
  padding-top: 1rem;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.hero h1 {
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: clamp(48px, 8vw, 104px);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.04em;
  margin: 0 0 1.25rem;
  max-width: none;
  text-wrap: balance;
}

.hero__eyebrow {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--teal);
  margin: 0 0 1rem;
}

.hero__gradient {
  background: linear-gradient(90deg, #80f3e2, #c8b6ff) no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

html[data-theme='dark'] .hero__gradient {
  background-image: linear-gradient(100deg, #6efbd0, #8fd4ff, #c8b6ff, #6efbd0);
  background-size: 220% 100%;
  animation: heroGradShift 10s ease-in-out infinite;
}

html[data-theme='light'] .hero__gradient {
  background-image: linear-gradient(
    100deg,
    color-mix(in srgb, var(--teal) 88%, #fff),
    #89c9ff,
    var(--violet),
    color-mix(in srgb, var(--teal) 88%, #fff)
  );
  background-size: 220% 100%;
  animation: heroGradShift 12s ease-in-out infinite;
}

@keyframes heroGradShift {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

.hero h1 .word {
  display: inline-block;
  margin-right: 0.35em;
  opacity: 0;
  transform: translateY(1.25rem);
  animation: wordReveal 0.5s var(--ease) forwards;
}

/* WebKit / iOS : translateY sur le mot casse souvent background-clip:text (mot « invisible ») */
.hero h1 .word.hero__gradient {
  display: inline-block;
  -webkit-font-smoothing: antialiased;
  isolation: isolate;
  transform: translateZ(0);
  animation-name: heroWordFadeIn;
  animation-duration: 0.55s;
  animation-timing-function: var(--ease);
  animation-fill-mode: forwards;
}

@keyframes heroWordFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}

@keyframes wordReveal {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Shimmer hero : fix iOS Safari + repli mobile lisible ── */
.shimmer-2026,
.hero__gradient,
.hero h1 .word.hero__gradient,
.hero__gradient .pp-hero-grad-text {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  isolation: isolate;
  will-change: opacity;
}

@media (hover: none) and (pointer: coarse) {
  .shimmer-2026::before,
  .hero__gradient::before {
    display: none !important;
    content: none !important;
  }
}

@keyframes shimmer-simple {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.6;
  }
}

@media (max-width: 768px), (hover: none) and (pointer: coarse) {
  .shimmer-2026,
  .hero__gradient,
  .hero h1 .word.hero__gradient,
  .hero__gradient .pp-hero-grad-text {
    background: none !important;
    background-image: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    -webkit-text-fill-color: var(--teal, #00e5b0) !important;
    color: var(--teal, #00e5b0) !important;
    animation: shimmer-simple 3s ease-in-out infinite !important;
  }
}

/* Mot « vivez. » toujours visible (repli si gradient / clip défaillants) */
.hero h1 .word.hero__gradient,
span.word.hero__gradient {
  color: #00e5b0 !important;
  -webkit-text-fill-color: #00e5b0 !important;
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
}

.hero h1 .accent {
  color: var(--teal);
  font-style: italic;
}

.glitch {
  position: relative;
}

.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}

.glitch::before {
  animation: glitch1 3s infinite;
  clip-path: polygon(0 0, 100% 0, 100% 35%, 0 35%);
  transform: translate(-2px, 0);
  opacity: 0.65;
  color: var(--teal);
}

.glitch::after {
  animation: glitch2 3s infinite;
  clip-path: polygon(0 65%, 100% 65%, 100% 100%, 0 100%);
  transform: translate(2px, 0);
  color: var(--violet);
  opacity: 0.65;
}

@keyframes glitch1 {
  0%,
  95%,
  100% {
    transform: translate(0);
  }
  96% {
    transform: translate(-2px, 1px);
  }
  98% {
    transform: translate(2px, -1px);
  }
}

@keyframes glitch2 {
  0%,
  95%,
  100% {
    transform: translate(0);
  }
  96% {
    transform: translate(2px, -1px);
  }
  98% {
    transform: translate(-2px, 1px);
  }
}

.hero__baseline {
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: 1rem;
  font-weight: 400;
  font-style: normal;
  line-height: 1.55;
  margin: 0 0 1.5rem;
  color: var(--muted);
  max-width: 36ch;
}

.hero__kicker {
  font-size: 0.9375rem;
  color: var(--muted);
  margin: 0 0 1rem;
  min-height: 1.8em;
}

.hero__kicker.is-tw-done {
  border-right: none;
  animation: none;
}

.hero__kicker--tw {
  overflow: hidden;
  white-space: nowrap;
  border-right: 2px solid var(--teal);
  width: 0;
  max-width: 100%;
  animation:
    heroTw 2.2s steps(var(--tw-steps, 48), end) 0.6s forwards,
    twBlink 0.8s step-end infinite;
}

@keyframes heroTw {
  to {
    width: var(--tw-end, 48ch);
  }
}

@keyframes twBlink {
  50% {
    border-color: transparent;
  }
}

.hero__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
}

/* ── Accueil : petits écrans & encoches (390px Safari cible) ── */
@media (max-width: 40rem) {
  .hero {
    min-height: min(100dvh, 100svh, 56rem);
    padding: clamp(0.85rem, 3.5vw, 1.5rem) 0 clamp(1.75rem, 5vw, 2.75rem);
  }

  .hero__inner {
    width: min(
      100% - max(1rem, env(safe-area-inset-left, 0px)) - max(1rem, env(safe-area-inset-right, 0px)),
      var(--max)
    );
    padding-top: 0.35rem;
  }

  .hero h1 {
    font-size: clamp(1.65rem, 6vw + 1vmin, 3.1rem);
    letter-spacing: -0.032em;
    line-height: 1.07;
    margin-bottom: 0.9rem;
  }

  .hero h1 .word {
    margin-right: 0.2em;
    margin-bottom: 0.04em;
  }

  .hero__eyebrow {
    font-size: clamp(0.58rem, 2.4vw, 0.6875rem);
    margin-bottom: 0.65rem;
    line-height: 1.35;
  }

  .hero__baseline {
    font-size: clamp(0.88rem, 3.4vw, 1.05rem);
    line-height: 1.58;
    max-width: none;
    margin-bottom: 1.1rem;
  }

  .hero__cta {
    flex-direction: column;
    align-items: stretch;
    gap: 0.55rem;
    margin-bottom: 1.5rem;
  }

  .hero__cta .btn,
  .hero__cta a.btn {
    width: 100%;
    justify-content: center;
    text-align: center;
    padding-inline: 1rem;
  }
}

@media (min-width: 40.001rem) and (max-width: 62rem) {
  .hero h1 {
    font-size: clamp(2rem, 4.2vw + 0.75rem, 4.5rem);
  }

  .hero__inner {
    width: min(
      100% - max(1.25rem, env(safe-area-inset-left, 0px)) -
        max(1.25rem, env(safe-area-inset-right, 0px)),
      var(--max)
    );
  }
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.75rem;
  border-radius: 0.25rem;
  border: 1px solid transparent;
  font-weight: 600;
  font-size: 0.9375rem;
  transition:
    transform 0.2s var(--ease),
    box-shadow 0.3s var(--ease),
    background-color 0.2s var(--ease),
    border-color 0.2s var(--ease),
    color 0.2s var(--ease);
}

.btn:active {
  transform: scale(0.98);
}

.btn--primary {
  background: var(--teal);
  color: var(--text-on-accent);
}

.btn--primary:hover {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--teal) 35%, transparent),
    0 0 1.25rem rgba(var(--accent-rgb), 0.12);
  animation: ctaPulse 0.3s var(--ease);
}

@keyframes ctaPulse {
  to {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--teal) 35%, transparent),
      0 0 1.25rem rgba(var(--accent-rgb), 0.12);
  }
}

.btn--ghost {
  position: relative;
  background: transparent;
  border-color: var(--teal);
  color: var(--teal);
  overflow: hidden;
  z-index: 0;
}

.btn--ghost::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 0.35rem;
  background: conic-gradient(
    from 0deg,
    var(--teal),
    transparent 120deg,
    transparent 240deg,
    var(--teal)
  );
  opacity: 0.35;
  animation: spinBorder 4s linear infinite;
  z-index: -1;
}

@keyframes spinBorder {
  to {
    transform: rotate(360deg);
  }
}

.btn--ghost:hover {
  background: color-mix(in srgb, var(--teal) 10%, transparent);
}

.btn--outline-violet {
  background: transparent;
  border-color: rgba(200, 180, 240, 0.55);
  color: #d8ccf0;
}

.btn--outline-violet:hover {
  background: color-mix(in srgb, var(--violet) 10%, transparent);
}

html[data-theme='light'] .btn--outline-violet {
  border-color: color-mix(in srgb, var(--violet) 45%, transparent);
  color: #5a3d7a;
}

.btn--violet {
  border-color: color-mix(in srgb, var(--violet) 45%, transparent);
  color: var(--violet);
}

.btn--violet:hover {
  background: color-mix(in srgb, var(--violet) 10%, transparent);
}

.scroll-hint {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  color: var(--muted);
  font-size: 0.625rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.72;
  /* margin-top: auto créait un grand vide entre les CTA et le contenu sous le hero */
  margin-top: 1.75rem;
  padding-top: 0.35rem;
}

.scroll-hint svg {
  width: 1.25rem;
  height: 1.25rem;
  animation: bounce 2s ease-in-out infinite;
}

/* Hero accueil : « Défiler » en overlay bas du bloc (plus de flex qui étire jusqu’au viewport) */
#top.hero .scroll-hint {
  position: absolute;
  left: 50%;
  right: auto;
  bottom: max(0.5rem, env(safe-area-inset-bottom, 0px));
  transform: translateX(-50%);
  margin-top: 0;
  padding-top: 0;
}

@keyframes bounce {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(0.35rem);
  }
}

.section {
  padding: 3.5rem 0;
  position: relative;
}

.section.section-light::before,
.story-block.section-light::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--teal), transparent);
  transform: translateX(-100%);
  opacity: 0;
  animation: lightSweepLine 0.55s var(--ease) forwards;
  pointer-events: none;
}

.story-block {
  position: relative;
}

@keyframes lightSweepLine {
  to {
    transform: translateX(100%);
    opacity: 1;
  }
}

.section__head {
  margin-bottom: 2rem;
}

.section__head h2 {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: clamp(1.75rem, 4vw, 3rem);
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  text-wrap: balance;
}

.section__head .accent,
.manifeste__quote .accent {
  color: var(--teal);
}

.section__sub {
  margin: 0;
  color: var(--muted);
  font-size: 0.9375rem;
}

[data-reveal] {
  opacity: 0;
  transform: translateY(1.25rem);
  transition:
    opacity 0.4s var(--ease),
    transform 0.4s var(--ease);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: translateY(0);
}

.manifeste__grid {
  display: grid;
  gap: 3rem;
}

@media (min-width: 62rem) {
  .manifeste__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.manifeste__col p {
  margin: 0;
  font-size: 1.0625rem;
}

.manifeste__quote {
  margin: 3rem auto 0;
  max-width: 48rem;
  text-align: center;
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: clamp(1.25rem, 2.8vw, 1.75rem);
  font-style: italic;
  line-height: 1.45;
}

.manifeste__cap {
  text-align: center;
  margin: 1rem 0 0;
  font-size: 0.8125rem;
  color: var(--muted);
}

.cards {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 48rem) {
  .cards {
    grid-template-columns: repeat(2, 1fr);
  }
}

.card {
  position: relative;
  isolation: isolate;
  background: color-mix(in srgb, var(--bg-card) 92%, transparent);
  border: 1px solid var(--card-border);
  border-radius: var(--glass-radius);
  padding: 1.25rem;
  transition:
    transform 0.2s var(--ease),
    border-color 0.2s var(--ease),
    box-shadow 0.2s var(--ease);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

.card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.card > * {
  position: relative;
  z-index: 1;
}

@media (min-width: 62rem) {
  .card {
    padding: 2rem;
  }
}

@media (hover: hover) and (pointer: fine) {
  .card:hover {
    transform: scale(1.02);
    border-color: color-mix(in srgb, var(--teal) 45%, var(--border));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--teal) 12%, transparent);
  }
}

.card__icon {
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 1rem;
  color: var(--teal);
}

.card--accent-violet .card__icon {
  color: var(--violet);
}

.card h3 {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
}

.card p {
  margin: 0 0 1rem;
  color: var(--muted);
  font-size: 0.9375rem;
}

.tag {
  display: inline-block;
  font-size: 0.6875rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  color: var(--muted);
}

.tag--teal {
  color: var(--teal);
  border-color: color-mix(in srgb, var(--teal) 40%, var(--border));
  background: var(--teal-glow);
}

.tag--violet {
  color: var(--violet);
  border-color: color-mix(in srgb, var(--violet) 40%, var(--border));
  background: var(--violet-glow);
}

.card--accent-violet .tag,
.card--accent-violet .tag--violet {
  color: #ece8f7;
  border-color: rgba(210, 200, 245, 0.45);
  background: rgba(255, 255, 255, 0.08);
}

.demo-grid {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 62rem) {
  .demo-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.demo {
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  overflow: hidden;
  background: var(--surface);
}

.demo__media {
  aspect-ratio: 16 / 10;
  position: relative;
}

.demo__cap {
  padding: 1rem 1.125rem;
  font-size: 0.9375rem;
}

.demo__neuro {
  margin: 0.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--violet);
  opacity: 0.85;
}

.ph {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 10rem;
  border: 0.125rem dashed color-mix(in srgb, var(--teal) 40%, transparent);
  border-radius: 0.5rem;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 1rem;
  color: var(--muted);
  font-size: 0.8125rem;
  line-height: 1.5;
  overflow: hidden;
  background: var(--surface);
}

.ph::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    110deg,
    transparent 0%,
    color-mix(in srgb, var(--teal) 12%, transparent) 45%,
    transparent 90%
  );
  background-size: 200% 100%;
  animation: shimmer 1.5s linear infinite;
  opacity: 0.35;
  pointer-events: none;
}

.ph--violet {
  border-color: color-mix(in srgb, var(--violet) 40%, transparent);
}

.ph--violet::after {
  background: linear-gradient(
    110deg,
    transparent 0%,
    color-mix(in srgb, var(--violet) 14%, transparent) 45%,
    transparent 90%
  );
}

@keyframes shimmer {
  to {
    background-position: -200% 0;
  }
}

.pipeline {
  padding: 1rem;
}

.pipeline svg {
  width: 100%;
  height: auto;
}

.pipe {
  stroke-dasharray: 120;
  stroke-dashoffset: 120;
  animation: dash 2.4s var(--ease) infinite alternate;
}

@keyframes dash {
  to {
    stroke-dashoffset: 0;
  }
}

.chat {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-height: 12rem;
}

.bubble {
  max-width: 88%;
  padding: 0.65rem 0.85rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  line-height: 1.5;
  opacity: 0;
  transform: translateY(0.35rem);
  transition:
    opacity 0.35s var(--ease),
    transform 0.35s var(--ease);
}

.bubble.is-on {
  opacity: 1;
  transform: translateY(0);
}

.bubble--user {
  align-self: flex-end;
  background: color-mix(in srgb, var(--violet) 30%, transparent);
  border: 1px solid color-mix(in srgb, var(--violet) 35%, transparent);
}

.bubble--ai {
  align-self: flex-start;
  background: color-mix(in srgb, var(--teal) 30%, transparent);
  border: 1px solid color-mix(in srgb, var(--teal) 35%, transparent);
}

.duo {
  display: grid;
  gap: 2rem;
}

@media (min-width: 62rem) {
  .duo {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 2.5rem;
  }
}

.duo__col {
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.25rem;
  background: color-mix(in srgb, var(--surface) 88%, transparent);
}

.duo__photo {
  position: relative;
  border-radius: 0.75rem;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  max-height: 22rem;
  margin: 0 auto 1rem;
}

.duo__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.duo__photo--teal:has(img)::after {
  content: '';
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--teal) 12%, transparent);
  mix-blend-mode: multiply;
  pointer-events: none;
}

.duo__photo--violet:has(img)::after {
  content: '';
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--violet) 12%, transparent);
  mix-blend-mode: multiply;
  pointer-events: none;
}

html[data-theme='light'] .duo__photo--teal:has(img)::after,
html[data-theme='light'] .duo__photo--violet:has(img)::after {
  mix-blend-mode: soft-light;
}

.duo__name {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: 1.5rem;
  margin: 0 0 0.25rem;
}

.duo__role {
  margin: 0 0 1rem;
  color: var(--muted);
  font-size: 0.9375rem;
}

.carousel {
  position: relative;
  overflow: hidden;
}

.carousel__track {
  display: flex;
  overflow: hidden;
  border-radius: 0.5rem;
  transition: transform 0.35s var(--ease);
}

.carousel__slide {
  flex: 0 0 100%;
}

.carousel__ph {
  aspect-ratio: 16 / 10;
}

.carousel__dots {
  display: flex;
  justify-content: center;
  gap: 0.35rem;
  margin-top: 0.75rem;
}

.carousel__dots button {
  width: 1.5rem;
  height: 1.5rem;
  min-width: 1.5rem;
  min-height: 1.5rem;
  border-radius: 999px;
  border: 0;
  padding: 0;
  cursor: pointer;
  background: radial-gradient(
    circle,
    color-mix(in srgb, var(--text) 35%, transparent) 0 32%,
    transparent 34%
  );
  flex-shrink: 0;
}

.carousel__dots button[aria-selected='true'] {
  background: radial-gradient(circle, var(--teal) 0 38%, transparent 40%);
}

html[data-theme='light'] .carousel__dots button {
  background: radial-gradient(circle, rgba(10, 10, 10, 0.28) 0 32%, transparent 34%);
}

.offers-wrap {
  width: min(100%, var(--max));
  margin-inline: auto;
}

.offers {
  display: flex;
  gap: 1rem;
  padding-bottom: 0.25rem;
}

@media (max-width: 61.99rem) {
  .offers {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-padding: 1rem;
    padding-inline: 1rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }
  .offer {
    flex: 0 0 min(22rem, 86vw);
    scroll-snap-align: center;
  }
}

@media (min-width: 62rem) {
  .offers {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.25rem;
    padding-inline: 0;
  }
}

.offer {
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  padding: 1.5rem 1.25rem;
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  box-shadow: 0 0.5rem 1.5rem rgba(0, 0, 0, 0.12);
}

.offer--featured {
  border-color: color-mix(in srgb, var(--teal) 55%, var(--border));
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--teal) 12%, transparent),
    0 0.5rem 1.5rem rgba(0, 0, 0, 0.12);
}

.badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  font-size: 0.6875rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 0.35rem 0.55rem;
  border-radius: 999px;
  border: 1px solid var(--border);
}

.badge--violet {
  color: #d8ccf0;
  border-color: rgba(200, 180, 240, 0.55);
}

html[data-theme='light'] .badge--violet {
  color: #5a3d7a;
  border-color: color-mix(in srgb, var(--violet) 35%, transparent);
}

.badge--teal {
  color: var(--teal);
  border-color: color-mix(in srgb, var(--teal) 35%, transparent);
}

.badge--ghost {
  color: var(--text);
  border-color: color-mix(in srgb, var(--text) 18%, transparent);
  background: color-mix(in srgb, var(--text) 15%, transparent);
}

.offer h3 {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  margin: 0;
  font-size: 1.5rem;
}

.offer ul {
  margin: 0;
  padding-left: 1rem;
  color: var(--muted);
  font-size: 0.9375rem;
}

.price {
  font-weight: 600;
  font-size: 1.125rem;
}

.beliefs {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 48rem) {
  .beliefs {
    grid-template-columns: repeat(2, 1fr);
  }
}

.belief {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  align-items: start;
  padding: 1rem;
  border: 1px solid var(--card-border);
  border-radius: var(--glass-radius);
  background: color-mix(in srgb, var(--bg-card) 92%, transparent);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  transition:
    transform 0.38s var(--ease),
    border-color 0.35s var(--ease),
    box-shadow 0.35s var(--ease);
}

.belief::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.belief > * {
  position: relative;
  z-index: 1;
}

.belief svg {
  width: 2rem;
  height: 2rem;
  color: var(--teal);
}

.belief--violet svg {
  color: var(--violet);
}

.belief p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9375rem;
}

.contact-shell {
  position: relative;
  padding: 1.25rem;
  border-radius: 0.75rem;
  --contact-glow: 0.02;
}

.contact-shell::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(
    ellipse 85% 55% at 50% 0%,
    color-mix(in srgb, var(--teal) 28%, transparent),
    transparent 72%
  );
  opacity: var(--contact-glow);
  transition: opacity 0.3s var(--ease);
}

.contact-shell > * {
  position: relative;
  z-index: 1;
}

.tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1.25rem;
}

.tab {
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--bg-card) 82%, transparent);
  backdrop-filter: blur(14px) saturate(170%);
  -webkit-backdrop-filter: blur(14px) saturate(170%);
  padding: 0.5rem 0.85rem;
  border-radius: 999px;
  font-size: 0.8125rem;
  font-weight: 600;
}

.tab[aria-selected='true'] {
  border-color: color-mix(in srgb, var(--teal) 55%, transparent);
  background: var(--teal);
  color: var(--text-on-accent);
}

html[data-theme='light'] .tab[aria-selected='true'] {
  color: var(--text-on-accent);
}

.contact-panel {
  position: relative;
  isolation: isolate;
  border: 1px solid var(--card-border);
  border-radius: var(--glass-radius);
  padding: 1.25rem;
  background: color-mix(in srgb, var(--bg-card) 90%, transparent);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

.contact-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.contact-panel > * {
  position: relative;
  z-index: 1;
}

.step {
  display: none;
}

.step.is-active {
  display: block;
}

.field {
  margin-bottom: 0.75rem;
}

.field label {
  display: block;
  font-size: 0.8125rem;
  color: var(--muted);
  margin-bottom: 0.35rem;
}

.field input[type='text'],
.field textarea {
  width: 100%;
  border-radius: 0.5rem;
  border: 1px solid var(--border);
  padding: 0.65rem 0.75rem;
  min-height: 2.75rem;
  background: color-mix(in srgb, var(--bg) 35%, var(--surface));
  font-size: 1rem;
}

.field textarea {
  min-height: 6rem;
  resize: vertical;
}

.choices {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.choices--pills {
  flex-direction: row;
  flex-wrap: wrap;
}

.choices--pills .choice {
  border-radius: 999px;
}

.choices--pills .choice:has(input:checked) {
  border-color: color-mix(in srgb, var(--teal) 45%, transparent);
  background: color-mix(in srgb, var(--teal) 10%, transparent);
}

.choice {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid var(--border);
  border-radius: 0.5rem;
  cursor: pointer;
}

.choice input {
  accent-color: var(--teal);
}

.contact-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 1rem;
}

.footer {
  position: relative;
  isolation: isolate;
  padding: 3rem 0 2.5rem;
  text-align: center;
  margin-top: 1rem;
  border-top: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--bg-card) 75%, transparent);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

.footer::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.1),
    rgba(var(--accent-2-rgb), 0.08),
    rgba(232, 244, 248, 0.06)
  );
  opacity: 0.03;
}

.footer .wrap {
  position: relative;
  z-index: 1;
}

.footer__logo {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: 1.375rem;
  color: var(--text);
  font-weight: 600;
  letter-spacing: -0.02em;
}

.footer__tag {
  margin: 0.5rem 0 1rem;
  color: var(--muted);
  font-size: 0.9375rem;
}

.footer__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem 1.25rem;
  font-size: 0.875rem;
  margin-bottom: 0.75rem;
}

.footer__links a {
  border-bottom: 1px solid transparent;
}

.footer__links a:hover {
  border-color: color-mix(in srgb, var(--teal) 35%, transparent);
}

.footer small {
  color: var(--muted);
  font-size: 0.8125rem;
}

.histoire-hero {
  min-height: 40vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 6rem 0 2rem;
}

@media (max-width: 24.375rem) {
  .histoire-hero {
    padding: 5rem 0 1.5rem;
  }
}

.histoire-citation {
  text-align: center;
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-style: italic;
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  max-width: 43.75rem;
  margin: 4rem auto;
  line-height: 1.7;
  color: var(--text);
}

.story-page-h1 {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: clamp(2.5rem, 6vw, 4rem);
  letter-spacing: -0.02em;
  margin: 0 0 2.5rem;
  text-wrap: balance;
}

.story-page-h1 .accent {
  color: var(--teal);
}

.story-block {
  margin-bottom: 3rem;
}

.story-block h2 {
  font-family: ui-serif, 'New York', 'Iowan Old Style', 'Apple Garamond', serif;
  font-size: clamp(1.35rem, 3vw, 2rem);
  margin: 0 0 1rem;
}

.story-block p {
  margin: 0 0 1rem;
  color: var(--muted);
  max-width: 65ch;
}

.two-col {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 48rem) {
  .two-col {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.story-cta {
  text-align: center;
  margin-top: 2rem;
}

/* Home sauvegarde 2026 : hero CTA + douleurs + preuves (vitrine + script.js) */
.hero .hero__cta .btn.btn--primary {
  border-radius: 999px;
  background: var(--btn-cta-bg);
  color: var(--nacre);
  border: 1px solid var(--btn-cta-bd);
}

.hero .hero__cta .btn.btn--primary:hover {
  box-shadow:
    0 0 0 1px color-mix(in srgb, var(--violet) 28%, transparent),
    0 0 1.25rem rgba(var(--accent-2-rgb), 0.12);
}

.hero .hero__cta .btn--ghost {
  border-radius: 999px;
  border-color: color-mix(in srgb, var(--text) 22%, transparent);
  color: var(--text);
}

.hero .hero__cta .btn--ghost::before {
  content: none;
  display: none;
}

.hero .hero__cta .btn--ghost:hover {
  border-color: color-mix(in srgb, var(--text) 38%, transparent);
  background: color-mix(in srgb, var(--surface) 40%, transparent);
}

.save-pain-stack {
  display: flex;
  flex-direction: column;
  gap: 1.125rem;
  margin-top: 0.5rem;
}

.save-pain {
  position: relative;
  isolation: isolate;
  border-radius: var(--glass-radius);
  padding: 1.5rem;
  background: color-mix(in srgb, var(--bg-card) 92%, transparent);
  border: 1px solid var(--card-border);
  text-align: left;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  transition:
    transform 0.38s var(--ease),
    border-color 0.35s var(--ease),
    box-shadow 0.35s var(--ease);
}

.save-pain::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.save-pain > * {
  position: relative;
  z-index: 1;
}

.save-pain__icon {
  font-size: 1.5rem;
  line-height: 1;
  margin-bottom: 0.75rem;
}

.save-pain h3 {
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  color: var(--text);
  text-wrap: balance;
}

.save-pain p {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--muted);
  max-width: 52ch;
}

.save-preuves__label {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--teal);
  margin-bottom: 0.75rem;
}

.save-preuves__title {
  font-family:
    -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica,
    system-ui, sans-serif;
  font-size: clamp(1.5rem, 4.5vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.12;
  margin: 0 0 2rem;
  text-wrap: balance;
}

.save-preuves__grid {
  display: grid;
  gap: 1.25rem;
}

@media (min-width: 48rem) {
  .save-preuves__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.save-chart-card {
  position: relative;
  isolation: isolate;
  border-radius: var(--glass-radius);
  padding: 1.85rem 1.25rem 1.75rem;
  background: color-mix(in srgb, var(--bg-card) 92%, transparent);
  border: 1px solid var(--card-border);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat));
}

.save-chart-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    128deg,
    rgba(var(--accent-rgb), 0.12),
    rgba(var(--accent-2-rgb), 0.1),
    rgba(232, 244, 248, 0.08)
  );
  opacity: 0.03;
}

.save-chart-card::after {
  content: '';
  position: absolute;
  top: 1rem;
  left: 1.15rem;
  right: 1.15rem;
  height: 1px;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(90deg, var(--teal), var(--violet));
  opacity: 0.65;
  border-radius: 1px;
}

.save-chart-card > * {
  position: relative;
  z-index: 1;
}

/* Nuit : verre plus visible sur #080d18 (fond plus transparent = le blur lit le canvas) */
html[data-theme='dark'] .card,
html[data-theme='dark'] .save-pain,
html[data-theme='dark'] .save-chart-card,
html[data-theme='dark'] .belief {
  background: color-mix(in srgb, var(--bg-card) 45%, transparent);
  border-color: color-mix(in srgb, var(--card-border) 35%, rgba(240, 248, 255, 0.14));
  box-shadow:
    inset 0 1px 0 0 rgba(255, 255, 255, 0.06),
    0 0 0 1px rgba(var(--accent-2-rgb), 0.06);
}

html[data-theme='dark'] .card::before,
html[data-theme='dark'] .save-pain::before,
html[data-theme='dark'] .save-chart-card::before,
html[data-theme='dark'] .belief::before {
  opacity: 0.075;
}

.save-chart-title {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--violet) 85%, var(--muted));
  margin: 0 0 1rem;
}

.save-bar-chart {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.5rem;
  min-height: 10.5rem;
  padding-top: 0.5rem;
}

.save-bar-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  min-width: 0;
}

.save-bar {
  width: 100%;
  max-width: 2.75rem;
  border-radius: 0.5rem 0.5rem 0.125rem 0.125rem;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: 0.2rem;
}

.save-bar-val {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--teal);
}

.save-bar-lbl {
  font-size: 0.6875rem;
  color: var(--muted);
  text-align: center;
  line-height: 1.25;
}

.save-bar--rel {
  height: 7.25rem;
  background: linear-gradient(
    180deg,
    var(--teal),
    color-mix(in srgb, var(--teal) 35%, transparent)
  );
}

.save-bar--dev {
  height: 5.5rem;
  background: linear-gradient(
    180deg,
    var(--violet),
    color-mix(in srgb, var(--violet) 35%, transparent)
  );
}

.save-bar--rdv {
  height: 4.5rem;
  background: linear-gradient(
    180deg,
    var(--accent-3),
    color-mix(in srgb, var(--accent-3) 40%, transparent)
  );
}

.save-bar--fac {
  height: 3.75rem;
  background: linear-gradient(
    180deg,
    var(--accent-4),
    color-mix(in srgb, var(--accent-4) 40%, transparent)
  );
}

.save-chart-foot {
  margin: 1rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--muted);
}

.save-donut-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1.25rem;
}

.save-donut {
  width: 6.25rem;
  height: 6.25rem;
  border-radius: 50%;
  flex-shrink: 0;
  background: conic-gradient(
    var(--teal) 0 45%,
    var(--violet) 45% 75%,
    var(--accent-3) 75% 90%,
    var(--accent-4) 90% 100%
  );
  mask: radial-gradient(circle closest-side, transparent 58%, #000 62%);
  -webkit-mask: radial-gradient(circle closest-side, transparent 58%, #000 62%);
}

.save-donut-legend {
  flex: 1;
  min-width: 10rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.8125rem;
}

.save-donut-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--text);
}

.save-donut-dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  flex-shrink: 0;
}

.save-donut-dot--a {
  background: var(--accent);
}

.save-donut-dot--b {
  background: var(--accent-2);
}

.save-donut-dot--c {
  background: var(--accent-3);
}

.save-donut-dot--d {
  background: var(--accent-4);
}

.save-curve {
  width: 100%;
  height: auto;
  margin-top: 0.25rem;
}

.save-curve__before {
  stroke: var(--chart-warn);
}

.save-curve__after {
  stroke: var(--accent);
}

.save-curve-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 0.75rem;
  font-size: 0.75rem;
  color: var(--muted);
}

.save-curve-leg {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.save-curve-line {
  width: 1.25rem;
  height: 2px;
  border-radius: 1px;
}

.save-curve-line--before {
  background: var(--chart-warn);
}

.save-curve-line--after {
  background: var(--accent);
}

.save-preuves__brand {
  text-align: center;
  margin-top: 2.5rem;
  font-size: 0.9375rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

/* Animations renforcées — nuit (biolum) + jour (océan), stagger sections sauvegarde */
html[data-theme='dark'] .hero__bg::after,
html[data-theme='light'] .hero__bg::after {
  content: '';
  position: absolute;
  inset: -18% -12%;
  z-index: 0;
  pointer-events: none;
  border-radius: inherit;
}

html[data-theme='dark'] .hero__bg::after {
  opacity: 0.5;
  mix-blend-mode: screen;
  background:
    radial-gradient(ellipse 100% 72% at 14% 8%, rgba(var(--accent-rgb), 0.38), transparent 54%),
    radial-gradient(ellipse 92% 58% at 90% 22%, rgba(var(--accent-2-rgb), 0.32), transparent 50%);
  animation: heroAurora 15s ease-in-out infinite alternate;
}

html[data-theme='light'] .hero__bg::after {
  opacity: 0.42;
  mix-blend-mode: soft-light;
  background:
    radial-gradient(ellipse 95% 62% at 10% 0%, rgba(var(--accent-rgb), 0.22), transparent 52%),
    radial-gradient(ellipse 85% 55% at 94% 28%, rgba(90, 170, 255, 0.2), transparent 50%);
  animation: heroAurora 19s ease-in-out infinite alternate;
}

@keyframes heroAurora {
  from {
    transform: translate3d(-1.8%, 0, 0) scale(1);
  }
  to {
    transform: translate3d(1.6%, -1.4%, 0) scale(1.05);
  }
}

html[data-theme='dark'] .hero__eyebrow {
  animation: eyebrowGlow 4.8s ease-in-out infinite;
}

html[data-theme='light'] .hero__eyebrow {
  animation: eyebrowGlow 6s ease-in-out infinite;
}

@keyframes eyebrowGlow {
  0%,
  100% {
    opacity: 1;
    filter: brightness(1);
  }
  50% {
    opacity: 0.9;
    filter: brightness(1.12);
  }
}

html[data-theme='dark'] .ellipses__b--1 {
  animation-duration: 7s;
}
html[data-theme='dark'] .ellipses__b--2 {
  animation-duration: 9.5s;
}
html[data-theme='dark'] .ellipses__b--3 {
  animation-duration: 11s;
}

#apropos.is-visible .save-pain {
  animation: savePainEnter 0.68s cubic-bezier(0.22, 1, 0.36, 1) both;
}

#apropos.is-visible .save-pain:nth-child(1) {
  animation-delay: 0.05s;
}
#apropos.is-visible .save-pain:nth-child(2) {
  animation-delay: 0.11s;
}
#apropos.is-visible .save-pain:nth-child(3) {
  animation-delay: 0.17s;
}
#apropos.is-visible .save-pain:nth-child(4) {
  animation-delay: 0.23s;
}
#apropos.is-visible .save-pain:nth-child(5) {
  animation-delay: 0.29s;
}
#apropos.is-visible .save-pain:nth-child(6) {
  animation-delay: 0.35s;
}

@keyframes savePainEnter {
  from {
    opacity: 0;
    transform: translateY(1.15rem) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

#preuves.is-visible .save-bar-chart .save-bar {
  transform-origin: bottom center;
  animation: barPop 0.95s cubic-bezier(0.22, 1, 0.36, 1) both;
}

#preuves.is-visible .save-bar-chart .save-bar-wrap:nth-child(1) .save-bar {
  animation-delay: 0.08s;
}
#preuves.is-visible .save-bar-chart .save-bar-wrap:nth-child(2) .save-bar {
  animation-delay: 0.16s;
}
#preuves.is-visible .save-bar-chart .save-bar-wrap:nth-child(3) .save-bar {
  animation-delay: 0.24s;
}
#preuves.is-visible .save-bar-chart .save-bar-wrap:nth-child(4) .save-bar {
  animation-delay: 0.32s;
}

@keyframes barPop {
  from {
    transform: scaleY(0.14);
    opacity: 0;
  }
  to {
    transform: scaleY(1);
    opacity: 1;
  }
}

#preuves.is-visible .save-chart-card:nth-of-type(2) .save-donut {
  animation: donutBreathe 9s ease-in-out infinite;
}

html[data-theme='dark'] #preuves.is-visible .save-chart-card:nth-of-type(2) .save-donut {
  animation: donutBreathe 7.5s ease-in-out infinite;
}

@keyframes donutBreathe {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.035);
  }
}

#preuves.is-visible .save-curve {
  animation: chartReveal 0.85s cubic-bezier(0.22, 1, 0.36, 1) 0.2s both;
}

@keyframes chartReveal {
  from {
    opacity: 0;
    transform: translateY(0.5rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (hover: hover) and (pointer: fine) {
  .save-pain:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--teal) 35%, var(--card-border));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--teal) 10%, transparent);
  }

  html[data-theme='dark'] .save-pain:hover {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--accent-2) 12%, transparent),
      0 0 1.25rem rgba(var(--accent-rgb), 0.1);
  }

  .belief:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--teal) 32%, var(--card-border));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--teal) 10%, transparent);
  }

  html[data-theme='dark'] .belief:hover {
    box-shadow:
      0 0 0 1px color-mix(in srgb, var(--accent-2) 12%, transparent),
      0 0 1.25rem rgba(var(--accent-rgb), 0.1);
  }
}

html[data-theme='dark'] .save-chart-card {
  transition:
    transform 0.4s var(--ease),
    border-color 0.35s var(--ease),
    box-shadow 0.4s var(--ease);
}

@media (hover: hover) and (pointer: fine) {
  html[data-theme='dark'] .save-chart-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--accent-2) 28%, var(--card-border));
    box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent-2) 10%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
  }
  .hero h1 .word {
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
  }
  .scroll-hint svg,
  .bg-rays span,
  .ellipses__b {
    animation: none !important;
  }
  .hero__kicker--tw {
    animation: none !important;
    width: auto !important;
    max-width: none !important;
    border-right: none !important;
  }
  .pipe {
    animation: none !important;
    stroke-dashoffset: 0 !important;
  }

  .hero__bg::after,
  .hero__eyebrow,
  .hero__gradient,
  #preuves .save-donut,
  #apropos.is-visible .save-pain,
  #preuves.is-visible .save-bar,
  #preuves.is-visible .save-curve {
    animation: none !important;
  }

  .hero__bg::after {
    transform: none !important;
    opacity: 0.35 !important;
  }

  #apropos.is-visible .save-pain,
  #preuves.is-visible .save-bar {
    opacity: 1 !important;
    transform: none !important;
  }

  #preuves.is-visible .save-curve {
    opacity: 1 !important;
    transform: none !important;
  }

  .bg-light-veil__pulse,
  .bg-light-veil__pulse--b,
  .bg-light-veil__pulse--c {
    animation: none !important;
  }

  .bg-light-veil__pulse {
    transform: translateX(-50%) scale(1) !important;
    opacity: 0.4 !important;
  }

  .bg-light-veil__pulse--b {
    opacity: 0.35 !important;
  }

  .bg-light-veil__pulse--c {
    transform: none !important;
    opacity: 0.3 !important;
  }
}

/* Skip link : hors flux (évite bande visible + réserve de place) */
.skip-link {
  position: absolute !important;
  top: -9999px !important;
  left: -9999px !important;
  z-index: 99999;
}
.skip-link:focus,
.skip-link:focus-visible {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
}

/* SEO : titre masqué visuellement, lu par les lecteurs d’écran */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
