
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --cream:#F4F7FB;
  --cream2:#E6ECF4;
  --cream3:#CBD5E1;
  --ink:#0B1220;
  --indigo:#123A63;
  --indigo2:#0F2F52;
  --indigo-light:#1E5B8F;
  --green:#0E9F6E;
  --green-dark:#087A56;
  --orange:#D97706;
  --orange-dark:#B45309;
  --yellow:#D6A21A;
  --white:#FFFFFF;
  --body-text:#334155;
  --muted:#64748B;
  --pink:#475569;
  --f-display:'Unbounded',sans-serif;
  --f-body:'Plus Jakarta Sans',sans-serif;
  --f-mono:'Space Mono',monospace;
}

html{scroll-behavior:smooth}

body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--f-body);
  overflow-x:hidden;
  cursor:none;
}

/* ── GRAIN OVERLAY ── */
body::after{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity:.022;pointer-events:none;z-index:9000;
}

/* ── CUSTOM CURSOR ── */
#cur{
  position:fixed;z-index:9999;pointer-events:none;
  width:14px;height:14px;
  background:var(--indigo);
  border-radius:50%;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,background .25s,opacity .25s;
  mix-blend-mode:multiply;
}
body:has(a:hover) #cur,
body:has(button:hover) #cur{
  width:40px;height:40px;
  background:var(--orange);
  opacity:.7;
}
body:has(.scard:hover) #cur{background:var(--green)}

/* ── FLOATING ORBS ── */
.orb{
  position:fixed;border-radius:50%;
  filter:blur(100px);opacity:.18;
  pointer-events:none;z-index:0;
  animation:orbFloat 16s ease-in-out infinite;
}
.orb1{width:500px;height:500px;background:var(--indigo);top:-150px;left:-150px;animation-delay:0s}
.orb2{width:350px;height:350px;background:var(--green);bottom:-100px;right:-100px;animation-delay:-5s}
.orb3{width:250px;height:250px;background:var(--orange);top:40%;left:55%;animation-delay:-10s}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(20px,-15px) scale(1.03)}
  66%{transform:translate(-15px,12px) scale(.97)}
}

/* ── PAGES ── */
.page{display:none;position:relative;z-index:1}
.page.active{display:block}

/* ── NAV ── */
nav{
  position:fixed;top:14px;left:50%;z-index:500;
  transform:translateX(-50%);
  width:calc(100% - 32px);max-width:1100px;
  height:54px;
  background:rgba(15,13,10,.94);
  backdrop-filter:blur(28px);
  border-radius:14px;
  border:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;
  justify-content:space-between;
  padding:0 8px 0 20px;
  box-shadow:0 4px 24px rgba(15,23,42,.2),0 0 0 1px rgba(255,255,255,.03);
}
.nav-logo{
  font-family:var(--f-display);
  font-size:16px;font-weight:900;
  color:var(--white);text-decoration:none;
  letter-spacing:-.02em;
  display:flex;align-items:center;gap:10px;
}
.nav-logo-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--green);
  box-shadow:0 0 12px var(--green);
  animation:dotPulse 2s ease-in-out infinite;
}
@keyframes dotPulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.6;transform:scale(.7)}
}
.nav-links{
  display:flex;gap:2px;list-style:none;
}
.nav-links li a{
  display:block;padding:7px 14px;border-radius:12px;
  font-family:var(--f-body);font-size:13px;font-weight:500;
  color:rgba(255,255,255,.55);text-decoration:none;
  transition:background .2s,color .2s;
}
.nav-links li a:hover,
.nav-links li a.active-link{
  background:rgba(255,255,255,.09);
  color:var(--white);
}
.nav-cta{
  background:var(--green);color:var(--white)!important;
  font-weight:600!important;border-radius:10px;
  padding:8px 16px!important;
  transition:transform .2s,background .2s!important;
  letter-spacing:-.01em;
}
.nav-cta:hover{
  transform:translateY(-1px)!important;
  background:var(--green-dark)!important;
}

/* ── BOTTOM NAV MOBILE ── */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:500;
  padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  background:rgba(22,18,14,.95);
  backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,.06);
}
.bnav{display:flex;justify-content:space-around}
.bi{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:6px 14px;border-radius:12px;
  border:none;background:none;cursor:none;
  transition:background .2s;
}
.bi.active-b{background:rgba(255,255,255,.07)}
.bi-ic{font-size:20px;line-height:1}
.bi-lb{font-size:10px;font-weight:500;color:rgba(255,255,255,.4);font-family:var(--f-body)}
.bi.active-b .bi-lb{color:var(--green)}
.bi.rdv-b{background:var(--green);border-radius:14px}
.bi.rdv-b .bi-lb{color:var(--ink);font-weight:700}

/* ═══════════════════════════════
   PAGE ACCUEIL
═══════════════════════════════ */
.home-page{padding-top:90px;padding-bottom:40px}

/* HERO */
.hero{
  padding:20px 24px 0;
  max-width:1100px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;align-items:start;
}
.hero-left{flex:1}
.hero-tag{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--green);
  border-radius:100px;padding:6px 16px;
  font-family:var(--f-mono);font-size:11px;
  margin-bottom:28px;
  animation:tagIn .6s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes tagIn{from{opacity:0;transform:translateY(-16px) scale(.9)}to{opacity:1;transform:none}}
.hero-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:dotPulse 2s infinite}

.hero h1{
  font-family:var(--f-display);
  font-size:clamp(44px,7vw,88px);
  font-weight:900;line-height:.95;
  letter-spacing:-.04em;
  color:var(--ink);
  margin-bottom:28px;
  overflow:hidden;
}
.hero h1 .line{
  display:block;
  animation:lineIn .7s cubic-bezier(.16,1,.3,1) both;
}
.hero h1 .line:nth-child(2){animation-delay:.08s}
.hero h1 .line:nth-child(3){animation-delay:.16s}
@keyframes lineIn{
  from{opacity:0;transform:translateY(60px)}
  to{opacity:1;transform:translateY(0)}
}
.hero h1 .accent{
  color:var(--indigo);
  display:inline-block;
  position:relative;
}
.hero h1 .accent::after{
  content:'';
  position:absolute;bottom:4px;left:0;right:0;height:5px;
  background:var(--green);border-radius:4px;
  transform:scaleX(0);transform-origin:left;
  animation:underlineIn .5s .6s cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes underlineIn{to{transform:scaleX(1)}}
.hero h1 .stroke{
  -webkit-text-stroke:3px var(--ink);
  color:transparent;
}

.hero-desc{
  font-size:17px;font-weight:300;
  color:var(--body-text);line-height:1.7;
  max-width:440px;margin-bottom:36px;
  animation:fadeUp .6s .3s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.hero-btns{
  display:flex;gap:14px;flex-wrap:wrap;
  animation:fadeUp .6s .4s both;
}

/* THE CARD */
.hero-card{
  background:var(--indigo);
  border-radius:20px;
  padding:28px 24px;
  border:2px solid rgba(255,255,255,.08);
  box-shadow:0 20px 60px rgba(18,58,99,.30);
  min-width:210px;
  animation:cardIn .8s .2s cubic-bezier(.34,1.56,.64,1) both;
  transform-origin:bottom right;
  position:relative;
  overflow:hidden;
}
@keyframes cardIn{
  from{opacity:0;transform:rotate(4deg) scale(.88) translateY(20px)}
  to{opacity:1;transform:rotate(-1deg) scale(1) translateY(0)}
}
.hero-card:hover{
  transform:rotate(0deg) scale(1.02);
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.hero-card::before{
  content:'';position:absolute;
  top:-40px;right:-40px;
  width:120px;height:120px;
  background:rgba(255,255,255,.06);
  border-radius:50%;
}
.hcard-label{
  font-family:var(--f-mono);font-size:10px;
  color:rgba(255,255,255,.5);letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:20px;
}
.hcard-stat{margin-bottom:18px}
.hcard-n{
  font-family:var(--f-display);
  font-size:52px;font-weight:900;
  color:var(--white);line-height:1;
  letter-spacing:-.03em;
}
.hcard-n em{font-style:normal;color:var(--green)}
.hcard-l{font-size:12px;color:rgba(255,255,255,.55);margin-top:2px}
.hcard-divider{height:1px;background:rgba(255,255,255,.1);margin:16px 0}

/* TRUST PILLS */
.trust-row{
  display:flex;gap:10px;flex-wrap:wrap;
  padding:28px 24px 0;max-width:1100px;margin:0 auto;
  animation:fadeUp .6s .5s both;
}
.tpill{
  display:flex;align-items:center;gap:7px;
  background:var(--white);
  border:1.5px solid var(--cream3);
  border-radius:100px;padding:7px 15px;
  font-size:13px;font-weight:500;color:var(--body-text);
  box-shadow:2px 2px 0 var(--cream3);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.tpill:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--cream3);border-color:var(--ink)}
.tpill span{font-size:15px}

/* SERVICES */
.services-section{
  padding:80px 24px 0;
  max-width:1100px;margin:0 auto;
}
.s-header{
  display:flex;align-items:baseline;
  justify-content:space-between;
  margin-bottom:36px;flex-wrap:wrap;gap:16px;
}
.s-title{
  font-family:var(--f-display);
  font-size:clamp(28px,4vw,44px);
  font-weight:900;letter-spacing:-.03em;
  color:var(--ink);
}
.s-title em{font-style:normal;color:var(--indigo)}
.s-more{
  font-family:var(--f-mono);font-size:12px;
  color:var(--indigo);text-decoration:none;
  display:flex;align-items:center;gap:6px;
  transition:gap .2s;background:none;border:none;cursor:none;
}
.s-more:hover{gap:10px}

.scard-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);gap:16px;
}
@media(min-width:768px){.scard-grid{grid-template-columns:repeat(3,1fr)}}

.scard{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:18px;padding:24px 22px;
  box-shadow:0 4px 16px rgba(15,23,42,.07),3px 3px 0 var(--cream3);
  cursor:none;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,border-color .25s;
  position:relative;overflow:hidden;
}
.scard:hover{
  transform:translate(-2px,-3px);
  box-shadow:0 12px 32px rgba(15,23,42,.12),5px 5px 0 var(--cream3);
  border-color:var(--cream3);
}
.scard-color-bar{
  position:absolute;top:0;left:0;right:0;height:4px;
  border-radius:22px 22px 0 0;
}
.c-indigo{background:var(--indigo)}
.c-green{background:var(--green)}
.c-orange{background:var(--orange)}
.scard-icon{font-size:34px;margin:12px 0 14px;display:block}
.scard-title{
  font-family:var(--f-display);font-size:16px;
  font-weight:700;color:var(--ink);margin-bottom:8px;
  letter-spacing:-.02em;
}
.scard-desc{
  font-size:13px;color:var(--body-text);
  line-height:1.65;font-weight:300;margin-bottom:16px;
}
.scard-foot{
  display:flex;align-items:center;
  justify-content:space-between;
  margin-top:auto;
}
.scard-price{
  font-family:var(--f-display);font-size:20px;
  font-weight:900;color:var(--ink);letter-spacing:-.02em;
}
.scard-price sub{font-size:11px;font-weight:400;color:var(--muted);font-family:var(--f-body);bottom:0}
.scard-arrow{
  width:34px;height:34px;border-radius:10px;
  background:var(--ink);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;
  transition:transform .2s,background .2s;
}
.scard:hover .scard-arrow{transform:translate(2px,-2px);background:var(--indigo)}

/* HOW IT WORKS */
.how-section{
  padding:80px 24px 0;
  max-width:1100px;margin:0 auto;
}
.how-title{
  font-family:var(--f-display);
  font-size:clamp(28px,4vw,44px);
  font-weight:900;letter-spacing:-.03em;
  color:var(--ink);margin-bottom:8px;
}
.how-sub{font-size:15px;color:var(--body-text);font-weight:300;margin-bottom:36px}
.steps-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media(min-width:600px){.steps-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.steps-grid{grid-template-columns:repeat(4,1fr)}}

.step-card{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:18px;padding:24px 22px;
  box-shadow:0 4px 16px rgba(15,23,42,.06),3px 3px 0 var(--cream3);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;
}
.step-card:hover{
  transform:translate(-2px,-2px);
  box-shadow:0 10px 28px rgba(15,23,42,.10),4px 4px 0 var(--cream3);
}
.step-num-badge{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:18px;
  font-weight:900;color:var(--white);
  margin-bottom:16px;
}
.n1{background:var(--indigo)}
.n2{background:var(--green)}
.n3{background:var(--orange)}
.n4{background:var(--pink)}
.step-name{
  font-family:var(--f-display);font-size:17px;
  font-weight:700;color:var(--ink);margin-bottom:8px;
  letter-spacing:-.02em;
}
.step-body{font-size:13px;color:var(--body-text);line-height:1.65;font-weight:300}

/* TESTIMONIALS */
.testi-section{
  padding:80px 24px 0;
  max-width:1100px;margin:0 auto;
}
.testi-title{
  font-family:var(--f-display);
  font-size:clamp(28px,4vw,44px);
  font-weight:900;letter-spacing:-.03em;
  margin-bottom:36px;
}
.tcard-grid{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:640px){.tcard-grid{grid-template-columns:repeat(3,1fr)}}

.tcard{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:18px;padding:24px;
  box-shadow:0 4px 16px rgba(15,23,42,.06),3px 3px 0 var(--cream3);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;
}
.tcard:hover{transform:translate(-2px,-2px);box-shadow:0 10px 28px rgba(15,23,42,.10),4px 4px 0 var(--cream3)}
.tcard:nth-child(2){background:var(--indigo);border-color:var(--indigo)}
.tcard:nth-child(2) .t-text,.tcard:nth-child(2) .t-name{color:var(--white)}
.tcard:nth-child(2) .t-role{color:rgba(255,255,255,.5)}
.tcard:nth-child(2) .t-stars{color:var(--yellow)}
.tcard:nth-child(2){box-shadow:0 8px 32px rgba(18,58,99,.24)}
.t-stars{color:var(--orange);font-size:14px;letter-spacing:2px;margin-bottom:12px}
.t-text{
  font-size:14px;color:var(--body-text);line-height:1.7;
  font-style:italic;font-weight:300;margin-bottom:18px;
}
.t-author{display:flex;align-items:center;gap:12px}
.t-av{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--indigo),var(--green));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--f-display);font-size:13px;
  font-weight:900;color:var(--white);flex-shrink:0;
}
.t-name{font-size:14px;font-weight:600;color:var(--ink)}
.t-role{font-size:12px;color:var(--muted);margin-top:2px}

/* CTA BAND */
.cta-band{
  margin:80px 24px 0;
  max-width:1100px;margin-left:auto;margin-right:auto;
  background:var(--indigo);
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:24px;
  padding:56px 48px;
  box-shadow:0 24px 64px rgba(18,58,99,.24);
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-band::before{
  content:'';position:absolute;
  top:-60px;right:-60px;width:240px;height:240px;
  background:rgba(255,255,255,.03);
  border-radius:50%;
}
.cta-band::after{
  content:'';position:absolute;
  bottom:-40px;left:-40px;width:160px;height:160px;
  background:rgba(0,168,120,.08);
  border-radius:50%;
}
.cta-band h2{
  font-family:var(--f-display);
  font-size:clamp(28px,5vw,52px);
  font-weight:900;color:var(--white);
  letter-spacing:-.03em;margin-bottom:12px;
}
.cta-band p{font-size:16px;color:rgba(255,255,255,.65);margin-bottom:32px;font-weight:300}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:12px;
  font-family:var(--f-display);font-size:13px;
  font-weight:700;text-decoration:none;
  border:1.5px solid transparent;
  cursor:none;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s,background .2s;
  letter-spacing:-.01em;
}
.btn-dark{background:var(--ink);color:var(--white);border-color:var(--ink);box-shadow:0 4px 14px rgba(15,23,42,.18)}
.btn-dark:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,.24)}
.btn-green{background:var(--green);color:var(--white);border-color:var(--green);box-shadow:0 4px 14px rgba(0,168,120,.22)}
.btn-green:hover{transform:translateY(-2px);background:var(--green-dark);box-shadow:0 8px 24px rgba(0,168,120,.32)}
.btn-white{background:var(--white);color:var(--ink);border-color:rgba(255,255,255,.12);box-shadow:0 4px 14px rgba(255,255,255,.06)}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(255,255,255,.12)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--cream3)}
.btn-outline:hover{border-color:var(--ink);transform:translateY(-1px)}

/* ═══ PAGE HERO GÉNÉRIQUE ═══ */
.page-top{
  padding:90px 24px 48px;
  max-width:1100px;margin:0 auto;
}
.pt-eyebrow{
  font-family:var(--f-mono);font-size:11px;
  color:var(--indigo);letter-spacing:.12em;
  text-transform:uppercase;margin-bottom:16px;
  display:flex;align-items:center;gap:10px;
}
.pt-eyebrow::before{content:'';width:24px;height:2px;background:var(--indigo)}
.pt-h1{
  font-family:var(--f-display);
  font-size:clamp(38px,7vw,80px);
  font-weight:900;color:var(--ink);
  letter-spacing:-.04em;line-height:.95;
  margin-bottom:16px;
}
.pt-h1 em{font-style:normal;color:var(--indigo)}
.pt-sub{
  font-size:17px;font-weight:300;color:var(--body-text);
  max-width:520px;line-height:1.65;margin-bottom:32px;
}

/* ═══ SERVICES PAGE ═══ */
.srv-page{padding-top:0;padding-bottom:60px}
.srv-full-grid{
  padding:0 24px 60px;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:16px;
}
@media(min-width:640px){.srv-full-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.srv-full-grid{grid-template-columns:repeat(3,1fr)}}

.sfcard{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:20px;padding:28px 24px;
  box-shadow:0 4px 16px rgba(15,23,42,.07),3px 3px 0 var(--cream3);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;
  display:flex;flex-direction:column;
}
.sfcard:hover{
  transform:translate(-2px,-3px);
  box-shadow:0 12px 32px rgba(15,23,42,.12),5px 5px 0 var(--cream3);
}
.sfcard-top{
  height:4px;border-radius:4px;margin-bottom:20px;
}
.sfcard-icon{font-size:38px;margin-bottom:14px}
.sfcard-title{
  font-family:var(--f-display);font-size:21px;
  font-weight:700;color:var(--ink);margin-bottom:4px;
  letter-spacing:-.02em;
}
.sfcard-sub{
  font-family:var(--f-mono);font-size:10px;
  color:var(--indigo);letter-spacing:.08em;
  margin-bottom:14px;
}
.sfcard-body{
  font-size:13px;color:var(--body-text);line-height:1.7;
  font-weight:300;margin-bottom:16px;flex:1;
}
.sfcard-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.chip{
  background:var(--cream2);
  border:1.5px solid var(--cream2);
  border-radius:100px;
  font-family:var(--f-mono);font-size:10px;
  padding:3px 10px;color:var(--body-text);
}
.sfcard-footer{
  display:flex;align-items:center;
  justify-content:space-between;
  border-top:1.5px solid var(--cream2);padding-top:16px;
}
.sfcard-price{
  font-family:var(--f-display);font-size:28px;
  font-weight:900;color:var(--ink);letter-spacing:-.03em;
}
.sfcard-price small{font-size:12px;font-family:var(--f-body);font-weight:300;color:var(--muted)}

/* ═══ MONTAGE PAGE ═══ */
.pc-page{padding-top:0;padding-bottom:60px}
.includes-wrap{
  padding:0 24px 48px;max-width:1100px;margin:0 auto;
}
.section-label{
  font-family:var(--f-display);font-size:22px;
  font-weight:700;color:var(--ink);
  letter-spacing:-.02em;margin-bottom:20px;
}
.includes-g{
  display:grid;grid-template-columns:1fr;gap:10px;
}
@media(min-width:560px){.includes-g{grid-template-columns:repeat(2,1fr)}}
@media(min-width:900px){.includes-g{grid-template-columns:repeat(3,1fr)}}

.inc-item{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:16px;padding:16px 18px;
  box-shadow:0 3px 10px rgba(15,23,42,.06);
  display:flex;align-items:flex-start;gap:12px;
  transition:transform .2s,box-shadow .2s;
}
.inc-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.10)}
.inc-ic{
  width:32px;height:32px;border-radius:9px;
  background:rgba(18,58,99,.10);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.inc-text strong{display:block;font-size:14px;font-weight:600;color:var(--ink)}
.inc-text span{font-size:12px;color:var(--muted);font-weight:300}

.builds-wrap{
  padding:0 24px 60px;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:16px;
}
@media(min-width:640px){.builds-wrap{grid-template-columns:repeat(3,1fr)}}

.bcard{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:20px;padding:28px 24px;
  box-shadow:0 4px 16px rgba(15,23,42,.07),3px 3px 0 var(--cream3);
  position:relative;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s;
}
.bcard:hover{
  transform:translate(-2px,-3px);
  box-shadow:0 12px 32px rgba(15,23,42,.12),5px 5px 0 var(--cream3);
}
.bcard.feat{
  background:var(--indigo);
  border-color:rgba(255,255,255,.08);
  box-shadow:0 8px 32px rgba(18,58,99,.24);
}
.bcard.feat:hover{box-shadow:0 16px 48px rgba(18,58,99,.32)}
.bcard.feat .bcard-name,
.bcard.feat .bcard-price,
.bcard.feat .bspec-val{color:var(--white)}
.bcard.feat .bspec-key{color:rgba(255,255,255,.5)}
.bcard.feat .bspec-row{border-color:rgba(255,255,255,.1)}
.bcard.feat .bcard-tags .chip{background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);border-color:transparent}
.bcard.feat .bcard-note{color:rgba(255,255,255,.4)}
.feat-badge{
  position:absolute;top:-12px;left:50%;
  transform:translateX(-50%);
  background:var(--green);color:var(--ink);
  font-family:var(--f-display);font-size:10px;font-weight:700;
  padding:4px 16px;border-radius:100px;
  border:2px solid var(--ink);white-space:nowrap;
}
.bcard-tier{
  font-family:var(--f-mono);font-size:10px;
  color:var(--indigo);letter-spacing:.1em;
  margin-bottom:12px;
}
.bcard.feat .bcard-tier{color:rgba(255,255,255,.5)}
.bcard-name{
  font-family:var(--f-display);font-size:26px;
  font-weight:900;color:var(--ink);
  letter-spacing:-.03em;margin-bottom:20px;
}
.bspec-row{
  display:flex;justify-content:space-between;
  padding:8px 0;border-bottom:1px solid var(--cream2);font-size:13px;
}
.bspec-key{color:var(--muted)}
.bspec-val{font-weight:600;color:var(--ink)}
.bcard-tags{display:flex;flex-wrap:wrap;gap:6px;margin:16px 0}
.bcard-price{
  font-family:var(--f-display);font-size:34px;
  font-weight:900;color:var(--ink);letter-spacing:-.03em;
}
.bcard-note{font-size:11px;color:var(--muted);margin-top:2px;margin-bottom:16px}

/* ═══ CONSOLE PAGE ═══ */
.con-page{padding-top:0;padding-bottom:60px}
.platforms-g{
  padding:0 24px 40px;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;
}
@media(min-width:560px){.platforms-g{grid-template-columns:repeat(4,1fr)}}
.plat-card{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:16px;padding:20px 16px;text-align:center;
  box-shadow:0 3px 10px rgba(15,23,42,.06);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;
}
.plat-card:hover{transform:translateY(-3px);box-shadow:0 10px 24px rgba(15,23,42,.12)}
.plat-ic{font-size:32px;margin-bottom:8px}
.plat-name{font-family:var(--f-display);font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.01em}

.repairs-wrap{
  padding:0 24px 60px;max-width:1100px;margin:0 auto;
}
.repair-list{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 4px 20px rgba(15,23,42,.08);
}
.rrow{
  display:flex;align-items:center;gap:16px;
  padding:18px 24px;
  border-bottom:1.5px solid var(--cream2);
  transition:background .2s;
}
.rrow:last-child{border-bottom:none}
.rrow:hover{background:var(--cream)}
.r-ic{font-size:22px;width:36px;text-align:center;flex-shrink:0}
.r-info{flex:1}
.r-name{font-family:var(--f-display);font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.r-desc{font-size:12px;color:var(--muted);font-weight:300;margin-top:2px}
.r-price{font-family:var(--f-display);font-size:22px;font-weight:900;color:var(--ink);white-space:nowrap;letter-spacing:-.02em}
.r-price.free{color:var(--green)}

/* ═══ CONTACT PAGE ═══ */
.cnt-page{padding-top:0;padding-bottom:80px}
.cnt-grid{
  padding:0 24px;max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:20px;
}
@media(min-width:768px){.cnt-grid{grid-template-columns:1fr 1fr}}
.cnt-infos{display:flex;flex-direction:column;gap:12px}
.cinfo-card{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:16px;padding:20px;
  box-shadow:0 3px 10px rgba(15,23,42,.06);
  display:flex;align-items:center;gap:16px;
  transition:transform .2s,box-shadow .2s;
}
.cinfo-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(15,23,42,.10)}
.cinfo-ic{
  width:46px;height:46px;border-radius:14px;
  background:rgba(18,58,99,.08);
  display:flex;align-items:center;justify-content:center;
  font-size:22px;flex-shrink:0;
}
.cinfo-label{font-family:var(--f-mono);font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:3px}
.cinfo-val{font-size:16px;font-weight:600;color:var(--ink)}
.cinfo-note{font-size:12px;color:var(--muted);margin-top:2px}

.cnt-form-wrap{
  background:var(--white);
  border:1.5px solid var(--cream2);
  border-radius:20px;padding:32px 28px;
  box-shadow:0 4px 20px rgba(15,23,42,.08);
}
.cnt-form-title{
  font-family:var(--f-display);font-size:22px;
  font-weight:700;color:var(--ink);letter-spacing:-.02em;
  margin-bottom:24px;
}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:500px){.frow{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fl{font-size:12px;font-weight:600;color:var(--ink);letter-spacing:.01em}
.fi{
  background:var(--cream);
  border:2px solid var(--cream2);
  border-radius:12px;padding:11px 14px;
  font-family:var(--f-body);font-size:14px;
  color:var(--ink);outline:none;
  transition:border-color .2s,background .2s;
  font-weight:300;-webkit-appearance:none;
}
.fi:focus{border-color:var(--indigo);background:var(--white)}
.fi::placeholder{color:#94A3B8}
select.fi{cursor:none}
textarea.fi{min-height:100px;resize:vertical}
.submit-btn{
  width:100%;
  background:var(--indigo);color:var(--white);
  border:1.5px solid var(--indigo);border-radius:12px;
  padding:14px;margin-top:6px;
  font-family:var(--f-display);font-size:14px;font-weight:700;
  cursor:none;letter-spacing:-.01em;
  box-shadow:0 4px 16px rgba(18,58,99,.22);
  transition:transform .2s,box-shadow .2s,background .2s;
}
.submit-btn:hover{
  transform:translateY(-2px);
  background:var(--indigo2);
  box-shadow:0 8px 24px rgba(18,58,99,.30);
}

/* ═══ FOOTER ═══ */
footer{
  background:var(--ink);
  padding:40px 24px calc(40px + env(safe-area-inset-bottom));
  margin-top:60px;
}
.foot-in{
  max-width:1100px;margin:0 auto;
  display:flex;flex-direction:column;
  align-items:center;gap:20px;text-align:center;
}
.foot-logo{
  font-family:var(--f-display);font-size:22px;
  font-weight:900;color:var(--white);
  letter-spacing:-.02em;
}
.foot-logo span{color:var(--green)}
.foot-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;list-style:none}
.foot-links a{
  font-size:13px;color:rgba(255,255,255,.45);
  text-decoration:none;transition:color .2s;cursor:none;
}
.foot-links a:hover{color:var(--white)}
.foot-copy{font-size:12px;color:rgba(255,255,255,.25)}

/* ═══ REVEAL ═══ */
.rv{
  opacity:0;transform:translateY(24px);
  transition:opacity .5s ease,transform .5s ease;
}
.rv.vis{opacity:1;transform:none}
.rv-l{opacity:0;transform:translateX(-24px);transition:opacity .5s ease,transform .5s ease}
.rv-l.vis{opacity:1;transform:none}
.rv-r{opacity:0;transform:translateX(24px);transition:opacity .5s ease,transform .5s ease}
.rv-r.vis{opacity:1;transform:none}


/* ═══ PRO REFINEMENTS ═══ */
:focus-visible{outline:3px solid rgba(14,159,110,.35);outline-offset:3px}
.hero-card,.cta-band,.bcard.feat{background:linear-gradient(145deg,var(--indigo),var(--indigo2))}
.scard,.sfcard,.step-card,.tcard,.inc-item,.bcard,.plat-card,.repair-list,.cinfo-card,.cnt-form-wrap,.tpill{border-color:rgba(203,213,225,.9)}
.scard-icon,.sfcard-icon,.plat-ic,.r-ic,.cinfo-ic,.inc-ic,.bi-ic{font-family:var(--f-display);font-weight:700;color:var(--indigo)}
.tcard:nth-child(2) .t-av{background:linear-gradient(135deg,var(--green),var(--indigo-light))}
.btn,.submit-btn,.nav-cta{box-shadow:none}
.hero h1 .accent::after{background:rgba(14,159,110,.25);height:12px;bottom:2px;z-index:-1}
.hero h1 .accent{z-index:1}
.orb{opacity:.10}
.c-orange{background:var(--orange-dark)}

/* ═══ MOBILE ═══ */
@media(max-width:768px){
  body{cursor:auto}
  #cur{display:none}
  .bottom-nav{display:block}
  .nav-links,.nav-cta{display:none}
  .page{padding-bottom:80px}
  footer{margin-bottom:0}
  .hero{grid-template-columns:1fr}
  .hero-card{transform:rotate(0);margin-top:20px;min-width:auto}
  .cta-band{margin:40px 24px 0;padding:40px 28px}
}
@media(max-width:480px){
  nav{width:calc(100% - 24px);padding:0 6px 0 14px}
  .nav-logo{font-size:14px}
}

/* ═════════ MENU MOBILE PREMIUM ACCESSIDEV ═════════ */
.mobile-menu-btn{
  display:none;
  width:46px;
  height:46px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.07);
  border-radius:14px;
  position:relative;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:6px;
  z-index:1001;
  transition:background .2s,transform .2s,border-color .2s;
}
.mobile-menu-btn:hover{background:rgba(255,255,255,.12);transform:translateY(-1px)}
.mobile-menu-btn span{
  width:22px;
  height:2px;
  background:var(--white);
  border-radius:10px;
  transition:transform .3s,opacity .3s;
}
.mobile-menu-btn[aria-expanded="true"] span:first-child{transform:translateY(4px) rotate(45deg)}
.mobile-menu-btn[aria-expanded="true"] span:last-child{transform:translateY(-4px) rotate(-45deg)}
.mobile-menu{
  position:fixed;
  inset:0;
  background:radial-gradient(circle at top left,rgba(14,159,110,.18),transparent 35%),rgba(11,18,32,.97);
  backdrop-filter:blur(24px);
  z-index:999;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transform:translateY(-10px);
  transition:opacity .35s ease,transform .35s ease;
}
.mobile-menu.active{opacity:1;pointer-events:auto;transform:translateY(0)}
.mobile-menu-content{
  width:min(100% - 40px,420px);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:12px;
}
.mobile-menu-content a{
  color:var(--white);
  text-decoration:none;
  font-family:var(--f-display);
  font-size:clamp(26px,8vw,38px);
  font-weight:800;
  letter-spacing:-.04em;
  line-height:1;
  padding:16px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.07);
  transition:background .2s,color .2s,transform .2s,border-color .2s;
}
.mobile-menu-content a:hover,
.mobile-menu-content a:focus-visible{
  color:var(--green);
  background:rgba(255,255,255,.08);
  border-color:rgba(14,159,110,.35);
  transform:translateX(3px);
}
.mobile-menu-content .mobile-cta{
  margin-top:10px;
  background:var(--green);
  color:var(--white)!important;
  border-color:var(--green);
  text-align:center;
  font-size:20px;
  box-shadow:0 18px 44px rgba(14,159,110,.22);
}
.mobile-menu-content .mobile-cta:hover{background:var(--green-dark);color:var(--white)!important;transform:translateY(-2px)}
.mobile-menu-footer{
  margin-top:22px;
  color:rgba(255,255,255,.55);
  font-size:13px;
  line-height:1.5;
  text-align:center;
}
.seo-local-block{
  max-width:1100px;
  margin:38px auto 0;
  padding:0 24px;
}
.seo-local-block h2{
  font-family:var(--f-display);
  font-size:clamp(24px,4vw,38px);
  line-height:1.08;
  letter-spacing:-.03em;
  color:var(--ink);
  max-width:760px;
}
.seo-local-block p{
  margin-top:14px;
  max-width:760px;
  color:var(--body-text);
  font-size:15px;
  line-height:1.75;
  font-weight:300;
}
@media(max-width:768px){
  body{cursor:auto;padding-bottom:0}
  #cur{display:none!important}
  nav{height:58px;width:calc(100% - 24px);top:12px;padding:0 8px 0 16px;border-radius:18px}
  .nav-links{display:none!important}
  .mobile-menu-btn{display:flex}
  .bottom-nav{display:none!important}
  .page{padding-bottom:46px}
  .home-page{padding-top:88px}
  .page-top{padding-top:96px;padding-bottom:36px}
  .hero{grid-template-columns:1fr;gap:22px;padding-inline:18px}
  .hero h1{font-size:clamp(42px,13vw,58px);line-height:.98;letter-spacing:-.05em;margin-bottom:22px}
  .hero h1 .stroke{-webkit-text-stroke:2px var(--ink)}
  .hero-desc{font-size:15px;line-height:1.65;margin-bottom:26px}
  .hero-btns{flex-direction:column}.hero-btns .btn{width:100%;justify-content:center}
  .hero-card{margin-top:8px;min-width:auto;width:100%;padding:24px 22px;transform:rotate(0)!important}
  .hcard-n{font-size:42px}
  .trust-row{padding-inline:18px;gap:8px}.tpill{width:100%;justify-content:center;padding:10px 14px}
  .services-section,.how-section,.testi-section{padding:58px 18px 0}
  .s-header{margin-bottom:24px}.s-title,.how-title,.testi-title{font-size:clamp(26px,9vw,36px)}
  .scard-grid,.srv-full-grid,.builds-wrap,.cnt-grid{grid-template-columns:1fr!important;padding-inline:18px}
  .sfcard-footer{align-items:flex-start;gap:14px;flex-direction:column}.sfcard-footer .btn{width:100%;justify-content:center}
  .platforms-g{grid-template-columns:1fr 1fr;padding-inline:18px}.repairs-wrap,.includes-wrap{padding-inline:18px}
  .rrow{align-items:flex-start;padding:16px;gap:12px}.r-price{font-size:18px}.r-desc{line-height:1.5}
  .cnt-form-wrap{padding:24px 20px}.cinfo-card{padding:18px 16px}.cinfo-val{font-size:15px}
  .cta-band{margin:46px 0 0;padding:34px 22px;border-radius:20px}.cta-btns{flex-direction:column}.cta-btns .btn{width:100%;justify-content:center}
  footer{margin-top:28px;padding-bottom:34px}
}
@media(max-width:420px){
  .nav-logo{font-size:13px}.nav-logo-dot{width:7px;height:7px}.mobile-menu-btn{width:42px;height:42px}
  .mobile-menu-content{width:calc(100% - 28px)}
  .mobile-menu-content a{padding:15px 16px}
  .hero-tag{font-size:10px;padding:6px 12px}.pt-h1{font-size:clamp(36px,13vw,48px)}
  .scard,.sfcard,.step-card,.tcard,.bcard{padding:22px 18px}
}

/* ═════════ FORMULAIRE SÉCURISÉ ═════════ */
.hp-field{
  position:absolute!important;
  left:-9999px!important;
  width:1px!important;
  height:1px!important;
  opacity:0!important;
  pointer-events:none!important;
}

.form-status{
  min-height:20px;
  margin-top:12px;
  font-size:13px;
  line-height:1.5;
  color:var(--muted);
}

.form-status.success{color:var(--green-dark)}
.form-status.error{color:#B91C1C}

.submit-btn:disabled{
  opacity:.65;
  transform:none!important;
  cursor:not-allowed;
}
