/* JoceOffice Pages — À propos + Contact */

:root {
  --jopg-f:    'Bricolage Grotesque','Helvetica Neue',Helvetica,Arial,sans-serif;
  --jopg-ease: cubic-bezier(.25,.46,.45,.94);
  --jopg-bd:   rgba(255,255,255,.08);
  --jopg-gap:  4rem;
}

/* ════════════════════════════════
   REVEAL — blur → net au scroll
════════════════════════════════ */
.jopg-reveal {
  opacity: 0;
  filter: blur(8px);
  transform: translateY(20px);
  transition:
    opacity  .85s var(--jopg-ease),
    filter   .85s var(--jopg-ease),
    transform .7s var(--jopg-ease);
  transition-delay: var(--delay, 0s);
}
.jopg-reveal.on {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* Ligne séparatrice */
.jopg-reveal--line {
  transform: scaleX(0);
  transform-origin: left;
  transition:
    opacity  .6s ease,
    filter   .6s ease,
    transform .9s var(--jopg-ease);
}
.jopg-reveal--line.on { transform: scaleX(1); }

/* Accessibilité + fallback si JS désactivé */
@media (prefers-reduced-motion: reduce) {
  .jopg-reveal {
    opacity: 1 !important;
    filter: none !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Sécurité : si le JS ne se charge pas, tout reste visible */
.no-js .jopg-reveal {
  opacity: 1;
  filter: none;
  transform: none;
}

/* ════════════════════════════════
   SÉPARATEUR
════════════════════════════════ */
.jopg-ap__sep {
  height: 1px;
  background: var(--jopg-bd);
  margin: calc(var(--jopg-gap) * .75) 0;
}

/* ════════════════════════════════
   À PROPOS
════════════════════════════════ */
.jopg-apropos {
  font-family: var(--jopg-f);
  color: #fafafa;
  padding: 5rem 0 4rem;
}

/* Header */
.jopg-ap__header { margin-bottom: 0; }
.jopg-ap__label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .18em;
  color: rgba(255,255,255,.35); margin: 0 0 1rem;
}
.jopg-ap__titre {
  font-size: clamp(2.5rem, 7vw, 8rem);
  font-weight: 500; letter-spacing: -.05em; line-height: .95;
  color: #fafafa; margin: 0;
}

/* Intro — texte large */
.jopg-ap__intro {
  max-width: 760px;
}
.jopg-ap__intro p {
  font-size: clamp(1.1rem, 2.2vw, 1.6rem);
  font-weight: 400; line-height: 1.45;
  letter-spacing: -.01em;
  color: rgba(255,255,255,.7);
  margin: 0;
}

/* 3 blocs en grille */
.jopg-ap__blocs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.jopg-ap__bloc-titre {
  font-size: 10px; text-transform: uppercase; letter-spacing: .16em;
  color: rgba(255,255,255,.3); margin: 0 0 .75rem;
}
.jopg-ap__bloc-texte p {
  font-size: .9rem; line-height: 1.65;
  color: rgba(255,255,255,.55); margin: 0;
}

/* CTA */
.jopg-ap__cta { padding: 1rem 0; }
.jopg-ap__cta-link {
  font-size: clamp(.95rem, 1.8vw, 1.25rem);
  font-weight: 500; letter-spacing: -.02em;
  color: #fafafa; text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.3);
  padding-bottom: 2px;
  transition: border-color .2s, opacity .2s;
}
.jopg-ap__cta-link:hover {
  border-color: #fafafa; opacity: .7;
}

/* ════════════════════════════════
   CONTACT
════════════════════════════════ */
.jopg-contact {
  font-family: var(--jopg-f);
  color: #fafafa;
  padding: 5rem 0 4rem;
}

.jopg-ct__header { margin-bottom: 0; }
.jopg-ct__label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .18em;
  color: rgba(255,255,255,.35); margin: 0 0 1rem;
}
.jopg-ct__titre {
  font-size: clamp(2.5rem, 7vw, 8rem);
  font-weight: 500; letter-spacing: -.05em; line-height: .95;
  color: #fafafa; margin: 0;
}
.jopg-ct__intro {
  font-size: clamp(1rem, 1.8vw, 1.3rem);
  color: rgba(255,255,255,.5); line-height: 1.55;
  max-width: 560px; margin: 0;
}

/* ── FORMULAIRE ── */
.jopg-form {
  display: flex; flex-direction: column; gap: 2rem;
  max-width: 760px;
  margin-top: calc(var(--jopg-gap) * .75);
}

.jopg-form__row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
}

.jopg-form__field {
  display: flex; flex-direction: column; gap: .5rem;
}

.jopg-form__label {
  font-size: 10px; text-transform: uppercase; letter-spacing: .14em;
  color: rgba(255,255,255,.35);
}

.jopg-form__input,
.jopg-form__textarea {
  font-family: var(--jopg-f);
  background: transparent;
  border: none; border-bottom: 1px solid rgba(255,255,255,.15);
  color: #fafafa; font-size: 1rem; line-height: 1.5;
  padding: .6rem 0;
  outline: none;
  transition: border-color .2s;
  width: 100%;
}
.jopg-form__input::placeholder,
.jopg-form__textarea::placeholder {
  color: rgba(255,255,255,.2);
}
.jopg-form__input:focus,
.jopg-form__textarea:focus {
  border-bottom-color: rgba(255,255,255,.5);
}
.jopg-form__textarea {
  resize: vertical; min-height: 140px;
}

/* Footer formulaire */
.jopg-form__footer {
  display: flex; align-items: center; gap: 1.5rem; padding-top: .5rem;
}

.jopg-form__submit {
  font-family: var(--jopg-f);
  font-size: .95rem; font-weight: 500; letter-spacing: -.01em;
  color: #0a0a0a; background: #fafafa;
  border: none; border-radius: 2px;
  padding: .75rem 2rem;
  cursor: pointer;
  transition: opacity .2s, transform .2s;
}
.jopg-form__submit:hover  { opacity: .85; }
.jopg-form__submit:active { transform: scale(.97); }
.jopg-form__submit:disabled {
  opacity: .4; cursor: not-allowed;
}

.jopg-form__status {
  font-size: .85rem; color: rgba(255,255,255,.45);
  transition: opacity .3s;
}
.jopg-form__status.ok  { color: rgba(255,255,255,.7); }
.jopg-form__status.err { color: rgba(255,100,100,.8); }

/* ── RESPONSIVE ── */
@media (max-width: 680px) {
  .jopg-ap__blocs    { grid-template-columns: 1fr; gap: 1.5rem; }
  .jopg-form__row    { grid-template-columns: 1fr; }
  .jopg-apropos,
  .jopg-contact      { padding: 3rem 0 3rem; }
}
