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

:root {
  --bg: #111009;
  --bg2: #191610;
  --surface: rgba(237,232,223,0.032);
  --border: rgba(237,232,223,0.08);
  --border-h: rgba(237,232,223,0.18);
  --text: #EDE8DF;
  --muted: rgba(237,232,223,0.42);
  --faint: rgba(237,232,223,0.16);
  --cream: #D8D0BC;
  --f-serif: 'Cormorant Garamond', Georgia, serif;
  --f-sans: 'Jost', sans-serif;
}

html { scroll-behavior: auto; height: 100%; background: var(--bg); }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--f-sans);
  font-weight: 300;
  overflow: hidden;
  cursor: none;
  height: 100svh;
  -webkit-text-size-adjust: 100%;
}

/* ── CURSOR ── */
.cur-h, .cur-v {
  position: fixed; pointer-events: none; z-index: 99999;
  background: var(--cream); opacity: .6;
  transition: width .2s, height .2s, opacity .2s;
  will-change: left, top;
}
.cur-h { width: 18px; height: 1px; transform: translate(-50%, -50%); }
.cur-v { width: 1px; height: 18px; transform: translate(-50%, -50%); }
.cur-dot {
  position: fixed; width: 4px; height: 4px; background: var(--cream);
  border-radius: 50%; pointer-events: none; z-index: 99999;
  transform: translate(-50%, -50%); opacity: .9;
  will-change: left, top;
}
.halo {
  position: fixed; width: 320px; height: 320px; border-radius: 50%;
  pointer-events: none; z-index: 0; transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(216,208,188,0.04) 0%, transparent 70%);
  will-change: left, top;
}

/* ── SCROLL WRAP ── */
.scroll-wrap {
  height: 100svh;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.scroll-wrap::-webkit-scrollbar { display: none; }
.panel {
  height: 100svh;
  min-height: -webkit-fill-available;
  width: 100%;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}

/* ── NAV ── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 1.8rem 3.5rem 1rem;
  pointer-events: none;
}
.logo-slot { pointer-events: all; }
.logo-slot img { height: 52px; width: auto; display: block; }
.nav-links { display: flex; gap: 3rem; pointer-events: all; padding-top: 1.4rem; }
.nav-links a {
  font-size: .72rem; font-weight: 400; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted); text-decoration: none;
  transition: color .3s;
}
.nav-links a:hover { color: var(--text); }

/* ── DOTS ── */
.dots {
  position: fixed; right: 2.5rem; top: 50%;
  transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 10px;
  z-index: 100; margin-top: 2rem;
}
.dot {
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--faint); cursor: pointer;
  transition: background .4s, transform .4s;
}
.dot.on { background: var(--cream); transform: scale(1.5); }

/* ── FOOTER ── */
.fbar {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem 3.5rem;
  border-top: .5px solid var(--border);
  opacity: 0; pointer-events: none; transition: opacity .5s;
}
.fcopy {
  font-size: .65rem; font-weight: 400;
  letter-spacing: .2em; text-transform: uppercase; color: var(--faint);
}

/* ── HERO ── */
#s1 { justify-content: flex-start; padding: 0; overflow: hidden; }

.hero-inner {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr auto;
  padding: clamp(5rem, 11vh, 9rem) 3.5rem 0;
  gap: 0;
  position: relative; z-index: 2;
  min-height: 0;
}

.hero-hl {
  grid-column: 1; grid-row: 1;
  align-self: flex-end;
  font-family: var(--f-serif);
  font-size: clamp(3.8rem, 8vw, 7.5rem);
  font-weight: 300; line-height: .88; letter-spacing: -.01em;
  overflow: hidden;
}
.hero-hl .word { display: inline-block; overflow: hidden; margin-right: .2em; }
.hero-hl .word span { display: inline-block; transform: translateY(110%); animation: slideUp .9s cubic-bezier(.16,1,.3,1) forwards; }
.word:nth-child(1) span { animation-delay: .15s; }
.word:nth-child(2) span { animation-delay: .32s; }
.hero-hl em { font-style: italic; color: var(--cream); }
@keyframes slideUp { to { transform: translateY(0); } }

@keyframes fadeIn { to { opacity: 1; } }

/* ── FREQUENCY VISUAL ── */
.hero-freq {
  grid-column: 2; grid-row: 1;
  position: relative;
  overflow: hidden;
  opacity: 0;
  animation: fadeIn .8s 0.8s ease forwards;
}
#freqCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}


/* Hero bottom */
.hero-bottom {
  grid-column: 1 / -1; grid-row: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(.8rem, 1.8vh, 1.8rem) 0;
  border-top: .5px solid var(--border);
  margin-top: clamp(.5rem, 1.5vh, 1.5rem);
}
.hero-desc-block {
  display: flex; flex-direction: column; gap: .6rem;
  opacity: 0; animation: fadeIn .6s 1.1s ease forwards;
}
.hero-tag {
  font-size: .8rem; font-weight: 400; letter-spacing: .2em;
  text-transform: uppercase; color: var(--cream);
  display: flex; align-items: center; gap: .7rem;
}
.hero-tag::before { content: ''; width: 20px; height: .5px; background: var(--cream); opacity: .5; }
.hero-p { font-size: .95rem; font-weight: 300; color: var(--muted); line-height: 1.9; max-width: 340px; }
.hero-right {
  display: flex; flex-direction: column; align-items: flex-end; gap: clamp(.8rem, 1.5vh, 2rem);
  opacity: 0; animation: fadeIn .6s 1.2s ease forwards;
}
.hero-stat { text-align: right; }
.hero-stat-num {
  font-family: var(--f-serif); font-size: 2.4rem; font-weight: 300;
  color: var(--cream); letter-spacing: -.02em; line-height: 1;
}
.hero-stat-lbl {
  font-size: .66rem; font-weight: 400; letter-spacing: .18em;
  text-transform: uppercase; color: var(--faint); margin-top: .3rem;
}
.btn-cta {
  display: inline-flex; align-items: center; gap: .8rem;
  padding: .85rem 1.8rem; background: transparent; color: var(--cream);
  text-decoration: none; font-family: var(--f-sans); font-size: .72rem;
  font-weight: 400; letter-spacing: .2em; text-transform: uppercase;
  border: .5px solid var(--cream); transition: background .3s, color .3s;
  white-space: nowrap;
}
.btn-cta:hover { background: var(--cream); color: var(--bg); }
.btn-cta svg {
  width: 12px; height: 12px; stroke: currentColor; fill: none;
  stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
  transition: stroke .3s;
}

/* ── ARROW HINT ── */
.arr-hint {
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-size: .58rem; font-weight: 400; letter-spacing: .2em;
  text-transform: uppercase; color: var(--faint);
  padding: 1rem 0 1.4rem;
  opacity: 0;
  animation: bob 3s 2s ease infinite, fadeIn .5s 1.5s forwards;
  flex-shrink: 0; z-index: 2;
}
.arr-hint svg {
  width: 13px; height: 13px; stroke: var(--faint); fill: none;
  stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
}
@keyframes bob { 0%, 100% { transform: translateY(0); } 55% { transform: translateY(6px); } }

/* ── S2 CURATION ── */
#s2 { justify-content: flex-start; }

.s2-inner {
  width: 100%;
  display: grid;
  grid-template-columns: 5fr 70px 7fr;
  column-gap: 1.8rem;
  padding: clamp(5rem, 11vh, 9rem) 3.5rem clamp(2rem, 4vh, 3rem);
  align-items: start;
}

/* S2 wave column */
.s2-wave {
  align-self: stretch;
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-90px);
  transition: opacity .9s cubic-bezier(.16,1,.3,1), transform .9s cubic-bezier(.16,1,.3,1);
}
.s2-wave.visible {
  opacity: 1;
  transform: translateY(0);
}
#s2WaveCanvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.s2-num {
  font-family: var(--f-serif);
  font-size: .75rem;
  letter-spacing: .25em;
  color: var(--cream);
  opacity: .45;
  margin-bottom: 1rem;
}

.s2-title {
  font-family: var(--f-serif);
  font-size: clamp(2.6rem, 4.5vw, 4.2rem);
  font-weight: 300;
  line-height: .92;
  letter-spacing: -.01em;
  color: var(--text);
  margin-bottom: 1.8rem;
}
.s2-title em { font-style: italic; color: var(--cream); }

.s2-desc {
  font-size: .9rem;
  font-weight: 300;
  color: rgba(237,232,223,0.65);
  line-height: 1.85;
  max-width: 360px;
  margin-bottom: 2.4rem;
}

.s2-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.s2-list li {
  font-size: .72rem;
  font-weight: 300;
  color: var(--muted);
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  line-height: 1.6;
}
.s2-list li::before {
  content: '—';
  color: var(--cream);
  opacity: .5;
  flex-shrink: 0;
}

/* S2 metrics */
.s2-metrics {
  display: flex;
  gap: 2rem;
  margin-top: 2.4rem;
  padding-top: 1.6rem;
  border-top: .5px solid var(--border);
}
.s2-metric { display: flex; flex-direction: column; gap: .3rem; }
.s2-metric-num {
  font-family: var(--f-serif);
  font-size: 1.8rem;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: -.02em;
  line-height: 1;
}
.s2-metric-lbl {
  font-size: .58rem;
  font-weight: 400;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--faint);
}

/* Curation demo container */
.curation-demo {
  border: .5px solid var(--border);
  padding: 1.6rem 1.8rem;
  display: flex;
  flex-direction: column;
  height: min(72vh, 600px);
}

.cd-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: .9rem;
  border-bottom: .5px solid var(--border);
  margin-bottom: 1.2rem;
  flex-shrink: 0;
}
.cd-phase-label {
  font-size: .55rem;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--faint);
}
.cd-header-right {
  display: flex;
  align-items: center;
  gap: .7rem;
}
.cd-phase {
  font-size: .55rem;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--cream);
  transition: opacity .3s;
}
.cd-pulse {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--cream);
  opacity: .5;
  animation: cdpulse 2.2s ease infinite;
}
@keyframes cdpulse {
  0%, 100% { opacity: .5; }
  50%       { opacity: .12; }
}

.cd-body { flex: 1; overflow: hidden; position: relative; }

/* Brief */
.cd-brief {
  display: flex;
  flex-direction: column;
  gap: .85rem;
  transition: opacity .4s;
}
.cd-brief-row {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity .4s, transform .4s;
}
.cd-brief-row.in { opacity: 1; transform: translateX(0); }
.cd-brief-label {
  font-size: .58rem;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--faint);
  width: 72px;
  flex-shrink: 0;
}
.cd-brief-val {
  font-size: .9rem;
  font-weight: 300;
  color: var(--text);
}
.cd-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: .5rem;
  opacity: 0;
  transition: opacity .5s .1s;
}
.cd-chips-row.in { opacity: 1; }
.cd-chip {
  font-size: .56rem;
  font-weight: 400;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cream);
  border: .5px solid rgba(216,208,188,.22);
  padding: .28rem .65rem;
  opacity: .75;
}

/* Tracks */
.cd-tracks {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  transition: opacity .5s, transform .5s;
}
.cd-track {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .52rem .55rem .52rem .8rem;
  opacity: 0;
  transform: translateX(14px);
  position: relative;
  transition: opacity .45s, transform .45s cubic-bezier(.16,1,.3,1), background .4s;
}
.cd-track::before {
  content: '';
  position: absolute;
  left: 0; top: 20%;
  width: 1.5px; height: 0;
  background: rgba(216,208,188,.45);
  transition: height .55s cubic-bezier(.16,1,.3,1);
}
.cd-track.in { opacity: 1; transform: translateX(0); }
.cd-track.accepted { background: rgba(216,208,188,.022); }
.cd-track.accepted::before { height: 60%; }
.cd-track.rejected { opacity: .13; transform: translateX(-4px); }
.cd-track-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--cream);
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .4s .2s;
}
.cd-track.accepted .cd-track-dot { opacity: .6; }
.cd-track-info { flex: 1; min-width: 0; }
.cd-track-title {
  font-size: .82rem;
  font-weight: 400;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}
.cd-track-artist {
  font-size: .68rem;
  font-weight: 300;
  color: var(--muted);
  line-height: 1.3;
}
.cd-track-bpm {
  font-size: .6rem;
  font-weight: 300;
  color: var(--faint);
  letter-spacing: .04em;
  flex-shrink: 0;
}

/* Playlist */
.cd-playlist {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  transition: opacity .5s;
}
.cd-pl-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: .65rem;
  border-bottom: .5px solid var(--border);
  margin-bottom: .3rem;
  flex-shrink: 0;
}
.cd-pl-title {
  font-size: .56rem;
  font-weight: 400;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--cream);
}
.cd-pl-count {
  font-size: .56rem;
  font-weight: 300;
  color: var(--faint);
  letter-spacing: .05em;
}
.cd-pl-track {
  display: flex;
  align-items: center;
  gap: .85rem;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity .35s, transform .35s;
}
.cd-pl-track.in { opacity: 1; transform: translateY(0); }
.cd-pl-num {
  font-family: var(--f-serif);
  font-size: .72rem;
  color: var(--faint);
  width: 18px;
  flex-shrink: 0;
  text-align: right;
}
.cd-pl-info { flex: 1; min-width: 0; }
.cd-pl-track-title {
  font-size: .7rem;
  font-weight: 400;
  color: var(--text);
  line-height: 1.25;
}
.cd-pl-track-artist {
  font-size: .6rem;
  font-weight: 300;
  color: var(--muted);
  line-height: 1.25;
}

/* Dossier */
.cd-dossier {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  transition: opacity .5s, transform .5s;
}
.cd-dossier-venue {
  font-size: .55rem;
  font-weight: 400;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--faint);
  padding-bottom: .75rem;
  margin-bottom: .2rem;
  border-bottom: .5px solid var(--border);
  flex-shrink: 0;
}
.cd-dossier-item {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .48rem .55rem .48rem .8rem;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .4s, transform .4s cubic-bezier(.16,1,.3,1), background .25s;
  position: relative;
}
.cd-dossier-item.selecting {
  background: rgba(216,208,188,.025);
}
.cd-dossier-item.selecting::before {
  height: 60%;
  transition: height .2s cubic-bezier(.16,1,.3,1), background .2s;
}
.cd-dossier-item.selecting .cd-dossier-dot  { opacity: .6; }
.cd-dossier-item.selecting .cd-dossier-name { color: var(--text); font-weight: 400; }
.cd-dossier-item.selecting .cd-dossier-num  { opacity: 1; }
.cd-dossier-item::before {
  content: '';
  position: absolute;
  left: 0; top: 20%;
  width: 1.5px; height: 0;
  background: rgba(216,208,188,.45);
  transition: height .5s cubic-bezier(.16,1,.3,1) .1s;
}
.cd-dossier-item.in { opacity: 1; transform: translateY(0); }
.cd-dossier-item.active { background: rgba(216,208,188,.025); }
.cd-dossier-item.active::before { height: 60%; }
.cd-dossier-dot {
  width: 3px; height: 3px;
  border-radius: 50%;
  background: var(--cream);
  flex-shrink: 0;
  opacity: 0;
  transition: opacity .2s;
}
.cd-dossier-item.active .cd-dossier-dot { opacity: .6; }
.cd-dossier-name {
  flex: 1;
  font-size: .78rem;
  font-weight: 300;
  color: var(--muted);
  line-height: 1.3;
  transition: color .25s;
}
.cd-dossier-item.active .cd-dossier-name {
  color: var(--text);
  font-weight: 400;
}
.cd-dossier-right {
  text-align: right;
  flex-shrink: 0;
}
.cd-dossier-num {
  font-family: var(--f-serif);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--cream);
  letter-spacing: -.02em;
  line-height: 1;
  opacity: .7;
}
.cd-dossier-item.active .cd-dossier-num { opacity: 1; }
.cd-dossier-num-lbl {
  font-size: .5rem;
  font-weight: 400;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--faint);
  margin-top: .15rem;
}


/* ── Hero wave mobile ── */
.hero-wave-mobile {
  display: none;
}

/* ── S2b : panel démo mobile uniquement ── */
#s2b { display: none; justify-content: flex-start; }
.s2b-inner {
  display: flex;
  flex-direction: column;
  width: 100%;
  flex: 1;
  padding: 5rem 1.4rem 2rem;
  gap: 0;
}
.s2b-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.8rem;
}
.s2b-num {
  font-family: var(--f-serif);
  font-size: .75rem;
  letter-spacing: .25em;
  color: var(--cream);
  opacity: .45;
}
.s2b-tag {
  font-size: .58rem;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--faint);
}
#s2b .curation-demo {
  flex: 1;
  height: auto;
}

/* ── RESPONSIVE — TABLET ≤900px ── */
@media (max-width: 900px) {
  .cur-h, .cur-v, .cur-dot, .halo { display: none; }
  body { cursor: auto; }
  .dots { display: none; }
  .nav { padding: 1rem 1.8rem; }
  .nav-links { gap: 1.4rem; }
  .nav-links a { font-size: .6rem; letter-spacing: .14em; }
  .fbar { padding: .85rem 1.8rem; }
  .logo-slot img { height: 36px; }

  /* S1 */
  .hero-freq { display: none; }
  .hero-inner {
    padding: 5.5rem 1.8rem 1.2rem;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
  }
  .hero-orb { display: none; }
  .hero-hl { grid-column: 1; grid-row: 1; align-self: start; }
  .hero-bottom {
    grid-column: 1; grid-row: 2;
    align-self: end;
    flex-direction: column; align-items: flex-start;
    gap: 1.2rem; padding-bottom: 2rem; padding-top: 1.2rem;
  }
  .hero-right { flex-direction: row; gap: 1.5rem; flex-wrap: wrap; }

  /* S2 tablette : texte gauche | démo droite, wave masquée */
  .s2-inner {
    grid-template-columns: 1fr 1fr;
    column-gap: 1.5rem;
    padding: 5.5rem 1.8rem 2rem;
    align-items: center;
  }
  .s2-wave { display: none; }
  .s2-desc { max-width: 100%; font-size: .85rem; }
  .curation-demo { height: min(58vh, 440px); }
}

/* ── MOBILE ≤580px — Design natif ── */
@media (max-width: 580px) {

  /* Nav : logo seul, épuré */
  .nav { padding: 1.1rem 1.4rem; align-items: center; }
  .logo-slot img { height: 26px; }
  .nav-links { display: none; }
  .fbar { display: none; }
  .dots { display: none; }

  /* S1 : flex colonne pleine hauteur */
  .hero-inner {
    display: flex;
    flex-direction: column;
    padding: 5.5rem 1.4rem 2rem;
    gap: 0;
    flex: 1;
  }
  .hero-freq { display: none; }

  /* Wave horizontale dans l'espace vide entre titre et description */
  .hero-wave-mobile {
    display: block;
    flex: 1;
    width: 100%;
    min-height: 80px;
    opacity: 0;
    animation: fadeIn .8s 1s ease forwards;
  }

  .hero-hl {
    font-size: clamp(3rem, 13vw, 4.2rem);
    line-height: .86;
    letter-spacing: -.02em;
    grid-column: unset; grid-row: unset;
    align-self: unset;
  }
  .hero-bottom {
    display: contents;
    border-top: none;
    padding: 0; margin: 0;
  }
  .hero-desc-block {
    margin-top: 2.2rem;
    padding-top: 1.1rem;
    border-top: .5px solid var(--border);
    gap: .5rem;
    opacity: 1; animation: none;
  }
  .hero-tag { font-size: .65rem; letter-spacing: .18em; }
  .hero-p { font-size: .85rem; line-height: 1.75; max-width: 100%; }
  .hero-right {
    margin-top: auto;
    padding-top: 2rem;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 1.1rem;
    opacity: 1; animation: none;
  }
  .hero-stat { text-align: left; }
  .hero-stat-num { font-size: 2.2rem; letter-spacing: -.03em; }
  .hero-stat-lbl { font-size: .58rem; max-width: 240px; }
  .btn-cta {
    width: 100%;
    justify-content: center;
    font-size: .65rem;
    padding: 1rem 1.4rem;
    letter-spacing: .18em;
  }
  .arr-hint { padding: .5rem 0 .8rem; font-size: .52rem; }

  /* S2 : flex colonne pleine hauteur */
  .s2-inner {
    display: flex;
    flex-direction: column;
    padding: 5rem 1.4rem 2rem;
    gap: 0;
    flex: 1;
  }
  /* s2-left occupe toute la hauteur pour ancrer les métriques en bas */
  .s2-left {
    display: flex;
    flex-direction: column;
    flex: 1;
  }
  .s2-wave { display: none; }
  .s2-right { display: none; }
  #s2b { display: flex; }

  /* Titre plus grand, plus d'impact */
  .s2-num { margin-bottom: .5rem; opacity: .35; }
  .s2-title {
    font-size: clamp(3rem, 13vw, 4rem);
    margin-bottom: 1.8rem;
    line-height: .86;
    letter-spacing: -.02em;
  }

  /* Description : phrase d'accroche courte, bien visible */
  .s2-desc {
    max-width: 100%;
    font-size: .95rem;
    line-height: 1.8;
    margin-bottom: 1.8rem;
    color: rgba(237,232,223,0.75);
  }

  /* Bullets : séparés visuellement, plus aérés */
  .s2-list {
    gap: 0;
    border-top: .5px solid var(--border);
  }
  .s2-list li {
    font-size: .75rem;
    padding: .75rem 0;
    border-bottom: .5px solid var(--border);
    gap: .9rem;
  }

  /* Métriques ancrées en bas */
  .s2-metrics {
    margin-top: auto;
    padding-top: 1.6rem;
    gap: 0;
    justify-content: space-between;
  }
  .s2-metric-num { font-size: 1.8rem; }
  .s2-metric-lbl { font-size: .54rem; }
}

/* ── iOS Safari ── */
@supports (-webkit-touch-callout: none) {
  body { overflow: hidden; height: -webkit-fill-available; }
  .scroll-wrap { height: -webkit-fill-available; }
  .panel { height: -webkit-fill-available; min-height: 100svh; }
}
