/* ═══════════════════════════════════════════════
   iDev Web — Feuille de styles principale
   Palette violet foncé / bleu
═══════════════════════════════════════════════ */
:root {
  --vd:  #3A0D6E;
  --vm:  #5A1A9E;
  --vb:  #7B2FFF;
  --bl:  #3B5BFF;
  --vl:  #9D5CFF;
  --dark:#0A0514;
  --dark2:#0F0720;
  --dark3:#150B2E;
  --grad: linear-gradient(135deg,#7B2FFF 0%,#3B5BFF 100%);
  --grad2: linear-gradient(135deg,#3A0D6E 0%,#5A1A9E 60%,#7B2FFF 100%);
  --grad3: linear-gradient(135deg,#3A0D6E 0%,#3B5BFF 100%);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:#fff;color:#333;overflow-x:hidden;}
::selection{background:var(--vb);color:#fff;}

/* ── PRELOADER ── */
#preloader{background:var(--grad2) !important;}
#preloader .jumper>div{background-color:rgba(255,255,255,0.9);}

/* ═══════════════════════════════════════
   HEADER
═══════════════════════════════════════ */
.idev-header{
  position:fixed;top:0;left:0;right:0;z-index:999;
  transition:box-shadow .3s;
}

.idev-nav{
  background:#fff;
  border-bottom:1px solid rgba(123,47,255,0.12);
  box-shadow:0 2px 20px rgba(123,47,255,0.06);
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 48px;
  transition:box-shadow .3s;
}

.idev-header.scrolled .idev-nav{
  box-shadow:0 4px 30px rgba(123,47,255,0.14);
}

/* Logo */
.idev-logo{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;flex-shrink:0;
}
.idev-logo-img{height:44px;width:auto;}
.idev-logo-name{
  font-family:'Raleway',sans-serif;font-weight:900;font-size:1.22rem;
  background:var(--grad);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:.5px;
}

/* Nav links */
.idev-nav-links{
  display:flex;align-items:center;gap:4px;
  list-style:none;margin:0;padding:0;
}
.idev-nav-links a{
  font-family:'Raleway',sans-serif;font-weight:600;font-size:.88rem;
  color:#3a3a5c;text-decoration:none;
  padding:8px 14px;border-radius:8px;
  letter-spacing:.02em;
  transition:color .2s,background .2s;
}
.idev-nav-links a:hover,
.idev-nav-links a.active{color:var(--vb);background:rgba(123,47,255,.07);}

.idev-nav-links .nav-cta a{
  background:var(--grad) !important;
  color:#fff !important;
  padding:10px 22px !important;
  border-radius:10px !important;
  font-weight:700 !important;
  box-shadow:0 4px 16px rgba(123,47,255,.28);
  transition:transform .2s,box-shadow .2s !important;
}
.idev-nav-links .nav-cta a:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(123,47,255,.42) !important;
}

/* Hamburger */
.idev-hamburger{
  display:none;
  flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:6px;
}
.idev-hamburger span{
  display:block;width:24px;height:2px;
  background:#3a3a5c;border-radius:2px;
  transition:all .3s;
}

@media(max-width:992px){
  .idev-nav{padding:0 24px;}
  .idev-hamburger{display:flex;}
  .idev-nav-links{
    display:none;flex-direction:column;align-items:flex-start;gap:4px;
    position:absolute;top:72px;left:0;right:0;
    background:#fff;padding:20px 24px 24px;
    border-bottom:1px solid rgba(123,47,255,.12);
    box-shadow:0 10px 32px rgba(123,47,255,.1);
  }
  .idev-nav-links.open{display:flex;}
  .idev-nav-links .nav-cta{width:100%;}
  .idev-nav-links .nav-cta a{display:block;text-align:center;}
}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.idev-hero{
  min-height:100vh;
  background:url('../images/hero-bg.jpg') center center / cover no-repeat;
  position:relative;display:flex;align-items:center;
}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,5,20,.88) 0%,rgba(58,13,110,.76) 45%,rgba(59,91,255,.45) 100%);
  z-index:1;
}
.hero-grid{
  position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(rgba(123,47,255,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(123,47,255,.07) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-content{position:relative;z-index:2;}

.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(123,47,255,.18);border:1px solid rgba(123,47,255,.35);
  padding:7px 18px;border-radius:100px;
  font-size:.76rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:#c9a8ff;margin-bottom:24px;
}
.hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;background:#9D5CFF;
  animation:blink 2s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

.hero-title{
  font-family:'Raleway',sans-serif;font-weight:800;
  font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.18;
  color:#fff;margin-bottom:20px;
}
.hero-title em{
  font-style:normal;
  background:linear-gradient(90deg,#c9a8ff,#7B2FFF,#3B5BFF);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-desc{
  color:rgba(255,255,255,.82);font-size:1.05rem;line-height:1.75;
  max-width:540px;margin:0 auto 36px;
}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* Boutons hero */
.btn-vp{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--grad);color:#fff;
  padding:13px 30px;border-radius:10px;
  font-family:'Raleway',sans-serif;font-weight:700;font-size:.92rem;
  text-decoration:none;border:none;cursor:pointer;
  box-shadow:0 8px 28px rgba(123,47,255,.38);
  transition:transform .2s,box-shadow .2s;
}
.btn-vp:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(123,47,255,.52);color:#fff;text-decoration:none;}

.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.1);color:#fff;
  padding:13px 30px;border-radius:10px;
  font-family:'Raleway',sans-serif;font-weight:600;font-size:.92rem;
  text-decoration:none;border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(8px);
  transition:background .2s,border-color .2s;
}
.btn-ghost:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.4);color:#fff;text-decoration:none;}

.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:transparent;color:var(--vb);
  padding:13px 28px;border-radius:10px;
  font-family:'Raleway',sans-serif;font-weight:700;font-size:.9rem;
  text-decoration:none;border:2px solid rgba(123,47,255,.3);cursor:pointer;
  transition:background .2s,border-color .2s;
}
.btn-outline:hover{background:rgba(123,47,255,.07);border-color:var(--vb);color:var(--vb);text-decoration:none;}

.w-100{width:100% !important;}

/* Scroll indicator */
.scroll-indicator{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:5px;
  color:rgba(255,255,255,.45);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  animation:bob 2s ease-in-out infinite;
}
.scroll-indicator i{font-size:1rem;}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* ═══════════════════════════════════════
   SECTIONS COMMUNES
═══════════════════════════════════════ */
.idev-sec{padding:90px 0;}
.sec-white{background:#fff;}
.sec-soft{background:#f4eeff;}
.sec-dark{background:linear-gradient(160deg,#0A0514 0%,#150B2E 60%,#0F0720 100%);}

.sec-label{
  display:inline-block;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--vb);margin-bottom:10px;
}
.sec-label.light{color:rgba(255,255,255,.5);}

.sec-title{
  font-family:'Raleway',sans-serif;font-weight:800;
  font-size:clamp(1.7rem,3.5vw,2.4rem);line-height:1.22;
  color:#1a0035;margin-bottom:14px;
}
.sec-title.light{color:#fff;}
.sec-text{font-size:.95rem;color:#555;line-height:1.78;}
.sec-text.light{color:rgba(255,255,255,.62);}

.divider{width:44px;height:3px;background:var(--grad);border-radius:2px;margin:14px 0 0;}
.divider.mx-auto{margin-left:auto;margin-right:auto;}

/* ═══════════════════════════════════════
   FEATURE CARDS (sous hero)
═══════════════════════════════════════ */
.feat-sec{padding-top:0;padding-bottom:80px;margin-top:-80px;position:relative;z-index:10;}

.feat-card{
  background:#fff;border-radius:18px;padding:32px 28px;
  border:1px solid rgba(123,47,255,.1);
  box-shadow:0 8px 40px rgba(123,47,255,.09);
  height:100%;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.feat-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(123,47,255,.17);border-color:rgba(123,47,255,.28);}

.feat-icon{
  width:56px;height:56px;border-radius:14px;
  background:var(--grad);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
  box-shadow:0 6px 20px rgba(123,47,255,.3);
}
.feat-icon i{color:#fff;font-size:1.3rem;}

.feat-card h5{font-family:'Raleway',sans-serif;font-weight:800;font-size:1rem;color:#1a0035;margin-bottom:10px;}
.feat-card p{font-size:.87rem;color:#666;line-height:1.7;margin:0;}

/* ═══════════════════════════════════════
   À PROPOS
═══════════════════════════════════════ */
.about-img-wrap{position:relative;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px rgba(123,47,255,.2);}
.about-img{width:100%;display:block;border-radius:20px;}

.about-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(123,47,255,.08);border:1px solid rgba(123,47,255,.18);
  border-radius:100px;padding:8px 18px;
  font-size:.82rem;color:var(--vm);font-weight:600;margin-bottom:18px;
}

.check-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:13px;}
.check-list li{display:flex;align-items:flex-start;gap:12px;font-size:.92rem;color:#444;line-height:1.6;}
.chk{
  width:22px;height:22px;border-radius:50%;
  background:var(--grad);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:800;flex-shrink:0;margin-top:1px;
}
.mt-3{margin-top:12px;}
.mt-4{margin-top:20px !important;}

/* ═══════════════════════════════════════
   SERVICES GRID
═══════════════════════════════════════ */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
@media(max-width:992px){.svc-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:576px){.svc-grid{grid-template-columns:1fr;}}

.svc-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(123,47,255,.18);
  border-radius:18px;padding:30px 26px;
  position:relative;overflow:hidden;
  transition:transform .3s,background .3s,border-color .3s,box-shadow .3s;
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--grad);opacity:0;transition:opacity .3s;
}
.svc-card:hover{transform:translateY(-6px);background:rgba(123,47,255,.08);border-color:rgba(123,47,255,.38);box-shadow:0 16px 48px rgba(123,47,255,.2);}
.svc-card:hover::before{opacity:1;}
.svc-ico{font-size:1.7rem;margin-bottom:16px;display:block;}
.svc-card h5{font-family:'Raleway',sans-serif;font-weight:800;font-size:.97rem;color:#fff;margin-bottom:8px;}
.svc-card p{font-size:.85rem;color:rgba(255,255,255,.56);line-height:1.68;margin:0;}

/* ═══════════════════════════════════════
   PROCESSUS
═══════════════════════════════════════ */
.idev-process{
  background:var(--grad3);padding:80px 0;position:relative;overflow:hidden;
}
.idev-process::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:50px 50px;
}

.process-row{
  display:flex;gap:0;position:relative;z-index:1;
}
.process-row::before{
  content:'';position:absolute;
  top:27px;left:calc(8.33% + 28px);right:calc(8.33% + 28px);
  height:1px;background:rgba(255,255,255,.16);
}
.p-step{flex:1;text-align:center;padding:0 10px;}
.p-num{
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.22);
  color:#fff;font-family:'Raleway',sans-serif;font-weight:900;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;
  transition:background .3s,border-color .3s;
}
.p-step:hover .p-num{background:var(--vb);border-color:var(--vl);}
.p-step h6{font-family:'Raleway',sans-serif;font-weight:800;font-size:.88rem;color:#fff;margin-bottom:6px;}
.p-step p{font-size:.77rem;color:rgba(255,255,255,.55);line-height:1.6;margin:0;}

@media(max-width:768px){
  .process-row{flex-direction:column;gap:28px;}
  .process-row::before{display:none;}
}

/* ═══════════════════════════════════════
   COMPTEURS
═══════════════════════════════════════ */
.idev-counters{background:linear-gradient(135deg,#0A0514 0%,#150B2E 100%);}
.cnt-row{display:flex;}
.cnt{
  flex:1;text-align:center;padding:48px 20px;
  border-right:1px solid rgba(123,47,255,.12);
}
.cnt:last-child{border-right:none;}
.cnt strong{
  display:block;font-family:'Raleway',sans-serif;font-weight:900;font-size:2.5rem;
  background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:6px;
}
.cnt span{font-size:.8rem;color:rgba(255,255,255,.48);letter-spacing:.06em;text-transform:uppercase;}

@media(max-width:600px){
  .cnt-row{flex-wrap:wrap;}
  .cnt{flex:1 0 50%;border:none;border-bottom:1px solid rgba(123,47,255,.1);}
}

/* ═══════════════════════════════════════
   TÉMOIGNAGES
═══════════════════════════════════════ */
.testi-card{
  background:#fff;border-radius:18px;padding:28px 26px;
  border:1px solid rgba(123,47,255,.1);
  box-shadow:0 4px 24px rgba(123,47,255,.06);
  height:100%;position:relative;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.testi-card::before{
  content:'"';position:absolute;top:14px;right:22px;
  font-size:4rem;line-height:1;color:rgba(123,47,255,.08);font-family:Georgia,serif;
}
.testi-card:hover{transform:translateY(-5px);box-shadow:0 16px 50px rgba(123,47,255,.14);border-color:rgba(123,47,255,.24);}
.stars{color:#f59e0b;font-size:.85rem;margin-bottom:14px;}
.testi-card p{font-size:.88rem;color:#555;line-height:1.72;margin-bottom:20px;}
.testi-foot{display:flex;align-items:center;gap:12px;border-top:1px solid #f0eeff;padding-top:16px;}
.testi-av{
  width:42px;height:42px;border-radius:50%;
  background:var(--grad);color:#fff;
  font-family:'Raleway',sans-serif;font-weight:800;font-size:1rem;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.testi-name{font-family:'Raleway',sans-serif;font-weight:700;font-size:.88rem;color:#1a0035;}
.testi-role{font-size:.76rem;color:var(--vb);font-weight:500;}

/* ═══════════════════════════════════════
   TARIFS
═══════════════════════════════════════ */
.plans-row{display:flex;gap:24px;align-items:stretch;}
@media(max-width:992px){.plans-row{flex-direction:column;}}

.plan{
  flex:1;background:#fff;border-radius:20px;
  border:1px solid rgba(123,47,255,.12);padding:36px 30px;
  transition:transform .3s,box-shadow .3s,border-color .3s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.plan:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(123,47,255,.14);border-color:rgba(123,47,255,.32);}
.plan.featured{
  background:linear-gradient(160deg,rgba(123,47,255,.07) 0%,rgba(59,91,255,.04) 100%);
  border-color:rgba(123,47,255,.32);box-shadow:0 12px 48px rgba(123,47,255,.13);
}
.plan-badge{
  position:absolute;top:18px;right:18px;
  background:var(--grad);color:#fff;
  font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 12px;border-radius:100px;
}
.plan-name{font-family:'Raleway',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--vb);margin-bottom:10px;}
.plan-price{font-family:'Raleway',sans-serif;font-size:1.1rem;color:#555;margin-bottom:4px;}
.plan-price strong{font-size:1.9rem;font-weight:900;color:#1a0035;}
.plan-note{font-size:.79rem;color:#999;margin-bottom:24px;}
.plan-list{
  list-style:none;padding:0;margin:0 0 28px;
  display:flex;flex-direction:column;gap:10px;
  border-top:1px solid #f0eeff;padding-top:20px;
  flex:1;
}
.plan-list li{display:flex;align-items:center;gap:10px;font-size:.87rem;color:#444;}
.plan-list li::before{
  content:'✓';width:20px;height:20px;border-radius:50%;
  background:rgba(123,47,255,.1);color:var(--vb);
  font-size:.64rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}

/* ═══════════════════════════════════════
   CONTACT
═══════════════════════════════════════ */
.contact-wrap{
  background:#fff;border-radius:24px;overflow:hidden;
  box-shadow:0 20px 80px rgba(123,47,255,.11);
  border:1px solid rgba(123,47,255,.1);
}
.contact-left{
  background:var(--grad2);padding:50px 40px;height:100%;
  position:relative;overflow:hidden;
}
.contact-left::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
}
.contact-left h3{font-family:'Raleway',sans-serif;font-weight:800;font-size:1.5rem;color:#fff;margin-bottom:10px;position:relative;}
.contact-left>p{color:rgba(255,255,255,.68);font-size:.9rem;line-height:1.7;margin-bottom:36px;position:relative;}
.c-infos{display:flex;flex-direction:column;gap:20px;position:relative;}
.c-info{display:flex;align-items:center;gap:14px;}
.c-ico{
  width:42px;height:42px;border-radius:10px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.95rem;flex-shrink:0;
}
.c-info small{display:block;font-size:.68rem;color:rgba(255,255,255,.45);margin-bottom:2px;text-transform:uppercase;letter-spacing:.06em;}
.c-info a{color:#fff;font-weight:600;font-size:.9rem;text-decoration:none;transition:opacity .2s;}
.c-info a:hover{opacity:.8;}
.c-socials{display:flex;gap:10px;margin-top:36px;position:relative;}
.c-socials a{
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  color:#fff;text-decoration:none;font-size:.9rem;
  transition:background .2s,transform .2s;
}
.c-socials a:hover{background:rgba(255,255,255,.22);transform:translateY(-2px);}

.contact-right{padding:48px 44px;}
.fg{margin-bottom:16px;}
.fg label{display:block;font-size:.8rem;font-weight:600;color:#3a3a5c;margin-bottom:6px;letter-spacing:.03em;}
.fg input,.fg select,.fg textarea{
  width:100%;background:#f7f4ff;
  border:1px solid rgba(123,47,255,.14);border-radius:10px;
  padding:12px 16px;
  font-family:'DM Sans',sans-serif;font-size:.9rem;color:#222;
  outline:none;transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--vb);box-shadow:0 0 0 3px rgba(123,47,255,.1);background:#fff;
}
.fg textarea{resize:vertical;min-height:120px;}
.form-note{font-size:.74rem;color:#aaa;text-align:center;margin:6px 0 0;}

@media(max-width:768px){
  .contact-left,.contact-right{padding:36px 28px;}
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
.idev-footer{
  background:#0A0514;
  border-top:1px solid rgba(123,47,255,.12);
  padding:64px 0 30px;
}
.f-brand{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
.f-tagline{font-size:.86rem;color:rgba(255,255,255,.4);line-height:1.65;max-width:280px;margin-bottom:22px;}
.f-socials{display:flex;gap:10px;}
.f-socials a{
  width:36px;height:36px;border-radius:9px;
  background:rgba(123,47,255,.1);border:1px solid rgba(123,47,255,.2);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.55);text-decoration:none;font-size:.85rem;
  transition:background .2s,color .2s,transform .2s;
}
.f-socials a:hover{background:var(--vb);color:#fff;transform:translateY(-2px);}

.f-nav-title{font-family:'Raleway',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);margin-bottom:16px;}
.f-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.f-nav a{color:rgba(255,255,255,.5);text-decoration:none;font-size:.87rem;transition:color .2s;}
.f-nav a:hover{color:var(--vl);}
.f-nav i{margin-right:8px;opacity:.45;font-size:.78rem;}

.f-bottom{
  border-top:1px solid rgba(123,47,255,.1);
  margin-top:48px;padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
}
.f-bottom p{font-size:.78rem;color:rgba(255,255,255,.25);margin:0;}

/* ═══════════════════════════════════════
   PAGE HERO (pages intérieures)
═══════════════════════════════════════ */
.page-hero {
  min-height: 340px;
  background: url('/images/hero-bg.jpg') center center / cover no-repeat;
  position: relative;
  display: flex;
  align-items: center;
  padding: 110px 0 70px;
}
.page-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(10,5,20,.92) 0%, rgba(58,13,110,.82) 50%, rgba(59,91,255,.55) 100%);
  z-index: 1;
}
.page-hero-grid {
  position: absolute; inset: 0; z-index: 1;
  background-image:
    linear-gradient(rgba(123,47,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(123,47,255,.07) 1px, transparent 1px);
  background-size: 60px 60px;
}
.page-hero-title {
  font-family: 'Raleway', sans-serif;
  font-weight: 800;
  font-size: clamp(1.9rem, 4vw, 3rem);
  color: #fff; line-height: 1.2;
  margin: 12px 0 16px;
}
.page-hero-desc {
  color: rgba(255,255,255,.78);
  font-size: 1rem; line-height: 1.75;
  max-width: 540px; margin: 0 auto 28px;
}

/* Breadcrumb */
.breadcrumb-custom {
  list-style: none; padding: 0; margin: 0;
  display: flex; align-items: center; gap: 8px;
  font-size: .8rem; color: rgba(255,255,255,.5);
}
.breadcrumb-custom a { color: rgba(255,255,255,.6); text-decoration: none; transition: color .2s; }
.breadcrumb-custom a:hover { color: #fff; }
.breadcrumb-custom .sep { color: rgba(255,255,255,.3); }
.breadcrumb-custom li:last-child { color: var(--vl); }

/* ═══════════════════════════════════════
   SERVICE BLOCKS (page services)
═══════════════════════════════════════ */
.srv-img-wrap {
  background: linear-gradient(135deg, #f4eeff 0%, #e8dcff 100%);
  border-radius: 24px;
  display: flex; align-items: center; justify-content: center;
  min-height: 320px;
  border: 1px solid rgba(123,47,255,.12);
  box-shadow: 0 12px 40px rgba(123,47,255,.1);
}
.sec-dark .srv-img-wrap {
  background: rgba(255,255,255,.05);
  border-color: rgba(123,47,255,.2);
}
.srv-icon-big { font-size: 5rem; }

.srv-list {
  list-style: none; padding: 0;
  display: flex; flex-direction: column; gap: 14px;
}
.srv-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: .92rem; color: #444; line-height: 1.6;
}
.srv-list li strong { color: #1a0035; }
.sec-dark .srv-list li { color: rgba(255,255,255,.7); }
.sec-dark .srv-list li strong { color: #fff; }

/* ═══════════════════════════════════════
   CONTACT PAGE
═══════════════════════════════════════ */
.contact-form-title {
  font-family: 'Raleway', sans-serif;
  font-weight: 800; font-size: 1.3rem;
  color: #1a0035; margin-bottom: 24px;
}
.c-guarantees {
  margin-top: 28px; position: relative;
  display: flex; flex-direction: column; gap: 10px;
}
.c-guar {
  font-size: .83rem; color: rgba(255,255,255,.65);
  display: flex; align-items: center; gap: 8px;
}
.c-guar i { color: #9D5CFF; font-size: .75rem; }

/* Alerts */
.alert-success-box, .alert-error-box {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 20px 24px; border-radius: 14px;
  margin-bottom: 32px; font-size: .92rem; line-height: 1.6;
}
.alert-success-box {
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.25); color: #166534;
}
.alert-error-box {
  background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.25); color: #991b1b;
}
.alert-ico { font-size: 1.4rem; flex-shrink: 0; margin-top: 2px; }
.alert-success-box strong, .alert-error-box strong { display: block; margin-bottom: 4px; }

/* FAQ */
.faq-list { display: flex; flex-direction: column; gap: 14px; }
.faq-item {
  background: #fff; border: 1px solid rgba(123,47,255,.1);
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 2px 12px rgba(123,47,255,.05);
  transition: box-shadow .3s, border-color .3s;
}
.faq-item:hover { border-color: rgba(123,47,255,.25); box-shadow: 0 6px 24px rgba(123,47,255,.1); }
.faq-q {
  padding: 18px 22px;
  font-family: 'Raleway', sans-serif; font-weight: 700;
  font-size: .95rem; color: #1a0035;
  display: flex; align-items: center; gap: 12px;
}
.faq-q i { color: var(--vb); font-size: .9rem; flex-shrink: 0; }
.faq-a {
  padding: 0 22px 18px 44px;
  font-size: .88rem; color: #555; line-height: 1.72;
}



/* Centrer les feat-icon si mx-auto */
.feat-icon.mx-auto { margin-left: auto; margin-right: auto; }

/* mt utilitaires */
.mt-4 { margin-top: 20px !important; }
.mt-5 { margin-top: 32px !important; }
.d-inline-block { display: inline-block; }
.text-center { text-align: center; }
.h-100 { height: 100%; }
.flex-row-reverse { flex-direction: row-reverse; }
@media(max-width:992px){ .flex-row-reverse { flex-direction: row !important; } }

/* ═══════════════════════════════════════
   PRESTATIONS CARDS (page tarifs)
═══════════════════════════════════════ */
.prestation-card {
  background: #fff;
  border: 1px solid rgba(123,47,255,.1);
  border-radius: 18px;
  padding: 28px 22px;
  text-align: center;
  height: 100%;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.prestation-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 48px rgba(123,47,255,.13);
  border-color: rgba(123,47,255,.28);
}
.prestation-ico { font-size: 2.2rem; margin-bottom: 14px; display: block; }
.prestation-card h5 {
  font-family: 'Raleway', sans-serif; font-weight: 800;
  font-size: .95rem; color: #1a0035; margin-bottom: 6px;
}
.prestation-price {
  font-family: 'Raleway', sans-serif; font-weight: 700;
  color: var(--vb); font-size: .9rem; margin-bottom: 8px;
}
.prestation-card p { font-size: .82rem; color: #777; line-height: 1.65; margin: 0; }

/* Fix plans-row boutons full width */
.plan .btn-vp, .plan .btn-outline {
  display: block !important;
  width: 100% !important;
  text-align: center;
  margin-top: auto;
}
.plan { display: flex; flex-direction: column; }
.plan-list { flex: 1; }

/* Fix btn-outline color dans plan */
.plan .btn-outline { color: var(--vb) !important; }
