
:root{
  --bg:#0a0f1d;
  --panel:rgba(14,22,28,0.6);
  --border:rgba(180,245,255,0.18);
  --txt:#e7f6ff;
  --muted:#a7c7d6;
  --accent:#3aaaff;
  --accent-2:#5ecbff;
  --shadow:0 8px 32px rgba(0,0,0,.4);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--txt);
  background:var(--bg);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  line-height:1.6;
  overflow-x:hidden;
}

.bg-stars{
  position: fixed;
  inset: 0;
  z-index: -4;
  pointer-events: none;
  background: transparent;  
  
  
}

/* Background grid */
.bg-grid{
  position:fixed; inset:0; pointer-events:none; z-index:-2;
  background:
    radial-gradient(transparent 1px, rgba(255,255,255,0.02) 1px) 0 0/40px 40px,
    linear-gradient(180deg, rgba(255,255,255,.06), transparent 25% 75%, rgba(255,255,255,.06)) no-repeat;
  mask-image: linear-gradient(#000,transparent 70%);
}
.bg-glow{
  position:fixed; inset:-20% -20% auto -20%; height:60vh; z-index:-1;
  background:radial-gradient(60% 60% at 50% 50%, rgba(82,210,255,.25), rgba(52,230,201,.18) 35%, transparent 70%);
  filter:blur(40px);
  opacity:.7;
}
.legal-card a {
  color: #3de6ce;              
  text-decoration: none;       
  font-weight: 500;
  transition: color 0.2s ease, text-shadow 0.2s ease;
}

.legal-card a:hover {
  color: #51d2ff;              
  text-shadow: 0 0 6px rgba(82,210,255,0.5);
}

/* Glass utility */
.glass{
  background:var(--panel);
  border:1px solid var(--border);
  backdrop-filter: blur(12px) saturate(120%);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
}
.soft{ box-shadow:0 6px 24px rgba(0,0,0,.28); }

/* Header / Nav */
.site-header{ position:sticky; top:12px; z-index:50; padding:0 16px;}
.nav{
  margin:auto; max-width:1100px; display:flex; align-items:center; justify-content:space-between;
  padding:10px 14px; gap:10px;
}
.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:var(--txt); font-weight:700;}
.brand img{ filter:drop-shadow(0 0 6px rgba(82,210,255,.6)); }
.nav-links{ list-style:none; display:flex; gap:18px; align-items:center; margin:0; padding:0; }
.nav-links a{ color:var(--txt); text-decoration:none; opacity:.9; padding:10px 12px; border-radius:12px; }
.nav-links a:hover{ background:rgba(255,255,255,.06); }

/* Burger */
.burger{ display:none; background:none; border:0; cursor:pointer; padding:8px; border-radius:12px; }
.burger span{ display:block; width:24px; height:2px; background:#dff9ff; margin:5px 0; transition:.3s; border-radius:2px; }

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px;
  border-radius:14px; text-decoration:none; border:1px solid var(--border); cursor:pointer; transition:transform .15s ease, background .3s ease; }
.btn:hover{ transform:translateY(-1px); }
.btn-primary{
  color:#00131a; font-weight:700;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow: 0 8px 18px rgba(82,210,255,.25);
}
.btn-ghost{ color:var(--txt); background:rgba(255,255,255,.03); }
.btn:focus-visible{ outline:2px solid var(--accent); outline-offset:2px;}

/* Ripple (JS adds span) */
.btn.ripple{ position:relative; overflow:hidden; }
.btn.ripple span.rip{ position:absolute; border-radius:999px; transform:translate(-50%,-50%); pointer-events:none; animation:rip .7s ease-out forwards; background:rgba(255,255,255,.5);}
@keyframes rip{ from{ width:0; height:0; opacity:.6;} to{ width:320px; height:320px; opacity:0;}}

/* Hero */
.hero{ padding:120px 16px 40px; }
.hero-inner{ max-width:1100px; margin:0 auto; text-align:center; }

.badge{
  display:inline-flex; align-items:center; gap:10px; padding:8px 14px; color:#dff9ff;
  border-radius:999px; font-weight:600; letter-spacing:.2px;
  position:relative; overflow:hidden;
}
.badge .dot{ width:8px; height:8px; background:#2cf59a; border-radius:50%; box-shadow:0 0 8px #2cf59a;
  position:relative; animation: dotPulse 1.8s ease-in-out infinite; box-shadow: 0 0 14px 2px #2cf59a, 0 0 34px rgba(44,245,154,.35);
}
.badge::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  transform:translateX(-120%) skewX(-20deg);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent);
  filter: blur(2px);
  animation: badgeSheen 3.2s ease-in-out infinite;
}
@keyframes badgeSheen{
  0%{ transform:translateX(-120%) skewX(-20deg); }
  55%{ transform:translateX(140%) skewX(-20deg); }
  100%{ transform:translateX(140%) skewX(-20deg); }
}
@keyframes dotPulse{
  0%,100%{ transform:scale(1); opacity:1; }
  50%{ transform:scale(1.35); opacity:.9; }
}
.badge .dot{ width:8px; height:8px; background:#2cf59a; border-radius:50%; box-shadow:0 0 8px #2cf59a; }

.title-gradient{
  font-family:Poppins,Inter,system-ui,sans-serif; font-weight:800; font-size:clamp(32px, 6vw, 64px); line-height:1.1; margin:18px auto 16px;
  background:linear-gradient(180deg, #a8ebff 0%, #51d2ff 40%, #3de6ce 70%, #dff9ff 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent; text-shadow:0 6px 22px rgba(82,210,255,.25);
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.35));
  animation:shine 8s linear infinite;
}
@keyframes shine{
  0%{ filter:drop-shadow(0 10px 22px rgba(0,0,0,.35)) hue-rotate(0deg);}
  100%{ filter:drop-shadow(0 10px 22px rgba(0,0,0,.35)) hue-rotate(360deg);}
}

.lead{
  max-width:760px; margin:0 auto 22px; padding:18px 22px; color:#cfefff;
}
.cta-row{ display:flex; justify-content:center; gap:14px; margin-top:10px; }

/* Stats */
.stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin:40px auto 0; max-width:1000px; }
.card{ padding:22px 18px; text-align:center; }
.card-icon{ font-size:20px; opacity:.9; margin-bottom:6px; }
.card-value{ font-size:36px; font-weight:800; letter-spacing:.5px; }
.card-label{ margin:4px 0 0; color:var(--muted); }

/* Sections */
.section{ padding:90px 16px 40px; }
.section-head{ max-width:900px; margin:0 auto 28px; text-align:center; }
.section h2{
  font-family:Poppins,Inter,sans-serif; font-size:clamp(24px,3.5vw,40px); margin:0 0 8px;
  background:linear-gradient(90deg,#dff9ff,#51d2ff,#3de6ce); -webkit-background-clip:text; color:transparent;
}
.section p{ color:#cfefff; }

.cards-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; max-width:1100px; margin:0 auto; }
.mini{ padding:18px; }
.mini h3{ margin:6px 0 8px; }
.mini p{ color:var(--muted); }

.steps{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:14px; max-width:1000px; margin:0 auto; padding:0; }
.steps li{ padding:16px; text-align:center;}

/* Pricing */
.pricing{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; padding:18px; }
.price-col{ padding:24px; border-radius:var(--radius); border:1px solid var(--border); background:rgba(14,22,28,.45); }
.price-col.highlight{ outline:2px solid var(--accent); box-shadow:0 0 24px rgba(82,210,255,.2); }
.price{ font-size:40px; font-weight:800; margin:10px 0 12px; }
.price span{ font-size:16px; color:var(--muted); display:inline-block; margin-left:6px; }
.price-col ul{ margin:0 0 18px 18px; color:var(--muted); }
.price-col .btn{ width:100%; }

/* Contact */
.contact-form{ max-width:900px; margin:0 auto; padding:22px; }
.contact-form .grid{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
label{ display:block; font-weight:600; margin-bottom:10px; color:#dbf8ff; }
input, textarea{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid var(--border);
  background:rgba(255,255,255,.03); color:var(--txt);
}
input::placeholder, textarea::placeholder{ color:#a9c8d6; }
.honeypot{ position:absolute; left:-9999px; opacity:0; }
.form-actions{ display:flex; align-items:center; gap:14px; margin-top:8px; }
.form-status{ color:#a7f3d0; min-height:22px; }

/* Footer */
.footer{ padding:40px 16px 80px; }
.footer > .glass{ max-width:1100px; margin:0 auto; padding:16px 20px; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-nav a{ color:#cfefff; text-decoration:none; margin:0 10px; }
.footer-nav a:hover{ text-decoration:underline; }

/* Responsive */
@media (max-width:1024px){
  .cards-grid{ grid-template-columns:repeat(2,1fr); }
  .steps{ grid-template-columns:repeat(2,1fr); }
  .pricing{ grid-template-columns:1fr; }
}
@media (max-width:768px){
  .stats{ grid-template-columns:1fr; }
  .contact-form .grid{ grid-template-columns:1fr; }
  .burger{ display:inline-block; }
  .nav-links{ position:absolute; right:16px; top:64px; flex-direction:column; gap:8px; padding:12px; min-width:220px;
    display:none; }
  .nav-links.open{ display:flex; }
}



.glass.liquid{
  position: relative; overflow: hidden;
  background:
    radial-gradient(1200px 1200px at 0% -10%, rgba(82,210,255,.12), transparent 60%),
    radial-gradient(800px 800px at 110% 110%, rgba(52,230,201,.10), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid rgba(180,245,255,.28);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.glass.liquid::before{ 
  content: "";
  position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background: conic-gradient(from 180deg at 50% 0%,
              rgba(255,255,255,.18), rgba(255,255,255,0) 20% 70%, rgba(255,255,255,.18));
  /* petit halo interne */
  -webkit-mask: radial-gradient(100% 100% at 50% 50%, transparent 65%, black 75%);
          mask: radial-gradient(100% 100% at 50% 50%, transparent 65%, black 75%);
  opacity: .7; filter: blur(8px);
  animation: glowDrift 18s ease-in-out infinite;
}


@keyframes glowDrift{
  0%   { --hx: 0%;   --hy: 0%;   }
  25%  { --hx: 90%;  --hy: 10%;  }
  50%  { --hx: 70%;  --hy: 100%; }
  75%  { --hx: 20%;  --hy: 70%;  }
  100% { --hx: 10%;  --hy: -10%; }
}


/* Navbar icons */
.nav-links a{ display:inline-flex; align-items:center; gap:8px; }
.icon{ width:16px; height:16px; fill:#c8f6ff; opacity:.9; filter:drop-shadow(0 0 6px rgba(82,210,255,.35)); }

/* Cards subtle internal shimmer */
.card.glass.liquid, .mini.glass.liquid, .price-col, .contact-form.glass.liquid, .footer > .glass.liquid{
  background-blend-mode: screen;
}

/* Improve nav hover for liquid look */
.nav-links a:hover{
  background: radial-gradient(60% 120% at 50% 0%, rgba(255,255,255,.08), rgba(255,255,255,.02));
  box-shadow: inset 0 0 0 1px rgba(180,245,255,.25);
}


/* Offre 48h */
.offer48{
  max-width:800px; margin:0 auto; padding:32px; text-align:center;
}
.offer48 h3{ font-size:28px; margin:0 0 12px; }
.offer48 p{ color:#dff9ff; margin-bottom:14px; }
.offer48 ul{ list-style:none; padding:0; margin:0 0 20px; text-align:left; max-width:500px; margin-left:auto; margin-right:auto; }
.offer48 li{ margin:6px 0; padding-left:20px; position:relative; }
.offer48 li::before{ content:""; position:absolute; left:0; top:8px; width:8px; height:8px; border-radius:50%; background:var(--accent); box-shadow:0 0 8px var(--accent); }
.offer48 .price{ font-size:32px; font-weight:800; margin:18px 0; color:#fff; }
.offer48 .price span{ font-size:16px; color:var(--muted); }


/* === Offre spéciale 48h === */
.offer{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:1.4fr .9fr; gap:24px; padding:22px; align-items:center; }
.offer h2{ margin:0 0 8px; }
.offer .pill{
  display:inline-block; padding:4px 10px; border-radius:999px; margin-left:8px; font-size:.9em; font-weight:800;
  color:#00131a; background:linear-gradient(90deg,var(--accent),var(--accent-2));
  box-shadow:0 6px 16px rgba(82,210,255,.28);
}
.offer .sub{ color:#cfefff; margin:0 0 12px; }
.offer .features{ margin:0 0 16px 0; padding-left:0; list-style:none; color:#a9c8d6; display:grid; gap:8px; }
.offer .cta-row{ justify-content:flex-start; }

.offer-right{ display:flex; flex-direction:column; gap:14px; align-items:center; }
.price-tag{
  display:grid; place-items:center; text-align:center; padding:18px 22px; min-width:260px;
  border-radius:20px; border:1px solid var(--border);
}
.pt-top{ color:#cfefff; letter-spacing:.3px; }
.pt-price{ font-size:56px; font-weight:900; line-height:1; margin:6px 0; background:linear-gradient(90deg,#dff9ff,#51d2ff,#3de6ce);
  -webkit-background-clip:text; color:transparent; }
.pt-note{ color:#a7c7d6; font-size:.9rem; }

.timers{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.chip{ padding:8px 12px; border-radius:999px; border:1px solid var(--border); background:rgba(255,255,255,.04); color:#dff9ff; }

.fine{ max-width:1100px; margin:10px auto 0; text-align:center; color:#86a9b9; }

@media (max-width:1024px){
  .offer{ grid-template-columns:1fr; }
  .offer-right{ align-items:flex-start; }
}



.card.glass.liquid, .mini.glass.liquid, .price-col, .contact-form.glass.liquid, .footer > .glass.liquid{
  background: linear-gradient(135deg, rgba(40,90,160,0.15), rgba(90,180,255,0.08));
  background-size: 200% 200%;
  animation: cardGrad 12s ease-in-out infinite alternate;
}
@keyframes cardGrad{
  0%{ background-position:0% 0%; }
  100%{ background-position:100% 100%; }
}


/* === Expertise Cards === */
.expertise-cards{ grid-template-columns:repeat(4,1fr); gap:22px; }
.expert-card{ padding:22px; display:flex; flex-direction:column; gap:10px; }
.expert-card h3{ margin:0; font-size:1.3rem; color:#dff9ff; }
.expert-card p{ flex-grow:1; color:#cfefff; font-size:.95rem; }
.expert-card ul{ list-style:none; margin:0; padding:0; display:grid; gap:6px; color:#8ed5ff; font-weight:600; }
.expert-card li{ display:flex; align-items:center; gap:6px; font-size:.9rem; }
.ex-icon{ font-size:1.6rem; margin-bottom:4px; }

@media(max-width:1024px){
  .expertise-cards{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:640px){
  .expertise-cards{ grid-template-columns:1fr; }
}


/* === Expertise cards === */
.expertise .section-head p{ color:#a9c8d6; }
.services-grid{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.service-card{ padding:18px; position:relative; overflow:hidden; }
.svc-top{ display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.svc-ico{ width:28px; height:28px; display:grid; place-items:center; border-radius:8px;
  background: linear-gradient(90deg, rgba(90,180,255,.18), rgba(20,140,240,.12)); border:1px solid rgba(180,245,255,.22); }
.svc-ico svg{ width:18px; height:18px; fill:#c8ecff; }
.svc-text{ color:#a9c8d6; margin:0 0 10px; }
.svc-list{ list-style:none; padding:0; margin:12px 0 0; display:grid; gap:8px; }
.svc-list li{ display:flex; align-items:center; gap:8px; color:#d9f3ff; font-weight:500; }
.chk{ width:18px; height:18px; border-radius:999px; display:inline-block; position:relative;
  background: radial-gradient(70% 70% at 50% 50%, #bff1ff 0%, #61c7ff 60%, rgba(0,0,0,0) 61%);
  box-shadow: inset 0 0 0 2px rgba(0,60,120,.35), 0 0 8px rgba(80,170,255,.35);
}
.chk::after{ content:""; position:absolute; left:5px; top:3px; width:6px; height:10px; border:2px solid #0a1a2a; border-top:none; border-left:none; transform:rotate(45deg); }

@media (max-width:1024px){
  .services-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:640px){
  .services-grid{ grid-template-columns:1fr; }
}


/* === Card animations (hover lift + glow + tilt) === */
.service-card, .price-tag, .mini.glass.liquid, .card.glass.liquid {
  transform: perspective(700px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(var(--ty, 0));
  transition: transform .2s ease, box-shadow .25s ease, outline-color .25s ease, background-position 1s ease;
  will-change: transform;
}
.service-card:hover, .price-tag:hover, .mini.glass.liquid:hover, .card.glass.liquid:hover {
  --ty: -6px;
  box-shadow: 0 14px 40px rgba(40,120,200,.25), inset 0 0 0 1px rgba(160,220,255,.35);
  background-position: 100% 0%;
  outline: 1px solid rgba(140,220,255,.35);
}
/* subtle inner sheen on hover */
.service-card:hover::after, .price-tag:hover::after{
  content:""; position:absolute; inset:0; pointer-events:none; border-radius:inherit;
  background: radial-gradient(60% 120% at 50% -20%, rgba(255,255,255,.10), transparent 60%);
}

/* reveal animation */
.reveal{ opacity:0; transform: translateY(14px); }
.reveal.show{ opacity:1; transform: translateY(0); transition: opacity .5s ease, transform .5s ease; }




.bg-aurora{
  position:fixed; inset:-10% -10% -10% -10%; z-index:-3; pointer-events:none;
  filter: blur(40px) saturate(120%);
  opacity:.7;
}
.bg-aurora::before, .bg-aurora::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(35% 45% at 20% 20%, rgba(90,180,255,.35), transparent 60%),
    radial-gradient(45% 35% at 80% 30%, rgba(120,80,255,.28), transparent 60%),
    radial-gradient(35% 45% at 40% 80%, rgba(40,220,255,.22), transparent 60%);
  animation: auroraMove 26s ease-in-out infinite;
  mix-blend-mode: screen;
}
.bg-aurora::after{
  transform: rotate(15deg);
  animation-duration: 34s;
  opacity:.8;
}

@keyframes auroraMove{
  0%   { transform: translate3d(-2%, -1%, 0) scale(1); }
  50%  { transform: translate3d(2%, 1%, 0)  scale(1.05); }
  100% { transform: translate3d(-2%, -1%, 0) scale(1); }
}



.bg-aurora{ will-change: transform, opacity; transform: translateZ(0); }
.bg-grid{ -webkit-mask-image: linear-gradient(#000, transparent 70%); }

/* Reduced motion: freeze long animations */
@media (prefers-reduced-motion: reduce){
  .bg-aurora::before, .bg-aurora::after{ animation: none !important; }
  .title-gradient{ animation: none !important; }
  .service-card, .price-tag, .mini.glass.liquid, .card.glass.liquid{ transition: none !important; }
}


/* === Square-ish cards override === */
.service-card{ border-radius: 14px !important; }
.price-col, .mini.glass.liquid, .card.glass.liquid, .contact-form.glass.liquid, .footer > .glass.liquid{ border-radius: 14px !important; }
.services-grid{ gap: 22px; } /* slightly more spacing for boxier look */


/* === Premium square check === */
.svc-list li{ align-items:flex-start; }
.chk{
  width:18px; height:18px; border-radius:4px; display:inline-block; position:relative; flex:0 0 18px; margin-top:3px;
  background: linear-gradient(180deg, rgba(90,180,255,.18), rgba(40,120,220,.10));
  border:1px solid rgba(160,220,255,.45);
  box-shadow: inset 0 0 0 1px rgba(90,170,255,.15), 0 2px 6px rgba(40,120,200,.25);
}
.chk::after{
  content:""; position:absolute; left:4px; top:2px; width:8px; height:12px;
  border:2px solid #dff6ff; border-top:none; border-left:none; transform:rotate(45deg);
  filter: drop-shadow(0 0 4px rgba(160,220,255,.6));
}


/* === Projets grid & cards === */
.proj-wrap{ max-width:1100px; margin:0 auto; padding:20px 16px 60px; }
.proj-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.proj-card{
  border-radius:14px; overflow:hidden; position:relative;
  border:1px solid rgba(160,220,255,.25);
  background:linear-gradient(135deg, rgba(40,90,160,0.12), rgba(90,180,255,0.06));
  backdrop-filter: blur(10px) saturate(120%);
  -webkit-backdrop-filter: blur(10px) saturate(120%);
  box-shadow: 0 10px 26px rgba(20,40,80,.35);
  display:flex; flex-direction:column;
}
.proj-thumb{ aspect-ratio: 16/9; width:100%; display:block; object-fit:cover; background:#0a1320; }
.proj-body{ padding:14px 14px 12px; display:flex; flex-direction:column; gap:8px; }
.proj-title{ font-weight:800; margin:2px 0 0; }
.proj-desc{ color:#a9c8d6; margin:0; }
.badges{ display:flex; flex-wrap:wrap; gap:8px; margin-top:2px; }
.badge-info{
  font-size:.85rem; padding:6px 10px; border-radius:999px;
  border:1px solid rgba(160,220,255,.25);
  background:rgba(255,255,255,.04); color:#dff9ff;
}
.proj-actions{ margin-top:10px; }
.proj-card .btn{ width:100%; }

/* hover */
.proj-card:hover{ transform: translateY(-4px); transition: transform .2s ease;}

/* responsive */
@media (max-width:1024px){ .proj-grid{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .proj-grid{ grid-template-columns:1fr;} }


/* === Méthode — 5 étapes === */
.methode-steps .section-head p{ color:#a9c8d6; }
.steps5{
  list-style:none; margin:0 auto; padding:0; max-width:1100px;
  display:grid; gap:16px;
}
.steps5 li{
  display:flex; align-items:center; gap:16px; padding:16px 18px; border-radius:16px;
  border:1px solid rgba(160,220,255,.22);
  background:linear-gradient(135deg, rgba(40,90,160,0.12), rgba(90,180,255,0.06));
}
.step-pill{
  flex:0 0 40px; height:40px; width:40px; display:grid; place-items:center; font-weight:900;
  color:#00131a; border-radius:10px;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  box-shadow:0 8px 18px rgba(82,210,255,.25), inset 0 0 0 1px rgba(255,255,255,.25);
}
.step-body h3{ margin:0 0 4px; color:#dff9ff; }
.step-body p{ margin:0; color:#cfefff; }

@media (max-width:700px){
  .steps5 li{ align-items:flex-start; }
  .step-pill{ flex:0 0 34px; height:34px; width:34px; font-size:.95rem; border-radius:8px; }
}


/* === Pricing (Abonnements) === */
.plans .section-head p{ color:#a9c8d6; }
.plans-grid{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.plan{ padding:18px; border-radius:16px; border:1px solid rgba(160,220,255,.28); }
.plan.highlight{ outline:2px solid var(--accent); box-shadow:0 0 28px rgba(90,180,255,.18); }
.plan-head{ display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.plan-ico{ width:28px; height:28px; display:grid; place-items:center; border-radius:8px;
  background:linear-gradient(90deg, rgba(90,180,255,.18), rgba(20,140,240,.12)); border:1px solid rgba(160,220,255,.25); }
.plan-ico svg{ width:18px; height:18px; fill:#c8ecff; }
.price{ font-size:40px; font-weight:900; margin:10px 0 12px; }
.price strong{ font-size:48px; }
.price span{ font-size:32px; }
.price em{ font-style:normal; font-weight:600; color:#a9c8d6; font-size:16px; margin-left:6px; }
.plan-list{ list-style:none; margin:0 0 14px; padding:0; display:grid; gap:10px; }
.plan-chips{ display:flex; gap:8px; flex-wrap:wrap; margin:8px 0 8px; }
.chip{ padding:6px 10px; border-radius:999px; border:1px solid rgba(160,220,255,.25); background:rgba(255,255,255,.04); color:#dff9ff; font-size:.9rem; }
.btn.full{ width:100%; margin-top:6px; }
.fine{ color:#88aabd; font-size:.95rem; margin-top:10px; }
.fine.center{ text-align:center; margin-top:16px; }

@media (max-width:1024px){ .plans-grid{ grid-template-columns:1fr; } .plan.highlight{ order:-1; } }


/* === Footer === */
.footer{ margin-top:60px; padding:28px 20px; border-top:1px solid rgba(160,220,255,.18); text-align:center; }
.footer-inner{ max-width:1100px; margin:0 auto; display:flex; flex-direction:column; align-items:center; gap:16px; }
.footer-brand{ display:flex; align-items:center; gap:10px; font-weight:700; font-size:1.1rem; color:#dff9ff; }
.footer-nav{ display:flex; flex-wrap:wrap; gap:18px; }
.footer-nav a{ color:#c8ecff; font-size:.95rem; transition:.2s; }
.footer-nav a:hover{ color:var(--accent); }
.footer-social{ display:flex; gap:14px; }
.footer-social a svg{ width:20px; height:20px; fill:#a9c8d6; transition:.2s; }
.footer-social a:hover svg{ fill:var(--accent); transform:scale(1.1); }
.footer-copy{ color:#88aabd; font-size:.9rem; margin-top:8px; }

@media (max-width:600px){
  .footer-nav{ justify-content:center; gap:12px; }
}


/* === Footer Modern === */
.footer-modern{ padding:40px 16px 20px; position:relative; 
}
.footer-modern::before{
  /* subtle top glow line */
  content:""; position:absolute; left:0; right:0; top:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(120,200,255,.45), transparent);
  opacity:.7;
}
.footer-modern .footer-inner{
  max-width:1100px; margin:0 auto; padding:20px; display:grid;
  grid-template-columns: 1fr; gap:18px; border-radius:16px;
 place-items:center; text-align:center;}
.footer-modern .brand{ text-decoration:none; color:var(--txt); font-weight:800; display:flex; align-items:center; gap:10px; 
justify-content:center; }
.footer-modern .ft-tag{ color:#a9c8d6; margin:8px 0 10px; }
.footer-modern h4{ margin:0 0 8px; font-weight:700; color:#dff9ff; }
.footer-modern ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer-modern a{ color:#cfefff; text-decoration:none; }
.footer-modern a:hover{ text-decoration:underline; }

.footer-modern .ft-socials{ display:flex; gap:8px; flex-wrap:wrap; 
justify-content:center; }
.footer-modern .chip{ padding:8px 12px; border-radius:999px; border:1px solid rgba(160,220,255,.25); background:rgba(255,255,255,.04); }

.ft-bar {
  max-width: 1100px;
  margin: 12px auto 0;
  padding: 10px 4px;
  display: flex;
  flex-direction: column; 
  align-items: center;
  gap: 6px;
  color: #86a9b9;
  text-align: center;
}

.ft-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.legal-links {
  font-size: 0.9rem;
  color: #a9c8d6;
}

.legal-links a {
  color: #cfefff;
  text-decoration: none;
  margin: 0 6px;
}

.legal-links a:hover {
  text-decoration: underline;
}

@media (max-width:900px){
  .footer-modern .footer-inner{ grid-template-columns:1fr;  place-items:center; text-align:center;}
  .ft-bar{ flex-direction:column; gap:8px; }
}
/* === Clients tracking === */
.client-toolbar{ max-width:1100px; margin:0 auto 16px; display:flex; gap:10px; padding:0 4px; }
.input{ background:rgba(255,255,255,.05); border:1px solid rgba(160,220,255,.25); border-radius:12px; padding:10px 12px; color:#e9fbff; outline:none; }
.input:focus{ box-shadow:0 0 0 2px rgba(120,200,255,.25); }

.clients-grid{ max-width:1100px; margin:0 auto; display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.client-card{ border-radius:16px; border:1px solid rgba(160,220,255,.28); background:linear-gradient(135deg, rgba(40,90,160,0.12), rgba(90,180,255,0.06)); padding:16px; }
.client-head{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:8px; }
.client-name{ font-weight:800; font-size:1.1rem; }
.badge{ padding:6px 10px; border-radius:999px; border:1px solid rgba(160,220,255,.25); background:rgba(255,255,255,.04); color:#dff9ff; font-size:.85rem; }
.progress{ height:10px; border-radius:999px; background:rgba(255,255,255,.06); overflow:hidden; border:1px solid rgba(160,220,255,.18); }
.progress > span{ display:block; height:100%; width:0%; background:linear-gradient(90deg, var(--accent), var(--accent-2)); box-shadow:0 6px 18px rgba(90,180,255,.35); }
.stage-steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:6px; margin-top:10px; }
.stage-steps .step{ text-align:center; padding:8px; border-radius:10px; border:1px solid rgba(160,220,255,.18); background:rgba(255,255,255,.04); font-size:.9rem; }
.step.done{ opacity:.9; }
.step.current{ outline:2px solid var(--accent); }
.meta{ margin-top:10px; display:flex; gap:10px; flex-wrap:wrap; }
.links{ display:flex; gap:8px; flex-wrap:wrap; }
.links .btn{ padding:8px 12px; border-radius:10px; }
.next-actions, .updates{ margin-top:10px; }
.next-actions ul, .updates ul{ margin:6px 0 0; padding-left:18px; color:#cfefff; }
@media (max-width:900px){ .clients-grid{ grid-template-columns:1fr; } }
/* Timeline 4 étapes */
.timeline{ position:relative; padding:24px 16px; border-radius:16px }
.tl-track{ position:relative; height:6px; background:rgba(255,255,255,.08);
  border:1px solid rgba(160,220,255,.18); border-radius:999px; overflow:hidden; }
.tl-fill{ display:block; height:100%;
  background:linear-gradient(90deg, var(--accent), var(--accent-2)); box-shadow:0 8px 24px rgba(90,180,255,.35);
  transition:width .8s cubic-bezier(.2,.7,.2,1); }
.tl-steps{ list-style:none; margin:10px 0 0; padding:0; display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.tl-step{ text-align:center; color:#a9c8d6; position:relative; }
.tl-step .dot{ display:inline-block; width:12px; height:12px; border-radius:50%;
  background:rgba(200,240,255,.3); border:1px solid rgba(160,220,255,.4); margin-bottom:6px;
  box-shadow:0 0 0 0 rgba(120,200,255,.25); transition:transform .4s; }
.tl-step.active .dot{ background:var(--accent); border-color:var(--accent);
  animation:pulseDot 1.6s ease-out infinite; }
.tl-step.completed .dot{ background:#9be8c7; border-color:#9be8c7; }
.tl-step .lbl{ display:block; font-size:.95rem; color:#dff9ff; }
@keyframes pulseDot{ 0%{box-shadow:0 0 0 0 rgba(120,200,255,.35)} 100%{box-shadow:0 0 0 14px rgba(120,200,255,0)} }
@media (max-width:640px){ .tl-step .lbl{ font-size:.9rem } }
.btn-whatsapp {
  background: linear-gradient(90deg, #25d366, #128c7e);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 8px 18px rgba(37,211,102,.25);
}
.btn-whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(37,211,102,.35);
}
