/* =========================================================
   GRACYL — PAGE À PROPOS
   ========================================================= */

body[data-page="a-propos"]{
  overflow-x:hidden;
}

.about-page,
.about-page *{
  box-sizing:border-box;
}

.about-page{
  position:relative;
  overflow:hidden;
}

.about-page::before{
  content:"";
  position:absolute;
  top:-260px;
  left:calc(50% - 50vw);
  width:100vw;
  height:1400px;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(70% 55% at 50% 0%, rgba(70,220,255,.25), transparent 68%),
    radial-gradient(42% 32% at 18% 36%, rgba(255,22,139,.12), transparent 70%),
    radial-gradient(45% 34% at 86% 34%, rgba(124,140,255,.14), transparent 72%);
  filter:blur(80px) saturate(150%);
}

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

.about-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin:0 0 14px;
  color:color-mix(in oklab, var(--muted, #5B6A7E), #000 12%);
  font-size:.82rem;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.about-kicker__dot{
  width:9px;
  height:9px;
  border-radius:999px;
  background:
    radial-gradient(circle at 30% 30%, #fff, rgba(255,255,255,.15) 38%, transparent 62%),
    linear-gradient(135deg, #12B3FF, #7C8CFF, #FF168B);
  box-shadow:0 8px 22px rgba(18,179,255,.20);
  flex:0 0 auto;
}

.about-section{
  padding:clamp(70px, 9vw, 124px) 0;
}

.about-section-head{
  max-width:980px;
  margin:0 auto clamp(34px, 5vw, 56px);
  text-align:center;
}

.about-section-head h2{
  margin:0 0 16px;
  font-size:clamp(34px, 5vw, 64px);
  line-height:1.02;
  letter-spacing:-.06em;
  text-wrap:balance;
  color:var(--ink, #0F172A);
}

.about-section-head p{
  margin:0 auto;
  max-width:76ch;
  color:var(--muted, #5B6A7E);
  font-size:1.08rem;
  line-height:1.78;
}

/* HERO */

.about-hero{
  padding:clamp(90px, 10vw, 150px) 0 clamp(64px, 8vw, 108px);
}

.about-hero__wrap{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(300px, 430px);
  gap:clamp(34px, 6vw, 90px);
  align-items:center;
}

.about-hero__content h1{
  margin:0;
  max-width:980px;
  font-size:clamp(44px, 7vw, 92px);
  line-height:.96;
  letter-spacing:-.075em;
  color:var(--ink, #0F172A);
  text-wrap:balance;
}

.about-hero__content p:not(.about-kicker){
  margin:28px 0 0;
  max-width:760px;
  color:var(--muted, #5B6A7E);
  font-size:clamp(1.1rem, 1.5vw, 1.28rem);
  line-height:1.78;
}

.about-hero__media{
  position:relative;
  margin:0;
  aspect-ratio:1 / 1.12;
  border-radius:38px;
  overflow:hidden;
  background:#fff;
  box-shadow:
    0 34px 90px rgba(15,23,42,.16),
    inset 0 1px 0 rgba(255,255,255,.82);
}

.about-hero__media::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, transparent 55%, rgba(15,23,42,.22)),
    radial-gradient(70% 50% at 30% 0%, rgba(18,179,255,.10), transparent 70%);
  pointer-events:none;
}

.about-hero__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}

/* STORY */

.about-story-section{
  padding:clamp(70px, 8vw, 112px) 0;
}

.about-story-card{
  padding:clamp(32px, 5vw, 70px);
  border-radius:42px;
  background:
    radial-gradient(70% 90% at 10% 0%, rgba(18,179,255,.15), transparent 66%),
    radial-gradient(70% 90% at 100% 100%, rgba(255,22,139,.11), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 34px 100px rgba(15,23,42,.12);
}

.about-story-card h2{
  margin:0 0 clamp(26px, 4vw, 42px);
  max-width:1080px;
  font-size:clamp(34px, 5vw, 66px);
  line-height:1.04;
  letter-spacing:-.06em;
  color:var(--ink, #0F172A);
  text-wrap:balance;
}



.about-story p{
  margin:0;
  color:var(--muted, #5B6A7E);
  font-size:1.05rem;
  line-height:1.82;
}

.about-story p:first-child{
  color:color-mix(in oklab, var(--ink, #0F172A), #fff 18%);
  font-weight:650;
}

/* STRENGTHS */

.about-strengths-section{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  background:
    radial-gradient(55% 85% at 12% 22%, rgba(18,179,255,.18), transparent 68%),
    radial-gradient(60% 85% at 86% 76%, rgba(255,22,139,.13), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.74), rgba(255,255,255,.54));
}

.about-strengths-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
}

.about-strength-card{
  min-width:0;
  padding:28px;
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.66));
  border:1px solid rgba(255,255,255,.78);
  box-shadow:0 20px 52px rgba(15,23,42,.08), inset 0 1px 0 rgba(255,255,255,.80);
  transition:transform .24s ease, box-shadow .24s ease;
}

.about-strength-card:hover{
  transform:translateY(-5px);
  box-shadow:0 30px 76px rgba(15,23,42,.13), inset 0 1px 0 rgba(255,255,255,.86);
}

.about-strength-card span{
  display:inline-flex;
  margin-bottom:22px;
  color:transparent;
  background:linear-gradient(90deg, #12B3FF, #7C8CFF, #FF168B);
  -webkit-background-clip:text;
  background-clip:text;
  font-size:1.2rem;
  font-weight:900;
  letter-spacing:-.04em;
}

.about-strength-card h3{
  margin:0 0 12px;
  color:var(--ink, #0F172A);
  font-size:1.22rem;
  letter-spacing:-.03em;
}

.about-strength-card p{
  margin:0;
  color:var(--muted, #5B6A7E);
  line-height:1.66;
}

/* ORIGIN */

.about-origin-section{
  padding:clamp(76px, 9vw, 130px) 0;
}

.about-origin-card{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(300px, 430px);
  gap:clamp(28px, 5vw, 70px);
  align-items:center;
  overflow:hidden;
  padding:clamp(34px, 5vw, 72px);
  border-radius:46px;
  background:
    radial-gradient(75% 90% at 0% 10%, rgba(18,179,255,.14), transparent 68%),
    radial-gradient(65% 85% at 100% 100%, rgba(255,22,139,.12), transparent 68%),
    #0F172A;
  box-shadow:0 38px 110px rgba(15,23,42,.24);
  color:#fff;
}

.about-origin__text h2{
  margin:0 0 24px;
  max-width:900px;
  font-size:clamp(38px, 6vw, 78px);
  line-height:.98;
  letter-spacing:-.07em;
  text-wrap:balance;
}

.about-origin__text h2 span{
  color:#7fd2ff;
}

.about-origin__text p{
  margin:1rem 0 0;
  max-width:78ch;
  color:rgba(255,255,255,.76);
  font-size:1.05rem;
  line-height:1.82;
}

.about-origin__text strong{
  color:#fff;
}

.about-origin-card .about-kicker{
  color:rgba(255,255,255,.58);
}

.about-origin__visual{
  position:relative;
  min-height:360px;
  display:grid;
  place-items:center;
  border-radius:34px;
  background:
    radial-gradient(70% 80% at 50% 15%, rgba(255,255,255,.10), transparent 68%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.10);
  overflow:hidden;
}

.about-origin__visual::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:
    radial-gradient(circle at 35% 35%, rgba(18,179,255,.20), transparent 30%),
    radial-gradient(circle at 70% 65%, rgba(255,22,139,.16), transparent 32%);
  filter:blur(34px);
}

.about-origin__word{
  position:relative;
  z-index:1;
  font-size:clamp(48px, 6vw, 86px);
  line-height:1;
  letter-spacing:-.08em;
  font-weight:300;
}

.about-origin__line{
  position:absolute;
  z-index:1;
  bottom:112px;
  width:58%;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.42), transparent);
}

.about-origin__small{
  position:absolute;
  z-index:1;
  bottom:46px;
  left:34px;
  right:34px;
  text-align:center;
  color:rgba(255,255,255,.64);
  line-height:1.5;
  font-weight:650;
}

/* METHOD */

.about-method-card{
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(320px, 1fr);
  gap:clamp(28px, 5vw, 70px);
  align-items:start;
  padding:clamp(32px, 5vw, 66px);
  border-radius:42px;
  background:
    radial-gradient(70% 90% at 10% 0%, rgba(18,179,255,.15), transparent 66%),
    radial-gradient(70% 90% at 100% 100%, rgba(255,22,139,.11), transparent 64%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 34px 100px rgba(15,23,42,.12);
}

.about-method-card h2{
  margin:0 0 18px;
  font-size:clamp(34px, 5vw, 62px);
  line-height:1.04;
  letter-spacing:-.06em;
  text-wrap:balance;
}

.about-method-card p{
  margin:0;
  color:var(--muted, #5B6A7E);
  line-height:1.76;
  font-size:1.05rem;
}

.about-method-list{
  display:grid;
  gap:14px;
}

.about-method-list div{
  padding:20px;
  border-radius:24px;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 14px 34px rgba(15,23,42,.06), inset 0 1px 0 rgba(255,255,255,.78);
}

.about-method-list strong{
  display:block;
  margin-bottom:6px;
  color:var(--ink, #0F172A);
  font-size:1rem;
}

.about-method-list span{
  display:block;
  color:var(--muted, #5B6A7E);
  line-height:1.5;
}

/* CTA */

.about-final{
  padding:clamp(72px, 9vw, 120px) 0 clamp(88px, 10vw, 140px);
}

.about-final-card{
  text-align:center;
  padding:clamp(34px, 6vw, 72px);
  border-radius:44px;
  background:
    radial-gradient(70% 90% at 50% -10%, rgba(255,22,139,.18), transparent 65%),
    radial-gradient(80% 100% at 20% 100%, rgba(18,179,255,.14), transparent 66%),
    linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.72));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 34px 100px rgba(15,23,42,.13);
}

.about-final-card h2{
  margin:0 0 18px;
  font-size:clamp(34px, 5.4vw, 70px);
  line-height:1.02;
  letter-spacing:-.065em;
  text-wrap:balance;
}

.about-final-card p{
  margin:0 auto;
  max-width:74ch;
  color:var(--muted, #5B6A7E);
  font-size:1.08rem;
  line-height:1.76;
}

.about-final-actions{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}

/* REVEAL */

.about-page .reveal{
  opacity:0;
  transform:translateY(24px);
  transition:
    opacity .7s ease,
    transform .7s cubic-bezier(.22,.61,.36,1);
}

.about-page .reveal.reveal-visible{
  opacity:1;
  transform:none;
}

/* RESPONSIVE */

@media (max-width:1080px){
  .about-strengths-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .about-story,
  .about-method-card{
    grid-template-columns:1fr;
  }
}

@media (max-width:900px){
  .about-hero__wrap,
  .about-origin-card{
    grid-template-columns:1fr;
  }

  .about-hero__media{
    max-width:460px;
  }

  .about-origin__visual{
    min-height:300px;
  }
}

@media (max-width:680px){
  .about-hero{
    padding-top:72px;
  }

  .about-story-card,
  .about-origin-card,
  .about-method-card,
  .about-final-card{
    border-radius:30px;
  }

  .about-strengths-grid{
    grid-template-columns:1fr;
  }

  .about-final-actions .btn{
    width:100%;
  }
}

@media (max-width:430px){
  .about-section-head,
  .about-final-card{
    text-align:left;
  }

  .about-final-actions{
    justify-content:flex-start;
  }
}

.about-story-newspaper{
  position:relative;
  max-width:1120px;
  margin:0 auto;
  column-count:2;
  column-gap:clamp(42px, 6vw, 78px);
  column-rule:1px solid rgba(15,23,42,.10);
  color:var(--muted, #5B6A7E);
  font-size:1.06rem;
  line-height:1.92;
  text-align:justify;
  text-justify:inter-word;
  hyphens:auto;
}

.about-story-newspaper p{
  margin:0 0 1.35rem;
  break-inside:avoid;
  orphans:3;
  widows:3;
}

.about-story-newspaper .about-story-intro{
  color:color-mix(in oklab, var(--ink, #0F172A), #fff 12%);
  font-weight:650;
  font-size:1.13rem;
  line-height:1.88;
}

.about-story-newspaper .about-story-intro::first-letter{
  float:left;
  margin:.12em .14em 0 0;
  font-size:4.8rem;
  line-height:.78;
  font-weight:800;
  letter-spacing:-.08em;
  color:transparent;
  background:linear-gradient(135deg, #12B3FF, #7C8CFF, #FF168B);
  -webkit-background-clip:text;
  background-clip:text;
}

.about-story-card{
  overflow:hidden;
}

@media (max-width:1080px){
  .about-story-newspaper{
    column-count:1;
    column-gap:0;
    column-rule:0;
    max-width:78ch;
  }
}

@media (max-width:680px){
  .about-story-newspaper{
    text-align:left;
    font-size:1rem;
    line-height:1.82;
  }

  .about-story-newspaper .about-story-intro::first-letter{
    font-size:3.8rem;
  }
}