/* ============================================================
   APROPOS.CSS — Styles de la page À propos
   Nathan COLIN alias WillyOL
   Fond BLANC — texte NOIR
   ============================================================ */

.page-apropos {
  background: var(--blanc);
  color:      var(--noir);
}

/* ─────────────────────────────────────────────
   HERO
   ───────────────────────────────────────────── */
.apropos-hero {
  padding:    clamp(8rem, 14vw, 12rem) var(--marge) clamp(3rem, 6vw, 5rem);
}

.apropos-titre {
  font-family:    var(--font-titre);
  font-size:      clamp(4rem, 12vw, 11rem);
  line-height:    1;
  letter-spacing: -0.02em;

  opacity:          0;
  transform:        translateY(30px);
  animation:        monter-in 1s var(--ease-out) 0.3s forwards;
}

.apropos-sous {
  font-family:    var(--font-mono);
  font-size:      var(--fs-mono-sm);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color:          var(--gris-moyen);
  margin-top:     1rem;

  opacity:          0;
  transform:        translateY(12px);
  animation:        monter-in 0.8s var(--ease-out) 0.6s forwards;
}

@keyframes monter-in {
  to { opacity: 1; transform: translateY(0); }
}

/* ─────────────────────────────────────────────
   BIO — Photo + texte
   ───────────────────────────────────────────── */
.apropos-main {
  padding-bottom: clamp(4rem, 8vw, 8rem);
}

.apropos-bio-section {
  display:   grid;
  grid-template-columns: 1fr 1fr;
  gap:       clamp(3rem, 6vw, 8rem);
  padding:   0 var(--marge) clamp(4rem, 8vw, 8rem);
  align-items: start;
}

/* Placeholder photo */
.apropos-photo {
  position: sticky;
  top:      clamp(5rem, 10vw, 8rem);
}

.photo-placeholder {
  width:        100%;
  aspect-ratio: 3 / 4;
  background:   var(--gris-clair);
  overflow:     hidden;
}

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

/* Texte bio */
.apropos-bio-texte {
  padding-top: clamp(1rem, 3vw, 3rem);
  display:     flex;
  flex-direction: column;
  gap:         1.5rem;
}

.bio-paragraphe {
  font-size:   var(--fs-corps);
  line-height: 1.9;
  font-weight: 300;
  color:       rgba(10,10,10,0.72);
}

@media (max-width: 768px) {
  .apropos-bio-section {
    grid-template-columns: 1fr;
  }
  .apropos-photo {
    position: static;
    max-width: 80%;
  }
}

/* ─────────────────────────────────────────────
   COMPÉTENCES
   ───────────────────────────────────────────── */
.apropos-competences {
  padding: clamp(4rem, 8vw, 8rem) var(--marge);
}

.label-section {
  font-family:    var(--font-mono);
  font-size:      0.85rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color:          var(--gris-moyen);
  margin-bottom:  2.5rem;
}

.competences-grille {
  display:               grid;
  grid-template-columns: repeat(3, 1fr);
  gap:                   2rem;
}

.competence-groupe {
  border-top:  1px solid rgba(10,10,10,0.12);
  padding-top: 1.5rem;
}

.comp-titre {
  font-family:    var(--font-corps);
  font-size:      1rem;
  font-weight:    500;
  letter-spacing: 0.05em;
  margin-bottom:  1rem;
}

.comp-liste {
  list-style: none;
  display:    flex;
  flex-direction: column;
  gap:        0.55rem;
}

.comp-liste li {
  font-family: var(--font-mono);
  font-size:   0.9rem;
  letter-spacing: 0.08em;
  color:       var(--gris-moyen);
}

@media (max-width: 768px) {
  .competences-grille {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .competences-grille {
    grid-template-columns: 1fr;
  }
}

/* ─────────────────────────────────────────────
   CONTACT RAPIDE
   ───────────────────────────────────────────── */
.apropos-contact {
  padding:    clamp(4rem, 8vw, 8rem) var(--marge);
  display:    flex;
  flex-direction: column;
  gap:        1.5rem;
}

.apropos-contact h2 {
  font-family:    var(--font-titre);
  font-size:      clamp(2.5rem, 6vw, 5rem);
  letter-spacing: -0.02em;
}

.contact-lien {
  font-family:    var(--font-corps);
  font-size:      clamp(1rem, 2vw, 1.3rem);
  font-weight:    300;
  display:        inline-block;
  position:       relative;
  overflow:       hidden;
  line-height:    1.2;
  vertical-align: bottom;
  color:          rgba(10,10,10,0.55);
  transition:     color 0.4s ease;
}

.contact-lien:hover { color: var(--noir); }

.contact-lien .ce-layer-top {
  display:    block;
  transition: transform 0.5s var(--ease-out);
}

.contact-lien .ce-layer-bot {
  position:   absolute;
  inset:      0;
  display:    block;
  transform:  translateY(105%);
  transition: transform 0.5s var(--ease-out);
  color:      var(--noir);
}

.contact-lien:hover .ce-layer-top { transform: translateY(-105%); }
.contact-lien:hover .ce-layer-bot { transform: translateY(0%); }
