:root{
  --bg:#0b0d12;
  --text:#e9ecf5;
  --muted:#a7b0c3;
  --line:rgba(255,255,255,.10);
  --shadow:0 20px 60px rgba(0,0,0,.45);
  --radius:22px;
  --max:1100px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background:
    radial-gradient(1000px 600px at 20% -10%, rgba(124,92,255,.35), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.18), transparent 55%),
    var(--bg);
  color:var(--text);
}

/* Helpers */
.wrap{
  width:min(var(--max), calc(100% - 112px));
  margin-inline:auto;
}
@media (max-width: 900px){
  .wrap{ width:min(var(--max), calc(100% - 48px)); }
}

/* TOP BAR */
.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background: rgba(11,13,18,.55);
  backdrop-filter: blur(14px);
}
.topbar__inner{
  height:96px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  display:flex;
  align-items:center;
  text-decoration:none;
  color:#fff;
}
.brand__logo{
  height: 52px;
  width: auto;
  display: block;
}
.topbar__right{
  display:flex;
  align-items:center;
  gap:28px;
}
.nav{
  display:flex;
  align-items:center;
  gap:42px;
}
.nav__link{
  text-decoration:none;
  color:rgba(233,236,245,.88);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:650;
  font-size:13px;
  padding:10px 0;
}
.nav__link:hover{ color:rgba(255,255,255,.98); }

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:700;
  font-size:12px;
  padding:14px 26px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  color:var(--text);
  background:transparent;
}
.btn--contact{
  background:#fff;
  color:#0b0d12;
  border-color:transparent;
  padding:14px 28px;
}
.btn--primary{
  background:#fff;
  color:#0b0d12;
  border-color:transparent;
  padding:18px 44px;
  font-size:12px;
}

.topbar__divider{
  height:1px;
  background:var(--line);
}

/* HERO */
.hero{ padding:92px 0 38px; }
.hero__inner{ text-align:center; padding-top:22px; }

.hero__kicker{
  margin-bottom:45px;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-weight:750;
  color:rgba(233,236,245,.88);
  font-size:20px;   /* ← PLUS PETIT, visible immédiatement */
  white-space:nowrap;
}

.hero__title{
  margin:0;
  font-weight:800;
  line-height:1.02;
  letter-spacing:-.02em;
  font-size:clamp(42px, 5.2vw, 66px);
}

/* ✅ underline EXACTEMENT largeur du texte */
.hero__welcome{
  margin-top:45px;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  width:fit-content;
  margin-left:auto;
  margin-right:auto;
}
.hero__welcomeText{
  display:inline-block;
  font-size:clamp(18px, 2.1vw, 34px);
  color:rgba(233,236,245,.92);
}
.hero__welcomeText strong{ color:#fff; font-weight:850; }
.hero__underline{
  height:2px;
  width:100%;
  background:rgba(255,255,255,.78);
  border-radius:99px;
  display:block;
  margin-top:1px;
}

/* Pills */
.pillRow{
  margin-top:85px;
  display:flex;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
}
.pill{
  padding:12px 22px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:700;
  font-size:12px;
  color:rgba(233,236,245,.88);
}

/* SECTIONS */
.section{ padding:76px 0; }
.sectionDivider{
  height:1px;
  background:var(--line);
  margin-top:76px;
}

.h2{
  margin:0 0 18px;
  font-size:clamp(40px, 4.6vw, 64px);
  letter-spacing:-.02em;
  font-weight:850;
}
.sub{
  margin:0 0 28px;
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
}
.lead{
  margin:0 0 22px;
  color:var(--muted);
  font-size:18px;
  line-height:1.75;
  max-width:62ch;
}
.p{
  margin:0 0 18px;
  color:rgba(233,236,245,.82);
  font-size:18px;
  line-height:1.85;
  max-width:70ch;
}
.p--strong{
  font-weight:650;
  color:rgba(233,236,245,.9);
}

/* CABINET layout */
.cabinet{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:54px;
  align-items:start;
}
.cabinet__right{
  display:flex;
  justify-content:flex-start;
  margin-top:90px; /* aligne le 1er texte à droite avec le 1er texte à gauche */
}

/* ✅ Picto plus gros, plus bas, et texte aligné “à la hauteur du picto” */
.cabinetAside{
  display:flex;
  gap:26px;
  align-items:center;     /* texte calé sur la hauteur du picto */
  margin-top:10px;
}
.cabinetAsides{
  display:flex;
  flex-direction:column;
  gap:44px; /* espace entre les deux blocs */
}
.cabinetAside__icon{
  flex:0 0 auto;
  margin-top:0;   /* OBLIGATOIRE */
}
.cabinetAside__icon img{
  width:120px;   /* plus grand, mais maîtrisé */
  height:auto;
  opacity:.9;
  display:block;
}
/* 1) Colonne icône fixe : les textes démarrent au même endroit */
.cabinetAside__icon{
  width:120px;              /* même largeur que la Tour Eiffel */
  display:flex;
  justify-content:center;   /* centre l’icône dans sa colonne */
}

/* 2) Picto distanciel plus petit */
.cabinetAside--remote .cabinetAside__icon img{
  width:72px;               /* plus petit que 92px */
  height:auto;
}

.cabinetAside__text{
  margin:0;
  color:rgba(233,236,245,.78);
  font-size:19px;
  line-height:1.85;
  max-width:42ch;
}

@media (max-width: 980px){
  .cabinet{ grid-template-columns: 1fr; }
  .cabinetAside{ margin-top:0; }
  .cabinetAside__icon{ margin-top:0; }
}

/* GRIDS */
.grid{ display:grid; gap:22px; }
.grid--2{ grid-template-columns:repeat(2, 1fr); }
.grid--3{ grid-template-columns:repeat(3, 1fr); }
.grid--4{ grid-template-columns:repeat(4, 1fr); }

@media (max-width: 980px){
  .grid--2{ grid-template-columns:1fr; }
  .grid--3{ grid-template-columns:1fr; }
  .grid--4{ grid-template-columns:1fr; }
}

/* OFFRE cards */
.card{
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:28px 30px;
  box-shadow: var(--shadow);
}
.card__title{
  margin:0 0 14px;
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:800;
  font-size:16px;
  line-height:1.25;
}
.card__text{
  margin:0;
  color:rgba(233,236,245,.75);
  font-size:18px;
  line-height:1.85;
}

/* APPROCHE bar cards */
.barCard{
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  padding:20px 22px;
}
.barCard__title{
  margin:0 0 10px;
  font-weight:800;
  font-size:18px;
  color:#fff;
}
.barCard__text{
  margin:0;
  color:rgba(233,236,245,.76);
  font-size:16px;
  line-height:1.75;
}

/* METHOD steps */
.step{
  background: rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:26px 26px 24px;
}
.step__num{
  font-weight:900;
  font-size:56px;
  letter-spacing:-.02em;
}
.step__title{
  margin:10px 0 10px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:850;
  font-size:14px;
}
.step__text{
  margin:0;
  color:rgba(233,236,245,.72);
  font-size:18px;
  line-height:1.7;
}

/* CONTACT */
.contact{
  padding-top:64px;
  padding-bottom:160px;
}
.contact__inner{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:40px;
}
@media (max-width: 980px){
  .contact__inner{ grid-template-columns:1fr; }
  .contact__cta{ justify-self:start; }
}

/* FOOTER */
.footer{
  border-top:1px solid var(--line);
  padding:26px 0 34px;
}

.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between; /* gauche / centre / droite bien répartis */
  gap:24px;
}

/* gauche */
.footer__left{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:flex-start;
}
.footer__line{
  color:rgba(233,236,245,.68);
  font-size:14px;
  white-space:nowrap;
}

/* centre */
.social{
  flex:0;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}

/* droite */
.footer__right{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  color:rgba(233,236,245,.55);
  font-size:14px;
  white-space:nowrap;
}

.footer__link{
  color:rgba(233,236,245,.55);
  text-decoration:none;
}
.footer__link:hover{ color:rgba(233,236,245,.8); }
.footer__dot{ opacity:.5; }

.social__btn{
  width:54px;
  height:54px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.03);
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(233,236,245,.78);
  text-decoration:none;
}
.social__btn svg{
  width:22px;
  height:22px;
  display:block;
}

/* mobile */
@media (max-width: 980px){
  .footer__inner{
    flex-direction:column;
    align-items:flex-start;
    gap:18px;
  }
  .footer__left,
  .footer__right{
    justify-content:flex-start;
    white-space:normal;
  }
}

/* Offset propre pour les ancres (menu sticky) */
section[id] {
  scroll-margin-top: 100px;
}
/* Supprimer toutes les lignes entre sections */
.sectionDivider{
  display:none;
}
/* ============================
   MENTIONS LÉGALES
   ============================ */

.legal{
  padding: 120px 0 140px;
}

.legal h1{
  font-size: clamp(40px, 4.5vw, 64px);
  font-weight: 850;
  margin-bottom: 32px;
}

.legal h2{
  font-size: 20px;
  font-weight: 750;
  margin: 48px 0 14px;
}

.legal p{
  font-size: 18px;
  line-height: 1.85;
  color: rgba(233,236,245,.8);
  max-width: 75ch;
}

.legal a{
  color: #fff;
  text-decoration: underline;
}
/* ============================
   MOBILE FIXES
   ============================ */
@media (max-width: 680px){

  /* TOPBAR : logo + menu + contact visibles */
  .topbar__inner{
    height:auto;
    padding:14px 0 12px;
    gap:12px;
    flex-wrap:wrap;
    align-items:center;
  }

  .brand__logo{
    height:38px;
  }

  .topbar__right{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
  }

  .nav{
    gap:18px;
    overflow-x:auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{ display:none; }

  .nav__link{
    font-size:11px;
    letter-spacing:.16em;
    white-space:nowrap;
  }

  .btn--contact{
    padding:10px 14px;
    font-size:11px;
    letter-spacing:.16em;
    white-space:nowrap;
  }

  /* HERO kicker : devient responsive (plus coupé) */
  .hero__kicker{
    white-space:normal;
    font-size:14px;
    line-height:1.35;
    padding:0 6px;
    text-align:center;
  }

  /* CABINET : tour Eiffel centrée + texte dessous */
  .cabinet__right{
    margin-top:28px;       /* au lieu de 120px */
    justify-content:center;
  }

  .cabinetAside{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:18px;
    margin-top:0;
  }

  .cabinetAside__icon img{
    width:110px; /* ajustable si tu veux un peu + petit/grand */
  }

    .cabinetAside__text{
    max-width:none;
  }

  .cabinetAside--remote .cabinetAside__icon img{
    width:72px; /* ou 80px si tu veux un peu plus grand sur mobile */
  }
  
  /* FOOTER : tout centré en 3 lignes */
  .footer__inner{
    flex-direction:column;
    align-items:center;
    gap:16px;
  }

  .footer__left,
  .footer__right{
    flex:0;
    width:100%;
    justify-content:center;
    text-align:center;
    white-space:normal;
  }

  .footer__line{
    text-align:center;
  }

  .social{
    justify-content:center;
  }

  .footer__right{
    flex-wrap:wrap;
  }
}
  /* ============================
   CONTACT FORM (blocs pliables)
   ============================ */

.contact__inner{
  align-items:flex-start; /* le formulaire est plus haut que le bouton, on aligne proprement */
}

.contact__form{
  width: min(520px, 100%);
}

.step-form{
  width: 100%;
  margin-top: 6px;
}

.formGrid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 720px){
  .formGrid2{ grid-template-columns: 1fr; }
}

.formField{
  display:grid;
  gap: 8px;
  margin: 12px 0;
}
.formField span{
  font-size: 14px;
  opacity: 0.85;
}
.formField input,
.formField textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.04);
  color: #fff;
  padding: 12px 14px;
  outline: none;
}
.formField input:focus,
.formField textarea:focus{
  border-color: rgba(255,255,255,.28);
}

.formStep{
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 20px;
  background: rgba(255,255,255,.03);
  overflow: hidden;
  margin: 14px 0;
  transition: opacity .2s ease, filter .2s ease;
}

.formStep__header{
  width: 100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 18px 18px;
  background: transparent;
  color: #fff;
  border: 0;
  cursor: pointer;
  text-align:left;
}

.formStep__title{
  font-weight: 800;
  letter-spacing: .02em;
}

.formStep__status{
  font-size: 13px;
  opacity: .7;
}

.formStep.is-collapsed .formStep__panel{
  display:none;
}

.formStep.is-locked{
  opacity: 0.45;
  filter: grayscale(.2);
}
.formStep.is-locked .formStep__header{
  cursor:not-allowed;
}
.formStep.is-locked .formStep__panel{
  display:none;
}

.formStep.is-done .formStep__status::before{
  content:"✓ ";
  opacity:.9;
}

.formStep__panel{
  padding: 0 18px 18px 18px;
}

.formActions{
  display:flex;
  gap: 10px;
  justify-content:flex-end;
  margin-top: 10px;
}

.formBtn{
  /* on garde ton style .btn/.btn--primary, juste au cas où */
}

.recap{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.25);
  padding: 14px;
  line-height: 1.6;
}
.recap h4{
  margin: 10px 0 6px;
  font-size: 14px;
  opacity: 0.9;
}
.recap p{
  margin: 0 0 6px;
  opacity: 0.85;
}

.toast{
  margin-top: 10px;
  font-size: 14px;
  opacity: 0.85;
}

.fineprint{
  font-size: 12px;
  opacity: 0.65;
  margin-top: 10px;
}
