/* ============================================================
   AGRH CONSULTING SARL — Stylesheet v4
   Charte : #17477E (navy) · #3BA9E0 (blue) · #85929E (steel) · #E5E5E5 (gray)
   Polices : Montserrat (titres) + Source Sans 3 (corps)
   RÈGLE D'OR : Fond sombre → texte blanc. Fond clair → texte navy/body.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,400;0,600;0,700;0,800;1,400&family=Source+Sans+3:wght@300;400;500;600;700&display=swap');

:root {
  --navy:        #17477E;
  --navy-deep:   #0f2f56;
  --navy-mid:    #1a5499;
  --blue:        #3BA9E0;
  --blue-light:  #6ac1ea;
  --blue-pale:   #d6eef8;
  --steel:       #85929E;
  --light-bg:    #F4F7FB;
  --border:      #E0E8F0;
  --white:       #FFFFFF;
  --text-dark:   #17477E;
  --text-body:   #374151;
  --text-muted:  #6B7A8D;
  --font-head:   'Montserrat', sans-serif;
  --font-body:   'Source Sans 3', sans-serif;
  --radius:      8px;
  --radius-lg:   16px;
  --transition:  0.3s cubic-bezier(0.4,0,0.2,1);
  --shadow-sm:   0 2px 12px rgba(23,71,126,0.08);
  --shadow-md:   0 8px 32px rgba(23,71,126,0.12);
  --shadow-lg:   0 20px 60px rgba(23,71,126,0.18);
  --shadow-blue: 0 8px 32px rgba(59,169,224,0.30);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{font-family:var(--font-body);color:var(--text-body);background:var(--white);line-height:1.75;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}

h1,h2,h3,h4,h5{font-family:var(--font-head);line-height:1.2;font-weight:700;color:var(--navy);}
h1{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;}
h2{font-size:clamp(1.7rem,3.5vw,2.6rem);}
h3{font-size:clamp(1.1rem,2vw,1.4rem);}
h4{font-size:1.05rem;}
p{font-size:1rem;line-height:1.8;}

/* SECTION LABEL — couleur selon contexte */
.section-label{font-family:var(--font-body);font-size:0.72rem;font-weight:700;letter-spacing:0.22em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:10px;margin-bottom:0.8rem;}
.gold-line{display:inline-block;width:36px;height:2px;background:var(--blue);flex-shrink:0;}

/* Sur fonds sombres, les section-labels deviennent bleu clair */
.services-bg .section-label,
.testimonials-bg .section-label,
.cta-banner .section-label,
.formation-ligne-section .section-label,
.hero .section-label{color:var(--blue-light)!important;}

.services-bg .gold-line,
.testimonials-bg .gold-line,
.cta-banner .gold-line,
.formation-ligne-section .gold-line{background:var(--blue-light)!important;}

/* H2/H3 sur fonds sombres → blanc */
.services-bg h2,.services-bg h3,
.testimonials-bg h2,.testimonials-bg h3,
.cta-banner h2,.cta-banner p,
.formation-ligne-section h2,.formation-ligne-section h3{color:var(--white)!important;}

.services-bg .section-header p,
.testimonials-bg .section-header p,
.formation-ligne-section .section-header p{color:rgba(255,255,255,0.88)!important;}

/* Layout */
.container{max-width:1180px;margin:0 auto;padding:0 2rem;}
section{padding:90px 0;}
.section-header{text-align:center;max-width:680px;margin:0 auto 64px;}
.section-header p{color:var(--text-muted);font-size:1.05rem;margin-top:1rem;}

/* Boutons */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.85rem 2rem;border-radius:var(--radius);font-family:var(--font-body);font-size:0.9rem;font-weight:600;letter-spacing:0.04em;cursor:pointer;border:2px solid transparent;transition:var(--transition);white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--navy-mid));color:var(--white);box-shadow:var(--shadow-blue);}
.btn-primary:hover{background:linear-gradient(135deg,var(--navy-mid),var(--navy));box-shadow:0 12px 40px rgba(59,169,224,0.45);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,0.75);}
.btn-outline:hover{background:rgba(255,255,255,0.12);border-color:var(--white);}
.btn-navy{background:var(--navy);color:var(--white);box-shadow:var(--shadow-md);}
.btn-navy:hover{background:var(--navy-deep);transform:translateY(-2px);}
.btn-white{background:var(--white);color:var(--navy);font-weight:700;}
.btn-white:hover{background:var(--blue-pale);transform:translateY(-2px);}

/* ── NAVIGATION ── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:1.2rem 0;transition:var(--transition);background:transparent;}
.navbar.scrolled{background:var(--navy-deep);padding:0.75rem 0;box-shadow:0 4px 32px rgba(15,47,86,0.35);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1180px;margin:0 auto;padding:0 2rem;}
.nav-logo img{height:40px;width:auto;background:#fff;padding:4px 8px;border-radius:6px;}
.nav-links{display:flex;align-items:center;gap:1.4rem;flex-wrap:nowrap;}
.nav-links a{font-family:var(--font-body);font-size:0.82rem;font-weight:500;color:rgba(255,255,255,0.85);transition:color var(--transition);position:relative;white-space:nowrap;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:2px;background:var(--blue);transform:scaleX(0);transition:transform var(--transition);border-radius:1px;}
.nav-links a:hover,.nav-links a.active{color:var(--blue-light);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-cta{background:linear-gradient(135deg,var(--blue),var(--navy-mid))!important;color:var(--white)!important;padding:0.5rem 1.2rem;border-radius:var(--radius);font-weight:700!important;font-size:0.8rem!important;box-shadow:0 4px 16px rgba(59,169,224,0.30);}
.nav-cta:hover{box-shadow:0 8px 24px rgba(59,169,224,0.45)!important;transform:translateY(-1px)!important;}
.nav-cta::after{display:none!important;}
.nav-badge-new{background:var(--blue);color:var(--white);font-size:0.5rem;padding:1px 5px;border-radius:3px;font-weight:700;letter-spacing:0.05em;vertical-align:middle;margin-left:2px;text-transform:uppercase;}
.nav-lang{display:flex;align-items:center;gap:0.3rem;}
.nav-lang a{font-size:0.72rem!important;font-weight:600!important;padding:0.25rem 0.5rem;border-radius:3px;color:rgba(255,255,255,0.85)!important;}
.nav-lang a.active,.nav-lang a:hover{color:var(--blue-light)!important;background:rgba(59,169,224,0.12);}
.nav-lang a::after{display:none!important;}
.nav-lang span{color:rgba(255,255,255,0.75);font-size:0.65rem;}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;padding:6px;background:none;border:none;width:36px;height:36px;position:relative;z-index:1001;}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;position:absolute;left:50%;transform:translateX(-50%);transition:top 0.3s ease 0.1s,transform 0.35s cubic-bezier(0.23,1,0.32,1),opacity 0.25s ease;}
.hamburger span:nth-child(1){top:10px;}
.hamburger span:nth-child(2){top:17px;}
.hamburger span:nth-child(3){top:24px;}
.hamburger.open span{transition:top 0.3s ease,transform 0.35s cubic-bezier(0.23,1,0.32,1) 0.1s,opacity 0.25s ease;}
.hamburger.open span:nth-child(1){top:17px;transform:translateX(-50%) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:translateX(-50%) scaleX(0);}
.hamburger.open span:nth-child(3){top:17px;transform:translateX(-50%) rotate(-45deg);}

/* ── HERO ACCUEIL ── */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 55%,var(--navy-mid) 100%);overflow:hidden;}
.hero-bg{position:absolute;inset:0;background-image:url('../images/realisations/hero-bg-accueil.jpeg');background-size:cover;background-position:center;opacity:0.22;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(115deg,rgba(15,47,86,0.97) 0%,rgba(23,71,126,0.88) 55%,rgba(26,84,153,0.55) 100%);}
.hero-pattern{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(59,169,224,0.14) 0%,transparent 55%),radial-gradient(ellipse at 10% 80%,rgba(59,169,224,0.10) 0%,transparent 45%);pointer-events:none;}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(59,169,224,0.12) 0%,transparent 65%);animation:orbeFloat 10s ease-in-out infinite;pointer-events:none;z-index:1;}
.hero::after{content:'';position:absolute;bottom:-150px;left:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(59,169,224,0.08) 0%,transparent 65%);animation:orbeFloat 14s ease-in-out infinite reverse;pointer-events:none;z-index:1;}
.hero-content{position:relative;z-index:2;width:100%;max-width:1180px;margin:0 auto;padding:140px 2rem 100px;display:grid;grid-template-columns:1.15fr 0.85fr;gap:5rem;align-items:center;}
.hero-text{animation:fadeSlideUp 0.8s ease both;}
.hero-tagline{font-family:var(--font-body);font-size:0.72rem;font-weight:700;color:var(--blue-light);letter-spacing:0.30em;text-transform:uppercase;display:flex;align-items:center;gap:12px;margin-bottom:1.5rem;animation:fadeSlideUp 0.7s 0.1s ease both;}
.hero-tagline::before{content:'';width:40px;height:2px;background:var(--blue);flex-shrink:0;}
.hero-title{color:var(--white);font-size:clamp(2.6rem,5vw,4rem);font-weight:800;line-height:1.08;letter-spacing:-0.025em;margin-bottom:1.8rem;animation:fadeSlideUp 0.7s 0.2s ease both;}
.hero-title em{color:var(--blue);font-style:normal;position:relative;}
.hero-title em::after{content:'';position:absolute;bottom:2px;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),transparent);border-radius:2px;}
.hero-desc{color:rgba(255,255,255,0.78);font-size:1.08rem;line-height:1.9;max-width:520px;margin-bottom:2.5rem;animation:fadeSlideUp 0.7s 0.3s ease both;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;animation:fadeSlideUp 0.7s 0.4s ease both;}
.hero-stats{display:flex;gap:2.5rem;margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid rgba(59,169,224,0.20);animation:fadeSlideUp 0.7s 0.55s ease both;}
.stat{display:flex;flex-direction:column;}
.stat-num{font-family:var(--font-head);font-size:2.4rem;font-weight:800;color:var(--blue);line-height:1;}
.stat-label{font-size:0.72rem;color:rgba(255,255,255,0.82);letter-spacing:0.06em;text-transform:uppercase;margin-top:0.35rem;}
.hero-visual{animation:fadeSlideIn 0.9s 0.35s ease both;position:relative;}
.hero-card{background:rgba(255,255,255,0.06);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(59,169,224,0.22);border-radius:var(--radius-lg);padding:2rem;position:relative;box-shadow:0 32px 80px rgba(15,47,86,0.45);}
.hero-card::before{content:'';position:absolute;top:0;left:15%;right:15%;height:1px;background:linear-gradient(90deg,transparent,rgba(59,169,224,0.70),transparent);}
.hero-card-img{border-radius:var(--radius);overflow:hidden;height:320px;box-shadow:0 12px 40px rgba(15,47,86,0.35);}
.hero-card-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform 0.8s ease;}
.hero-card-img img:hover{transform:scale(1.04);}
.hero-badge{position:absolute;bottom:-18px;left:-18px;background:linear-gradient(135deg,var(--blue),var(--navy-mid));color:var(--white);padding:1.1rem 1.5rem;border-radius:10px;font-family:var(--font-head);font-weight:800;text-align:center;box-shadow:0 12px 36px rgba(59,169,224,0.45);border:1px solid rgba(255,255,255,0.15);}
.hero-badge strong{display:block;font-size:1.9rem;line-height:1;}
.hero-badge span{font-size:0.65rem;font-family:var(--font-body);font-weight:500;opacity:0.9;letter-spacing:0.06em;text-transform:uppercase;}
.hero-card::after{content:"10+ ans d'expertise RH";position:absolute;top:-16px;right:16px;background:var(--navy-deep);color:rgba(255,255,255,0.90);padding:0.5rem 1rem;border-radius:6px;font-family:var(--font-body);font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;border:1px solid rgba(59,169,224,0.30);box-shadow:0 6px 20px rgba(15,47,86,0.30);white-space:nowrap;}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:0.5rem;color:rgba(255,255,255,0.75);font-size:0.65rem;letter-spacing:0.20em;text-transform:uppercase;cursor:pointer;transition:color var(--transition);animation:fadeSlideUp 0.8s 1s ease both;}
.hero-scroll:hover{color:var(--blue);}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(59,169,224,0.6),transparent);animation:scrollDown 2.5s ease-in-out infinite;}

/* ── PAGE-HERO (pages internes) ── */
.page-hero{position:relative;background:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 60%,var(--navy-mid) 100%);padding:155px 0 90px;text-align:center;overflow:hidden;}
.page-hero::before{content:'';position:absolute;inset:0;background-image:url('../images/realisations/hero-bg-pages.jpeg');background-size:cover;background-position:center;opacity:0.16;}
.page-hero::after{content:'';position:absolute;top:-120px;right:8%;width:450px;height:450px;border-radius:50%;background:radial-gradient(circle,rgba(59,169,224,0.16) 0%,transparent 65%);animation:orbeFloat 12s ease-in-out infinite;pointer-events:none;}
.page-hero .container{position:relative;z-index:2;}
.page-hero h1{color:var(--white);font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;letter-spacing:-0.02em;animation:fadeSlideUp 0.7s ease both;}
.page-hero p{color:rgba(255,255,255,0.72);max-width:580px;margin:1.2rem auto 0;font-size:1.05rem;line-height:1.8;animation:fadeSlideUp 0.7s 0.15s ease both;}
.page-hero-divider{width:70px;height:3px;background:linear-gradient(90deg,var(--blue),rgba(59,169,224,0.2));margin:1.8rem auto 0;border-radius:2px;}
.breadcrumb{display:flex;justify-content:center;align-items:center;gap:0.5rem;margin-bottom:1.5rem;font-size:0.8rem;position:relative;z-index:2;animation:fadeSlideUp 0.6s ease both;}
.breadcrumb a{color:rgba(255,255,255,0.85);transition:color var(--transition);}
.breadcrumb a:hover{color:var(--blue-light);}
.breadcrumb .sep{color:rgba(255,255,255,0.75);}
.breadcrumb .current{color:var(--blue-light);font-weight:600;}

/* ── ABOUT STRIP ── */
.about-strip{background:var(--light-bg);padding:3rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.strip-inner{display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap;}
.strip-text h3{color:var(--navy);font-size:1.2rem;margin-bottom:0.5rem;}
.strip-text p{color:var(--text-body);max-width:440px;font-size:0.95rem;}
.strip-logos{display:flex;flex-wrap:wrap;gap:1rem;}
.strip-logo-item{display:flex;align-items:center;gap:0.5rem;color:var(--navy);font-size:0.85rem;font-weight:600;background:var(--white);padding:0.5rem 1rem;border-radius:6px;border:1px solid var(--border);box-shadow:var(--shadow-sm);}
.strip-logo-item i{color:var(--blue);}

/* ── SERVICES FOND SOMBRE ── */
.services-bg{background:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 100%);}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.service-card{background:rgba(255,255,255,0.05);border:1px solid rgba(59,169,224,0.16);border-radius:var(--radius-lg);padding:2rem;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);}
.service-card:hover{transform:translateY(-6px);border-color:rgba(59,169,224,0.40);box-shadow:0 24px 60px rgba(15,47,86,0.40);}
.service-num{font-family:var(--font-head);font-size:2.8rem;font-weight:800;color:rgba(59,169,224,0.22);line-height:1;margin-bottom:0.8rem;}
.service-icon{width:48px;height:48px;background:rgba(59,169,224,0.14);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.2rem;color:var(--blue);font-size:1.3rem;}
.service-card h3{color:var(--white);font-size:1.05rem;margin-bottom:0.8rem;}
.service-card p{color:rgba(255,255,255,0.85);font-size:0.9rem;line-height:1.75;}
.service-link{display:inline-flex;align-items:center;gap:0.4rem;color:var(--blue-light);font-size:0.82rem;font-weight:600;margin-top:1.2rem;transition:gap var(--transition),color var(--transition);}
.service-link:hover{gap:0.7rem;color:var(--white);}
.service-illustration{display:none;}

/* ── WHY US ── */
.whyus-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.whyus-text h2{color:var(--navy);margin-bottom:1.2rem;}
.whyus-text>p{color:var(--text-body);margin-bottom:2rem;}
.whyus-points{display:flex;flex-direction:column;gap:1.5rem;}
.point-item{display:flex;gap:1.2rem;align-items:flex-start;}
.point-num{font-family:var(--font-head);font-size:1rem;font-weight:800;color:var(--blue);background:var(--blue-pale);width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.point-content strong{display:block;color:var(--navy);font-weight:700;margin-bottom:0.25rem;}
.point-content span{color:var(--text-body);font-size:0.92rem;line-height:1.7;}
.whyus-visual{position:relative;}
.whyus-img-main{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg);}
.whyus-img-main img{width:100%;height:100%;object-fit:cover;object-position:top;}
.whyus-img-small{position:absolute;bottom:-20px;right:-20px;width:200px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);border:4px solid var(--white);}
.whyus-img-small img{width:100%;height:140px;object-fit:cover;object-position:top;}
.whyus-exp-badge{position:absolute;top:24px;right:-16px;background:linear-gradient(135deg,var(--blue),var(--navy-mid));color:var(--white);padding:1rem 1.3rem;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-blue);}
.whyus-exp-badge strong{display:block;font-size:1.6rem;font-family:var(--font-head);}
.whyus-exp-badge span{font-size:0.65rem;opacity:0.85;text-transform:uppercase;letter-spacing:0.08em;}

/* ── MV CARDS ── */
.mv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.mv-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;transition:transform var(--transition),box-shadow var(--transition);}
.mv-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);}
.mv-icon{width:56px;height:56px;background:var(--blue-pale);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 1.2rem;color:var(--blue);font-size:1.4rem;}
.mv-card h3{color:var(--navy);font-size:1rem;margin-bottom:0.7rem;}
.mv-card p{color:var(--text-body);font-size:0.88rem;line-height:1.7;}

/* ── RÉALISATIONS ── */
.realisations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}

/* ── PORTFOLIO ── */
.portfolio-filter{display:flex;gap:0.75rem;flex-wrap:wrap;margin-bottom:2.5rem;justify-content:center;}
.filter-btn{background:var(--white);border:1.5px solid var(--border);color:var(--text-dark);padding:0.5rem 1.2rem;border-radius:6px;font-family:var(--font-body);font-size:0.82rem;font-weight:600;cursor:pointer;transition:var(--transition);}
.filter-btn.active,.filter-btn:hover{background:var(--navy);color:var(--white);border-color:var(--navy);box-shadow:var(--shadow-md);}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.portfolio-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-sm);cursor:pointer;}
.portfolio-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;}
.portfolio-item:hover img{transform:scale(1.06);}
.portfolio-overlay{position:absolute;inset:0;background:linear-gradient(transparent 35%,rgba(15,47,86,0.93) 100%);padding:1.5rem;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity var(--transition);}
.portfolio-item:hover .portfolio-overlay{opacity:1;}
.portfolio-overlay span{color:var(--blue-light);font-size:0.68rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:0.4rem;}
.portfolio-overlay h4{color:var(--white);font-size:0.95rem;margin-bottom:0.4rem;}
.portfolio-overlay p{color:rgba(255,255,255,0.80);font-size:0.78rem;line-height:1.6;}

/* ── TESTIMONIALS ── */
.testimonials-bg{background:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 100%);}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.testimonial-card{background:rgba(255,255,255,0.07);border:1px solid rgba(59,169,224,0.18);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;gap:1rem;transition:transform var(--transition),box-shadow var(--transition);}
.testimonial-card:hover{transform:translateY(-5px);box-shadow:0 20px 60px rgba(15,47,86,0.40);}
.stars{color:#f59e0b;font-size:0.9rem;letter-spacing:2px;}
.quote-icon{font-size:3.5rem;font-family:Georgia,serif;color:var(--blue-light);line-height:0.8;opacity:0.60;margin-top:-0.5rem;}
.testimonial-text{color:rgba(255,255,255,0.80);font-size:0.92rem;line-height:1.8;flex:1;}
.testimonial-author{display:flex;align-items:center;gap:0.9rem;border-top:1px solid rgba(59,169,224,0.14);padding-top:1rem;margin-top:auto;}
.author-avatar{width:46px;height:46px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:1.1rem;font-weight:700;}
.author-avatar img{width:100%;height:100%;object-fit:cover;}
.author-info strong{display:block;color:var(--white);font-size:0.88rem;font-weight:700;}
.author-info span{color:var(--blue-light);font-size:0.78rem;}

/* ── FONDATEUR ── */
.fondateur-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}

/* ── CTA BANNER ── */
.cta-banner{background:linear-gradient(135deg,var(--blue) 0%,var(--navy) 100%);padding:90px 0;text-align:center;position:relative;overflow:hidden;}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 50%,rgba(255,255,255,0.07) 0%,transparent 60%),radial-gradient(ellipse at 20% 50%,rgba(255,255,255,0.05) 0%,transparent 60%);pointer-events:none;}
.cta-banner h2{color:var(--white);margin-bottom:1rem;}
.cta-banner p{color:rgba(255,255,255,0.80);max-width:580px;margin:0 auto 2.5rem;font-size:1.05rem;}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* ── FOOTER ── */
.footer{background:linear-gradient(160deg,var(--navy-deep) 0%,var(--navy) 100%);padding:70px 0 0;border-top:3px solid var(--blue);}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:3rem;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,0.08);}
.footer-logo img{height:36px;background:#fff;padding:3px 8px;border-radius:5px;margin-bottom:1.2rem;}
.footer-brand p{color:rgba(255,255,255,0.85);font-size:0.9rem;line-height:1.7;}
.footer-social{display:flex;gap:0.7rem;margin-top:1.5rem;}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,0.08);border:1px solid rgba(59,169,224,0.22);border-radius:8px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.85);font-size:0.9rem;transition:var(--transition);}
.footer-social a:hover{background:var(--blue);border-color:var(--blue);color:var(--white);}
.footer-col h5{color:var(--white);font-family:var(--font-head);font-size:0.78rem;letter-spacing:0.14em;text-transform:uppercase;margin-bottom:1.3rem;}
.footer-links{display:flex;flex-direction:column;gap:0.65rem;}
.footer-links a{color:rgba(255,255,255,0.85);font-size:0.88rem;transition:color var(--transition);}
.footer-links a:hover{color:var(--blue-light);}
.footer-contact-item{display:flex;align-items:flex-start;gap:0.7rem;color:rgba(255,255,255,0.85);font-size:0.88rem;margin-bottom:0.75rem;}
.footer-contact-item i{color:var(--blue);margin-top:3px;flex-shrink:0;}
.footer-contact-item a{color:rgba(255,255,255,0.72);}
.footer-contact-item a:hover{color:var(--blue-light);}
.footer-bottom{padding:1.5rem 0;}
.footer-legal{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;}
.footer-legal>p{color:rgba(255,255,255,0.90);font-size:0.80rem;}
.footer-legal-links{display:flex;gap:1.5rem;flex-wrap:wrap;}
.footer-legal-links a{color:rgba(255,255,255,0.85);font-size:0.80rem;transition:color var(--transition);}
.footer-legal-links a:hover{color:var(--blue-light);}
.footer-lang-switcher{display:flex;align-items:center;gap:0.5rem;}
.footer-lang-switcher a{display:inline-flex;align-items:center;gap:0.3rem;color:rgba(255,255,255,0.85);font-size:0.80rem;font-weight:500;padding:0.25rem 0.6rem;border-radius:4px;border:1px solid transparent;transition:var(--transition);}
.footer-lang-switcher a.active,.footer-lang-switcher a:hover{color:var(--white);border-color:rgba(59,169,224,0.35);background:rgba(59,169,224,0.12);}
.lang-sep{color:rgba(255,255,255,0.75);}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:4rem;align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:1.2rem;}
.contact-item{display:flex;align-items:flex-start;gap:1rem;background:var(--light-bg);padding:1.2rem;border-radius:var(--radius);border:1px solid var(--border);}
.contact-ic{width:44px;height:44px;background:var(--blue-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:1.1rem;flex-shrink:0;}
.contact-item h4{color:var(--navy);font-size:0.85rem;margin-bottom:0.2rem;}
.contact-item p,.contact-item a{color:var(--text-body);font-size:0.9rem;}
.contact-item a:hover{color:var(--blue);}
.contact-hours{background:var(--navy);border-radius:var(--radius-lg);padding:1.5rem;color:rgba(255,255,255,0.90);font-size:0.88rem;line-height:1.8;}
.contact-hours h4{color:var(--white);margin-bottom:0.8rem;}
.contact-form{background:var(--light-bg);border-radius:var(--radius-lg);padding:2.5rem;border:1px solid var(--border);}
.form-group{margin-bottom:1.3rem;}
.form-group label{display:block;color:var(--navy);font-size:0.85rem;font-weight:600;margin-bottom:0.5rem;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.8rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:0.92rem;color:var(--text-dark);background:var(--white);transition:border-color var(--transition);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,169,224,0.12);}
.form-group textarea{resize:vertical;min-height:140px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.form-submit{width:100%;padding:1rem;background:linear-gradient(135deg,var(--blue),var(--navy-mid));color:var(--white);border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:0.95rem;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-blue);}
.form-submit:hover{background:linear-gradient(135deg,var(--navy-mid),var(--navy));box-shadow:0 8px 32px rgba(59,169,224,0.40);transform:translateY(-2px);}

/* ── À PROPOS ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-img-wrap{position:relative;}
.about-img-main{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;box-shadow:var(--shadow-lg);}
.about-img-main img{width:100%;height:100%;object-fit:cover;object-position:top;}
.about-img-accent{position:absolute;bottom:-18px;right:-18px;width:180px;border-radius:var(--radius);overflow:hidden;border:4px solid var(--white);box-shadow:var(--shadow-md);}
.about-img-accent img{width:100%;height:130px;object-fit:cover;object-position:top;}
.about-gold-bar{width:60px;height:4px;background:var(--blue);border-radius:2px;margin-bottom:1.5rem;}
.about-text-block h2{color:var(--navy);margin-bottom:1.2rem;}
.about-text-block p{color:var(--text-body);margin-bottom:1rem;}
.about-values{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem;}
.value-item{display:flex;align-items:flex-start;gap:1rem;}
.value-icon{width:42px;height:42px;background:var(--blue-pale);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:1.1rem;flex-shrink:0;}
.value-text strong{display:block;color:var(--navy);font-weight:700;font-size:0.92rem;}
.value-text span{color:var(--text-body);font-size:0.88rem;line-height:1.65;}
.timeline-line{display:none;}

/* ── PARTENAIRES ── */
.partners-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.partner-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem 1.5rem;text-align:center;transition:transform var(--transition),box-shadow var(--transition);}
.partner-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.partner-logo{width:80px;height:80px;background:var(--light-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2rem;color:var(--blue);}
.partner-name{color:var(--navy);font-weight:700;font-size:0.95rem;margin-bottom:0.3rem;}
.partner-type{color:var(--text-muted);font-size:0.80rem;}

/* ── FORMATIONS ── */
.parcours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.parcours-card{background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);position:relative;}
.parcours-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--blue);}
.parcours-card.featured{border-color:var(--blue);box-shadow:var(--shadow-blue);}
.popular-tag{
  position:absolute;
  top:-14px; right:20px;
  background: linear-gradient(135deg, #e5a715, #c8890a);
  color:#fff;
  font-size:0.68rem;
  font-weight:800;
  padding:0.35rem 1rem;
  border-radius:20px;
  text-transform:uppercase;
  letter-spacing:0.10em;
  box-shadow: 0 4px 16px rgba(229,167,21,0.50);
  border: 1px solid rgba(255,255,255,0.20);
  white-space:nowrap;
  z-index:10;
}
.parcours-niveau{display:inline-block;font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.10em;color:var(--blue);background:var(--blue-pale);padding:0.25rem 0.7rem;border-radius:4px;margin-bottom:0.8rem;}
.parcours-card h3{color:var(--navy);font-size:1.05rem;margin-bottom:0.8rem;}
.parcours-card p{color:var(--text-body);font-size:0.88rem;line-height:1.7;margin-bottom:1rem;}
.parcours-duree{display:flex;align-items:center;gap:0.5rem;color:var(--steel);font-size:0.80rem;font-weight:600;}
.parcours-duree i{color:var(--blue);}
.parcours-items{margin-top:1.2rem;display:flex;flex-direction:column;gap:0.5rem;}
.parcours-items li{display:flex;align-items:flex-start;gap:0.6rem;color:var(--text-body);font-size:0.85rem;}
.parcours-items li i{color:var(--blue);margin-top:3px;flex-shrink:0;}
.formation-ligne-section{background:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 100%);}
.bonus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.bonus-item{background:rgba(255,255,255,0.06);border:1px solid rgba(59,169,224,0.18);border-radius:var(--radius-lg);padding:1.8rem;display:flex;flex-direction:column;gap:0.5rem;}
.bonus-item strong{color:var(--white);font-size:0.95rem;display:block;margin-bottom:0.3rem;}
.bonus-item span{color:rgba(255,255,255,0.90);font-size:0.85rem;line-height:1.55;display:block;}
.bonus-icon{width:48px;height:48px;background:rgba(59,169,224,0.14);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--blue-light);font-size:1.3rem;margin-bottom:1rem;}
.bonus-item h4{color:var(--white);margin-bottom:0.5rem;}
.bonus-item p{color:rgba(255,255,255,0.65);font-size:0.88rem;}
.avantage-item{display:flex;align-items:flex-start;gap:0.8rem;margin-bottom:1.2rem;padding:1rem 1.2rem;background:rgba(255,255,255,0.07);border:1px solid rgba(59,169,224,0.20);border-radius:10px;transition:background 0.2s;}
.avantage-item:hover{background:rgba(59,169,224,0.12);}
.avantage-item i{color:var(--blue-light);margin-top:4px;font-size:1.2rem;flex-shrink:0;min-width:24px;}
.avantage-item p{color:rgba(255,255,255,0.80);font-size:0.92rem;}
.avantage-item strong{color:#ffffff!important;font-size:0.95rem;font-family:var(--font-head);display:block;margin-bottom:0.2rem;font-weight:700;}
.avantage-item span{color:rgba(255,255,255,0.88)!important;font-size:0.84rem;line-height:1.55;display:block;}
.formation-avantages{display:grid;grid-template-columns:repeat(2,1fr);gap:0.8rem;}
.parcours-full-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
/* parcours-full-card styles → see formations section below */
.card-header-row{background:var(--navy);padding:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.5rem;}
.card-header-row h3{color:var(--white);font-size:1rem;}
.card-niveau-tag{background:rgba(59,169,224,0.20);color:var(--blue-light);font-size:0.68rem;font-weight:700;padding:0.3rem 0.7rem;border-radius:4px;text-transform:uppercase;}
.card-duree-big{font-size:0.80rem;color:rgba(255,255,255,0.85);display:flex;align-items:center;gap:0.4rem;}
.card-modules{padding:1.5rem;display:flex;flex-direction:column;gap:0.7rem;}
.card-objectif{display:flex;align-items:flex-start;gap:0.7rem;color:var(--text-body);font-size:0.88rem;}
.card-objectif i{color:var(--blue);margin-top:4px;flex-shrink:0;}
.card-footer-row{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;}
.attestation-tag{display:flex;align-items:center;gap:0.5rem;color:var(--blue);font-size:0.78rem;font-weight:600;}
.btn-inscrire-card{background:var(--blue);color:var(--white);border:none;padding:0.5rem 1.2rem;border-radius:6px;font-family:var(--font-body);font-size:0.80rem;font-weight:700;cursor:pointer;transition:var(--transition);text-decoration:none;display:inline-block;}
.btn-inscrire-card:hover{background:var(--navy);}
.inscription-section{background:var(--light-bg);}
.inscription-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start;}
.form-block{background:var(--white);border-radius:var(--radius-lg);padding:2.5rem;border:1px solid var(--border);box-shadow:var(--shadow-sm);}
.form-note{color:var(--text-muted);font-size:0.80rem;margin-top:0.7rem;display:flex;align-items:center;gap:0.4rem;}
.form-note i{color:var(--blue);}
.public-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.public-card{background:var(--light-bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.8rem;text-align:center;transition:transform var(--transition);}
.public-card:hover{transform:translateY(-4px);}
.public-card i{font-size:2rem;color:var(--blue);margin-bottom:1rem;}
.public-card h4{color:var(--navy);margin-bottom:0.5rem;}
.public-card p{color:var(--text-body);font-size:0.88rem;}
.pourquoi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.pourquoi-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem;transition:transform var(--transition),box-shadow var(--transition);}
.pourquoi-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}
.pourquoi-card>i{font-size:1.8rem;color:var(--blue);margin-bottom:1rem;}
.pourquoi-card h4{color:var(--navy);margin-bottom:0.5rem;}
.pourquoi-card p{color:var(--text-body);font-size:0.88rem;}
.question-card{background:var(--light-bg);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;}
.question-card h4{color:var(--navy);font-size:0.95rem;margin-bottom:0.5rem;display:flex;align-items:flex-start;gap:0.7rem;}
.question-card h4 i{color:var(--blue);flex-shrink:0;margin-top:2px;}
.question-card p{color:var(--text-body);font-size:0.88rem;padding-left:1.7rem;}
.wa-block{background:var(--navy);border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;gap:1rem;}
.wa-block h4{color:var(--white);}
.wa-block p{color:rgba(255,255,255,0.70);font-size:0.9rem;}
.wa-icon-big{font-size:2.5rem;color:#25D366;}
.wa-direct{display:inline-flex;align-items:center;gap:0.6rem;background:#25D366;color:var(--white);padding:0.8rem 1.5rem;border-radius:var(--radius);font-weight:700;font-size:0.9rem;transition:var(--transition);}
.wa-direct:hover{background:#1aab53;transform:translateY(-2px);}
.wa-number-display{color:var(--blue-light);font-size:0.9rem;font-weight:600;}
.feature-item{display:flex;align-items:flex-start;gap:0.8rem;margin-bottom:1rem;}
.feature-check{color:var(--blue);flex-shrink:0;margin-top:3px;}
.feature-item p{color:var(--text-body);font-size:0.92rem;}
.hero-stats-row{display:flex;flex-wrap:wrap;gap:2rem;margin-top:2rem;}
.hero-stat{text-align:center;}
.form-hero{background:rgba(255,255,255,0.06);border:1px solid rgba(59,169,224,0.20);border-radius:var(--radius-lg);padding:2rem;backdrop-filter:blur(10px);}
.form-hero .form-group label{color:rgba(255,255,255,0.85);}
.form-hero .form-group input,.form-hero .form-group select{background:rgba(255,255,255,0.10);border-color:rgba(59,169,224,0.25);color:var(--white);}
.form-hero .form-group input::placeholder{color:rgba(255,255,255,0.75);}
.form-hero-badge{display:flex;align-items:center;gap:0.6rem;color:rgba(255,255,255,0.65);font-size:0.82rem;margin-top:1rem;}
.form-hero-badge i{color:#25D366;}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:0.4rem;color:rgba(255,255,255,0.75);font-size:0.68rem;letter-spacing:0.15em;text-transform:uppercase;margin-top:2rem;}
.scroll-cue i{animation:scrollDown 2.5s ease-in-out infinite;}

/* ── SERVICE DÉTAIL ── */
.service-detail{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;padding:5rem 0;border-bottom:1px solid var(--border);}
.service-detail:last-child{border-bottom:none;}
.service-detail.reverse{direction:rtl;}
.service-detail.reverse>*{direction:ltr;}
.service-detail-img{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-md);}
.service-detail-img img{width:100%;height:100%;object-fit:cover;}
.service-detail-content h2{color:var(--navy);margin-bottom:1.2rem;}
.service-detail-content p{color:var(--text-body);margin-bottom:1.5rem;}
.service-features{display:flex;flex-direction:column;gap:0.8rem;}
.service-features li{display:flex;align-items:flex-start;gap:0.7rem;color:var(--text-body);font-size:0.92rem;}
.service-features li i{color:var(--blue);margin-top:4px;flex-shrink:0;}

/* ── LÉGALES ── */
.legal-page{padding:5rem 0;}
.legal-page h1{color:var(--navy);}
.last-update{color:var(--text-muted);font-size:0.85rem;margin-bottom:3rem;display:block;}
.legal-section{margin-bottom:2.5rem;}
.legal-section h2{font-size:1.15rem;color:var(--navy);margin-bottom:1rem;padding-bottom:0.5rem;border-bottom:2px solid var(--blue);display:inline-block;}
.legal-section p,.legal-section li{color:var(--text-body);line-height:1.8;margin-bottom:0.8rem;font-size:0.95rem;}
.legal-section ul{padding-left:1.5rem;list-style:disc;}
.legal-intro{background:var(--blue-pale);border-left:4px solid var(--blue);padding:1.2rem 1.5rem;border-radius:0 var(--radius) var(--radius) 0;margin-bottom:2.5rem;color:var(--navy);font-size:0.95rem;}
.data-table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:0.88rem;}
.data-table th{background:var(--navy);color:var(--white);padding:0.7rem 1rem;text-align:left;font-family:var(--font-head);font-size:0.82rem;}
.data-table td{padding:0.7rem 1rem;border-bottom:1px solid var(--border);color:var(--text-body);}
.data-table tr:hover td{background:var(--light-bg);}
.divider-or{text-align:center;position:relative;margin:1.5rem 0;color:var(--text-muted);font-size:0.8rem;}
.divider-or::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);}
.divider-or span{background:var(--white);padding:0 1rem;position:relative;}

/* ── WHATSAPP FLOAT ── */
.whatsapp-float{position:fixed;bottom:2rem;right:2rem;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--white);font-size:1.5rem;box-shadow:0 8px 32px rgba(37,211,102,0.45);z-index:999;transition:transform var(--transition),box-shadow var(--transition);}
.whatsapp-float:hover{transform:scale(1.12) translateY(-3px);box-shadow:0 16px 48px rgba(37,211,102,0.55);}
.whatsapp-float svg{width:26px;height:26px;fill:var(--white);}
.whatsapp-tooltip{position:absolute;right:68px;background:var(--white);color:var(--text-dark);padding:0.4rem 0.9rem;border-radius:6px;font-size:0.78rem;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity var(--transition);font-family:var(--font-body);}
.whatsapp-float:hover .whatsapp-tooltip{opacity:1;}
.scroll-top{position:fixed;bottom:6.5rem;right:2rem;width:44px;height:44px;background:var(--navy);color:var(--white);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;box-shadow:var(--shadow-md);opacity:0;transform:translateY(20px);transition:opacity var(--transition),transform var(--transition),background var(--transition);z-index:998;}
.scroll-top.visible{opacity:1;transform:translateY(0);}
.scroll-top:hover{background:var(--blue);}

/* ── TEAM ── */
.team-card{text-align:center;}
.team-photo{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/4;margin-bottom:1rem;box-shadow:var(--shadow-md);}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top;}
.team-info h4{color:var(--navy);margin-bottom:0.2rem;}
.role{color:var(--blue);font-size:0.82rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;}
.team-social{display:flex;justify-content:center;gap:0.5rem;margin-top:0.8rem;}
.team-social a{width:32px;height:32px;background:var(--blue-pale);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--blue);font-size:0.85rem;transition:var(--transition);}
.team-social a:hover{background:var(--blue);color:var(--white);}
.team-question-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}

/* ── ANIMATIONS ── */
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeSlideIn{from{opacity:0;transform:translateX(28px);}to{opacity:1;transform:translateX(0);}}
@keyframes orbeFloat{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(-25px,18px) scale(1.04);}66%{transform:translate(18px,-15px) scale(0.97);}}
@keyframes scrollDown{0%{opacity:0;transform:scaleY(0);transform-origin:top;}40%{opacity:1;}100%{opacity:0;transform:scaleY(1);transform-origin:top;}}

/* Reveal au scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.65s ease,transform 0.65s ease;}
.reveal.visible{opacity:1;transform:none;}
.reveal-delay-1{transition-delay:0.10s;}
.reveal-delay-2{transition-delay:0.22s;}
.reveal-delay-3{transition-delay:0.34s;}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;gap:3rem;padding:120px 2rem 80px;}
  .hero-visual{max-width:420px;margin:0 auto;}
  .hero-card::after{display:none;}
  .whyus-grid,.fondateur-grid,.about-grid{grid-template-columns:1fr;gap:3rem;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .testimonials-grid{grid-template-columns:repeat(2,1fr);}
  .partners-grid{grid-template-columns:repeat(2,1fr);}
  .mv-grid{grid-template-columns:1fr !important;}
  .service-detail{grid-template-columns:1fr;gap:2.5rem;}
  .service-detail.reverse{direction:ltr;}
  .contact-grid,.inscription-grid,.parcours-full-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem;}
}
@media(max-width:768px){
  section{padding:60px 0;}
  /* Grids → 1 colonne sur mobile */
  .services-grid,.testimonials-grid,.bonus-grid,.pourquoi-grid{grid-template-columns:1fr;}
  /* Grids qui restent en 2 colonnes (éléments assez larges) */
  .partners-grid,.public-grid{grid-template-columns:1fr 1fr;}
  .mv-grid,.team-question-grid{grid-template-columns:1fr !important;}
  .realisations-grid{grid-template-columns:1fr 1fr;}
  .portfolio-grid,.parcours-grid{grid-template-columns:1fr !important;}
  /* Formations — tout en 1 colonne */
  .parcours-full-grid{grid-template-columns:1fr !important;}
  .formation-avantages{grid-template-columns:1fr !important;}
  .inscription-grid{grid-template-columns:1fr !important;}
  /* À propos interventions 2→1 col */
  .about-interventions-grid{grid-template-columns:1fr 1fr !important;}
  /* Contact */
  .contact-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  /* Hero */
  .hero-stats{flex-wrap:wrap;gap:1.5rem;}
  .strip-inner{flex-direction:column;gap:1.5rem;}
  /* Footer */
  .footer-grid{grid-template-columns:1fr;}
  .footer-legal{flex-direction:column;align-items:flex-start;gap:0.8rem;}
  .cta-actions{flex-direction:column;align-items:center;}
  /* Nav mobile */
  .nav-links{display:none;}
  .hamburger{display:flex;}
  .nav-links.open{display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--navy-deep);justify-content:center;align-items:center;gap:2rem;z-index:999;}
  .nav-links.open a{font-size:1.1rem;color:var(--white);}
  .nav-links.open .nav-cta{font-size:1rem!important;padding:0.8rem 2rem;}
  /* Image galeries → 1 col */
  .galerie-grid,[style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr 1fr !important;}
}
@media(max-width:480px){
  .container{padding:0 1.2rem;}
  h1{font-size:2rem;}
  h2{font-size:1.6rem;}
  .hero-content{padding:110px 1.2rem 70px;}
  .page-hero{padding:130px 0 70px;}
  /* Tout en 1 colonne sur très petit écran */
  .realisations-grid,.portfolio-grid,.partners-grid,.mv-grid,.public-grid,
  .parcours-grid,.testimonials-grid,.public-grid,.team-question-grid,
  .about-interventions-grid{grid-template-columns:1fr !important;}
  /* Formations */
  .parcours-full-grid,.formation-avantages,.inscription-grid{grid-template-columns:1fr !important;}
  /* Services sur a-propos (grille 3 col inline) */
  .stat-num{font-size:1.8rem;}
  .footer-grid{gap:1.5rem;}
  /* Réduire les paddings des cartes parcours */
  .parcours-full-card{padding:2rem 1.5rem;}
  /* Stats bar */
  .stats-bar-inner{grid-template-columns:1fr 1fr !important;}
  /* Svc grid (index.html) */
  .svc-grid{grid-template-columns:1fr !important;}
  /* public-card images mobile */
  .public-card-img{height:120px !important;}
}

/* ══════════════════════════════════════════════════════════
   FORMATIONS — styles complémentaires (pas de CSS embarqué)
══════════════════════════════════════════════════════════ */

/* Hero formations (différent du page-hero standard) */
.form-hero {
  background: linear-gradient(145deg, var(--navy-deep) 0%, var(--navy) 55%, var(--navy-mid) 100%);
  position: relative;
  overflow: hidden;
  padding: 150px 0 90px;
  text-align: center;
}
.form-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url('../images/realisations/hero-bg-formations.jpeg');
  background-size: cover;
  background-position: center;
  opacity: 0.12;
}
.form-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, rgba(15,47,86,0.97) 0%, rgba(23,71,126,0.88) 60%, rgba(26,84,153,0.55) 100%);
}
.form-hero .container { position: relative; z-index: 1; }
.form-hero h1 {
  font-size: clamp(2rem, 5vw, 3.5rem);
  color: var(--white);
  line-height: 1.15;
  margin-bottom: 1.5rem;
  font-weight: 800;
}
.form-hero h1 em { color: var(--blue); font-style: normal; }
.form-hero p { color: rgba(255,255,255,0.72); max-width: 620px; margin: 0 auto 2.5rem; font-size: 1.05rem; }

/* Badge hero formations */
.form-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(59,169,224,0.40);
  border-radius: 30px;
  padding: 0.5rem 1.4rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--blue-light);
  margin-bottom: 2rem;
}

/* Stats row hero formations */
.hero-stats-row {
  display: flex;
  justify-content: center;
  gap: 3rem;
  margin-top: 3rem;
  flex-wrap: wrap;
  padding-top: 2.5rem;
  border-top: 1px solid rgba(59,169,224,0.18);
}
.hero-stat { text-align: center; }
.hero-stat strong {
  display: block;
  font-size: 2rem;
  font-family: var(--font-head);
  color: var(--blue);
  font-weight: 800;
  line-height: 1;
}
.hero-stat span {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.52);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 0.3rem;
  display: block;
}

/* Parcours full cards (fond navy) */
.parcours-full-card {
  background: var(--navy);
  border-radius: var(--radius-lg);
  padding: 2.5rem 2rem;
  position: relative;
  overflow: visible; /* ← important : laisse le badge popular-tag dépasser */
  border: 1px solid rgba(59,169,224,0.15);
  transition: var(--transition);
}
/* Accent coloré en haut de chaque carte selon le niveau */
.parcours-full-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: rgba(59,169,224,0.25);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  transition: background var(--transition);
}
/* Niveau 1 — Initiation : accent acier/discret */
.parcours-full-card:nth-child(1)::after { background: linear-gradient(90deg,#85929E,#b0bec5); }
/* Niveau 2 — Opérationnelle : accent bleu standard */
.parcours-full-card:nth-child(2)::after { background: linear-gradient(90deg,var(--blue),var(--blue-light)); }
/* Niveau 3 — Avancée : accent bleu vif + or (featured) */
.parcours-full-card:nth-child(3)::after { background: linear-gradient(90deg,var(--blue),#e5a715); height: 4px; }
/* Niveau 4 — Expert : accent dégradé navy→bleu premium */
.parcours-full-card:nth-child(4)::after { background: linear-gradient(90deg,#2a6099,var(--blue-light)); }

.parcours-full-card::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(59,169,224,0.06) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.parcours-full-card:hover {
  border-color: rgba(59,169,224,0.45);
  transform: translateY(-4px);
  box-shadow: 0 20px 50px rgba(15,47,86,0.4);
}

/* Couleurs de fond distinctes par niveau */
.parcours-full-card:nth-child(1) { background: #16304f; } /* Initiation — bleu nuit doux */
.parcours-full-card:nth-child(2) { background: #122a47; } /* Opérationnelle — navy mid */
.parcours-full-card:nth-child(3) { background: linear-gradient(145deg,#0d1e38 0%,#132240 60%,#0e2035 100%); } /* Avancée — plus sombre, premium */
.parcours-full-card:nth-child(4) { background: #0f2035; } /* Expert — navy deep */

/* Featured (niveau 3 - "Le plus choisi") */
.parcours-full-card.featured-card {
  border: 2px solid rgba(229,167,21,0.55); /* bordure or subtile */
  box-shadow: 0 12px 50px rgba(15,47,86,0.45), 0 0 0 1px rgba(229,167,21,0.15);
}
.parcours-full-card.featured-card:hover {
  border-color: rgba(229,167,21,0.80);
  box-shadow: 0 24px 70px rgba(15,47,86,0.50), 0 0 0 1px rgba(229,167,21,0.30);
}
.parcours-full-card h3 { color: var(--white); font-size: 1.05rem; margin-bottom: 0.8rem; }
.card-header-row {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  margin-bottom: 1.8rem;
}
.card-duree-big {
  font-family: var(--font-head);
  font-size: 3rem;
  color: var(--blue);
  line-height: 1;
  font-weight: 800;
}
.card-duree-big small {
  font-size: 1rem;
  font-family: var(--font-body);
  color: rgba(255,255,255,0.45);
}
.card-niveau-tag {
  display: inline-block;
  background: rgba(59,169,224,0.12);
  border: 1px solid rgba(59,169,224,0.25);
  color: var(--blue-light);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 4px;
  margin-bottom: 0.8rem;
}
.card-footer-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(59,169,224,0.12);
  flex-wrap: wrap;
  gap: 1rem;
}
.attestation-tag {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--blue-light);
  font-size: 0.78rem;
  font-weight: 600;
}
.btn-inscrire-card {
  background: var(--blue);
  color: var(--white);
  border: none;
  padding: 0.6rem 1.4rem;
  border-radius: 6px;
  font-family: var(--font-body);
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.btn-inscrire-card:hover { background: var(--white); color: var(--navy); }

/* WA button formations */
.btn-wa-big {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  background: #25D366;
  color: var(--white);
  padding: 1rem 2rem;
  border-radius: var(--radius);
  font-weight: 700;
  font-size: 1rem;
  transition: var(--transition);
  box-shadow: 0 8px 24px rgba(37,211,102,0.35);
}
.btn-wa-big:hover {
  background: #1aab53;
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(37,211,102,0.50);
}

/* Scroll cue */
.scroll-cue {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255,255,255,0.35);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-top: 3rem;
  cursor: pointer;
}
.scroll-cue i { animation: bounce 2s ease-in-out infinite; }
@keyframes bounce { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(6px); } }

/* Particules hero formations */
.particle {
  position: absolute;
  border-radius: 50%;
  opacity: 0.12;
  animation: float 8s ease-in-out infinite;
  pointer-events: none;
}
@keyframes float { 0%,100%{ transform: translateY(0) rotate(0deg); } 50%{ transform: translateY(-30px) rotate(180deg); } }

/* ══════════════════════════════════════════════════════════
   INDEX.HTML — Stats bar, clients grid
══════════════════════════════════════════════════════════ */
.stats-bar {
  background: var(--navy-deep);
  padding: 2.5rem 0;
  border-top: 1px solid rgba(59,169,224,0.15);
  border-bottom: 1px solid rgba(59,169,224,0.15);
}
.stats-bar-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  text-align: center;
}
.stats-bar .stat-num { font-size: 2.6rem; color: var(--blue); }
.stats-bar .stat-label { color: rgba(255,255,255,0.85); font-size: 0.75rem; }
.stats-bar-item {
  padding: 1rem;
  border-right: 1px solid rgba(255,255,255,0.06);
}
.stats-bar-item:last-child { border-right: none; }

/* Clients grid */
.clients-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.client-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.5rem;
  text-align: center;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.client-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
  border-color: var(--blue-pale);
}
.client-icon {
  width: 56px; height: 56px;
  background: var(--blue-pale);
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.2rem;
  color: var(--blue);
  font-size: 1.5rem;
}
.client-card h3 { color: var(--navy); font-size: 1rem; margin-bottom: 0.6rem; }
.client-card p  { color: var(--text-body); font-size: 0.87rem; line-height: 1.7; }

/* Avatar témoignages (img) */
.testi-avatar-img {
  width: 46px; height: 46px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

/* Services cards image (index.html) */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.svc-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
  cursor: pointer;
  box-shadow: var(--shadow-md);
}
.svc-card-img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.6s ease;
}
.svc-card:hover .svc-card-img { transform: scale(1.07); }
.svc-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(15,47,86,0.97) 0%, rgba(15,47,86,0.60) 50%, rgba(15,47,86,0.15) 100%);
  transition: background 0.4s ease;
}
.svc-card:hover .svc-card-overlay {
  background: linear-gradient(to top, rgba(15,47,86,0.99) 0%, rgba(23,71,126,0.75) 55%, rgba(23,71,126,0.25) 100%);
}
.svc-card-body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 1.8rem;
}
.svc-card-num {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--blue-light);
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.svc-card-title {
  font-family: var(--font-head);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 0.6rem;
  line-height: 1.25;
}
.svc-card-desc {
  font-size: 0.83rem;
  color: rgba(255,255,255,0.72);
  line-height: 1.65;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}
.svc-card:hover .svc-card-desc { max-height: 80px; }
.svc-card-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--blue-light);
  margin-top: 0.8rem;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.svc-card:hover .svc-card-link { opacity: 1; transform: translateY(0); }

/* Real cards réalisations */
.real-card {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  aspect-ratio: 4/3;
  box-shadow: var(--shadow-sm);
}
.real-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.real-card:hover img { transform: scale(1.05); }
.real-card-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(15,47,86,0.92));
  padding: 1.2rem;
}
.real-card-tag {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--blue-light);
  margin-bottom: 0.3rem;
}
.real-card-caption h4 {
  font-size: 0.88rem;
  color: var(--white);
  font-weight: 600;
  margin: 0;
}

/* Fondateur section */
.fondateur-section {
  background: linear-gradient(145deg, var(--navy-deep), var(--navy));
  padding: 90px 0;
  overflow: hidden;
  position: relative;
}
.fondateur-section::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(59,169,224,0.10) 0%, transparent 65%);
  pointer-events: none;
}
.fondateur-photo-wrap {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3/4;
  max-height: 540px;
  box-shadow: 0 32px 80px rgba(15,47,86,0.50);
}
.fondateur-photo-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top;
}
.fondateur-badge {
  position: absolute;
  bottom: -16px; left: -16px;
  background: linear-gradient(135deg, var(--blue), var(--navy-mid));
  color: var(--white);
  padding: 1.1rem 1.5rem;
  border-radius: 12px;
  box-shadow: 0 12px 36px rgba(59,169,224,0.40);
  border: 1px solid rgba(255,255,255,0.15);
  font-family: var(--font-head);
  text-align: center;
}
.fondateur-badge strong {
  display: block;
  font-size: 1.9rem;
  font-weight: 800;
  line-height: 1;
  color: var(--white);
}
.fondateur-badge span {
  font-size: 0.62rem;
  font-weight: 600;
  color: rgba(255,255,255,0.85);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.fondateur-quote {
  border-left: 3px solid var(--blue);
  padding-left: 1.5rem;
  margin-bottom: 1.8rem;
}
.fondateur-quote p {
  color: rgba(255,255,255,0.78);
  font-size: 0.98rem;
  line-height: 1.85;
  font-style: italic;
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE COMPLÉMENTS
══════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .stats-bar-inner { grid-template-columns: repeat(2, 1fr); }
  .clients-grid { grid-template-columns: repeat(2, 1fr); }
  .fondateur-grid { grid-template-columns: 1fr !important; gap: 3rem; }
}
@media (max-width: 560px) {
  .svc-grid { grid-template-columns: 1fr; }
  .clients-grid { grid-template-columns: 1fr; }
  .stats-bar-inner { grid-template-columns: repeat(2, 1fr); }
  .form-hero { padding: 120px 0 60px; }
  /* Formations — parcours en 1 col dès 560px */
  .parcours-full-grid { grid-template-columns: 1fr !important; }
  .formation-avantages { grid-template-columns: 1fr !important; }
  /* Témoignages */
  .testimonials-grid { grid-template-columns: 1fr !important; }
  /* Public cible */
  .public-grid { grid-template-columns: 1fr 1fr !important; }
}


/* ══════════════════════════════════════════════════════════
   CORRECTIONS MOBILES SUPPLÉMENTAIRES
══════════════════════════════════════════════════════════ */

/* Grille interventions a-propos.html (3 col inline → forcer 1 col mobile) */
@media (max-width: 768px) {
  /* Forcer les grilles inline à passer en 2 colonnes */
  div[style*="grid-template-columns:repeat(3,1fr)"],
  div[style*="grid-template-columns: repeat(3, 1fr)"],
  div[style*="grid-template-columns:1fr 1fr 1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }
  /* Image sections de contact et autres pages */
  div[style*="grid-template-columns:1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Image bande approach (index.html 4 photos) */
  div[style*="grid-template-columns:1fr 1fr 1fr 1fr"] {
    grid-template-columns: 1fr 1fr !important;
  }
  /* Réduire les marges décalées des photos sur mobile */
  div[style*="margin-top:2rem"] {
    margin-top: 0 !important;
  }
}

@media (max-width: 480px) {
  /* Tout en 1 colonne sur très petit écran */
  div[style*="grid-template-columns:repeat(3,1fr)"],
  div[style*="grid-template-columns: repeat(3, 1fr)"],
  div[style*="grid-template-columns:1fr 1fr 1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr 1fr 1fr"],
  div[style*="grid-template-columns:1fr 1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  div[style*="grid-template-columns:1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  /* Réduire hauteurs aspect-ratio sur mobile */
  div[style*="aspect-ratio:3/4"] {
    max-height: 260px;
  }
}

/* ═══ CARD NIVEAU — carte-niveau spécifique du texte haut ═══ */
/* Sur mobile, le card-niveau-tag doit rester lisible */
@media (max-width: 768px) {
  .card-niveau-tag {
    font-size: 0.65rem;
    padding: 0.2rem 0.6rem;
  }
  .card-duree-big {
    font-size: 2.2rem;
  }
  .parcours-full-card {
    padding: 2rem 1.5rem;
  }
  .popular-tag {
    font-size: 0.62rem;
    padding: 0.3rem 0.8rem;
    right: 12px;
  }
}

/* ═══ public-card image covers sur mobile ═══ */
@media (max-width: 768px) {
  .public-card > div > img {
    height: 130px !important;
  }
}


/* ════════════════════════════════════════════════════════════════
   RESPONSIVE MOBILE — BLOC FINAL CONSOLIDÉ v6
   Un seul bloc, pas de conflits, priorité maximale
   ════════════════════════════════════════════════════════════════ */

/* ── CLASSES pour les anciens grids inline ────────────────────── */
.timeline-grid        { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; position:relative; }
.interventions-grid   { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:3rem; }
.portfolio-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2rem; text-align:center; }
.portfolio-mosaic-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:0.8rem; }
.partner-content-grid { display:grid; grid-template-columns:1fr 280px; gap:4rem; align-items:start; }
.contact-trust-grid   { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.public-cible-grid    { display:grid; grid-template-columns:repeat(5,1fr); gap:1.2rem; margin-top:3rem; }
.service-bonus-grid   { display:grid; grid-template-columns:1fr auto; gap:3rem; align-items:center; margin-top:3rem; }
.mv-grid-3            { grid-template-columns:repeat(3,1fr) !important; }

/* Mosaic cells (portfolio) */
.mosaic-cell          { border-radius:6px; overflow:hidden; aspect-ratio:1; }
.mosaic-cell img      { width:100%; height:100%; object-fit:cover; transition:transform 0.4s; }
.mosaic-cell img:hover{ transform:scale(1.05); }

/* ════════════════════════════════════════════
   TABLET max-width: 1024px
═══════════════════════════════════════════════ */
@media (max-width:1024px) {
  .public-cible-grid    { grid-template-columns:repeat(3,1fr) !important; }
  .portfolio-stats-grid { grid-template-columns:repeat(2,1fr) !important; }
  .partner-content-grid { grid-template-columns:1fr !important; gap:2rem !important; }
  .portfolio-mosaic-grid{ grid-template-columns:repeat(3,1fr) !important; }
}

/* ════════════════════════════════════════════
   MOBILE max-width: 768px
   → 1 carte par ligne partout
═══════════════════════════════════════════════ */
@media (max-width:768px) {

  /* ── A-PROPOS : "Ce qui nous guide" (3 ou 4 cartes) → 1 par ligne ── */
  .mv-grid,
  .mv-grid-3 { grid-template-columns:1fr !important; }

  /* ── A-PROPOS : Mot du fondateur — image au-dessus du texte ── */
  .fondateur-grid {
    grid-template-columns:1fr !important;
    gap:1.5rem !important;
  }
  /* Badge nom positionné en absolu → le masquer (le nom est dans le texte en dessous) */
  .fondateur-grid > div:first-child div[style*="position:absolute"] {
    display:none !important;
  }
  /* Image DG : paysage sur mobile, pas trop haute */
  .fondateur-grid > div:first-child div[style*="aspect-ratio"] {
    aspect-ratio:4/3 !important;
    max-height:260px !important;
  }

  /* ── A-PROPOS : Équipe + question-card → 1 par ligne ── */
  .team-question-grid { grid-template-columns:1fr !important; }
  .team-question-grid > * { grid-column:auto !important; }

  /* ── A-PROPOS : Timeline 4 étapes → 2 par ligne ── */
  .timeline-grid { grid-template-columns:1fr 1fr !important; gap:1.2rem !important; }
  /* Masquer la ligne absolue derrière les bulles */
  .timeline-grid > div[style*="position:absolute"] { display:none !important; }

  /* ── A-PROPOS : Interventions services → 1 col ── */
  .interventions-grid { grid-template-columns:1fr !important; }

  /* ── SERVICES : parcours 3/6/9/12 mois → 1 carte par ligne ── */
  .parcours-grid { grid-template-columns:1fr !important; }
  .parcours-card { max-width:100% !important; }

  /* ── FORMATIONS : parcours-full-grid → 1 par ligne ── */
  .parcours-full-grid   { grid-template-columns:1fr !important; }
  .parcours-full-card   { padding:2rem 1.5rem !important; overflow:visible !important; }
  .popular-tag          { top:-12px !important; right:16px !important; }
  .formation-avantages  { grid-template-columns:1fr !important; }
  .inscription-grid     { grid-template-columns:1fr !important; }

  /* ── PORTFOLIO / RÉALISATIONS : 1 image par ligne ── */
  .portfolio-grid       { grid-template-columns:1fr !important; }
  .realisations-grid    { grid-template-columns:1fr !important; }
  /* Ratio paysage pour que l'image soit bien visible */
  .portfolio-item       { aspect-ratio:16/9 !important; }
  /* Sur mobile le survol n'existe pas → overlay toujours visible */
  .portfolio-overlay    { opacity:1 !important; }
  /* Le paragraphe description déborde → masqué, titre seul */
  .portfolio-overlay p  { display:none !important; }
  .portfolio-overlay h4 { font-size:0.9rem !important; line-height:1.4 !important; }
  .portfolio-overlay span{ font-size:0.65rem !important; }

  /* PORTFOLIO : stats 4 chiffres → 2 par ligne */
  .portfolio-stats-grid  { grid-template-columns:1fr 1fr !important; }
  /* Mosaïque → 2 par ligne */
  .portfolio-mosaic-grid { grid-template-columns:1fr 1fr !important; }
  .mosaic-cell           { aspect-ratio:4/3 !important; }

  /* ── CONTACT : images confiance → 1 par ligne ── */
  .contact-trust-grid { grid-template-columns:1fr !important; }

  /* ── PARTENAIRES : sidebar → empilé ── */
  .partner-content-grid { grid-template-columns:1fr !important; gap:2rem !important; }

  /* ── SERVICES : bonus row → empilé ── */
  .service-bonus-grid { grid-template-columns:1fr !important; }

  /* ── FORMATIONS : public cible → 2 par ligne ── */
  .public-cible-grid { grid-template-columns:1fr 1fr !important; }

  /* ── GENERAUX ── */
  .services-grid,.testimonials-grid,.bonus-grid,.pourquoi-grid { grid-template-columns:1fr !important; }
  .partners-grid,.public-grid { grid-template-columns:1fr 1fr !important; }
  .contact-grid { grid-template-columns:1fr !important; }
  .form-row { grid-template-columns:1fr !important; }
  .footer-grid { grid-template-columns:1fr !important; }
  .footer-legal { flex-direction:column; align-items:flex-start; gap:0.8rem; }
  .cta-actions { flex-direction:column; align-items:center; }
  .hero-stats { flex-wrap:wrap; gap:1.5rem; }
  .strip-inner { flex-direction:column; gap:1.5rem; }
  .about-grid,.whyus-grid { grid-template-columns:1fr !important; }
  .service-detail { grid-template-columns:1fr !important; gap:2rem !important; }
  .service-detail.reverse { direction:ltr !important; }
}

/* ════════════════════════════════════════════
   MOBILE max-width: 480px
   → tout en 1 colonne
═══════════════════════════════════════════════ */
@media (max-width:480px) {
  .container { padding:0 1.2rem; }
  h1 { font-size:2rem; }
  h2 { font-size:1.6rem; }
  .page-hero { padding:130px 0 70px; }

  /* Tout → 1 colonne */
  .mv-grid,.mv-grid-3,
  .timeline-grid,
  .interventions-grid,
  .portfolio-stats-grid,
  .portfolio-mosaic-grid,
  .contact-trust-grid,
  .public-cible-grid,
  .realisations-grid,
  .portfolio-grid,
  .parcours-grid,
  .parcours-full-grid,
  .testimonials-grid,
  .public-grid,
  .mv-grid,
  .partners-grid,
  .clients-grid,
  .team-question-grid,
  .services-grid,
  .bonus-grid,
  .pourquoi-grid,
  .formation-avantages,
  .inscription-grid,
  .footer-grid { grid-template-columns:1fr !important; }

  .mosaic-cell { aspect-ratio:16/9 !important; }
  .portfolio-item { aspect-ratio:16/9 !important; }

  /* Réduire paddings */
  section { padding:50px 0 !important; }
  .parcours-full-card { padding:1.8rem 1.2rem !important; }
  .card-duree-big { font-size:2rem !important; }

  /* Stats bar : garder 2 par ligne */
  .stats-bar-inner { grid-template-columns:1fr 1fr !important; }
  .stat-num { font-size:1.8rem; }
}

/* ── SECTION FORMATIONS PRATIQUES ── */
@media (max-width: 768px) {
  .pratique-grid {
    grid-template-columns: 1fr !important;
  }
  .pratique-grid > div:last-child {
    position: static !important;
  }
}
