
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
:root {
  --noir:#0b1614; --teal-prof:#0f2220; --teal-mid:#1a3d3a; --teal-clair:#2a5550;
  --rose:#c8a48a; --rose-pale:#e8c5a0; --or:#c4a96b; --blanc:#f0ece3; --gris:#8a9490;
  --serif:'Playfair Display',Georgia,serif; --sans:'Jost',sans-serif;
}
html { scroll-behavior:smooth; }
body { background:var(--noir); color:var(--blanc); font-family:var(--sans); font-weight:300; overflow-x:hidden; cursor:none; }
body::before {
  content:''; position:fixed; inset:0; pointer-events:none; z-index:1000; opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:180px;
}
#cur { position:fixed; width:6px; height:6px; background:var(--or); border-radius:50%; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:width .3s,height .3s; }
#cur-ring { position:fixed; width:28px; height:28px; border:1px solid rgba(196,169,107,.3); border-radius:50%; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); }
@media(max-width:900px){#cur,#cur-ring{display:none}body{cursor:auto}}

/* ── NAV ── */
nav { position:fixed; top:0; left:0; right:0; z-index:500; display:flex; align-items:center; justify-content:space-between; padding:1.4rem 4rem; transition:background .4s; }
nav.scrolled { background:rgba(11,22,20,.94); backdrop-filter:blur(12px); border-bottom:1px solid rgba(196,169,107,.1); }
.nav-logo { display:flex; align-items:center; gap:1rem; text-decoration:none; }
.nav-logo-icon { width:36px; height:36px; object-fit:contain; }
.nav-logo-txt { display:flex; flex-direction:column; line-height:1.1; }
.nav-logo-txt .name { font-family:var(--serif); font-size:1rem; font-weight:500; color:var(--blanc); letter-spacing:.04em; }
.nav-logo-txt .sub { font-family:var(--sans); font-size:.5rem; font-weight:300; letter-spacing:.3em; text-transform:uppercase; color:var(--gris); }
.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a { font-family:var(--sans); font-size:.78rem; font-weight:400; letter-spacing:.18em; text-transform:uppercase; color:rgba(240,236,227,.82); text-decoration:none; transition:color .3s; }
.nav-links a:hover { color:var(--or); }
/* Bouton fermer masqué sur desktop */
.nav-close { display:none; }
.nav-links a:hover { color:var(--or); }
.nav-cta { font-family:var(--sans); font-size:.65rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase; color:var(--noir); background:var(--or); padding:.65rem 1.4rem; text-decoration:none; transition:background .3s; }
.nav-cta:hover { background:var(--rose-pale); }
@media(max-width:900px){ .nav-links,.nav-cta { display:none; } nav { padding:1.2rem 1.5rem; } }

/* ── HERO ── */
#hero { position:relative; height:100vh; display:flex; flex-direction:column; justify-content:flex-end; padding:0 4rem 7rem; overflow:hidden; }
.hero-bg { position:absolute; inset:0; z-index:0; background-image:var(--hero-bg-url); background-size:cover; background-position:center; opacity:.42; }
.hero-overlay { position:absolute; inset:0; z-index:1; background:linear-gradient(to top,rgba(11,22,20,.95) 0%,rgba(11,22,20,.45) 45%,rgba(11,22,20,.15) 100%),linear-gradient(to right,rgba(11,22,20,.35) 0%,transparent 65%); }
.hero-tag { position:relative; z-index:2; font-family:var(--sans); font-size:.6rem; font-weight:300; letter-spacing:.35em; text-transform:uppercase; color:var(--or); display:flex; align-items:center; gap:1rem; margin-bottom:1.8rem; opacity:0; animation:fadeUp .9s ease .3s forwards; }
.hero-tag::before { content:''; width:30px; height:1px; background:var(--or); opacity:.5; }
.hero-title { position:relative; z-index:2; font-family:var(--serif); font-size:clamp(3.8rem,8.5vw,8.5rem); font-weight:400; line-height:.9; letter-spacing:-.02em; color:var(--blanc); opacity:0; animation:fadeUp 1s ease .55s forwards; }
.hero-title em { font-style:italic; color:var(--or); }
.hero-sub { position:relative; z-index:2; margin-top:2.5rem; max-width:480px; font-size:1rem; font-weight:300; line-height:1.8; color:var(--gris); opacity:0; animation:fadeUp .9s ease .8s forwards; }
.hero-cta { position:relative; z-index:2; margin-top:3rem; display:flex; gap:2rem; align-items:center; opacity:0; animation:fadeUp .9s ease 1.05s forwards; }
.btn-or { font-family:var(--sans); font-size:.68rem; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:var(--noir); background:var(--or); padding:1rem 2.8rem; text-decoration:none; transition:background .3s,transform .2s; }
.btn-or:hover { background:var(--rose-pale); transform:translateY(-2px); }
.btn-outline { font-family:var(--sans); font-size:.68rem; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:var(--gris); text-decoration:none; padding-bottom:2px; border-bottom:1px solid rgba(138,148,144,.3); transition:color .3s,border-color .3s; }
.btn-outline:hover { color:var(--blanc); border-color:var(--blanc); }
.hero-scroll { position:absolute; right:4rem; bottom:3.5rem; z-index:2; display:flex; flex-direction:column; align-items:center; gap:.6rem; opacity:0; animation:fadeUp .9s ease 1.3s forwards; }
.hero-scroll span { font-family:var(--sans); font-size:.55rem; font-weight:300; letter-spacing:.3em; text-transform:uppercase; color:var(--gris); writing-mode:vertical-rl; }
@media(max-width:900px){
  .hero-scroll { display:none; }
  .hero-cta { flex-direction:column; align-items:flex-start; gap:1.2rem; }
  .btn-outline { border-bottom:1px solid rgba(138,148,144,.3); }
}
.scroll-line { width:1px; height:55px; background:linear-gradient(to bottom,var(--or),transparent); animation:pulse 2.2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:.25} 50%{opacity:1} }
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@media(max-width:900px){ #hero { padding:0 1.5rem 4rem; } }

.divider { width:100%; height:1px; background:linear-gradient(to right,transparent,rgba(196,169,107,.2),transparent); }

/* ── SECTIONS ── */
section { padding:8rem 4rem; }
.s-label { font-family:var(--sans); font-size:.58rem; font-weight:300; letter-spacing:.35em; text-transform:uppercase; color:var(--or); display:flex; align-items:center; gap:.8rem; margin-bottom:2.5rem; }
.s-label::after { content:''; width:50px; height:1px; background:var(--or); opacity:.4; }
h2 { font-family:var(--serif); font-size:clamp(2.4rem,4.5vw,4rem); font-weight:400; line-height:1.05; letter-spacing:-.015em; color:var(--blanc); }
h2 em { font-style:italic; color:var(--or); }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .85s ease,transform .85s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.d1 { transition-delay:.1s; } .d2 { transition-delay:.2s; } .d3 { transition-delay:.3s; }
@media(max-width:900px){ section { padding:4.5rem 1.5rem; } }

/* ── À PROPOS ── */
#apropos { background:var(--teal-prof); display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; }
.apropos-body { margin-top:2rem; }
.apropos-body p { font-size:1rem; line-height:1.9; color:var(--gris); margin-top:1.2rem; }
.apropos-body strong { color:var(--rose-pale); font-weight:300; }
.atouts { margin-top:2.5rem; display:flex; flex-direction:column; gap:.8rem; }
.atout { display:flex; align-items:flex-start; gap:1rem; padding:.9rem 1.1rem; border:1px solid rgba(196,169,107,.1); background:rgba(196,169,107,.03); transition:border-color .3s,background .3s; }
.atout:hover { border-color:rgba(196,169,107,.25); background:rgba(196,169,107,.06); }
.atout-icon { color:var(--or); flex-shrink:0; margin-top:.1rem; }
.atout-text { font-size:.88rem; line-height:1.65; color:var(--gris); }
.atout-text strong { color:var(--blanc); font-weight:300; display:block; margin-bottom:.15rem; }

/* LOGO SIDE */
.apropos-right { display:flex; flex-direction:column; align-items:center; gap:3rem; }
.logo-block { display:flex; flex-direction:column; align-items:center; gap:.6rem; }
.logo-block img { width:160px; height:160px; object-fit:contain; }
.logo-block .brand-name { font-family:var(--serif); font-size:1.5rem; font-weight:500; color:var(--blanc); letter-spacing:.06em; text-align:center; margin-top:.3rem; }
.logo-block .brand-sub { font-family:var(--sans); font-size:.58rem; font-weight:300; letter-spacing:.35em; text-transform:uppercase; color:var(--gris); }
.apropos-chiffres { display:grid; grid-template-columns:1fr 1fr; gap:2px; width:100%; }
.chiffre { background:rgba(196,169,107,.05); border:1px solid rgba(196,169,107,.08); padding:1.6rem 1.5rem; transition:background .3s; }
.chiffre:hover { background:rgba(196,169,107,.1); }
.chiffre-val { font-family:var(--serif); font-size:2.3rem; font-weight:400; color:var(--or); letter-spacing:-.03em; display:block; }
.chiffre-lbl { font-family:var(--sans); font-size:.56rem; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:var(--gris); margin-top:.3rem; display:block; }
@media(max-width:900px){ #apropos { grid-template-columns:1fr; gap:3rem; } }

/* ── SERVICES ── */
#services { background:var(--noir); }
.services-head { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-bottom:5rem; align-items:end; }
.services-head p { font-size:1rem; line-height:1.85; color:var(--gris); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; }
.srv { background:var(--teal-prof); padding:2.8rem 2.2rem; position:relative; overflow:hidden; transition:background .4s; display:flex; flex-direction:column; gap:1rem; }
.srv::before { content:''; position:absolute; top:0; left:0; width:100%; height:2px; background:var(--or); transform:scaleX(0); transform-origin:left; transition:transform .4s; }
.srv:hover::before { transform:scaleX(1); }
.srv:hover { background:var(--teal-mid); }
.srv-num { font-family:var(--sans); font-size:.58rem; font-weight:300; letter-spacing:.25em; text-transform:uppercase; color:var(--or); opacity:.5; }
.srv-icon { width:34px; height:34px; border:1px solid rgba(196,169,107,.2); display:flex; align-items:center; justify-content:center; color:var(--or); }
.srv-title { font-family:var(--serif); font-size:1.25rem; font-weight:400; color:var(--blanc); line-height:1.2; }
.srv-desc { font-size:.87rem; line-height:1.75; color:var(--gris); flex:1; }
.srv-tags { display:flex; flex-wrap:wrap; gap:.35rem; margin-top:.4rem; }
.srv-tag { font-family:var(--sans); font-size:.52rem; font-weight:300; letter-spacing:.13em; text-transform:uppercase; color:var(--or); border:1px solid rgba(196,169,107,.2); padding:.2rem .6rem; }
@media(max-width:1024px){ .services-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:900px){ .services-head { grid-template-columns:1fr; gap:1.5rem; } .services-grid { grid-template-columns:1fr; } }

/* ── RÉALISATIONS + INSTAGRAM WIDGET ── */
#realisations { background:var(--teal-prof); }
.real-head { display:grid; grid-template-columns:1fr 1fr; gap:4rem; margin-bottom:4rem; align-items:end; }
.real-head p { font-size:1rem; line-height:1.85; color:var(--gris); }

.ig-widget {
  border:1px solid rgba(196,169,107,.15);
  background:rgba(196,169,107,.03);
  overflow:hidden;
}
.ig-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.2rem 1.5rem;
  border-bottom:1px solid rgba(196,169,107,.1);
}
.ig-profile { display:flex; align-items:center; gap:1rem; }
.ig-avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--teal-mid),var(--or));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:1.1rem; color:var(--blanc); font-weight:400;
  flex-shrink:0;
}
.ig-info { display:flex; flex-direction:column; gap:.2rem; }
.ig-handle { font-family:var(--sans); font-size:.85rem; font-weight:400; color:var(--blanc); }
.ig-name { font-family:var(--sans); font-size:.65rem; font-weight:300; color:var(--gris); letter-spacing:.05em; }
.ig-btn {
  font-family:var(--sans); font-size:.62rem; font-weight:300; letter-spacing:.18em; text-transform:uppercase;
  color:var(--noir); background:var(--or); padding:.5rem 1.2rem; text-decoration:none;
  display:flex; align-items:center; gap:.4rem; transition:background .3s;
  flex-shrink:0;
}
.ig-btn:hover { background:var(--rose-pale); }
.ig-btn svg { width:12px; height:12px; }

.ig-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2px;
  padding:2px;
}
.ig-cell {
  aspect-ratio:1/1; position:relative; overflow:hidden;
  background:var(--teal-mid); cursor:pointer;
}
.ig-cell img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease,opacity .4s; }
.ig-cell:hover img { transform:scale(1.05); opacity:.8; }
.ig-cell-overlay {
  position:absolute; inset:0; z-index:1;
  background:rgba(11,22,20,.65);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .3s;
}
.ig-cell:hover .ig-cell-overlay { opacity:1; }
.ig-cell-overlay svg { color:var(--blanc); }

/* Placeholder cells pour les cases vides */
.ig-cell-empty {
  aspect-ratio:1/1; background:var(--teal-mid);
  border:1px solid rgba(196,169,107,.08);
  display:flex; align-items:center; justify-content:center;
}
.ig-cell-empty svg { opacity:.15; }

.ig-footer {
  padding:1rem 1.5rem;
  border-top:1px solid rgba(196,169,107,.1);
  display:flex; align-items:center; justify-content:space-between;
}
.ig-footer span { font-family:var(--sans); font-size:.65rem; font-weight:300; color:var(--gris); }
.ig-footer a { font-family:var(--sans); font-size:.65rem; font-weight:300; color:var(--or); text-decoration:none; letter-spacing:.1em; }
.ig-footer a:hover { text-decoration:underline; }
@media(max-width:900px){ .real-head { grid-template-columns:1fr; gap:1.5rem; } .ig-grid { grid-template-columns:repeat(3,1fr); } }

/* ── PROCESSUS ── */
#processus { background:var(--noir); }
.proc-intro { margin-bottom:4rem; max-width:600px; }
.proc-intro p { font-size:1rem; line-height:1.85; color:var(--gris); margin-top:1.5rem; }
.proc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; }
.etape { background:var(--teal-prof); padding:2.8rem 2rem; border-top:1px solid rgba(196,169,107,.08); transition:background .3s; }
.etape:hover { background:var(--teal-mid); }
.etape-n { font-family:var(--serif); font-size:5rem; font-weight:400; color:rgba(196,169,107,.07); line-height:1; letter-spacing:-.05em; margin-bottom:.8rem; }
.etape-title { font-family:var(--serif); font-size:1.1rem; font-weight:400; color:var(--blanc); margin-bottom:.8rem; }
.etape-desc { font-size:.85rem; line-height:1.75; color:var(--gris); }
@media(max-width:1024px){ .proc-grid { grid-template-columns:1fr 1fr; } }

/* ── CONTACT ── */
#contact { background:var(--teal-prof); display:grid; grid-template-columns:1fr 1fr; gap:7rem; align-items:start; }
.contact-left p { font-size:1rem; line-height:1.85; color:var(--gris); margin-top:1.8rem; margin-bottom:3rem; }
.contact-details { display:flex; flex-direction:column; gap:1.5rem; }
.cd-item { display:flex; flex-direction:column; gap:.3rem; }
.cd-item .lbl { font-family:var(--sans); font-size:.54rem; font-weight:300; letter-spacing:.3em; text-transform:uppercase; color:var(--or); opacity:.6; }
.cd-item a,.cd-item span { font-size:.98rem; font-weight:300; color:var(--rose-pale); text-decoration:none; transition:color .3s; }
.cd-item a:hover { color:var(--or); }
.form { display:flex; flex-direction:column; gap:1.4rem; }
.fg { display:flex; flex-direction:column; gap:.4rem; }
.fg label { font-family:var(--sans); font-size:.54rem; font-weight:300; letter-spacing:.3em; text-transform:uppercase; color:var(--gris); }
.fg input,.fg select,.fg textarea { background:rgba(255,255,255,.03); border:none; border-bottom:1px solid rgba(196,169,107,.2); color:var(--blanc); font-family:var(--sans); font-size:.95rem; font-weight:300; padding:.85rem .2rem; outline:none; resize:none; appearance:none; transition:border-color .3s; }
.fg input:focus,.fg select:focus,.fg textarea:focus { border-color:var(--or); }
.fg select option { background:var(--teal-prof); color:var(--blanc); }
.fg input::placeholder,.fg textarea::placeholder { color:rgba(138,148,144,.35); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.btn-submit { font-family:var(--sans); font-size:.68rem; font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:var(--noir); background:var(--or); border:none; padding:1rem 2.5rem; cursor:pointer; align-self:flex-start; transition:background .3s,transform .2s; margin-top:.5rem; }
.btn-submit:hover { background:var(--rose-pale); transform:translateY(-2px); }
@media(max-width:900px){ #contact { grid-template-columns:1fr; gap:3rem; } .form-row { grid-template-columns:1fr; } }

/* ── FOOTER ── */
footer { background:var(--noir); padding:2.5rem 4rem; display:flex; align-items:center; justify-content:space-between; border-top:1px solid rgba(196,169,107,.08); }
.ft-logo { display:flex; align-items:center; gap:.9rem; text-decoration:none; }
.ft-logo img { width:28px; height:28px; object-fit:contain; }
.ft-logo-txt { display:flex; flex-direction:column; line-height:1.1; }
.ft-logo-txt .name { font-family:var(--serif); font-size:.9rem; font-weight:500; color:var(--blanc); letter-spacing:.04em; }
.ft-logo-txt .sub { font-family:var(--sans); font-size:.48rem; font-weight:300; letter-spacing:.28em; text-transform:uppercase; color:var(--gris); }
.ft-copy { font-family:var(--sans); font-size:.57rem; font-weight:300; letter-spacing:.13em; color:var(--gris); }
.ft-links { display:flex; gap:2rem; list-style:none; }
.ft-links a { font-family:var(--sans); font-size:.57rem; font-weight:300; letter-spacing:.13em; text-transform:uppercase; color:var(--gris); text-decoration:none; transition:color .3s; }
.ft-links a:hover { color:var(--or); }
@media(max-width:900px){ footer { flex-direction:column; gap:1.5rem; text-align:center; } }

/* ── INSTAGRAM NOTE ── */
.ig-note {
  padding:1rem 1.5rem;
  border-top:1px solid rgba(196,169,107,.1);
  font-family:var(--sans); font-size:.8rem; line-height:1.7; color:var(--gris);
}
.ig-note a { color:var(--or); text-decoration:none; }
.ig-note a:hover { text-decoration:underline; }
.ig-note strong { color:var(--blanc); font-weight:300; }
.ig-feed-plugin { padding:1rem; }
.ig-ph { width:100%; height:100%; }

/* ── PHRASE ACCOMPAGNEMENT SERVICES ── */
.services-note {
  margin-top: 3px;
}
.services-note-inner {
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  padding: 2rem 2.5rem;
  background: var(--teal-mid);
  border-left: 2px solid var(--or);
}
.services-note-icon {
  color: var(--or);
  flex-shrink: 0;
  margin-top: .15rem;
}
.services-note-inner p {
  font-family: var(--serif);
  font-size: 1.05rem;
  font-style: italic;
  font-weight: 400;
  line-height: 1.75;
  color: var(--rose-pale);
  margin: 0;
}




/* ══════════════════════════════════════
   WPFORMS — Charte Trajectoire v4
   ══════════════════════════════════════ */

/* Reset général */
.wpforms-container { width:100% !important; }
.wpforms-form { display:flex !important; flex-direction:column !important; gap:1.2rem !important; }
.wpforms-title, .wpforms-description, .wpforms-required-label { display:none !important; }
.wpforms-form * { box-sizing:border-box !important; }

/* Chaque champ */
.wpforms-field { padding:0 !important; margin:0 0 1.2rem 0 !important; }

/* Label principal */
.wpforms-field-label {
  font-family:'Jost',sans-serif !important;
  font-size:.54rem !important;
  font-weight:300 !important;
  letter-spacing:.3em !important;
  text-transform:uppercase !important;
  color:#8a9490 !important;
  margin:0 0 .5rem 0 !important;
  padding:0 !important;
  display:block !important;
  float:none !important;
  width:100% !important;
}

/* Sous-labels (Prénom/Nom) — invisibles mais sans impact layout */
.wpforms-field-sublabel {
  visibility:hidden !important;
  height:0 !important;
  line-height:0 !important;
  font-size:0 !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
  display:block !important;
}

/* Champ Nom : deux colonnes */
.wpforms-field-name > .wpforms-field-row {
  display:flex !important;
  flex-direction:row !important;
  align-items:flex-end !important;
  gap:1.5rem !important;
  width:100% !important;
  float:none !important;
}
.wpforms-field-name > .wpforms-field-row::before,
.wpforms-field-name > .wpforms-field-row::after { display:none !important; }
.wpforms-field-name .wpforms-field-row-block {
  flex:1 1 0 !important;
  width:auto !important;
  float:none !important;
  padding:0 !important;
  margin:0 !important;
  min-width:0 !important;
}
.wpforms-field-name .wpforms-field-row-block input {
  width:100% !important;
}

/* Tous les inputs / select / textarea */
.wpforms-form input[type=text],
.wpforms-form input[type=email],
.wpforms-form input[type=tel],
.wpforms-form input[type=url],
.wpforms-form input[type=number],
.wpforms-form textarea,
.wpforms-form select {
  display:block !important;
  float:none !important;
  width:100% !important;
  background:transparent !important;
  border:none !important;
  border-bottom:1px solid rgba(196,169,107,.3) !important;
  border-radius:0 !important;
  box-shadow:none !important;
  -webkit-box-shadow:none !important;
  color:#f0ece3 !important;
  font-family:'Jost',sans-serif !important;
  font-size:.95rem !important;
  font-weight:300 !important;
  line-height:1.5 !important;
  padding:.7rem 0 !important;
  margin:0 !important;
  outline:none !important;
  transition:border-color .3s !important;
  -webkit-appearance:none !important;
  appearance:none !important;
}
.wpforms-form input[type=text]:focus,
.wpforms-form input[type=email]:focus,
.wpforms-form input[type=tel]:focus,
.wpforms-form textarea:focus,
.wpforms-form select:focus {
  border-bottom-color:#c4a96b !important;
  box-shadow:none !important;
  outline:none !important;
}

/* Placeholder */
.wpforms-form input::placeholder,
.wpforms-form textarea::placeholder {
  color:rgba(240,236,227,.45) !important;
  font-family:'Jost',sans-serif !important;
  font-weight:300 !important;
}

/* Select options */
.wpforms-form select option { background:#0f2220 !important; color:#f0ece3 !important; }

/* Textarea */
.wpforms-form textarea { resize:vertical !important; min-height:130px !important; }

/* Bouton submit */
.wpforms-submit-container { padding:0 !important; margin:0 !important; }
.wpforms-form .wpforms-submit,
.wpforms-form button[type=submit],
.wpforms-form input[type=submit] {
  display:inline-block !important;
  float:none !important;
  width:auto !important;
  font-family:'Jost',sans-serif !important;
  font-size:.68rem !important;
  font-weight:300 !important;
  letter-spacing:.2em !important;
  text-transform:uppercase !important;
  color:#0b1614 !important;
  background:#c4a96b !important;
  border:none !important;
  border-radius:0 !important;
  padding:1rem 2.5rem !important;
  cursor:pointer !important;
  box-shadow:none !important;
  -webkit-box-shadow:none !important;
  transition:background .3s, transform .2s !important;
  margin-top:.5rem !important;
}
.wpforms-form .wpforms-submit:hover { background:#e8c5a0 !important; transform:translateY(-2px) !important; }

/* Confirmation */
.wpforms-confirmation-container-full,
.wpforms-confirmation-container {
  background:rgba(196,169,107,.06) !important;
  border:1px solid rgba(196,169,107,.2) !important;
  border-radius:0 !important;
  color:#f0ece3 !important;
  font-family:'Jost',sans-serif !important;
  font-weight:300 !important;
  font-size:.95rem !important;
  padding:1.5rem 2rem !important;
  margin-top:1rem !important;
}

/* Erreurs */
.wpforms-form label.wpforms-error {
  display:block !important;
  float:none !important;
  color:#c8a48a !important;
  font-family:'Jost',sans-serif !important;
  font-size:.72rem !important;
  font-weight:300 !important;
  letter-spacing:.05em !important;
  margin-top:.25rem !important;
  padding:0 !important;
  background:none !important;
  border:none !important;
}
.wpforms-form input.wpforms-error,
.wpforms-form textarea.wpforms-error { border-bottom-color:#c8a48a !important; }

/* Nettoyage clearfix */
.wpforms-field::before, .wpforms-field::after,
.wpforms-field-row::before, .wpforms-field-row::after,
.wpforms-form::before, .wpforms-form::after { display:none !important; content:none !important; }

/* ── Alignement précis Prénom / Nom ── */
.wpforms-field-name .wpforms-field-row-block.wpforms-first,
.wpforms-field-name .wpforms-field-row-block.wpforms-last {
  flex: 1 1 0 !important;
  width: auto !important;
  float: none !important;
  padding: 0 !important;
  margin: 0 !important;
  vertical-align: bottom !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-end !important;
}
.wpforms-field-name .wpforms-field-row-block.wpforms-first input,
.wpforms-field-name .wpforms-field-row-block.wpforms-last input {
  width: 100% !important;
  margin: 0 !important;
  padding: .7rem 0 !important;
  vertical-align: bottom !important;
}

/* ── Corrections finales formulaire ── */

/* Séparateur entre Prénom et Nom */
.wpforms-field-name .wpforms-field-row {
  gap: 0 !important;
}
.wpforms-field-name .wpforms-field-row-block.wpforms-first {
  padding-right: 1.5rem !important;
  border-right: 1px solid rgba(196,169,107,.2) !important;
}
.wpforms-field-name .wpforms-field-row-block.wpforms-last {
  padding-left: 1.5rem !important;
}

/* Supprimer le fond blanc au focus et à l'autofill */
.wpforms-form input:focus,
.wpforms-form input:active,
.wpforms-form textarea:focus {
  background: transparent !important;
  background-color: transparent !important;
  color: #f0ece3 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}

/* Supprimer le fond blanc de l'autofill navigateur */
.wpforms-form input:-webkit-autofill,
.wpforms-form input:-webkit-autofill:hover,
.wpforms-form input:-webkit-autofill:focus,
.wpforms-form input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 100px #0f2220 inset !important;
  -webkit-text-fill-color: #f0ece3 !important;
  caret-color: #f0ece3 !important;
  border-bottom: 1px solid rgba(196,169,107,.3) !important;
  transition: background-color 9999s ease-in-out 0s !important;
}

/* Police cohérente partout */
.wpforms-form input,
.wpforms-form textarea,
.wpforms-form select {
  font-family: 'Jost', sans-serif !important;
  font-weight: 300 !important;
  font-size: .95rem !important;
  letter-spacing: .02em !important;
}

/* Retirer la barre verticale dorée entre Prénom et Nom */
.wpforms-field-name .wpforms-field-row-block.wpforms-first {
  border-right: none !important;
}

/* ── Message de confirmation WPForms ── */
@keyframes confirmFadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.wpforms-confirmation-container-full,
.wpforms-confirmation-container,
div[submit-success] .wpforms-confirmation-container-full,
.wpforms-form .wpforms-confirmation-container-full {
  animation: confirmFadeUp .8s ease forwards !important;
  background: transparent !important;
  border: none !important;
  border-left: 2px solid #c4a96b !important;
  border-radius: 0 !important;
  padding: 2rem 2.5rem !important;
  margin: 0 !important;
  box-shadow: none !important;
}

.wpforms-confirmation-container-full p,
.wpforms-confirmation-container p {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 1.3rem !important;
  font-weight: 400 !important;
  font-style: italic !important;
  color: #f0ece3 !important;
  line-height: 1.7 !important;
  margin: 0 0 .8rem 0 !important;
  opacity: 1 !important;
}

.wpforms-confirmation-container-full::before,
.wpforms-confirmation-container::before {
  content: '✓' !important;
  display: block !important;
  font-family: 'Jost', sans-serif !important;
  font-size: .6rem !important;
  font-weight: 300 !important;
  font-style: normal !important;
  letter-spacing: .4em !important;
  text-transform: uppercase !important;
  color: #c4a96b !important;
  margin-bottom: 1rem !important;
}

/* ── Corrections message confirmation ── */
.wpforms-confirmation-container-full p,
.wpforms-confirmation-container p {
  font-family: 'Jost', sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 300 !important;
  font-style: normal !important;
  color: #f0ece3 !important;
  line-height: 1.8 !important;
  letter-spacing: .03em !important;
}
.wpforms-confirmation-container-full::before,
.wpforms-confirmation-container::before {
  font-size: 1.2rem !important;
  letter-spacing: .5em !important;
  margin-bottom: 1.2rem !important;
}

/* ── PAGES LÉGALES — fond grain + curseur ── */
body.page-template-default,
body.error404 {
  cursor: none !important;
  background: #0b1614 !important;
}

/* Fond grain sur pages légales */
body.page-template-default::after,
body.error404::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image: var(--hero-bg-url);
  background-size: cover;
  background-position: center;
  opacity: .18;
}

/* Overlay teal par-dessus le grain */
body.page-template-default::before,
body.error404::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  background: rgba(11,22,20,.82);
}

/* Curseur custom sur toutes les pages */
body.page-template-default #cur,
body.page-template-default #cur-ring { display: block !important; }

/* ── LANGUAGE SWITCHER ── */
.lang-switcher {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-right: 1.2rem;
  background: rgba(196,169,107,.22);
  border: 1px solid rgba(196,169,107,.65);
  border-radius: 2px;
  overflow: hidden;
  flex-shrink: 0;
}
.lang-btn {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-family: var(--sans);
  font-size: .58rem;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  text-decoration: none;
  padding: .5rem .75rem;
  color: rgba(240,236,227,.85);
  transition: color .25s, background .25s;
  line-height: 1;
  white-space: nowrap;
}
.lang-btn:hover { color: var(--blanc); background: rgba(196,169,107,.15); }
.lang-btn.active {
  color: var(--or);
  background: rgba(196,169,107,.32);
}
.lang-btn .flag { font-size: .8rem; line-height: 1; }
.lang-sep {
  width: 1px; height: 100%;
  min-height: 28px;
  background: rgba(196,169,107,.2);
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════
   V6 — Animations, mobile, compteurs, hamburger
   ══════════════════════════════════════════════════════ */

/* ── Hero title — animation mot par mot ─────────────── */
.hw { display:inline-block; opacity:0; transform:translateY(30px); }
.hw-anim { animation: hwReveal .7s cubic-bezier(.22,1,.36,1) forwards; }
@keyframes hwReveal {
  to { opacity:1; transform:translateY(0); }
}

/* ── Back to top ──────────────────────────────────────── */
#back-to-top {
  position:fixed; bottom:2rem; right:2rem; z-index:200;
  width:44px; height:44px;
  background:rgba(196,169,107,.15);
  border:1px solid rgba(196,169,107,.3);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  cursor:none;
  opacity:0; transform:translateY(12px);
  transition:opacity .4s, transform .4s, background .3s;
  pointer-events:none;
}
#back-to-top.visible { opacity:1; transform:translateY(0); pointer-events:auto; }
#back-to-top:hover { background:rgba(196,169,107,.3); }
#back-to-top svg { color:var(--or); }

/* ── Compteurs — highlight au survol ─────────────────── */
.chiffre-val { display:inline-block; transition:color .3s; }
.chiffre:hover .chiffre-val { color:var(--blanc); }

/* ── Étapes — ligne de progression ───────────────────── */
.proc-grid { position:relative; }
.proc-line {
  position:absolute;
  top:2.5rem; left:0; right:0; height:1px;
  background:linear-gradient(to right, transparent, rgba(196,169,107,.15), transparent);
  transform:scaleX(0); transform-origin:left;
  transition:transform 1.2s cubic-bezier(.22,1,.36,1) .3s;
}
.proc-line.animate { transform:scaleX(1); }
@media(max-width:768px) { .proc-line { display:none; } }

/* ── Services — tilt 3D ──────────────────────────────── */
.srv { transform-style:preserve-3d; perspective:600px; transition:transform .15s ease,box-shadow .3s; }

/* ── Hamburger menu mobile ───────────────────────────── */
#burger {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:.5rem;
  z-index:201;
}
#burger span {
  display:block;
  width:24px; height:1.5px;
  background:var(--blanc);
  transition:transform .35s cubic-bezier(.22,1,.36,1), opacity .25s, width .3s;
  transform-origin:center;
}
#burger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
#burger.open span:nth-child(2) { opacity:0; width:0; }
#burger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* ── Nav mobile — Drawer latéral ────────────────────── */
@media(max-width:900px) {
  .nav-right { display:none !important; }
  #burger { display:flex; z-index:400; position:relative; }
  /* Masquer le burger entièrement quand le menu est ouvert */
  #burger.open { opacity:0 !important; pointer-events:none !important; }
  /* Bouton fermer visible sur mobile */
  .nav-close { display:flex !important; }

  /* Overlay sombre derrière le drawer */
  .nav-overlay {
    position:fixed; inset:0; z-index:290;
    background:rgba(0,0,0,.55);
    opacity:0; visibility:hidden; pointer-events:none;
    transition:opacity .35s ease, visibility 0s linear .35s;
  }
  .nav-overlay.open {
    opacity:1; visibility:visible; pointer-events:auto;
    transition:opacity .35s ease, visibility 0s linear 0s;
  }

  /* Drawer — glisse depuis la droite, 60% de largeur */
  .nav-links {
    position:fixed !important;
    top:0 !important; right:0 !important; bottom:0 !important;
    width:62vw !important; max-width:300px !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    justify-content:flex-start !important;
    gap:0 !important;
    list-style:none !important;
    padding:4.5rem 2rem 3rem !important;
    margin:0 !important;
    background:rgba(11,22,20,.98) !important;
    border-left:1px solid rgba(196,169,107,.12) !important;
    z-index:300 !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
    transform:translateX(100%) !important;
    transition:transform .38s cubic-bezier(.22,1,.36,1), opacity .3s ease, visibility 0s linear .38s !important;
    overflow-y:auto !important;
  }
  .nav-links.open {
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    transform:translateX(0) !important;
    transition:transform .38s cubic-bezier(.22,1,.36,1), opacity .3s ease, visibility 0s linear 0s !important;
  }

  /* Bouton fermer dans le drawer */
  .nav-close {
    position:absolute;
    top:1.2rem; right:1.5rem;
    background:none; border:none;
    color:var(--or); cursor:pointer;
    font-size:1.6rem; line-height:1;
    padding:.4rem; opacity:.85;
    transition:opacity .2s;
    display:flex; align-items:center; justify-content:center;
    width:40px; height:40px;
  }
  .nav-close:hover { opacity:1; }

  /* Liens nav dans le drawer */
  .nav-links > li { width:100%; padding:.65rem 0; border-bottom:1px solid rgba(196,169,107,.07); }
  .nav-links > li:last-child { border-bottom:none; }
  .nav-links > li > a:not(.lang-btn):not(.nav-cta-mobile) {
    font-size:1.25rem !important;
    font-family:'Playfair Display', Georgia, serif !important;
    font-weight:400 !important;
    color:rgba(240,236,227,.88) !important;
    text-decoration:none !important;
    letter-spacing:.02em !important;
    display:block !important;
    transition:color .25s, padding-left .25s !important;
    text-transform:none !important;
  }
  .nav-links > li > a:hover:not(.lang-btn):not(.nav-cta-mobile) {
    color:var(--or) !important;
    padding-left:.4rem !important;
  }

  /* Switcher langue — EN HAUT du drawer */
  .nav-links-lang {
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:.3rem !important;
    order:-1 !important;
    align-self:center !important;
    width:auto !important;
    margin-bottom:1.8rem !important;
    margin-top:0 !important;
    padding:.5rem 1.2rem !important;
    border:1px solid rgba(196,169,107,.35) !important;
    border-bottom:1px solid rgba(196,169,107,.35) !important;
    background:rgba(196,169,107,.08) !important;
  }
  .nav-links-lang .lang-btn {
    font-family:'Jost',sans-serif !important;
    font-size:.62rem !important; font-weight:300 !important;
    letter-spacing:.18em !important; text-transform:uppercase !important;
    color:rgba(240,236,227,.65) !important;
    text-decoration:none !important; padding:.3rem .4rem !important;
    display:flex !important; align-items:center !important; gap:.3rem !important;
    background:none !important; border:none !important;
    transition:color .25s !important;
  }
  .nav-links-lang .lang-btn.active { color:var(--or) !important; }
  .nav-links-lang .lang-sep { width:1px; height:10px; background:rgba(196,169,107,.3); display:inline-block; }

  /* CTA */
  .nav-links-cta { margin-top:2rem !important; display:block !important; width:100% !important; border-bottom:none !important; padding:0 !important; }
  .nav-cta-mobile {
    font-family:'Jost',sans-serif !important;
    font-size:.62rem !important; font-weight:300 !important;
    letter-spacing:.18em !important; text-transform:uppercase !important;
    color:#0b1614 !important; background:var(--or) !important;
    padding:.85rem 1.5rem !important; text-decoration:none !important;
    display:block !important; text-align:center !important;
    transition:background .3s !important; width:100% !important;
    box-sizing:border-box !important;
  }
  .nav-cta-mobile:hover { background:#e8c5a0 !important; }

  /* scroll lock géré en JS pour iOS Safari */
}

/* ── SEO — titres pages légales ──────────────────────── */
@media(max-width:768px) {
  .hero-title { font-size:clamp(3.5rem,14vw,6rem); }
  .apropos-chiffres { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .proc-grid { grid-template-columns:1fr; gap:2rem; }
  .contact-section { flex-direction:column; }
}

/* ── Scroll indicator hero ───────────────────────────── */
.hero-scroll { opacity:.6; }
.hero-scroll:hover { opacity:1; }

/* ── Masquer les éléments mobile-only sur desktop ──── */
.nav-links-lang, .nav-links-cta { display:none; }

/* ── Stagger reveal amélioré ─────────────────────────── */
.reveal { transition-duration:.75s; }
.reveal.d1 { transition-delay:.12s; }
.reveal.d2 { transition-delay:.24s; }
.reveal.d3 { transition-delay:.36s; }

/* ── Section processus — réassurance ────────────────── */
.proc-reassurance {
  grid-column:1/-1;
  display:flex;
  align-items:flex-start;
  gap:1.2rem;
  padding:1.8rem 2rem;
  border:1px solid rgba(196,169,107,.12);
  border-left:2px solid var(--or);
  background:rgba(196,169,107,.03);
  margin-top:1rem;
}
.proc-reassurance-icon { color:var(--or); opacity:.7; flex-shrink:0; margin-top:.2rem; }
.proc-reassurance p { font-family:var(--sans); font-size:.9rem; font-weight:300; color:var(--gris); line-height:1.8; margin:0; }
.proc-reassurance strong { color:var(--or); font-weight:300; }


.nav-right { display:flex; align-items:center; gap:.8rem; flex-shrink:0; }

/* ══════════════════════════════════════════════════════
   MOBILE — Services carrousel + Méthode 2 colonnes
   ══════════════════════════════════════════════════════ */
@media(max-width:768px) {

  /* ── Services — carrousel horizontal ─────────────── */
  .services-grid {
    display:flex !important;
    flex-direction:row !important;
    overflow-x:auto !important;
    scroll-snap-type:x mandatory !important;
    -webkit-overflow-scrolling:touch !important;
    gap:1rem !important;
    padding:0 1.5rem 1.5rem !important;
    margin:0 -1.5rem !important;
    scrollbar-width:none !important;
    /* Indicateur de scroll */
    cursor:grab;
  }
  .services-grid::-webkit-scrollbar { display:none !important; }
  .services-grid:active { cursor:grabbing; }

  .srv {
    flex:0 0 80vw !important;
    max-width:300px !important;
    scroll-snap-align:start !important;
    scroll-snap-stop:always !important;
    height:auto !important;
    transform:none !important;
  }

  /* Indicateur de swipe sous le carrousel */
  .services-grid::after {
    content:'';
    flex:0 0 1px;
    /* Espace de fin pour voir qu'il y a une carte suivante */
  }

  /* Hint visuel — "swipeable" */
  .services-head::after {
    content:'→ Balayer pour voir tous les services';
    display:block;
    font-family:'Jost', sans-serif;
    font-size:.6rem;
    font-weight:300;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:rgba(196,169,107,.5);
    margin-top:.8rem;
  }

  /* Dots indicateurs */
  .services-dots {
    display:flex !important;
    justify-content:center;
    gap:.4rem;
    margin-top:1rem;
  }
  .services-dots span {
    width:20px; height:2px;
    background:rgba(196,169,107,.25);
    transition:background .3s, width .3s;
  }
  .services-dots span.active {
    background:var(--or);
    width:32px;
  }

  /* ── Méthode — 2 colonnes ─────────────────────────── */
  .proc-grid {
    grid-template-columns:1fr 1fr !important;
    gap:1rem !important;
  }
  .etape {
    padding:1.4rem 1.2rem !important;
  }
  .etape-n {
    font-size:3rem !important;
    margin-bottom:.5rem !important;
  }
  .etape-title {
    font-size:1rem !important;
    margin-bottom:.5rem !important;
  }
  .etape-desc {
    font-size:.8rem !important;
    line-height:1.6 !important;
  }
}
