/* ═══════════════════════════════════════════════════════
   MyQMa Custom Theme v1.1 — main.css
   Cyan #00B4D8 · Vert #10B981 · Dark #0F172A
═══════════════════════════════════════════════════════ */

:root {
  --cyan:     #00B4D8;
  --cyan-d:   #0096B7;
  --cyan-rgb: 0,180,216;
  --green:    #10B981;
  --green-rgb:16,185,129;
  --dark:     #0F172A;
  --mid:      #1E293B;
  --slate:    #475569;
  --muted:    #94A3B8;
  --canvas:   #F8FAFC;
  --border:   #E2E8F0;
  --white:    #FFFFFF;
  --radius:   10px;
  --shadow:   0 4px 24px rgba(0,0,0,.08);
  --shadow-lg:0 16px 48px rgba(0,0,0,.14);
  --font:     'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --max:      1160px;
  --nav-h:    72px;
  --ease-out: cubic-bezier(.22,1,.36,1);
}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--dark);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--cyan);text-decoration:none}
a:hover{color:var(--cyan-d)}
ul{list-style:none}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}

/* ── Typography ──────────────────────────────────────── */
h1,h2,h3,h4,h5{font-weight:700;line-height:1.2;color:inherit}
h1{font-size:clamp(2.1rem,4.5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:clamp(1.05rem,2vw,1.4rem)}
h4{font-size:1rem;font-weight:600}
.label{display:inline-block;font-size:.7rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--cyan);margin-bottom:.75rem}
.label--green{color:var(--green)}

/* ── Container ───────────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 28px}

/* ── Buttons ─────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.72rem 1.6rem;border-radius:8px;font-family:var(--font);font-size:.9rem;font-weight:600;border:none;cursor:pointer;transition:all .22s ease;white-space:nowrap;letter-spacing:.01em}
.btn-primary{background:var(--cyan);color:#fff}
.btn-primary:hover{background:var(--cyan-d);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(var(--cyan-rgb),.38)}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(var(--cyan-rgb),.08)}
.btn-outline-dark{background:transparent;color:var(--dark);border:1.5px solid var(--border)}
.btn-outline-dark:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:#0da874;color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--cyan);font-weight:700}
.btn-white:hover{background:var(--canvas);color:var(--cyan-d)}

/* ═══════════════════════════════════════════════════════
   HEADER
═══════════════════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);
  background:rgba(15,23,42,.96);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  z-index:1000;
  border-bottom:1px solid rgba(255,255,255,.06);
  transition:box-shadow .3s ease, background .3s ease;
}
.site-header.scrolled{box-shadow:0 4px 32px rgba(0,0,0,.35);background:rgba(15,23,42,.99)}

.header-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:24px;
  height:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 28px;
}

/* Logo */
.site-logo{
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  flex-shrink:0;
}
.site-logo .logo-img{
  height:38px;
  width:auto;
  object-fit:contain;
  filter:brightness(0) invert(1);/* Logo blanc sur fond sombre */
}
.logo-mark{
  width:36px;height:36px;
  background:var(--cyan);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:#fff;font-weight:900;
  flex-shrink:0;
}
.logo-text{font-size:1.25rem;font-weight:700;color:#fff;letter-spacing:-.01em}
.logo-text strong{font-weight:900;color:var(--cyan)}

/* Nav */
.nav-primary{display:flex;justify-content:center}
.nav-list{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-list li a{
  display:block;padding:.45rem 1rem;
  font-size:.87rem;font-weight:500;
  color:rgba(255,255,255,.72);
  border-radius:6px;
  transition:color .2s,background .2s;
}
.nav-list li a:hover,.nav-list li.active>a,.nav-list li.current-menu-item>a{color:#fff;background:rgba(255,255,255,.07)}
.nav-list li.current-menu-item>a{color:var(--cyan);background:rgba(var(--cyan-rgb),.1)}

/* Header right */
.header-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-cta{font-size:.84rem;padding:.55rem 1.2rem}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .25s var(--ease-out)}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ═══════════════════════════════════════════════════════
   SECTIONS
═══════════════════════════════════════════════════════ */
.section{padding:100px 0}
.section--sm{padding:64px 0}
.section--dark{background:var(--dark);color:#fff}
.section--mid{background:var(--mid);color:#fff}
.section--canvas{background:var(--canvas)}

.section-head{margin-bottom:60px}
.section-head p{margin-top:.75rem;font-size:1.05rem;color:var(--slate)}
.section-head--center{text-align:center;max-width:680px;margin:0 auto 60px}
.section--dark .section-head p,
.section--mid .section-head p{color:rgba(255,255,255,.6)}

/* ═══════════════════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════════════════ */

/* — Keyframes — */
@keyframes fadeUp     {from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft   {from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeRight  {from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn     {from{opacity:0}to{opacity:1}}
@keyframes scaleIn    {from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@keyframes shimmer    {0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes pulse-ring {0%{box-shadow:0 0 0 0 rgba(var(--cyan-rgb),.4)}70%{box-shadow:0 0 0 14px rgba(var(--cyan-rgb),0)}100%{box-shadow:0 0 0 0 rgba(var(--cyan-rgb),0)}}
@keyframes float      {0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* — Hero load animations — */
.hero-badge    {opacity:0;animation:fadeUp   .5s var(--ease-out) .1s  both}
.hero h1       {opacity:0;animation:fadeUp   .65s var(--ease-out) .25s both}
.hero-sub      {opacity:0;animation:fadeUp   .6s var(--ease-out) .4s  both}
.hero-tags     {opacity:0;animation:fadeUp   .55s var(--ease-out) .52s both}
.hero-actions  {opacity:0;animation:fadeUp   .55s var(--ease-out) .64s both}
.hero-visual   {opacity:0;animation:fadeRight .7s var(--ease-out) .4s  both}

/* Staggered card animations for hero */
.hero-card:nth-child(1){animation:fadeUp .6s var(--ease-out) .55s both}
.hero-card:nth-child(2){animation:fadeUp .6s var(--ease-out) .72s both}
.hero-card:nth-child(3){animation:fadeUp .6s var(--ease-out) .89s both}

/* — Scroll reveal — */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity .65s var(--ease-out),transform .65s var(--ease-out)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.94);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* Stagger delays */
.stagger-1{transition-delay:.08s}.stagger-2{transition-delay:.16s}
.stagger-3{transition-delay:.24s}.stagger-4{transition-delay:.32s}
.stagger-5{transition-delay:.40s}.stagger-6{transition-delay:.48s}

/* Page header text */
.page-header .breadcrumb{opacity:0;animation:fadeUp .5s var(--ease-out) .1s both}
.page-header .label      {opacity:0;animation:fadeUp .55s var(--ease-out) .2s both;display:block}
.page-header h1          {opacity:0;animation:fadeUp .65s var(--ease-out) .3s both}
.page-header p           {opacity:0;animation:fadeUp .6s var(--ease-out) .45s both}

/* ═══════════════════════════════════════════════════════
   ICON SYSTEM (Font Awesome — blanc)
═══════════════════════════════════════════════════════ */
.icon-box{
  width:52px;height:52px;
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;
  flex-shrink:0;
}
.icon-box i{color:#fff}
.icon-box.cyan  {background:rgba(var(--cyan-rgb),.18);border:1px solid rgba(var(--cyan-rgb),.3)}
.icon-box.green {background:rgba(var(--green-rgb),.18);border:1px solid rgba(var(--green-rgb),.3)}
.icon-box.purple{background:rgba(139,92,246,.18);border:1px solid rgba(139,92,246,.3)}
.icon-box.white {background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18)}
/* Sur fonds clairs, forcer la couleur de l'icône */
.section--canvas .icon-box i,
.section:not(.section--dark):not(.section--mid) .icon-box i{color:#fff}

/* ═══════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;
  display:flex;align-items:center;
  background:var(--dark);
  background-image:
    radial-gradient(ellipse 900px 700px at 70% 40%,rgba(0,180,216,.13) 0%,transparent 65%),
    radial-gradient(ellipse 600px 500px at 5% 85%, rgba(16,185,129,.09) 0%,transparent 60%);
  color:#fff;
  padding:calc(var(--nav-h) + 72px) 0 96px;
  overflow:hidden;
  position:relative;
}
/* Grille de fond subtile */
.hero::before{
  content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 40%,transparent 100%);
  pointer-events:none;
}
.hero-inner{
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:64px;align-items:center;
  max-width:var(--max);margin:0 auto;padding:0 28px;
  position:relative;z-index:1;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(var(--cyan-rgb),.1);
  border:1px solid rgba(var(--cyan-rgb),.28);
  color:var(--cyan);
  font-size:.74rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:.38rem 1rem;border-radius:100px;
  margin-bottom:1.5rem;
}
.hero h1{font-size:clamp(2.2rem,4.5vw,3.5rem);font-weight:900;line-height:1.12;margin-bottom:1.25rem;letter-spacing:-.02em}
.hero h1 span{color:var(--cyan)}
.hero-sub{font-size:1.07rem;color:rgba(255,255,255,.68);margin-bottom:1.75rem;line-height:1.72;max-width:520px}
.hero-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem}
.hero-tag{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.11);color:rgba(255,255,255,.78);font-size:.78rem;font-weight:500;padding:.3rem .9rem;border-radius:100px}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap}

/* Visual */
.hero-visual{display:flex;justify-content:flex-end;align-items:center}
.hero-card-stack{width:100%;max-width:400px;display:flex;flex-direction:column;gap:14px}
.hero-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.09);
  border-radius:16px;padding:22px 24px;
  backdrop-filter:blur(8px);
  display:flex;align-items:center;gap:16px;
  transition:transform .3s var(--ease-out),border-color .3s;
}
.hero-card:hover{transform:translateX(-6px);border-color:rgba(var(--cyan-rgb),.3)}
.hero-card:nth-child(2){margin-left:24px}
.hero-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;flex-shrink:0}
.hero-card-icon i{color:#fff}
.hero-card-icon.c{background:rgba(var(--cyan-rgb),.2)}
.hero-card-icon.g{background:rgba(var(--green-rgb),.2)}
.hero-card-icon.v{background:rgba(139,92,246,.2)}
.hero-card h4{font-size:.92rem;color:#fff;margin-bottom:.18rem}
.hero-card p{font-size:.8rem;color:rgba(255,255,255,.5);margin:0;line-height:1.45}

/* ═══════════════════════════════════════════════════════
   TEASER GRID (home)
═══════════════════════════════════════════════════════ */
.teaser-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.teaser-card{
  background:#fff;border:1px solid var(--border);
  border-radius:14px;padding:36px 28px;
  transition:box-shadow .28s,transform .28s,border-color .28s;
  position:relative;overflow:hidden;
}
.teaser-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(var(--cyan-rgb),.04) 0%,transparent 60%);
  opacity:0;transition:opacity .3s;
}
.teaser-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:rgba(var(--cyan-rgb),.3)}
.teaser-card:hover::before{opacity:1}
.teaser-icon{
  width:54px;height:54px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;margin-bottom:1.25rem;
}
.teaser-icon i{color:#fff}
.teaser-icon.cyan  {background:var(--cyan)}
.teaser-icon.green {background:var(--green)}
.teaser-icon.purple{background:#8B5CF6}
.teaser-card h3{font-size:1.1rem;margin-bottom:.55rem}
.teaser-card p{font-size:.9rem;color:var(--slate);line-height:1.65}
.teaser-card .card-link{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:.85rem;font-weight:600;color:var(--cyan);margin-top:1.2rem;
  transition:gap .2s;
}
.teaser-card .card-link i{font-size:.8rem;transition:transform .2s}
.teaser-card:hover .card-link i{transform:translateX(5px)}

/* ═══════════════════════════════════════════════════════
   PAIN POINTS
═══════════════════════════════════════════════════════ */
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:780px;margin:0 auto 48px}
.pain-item{
  display:flex;gap:14px;padding:22px;
  background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);
  transition:box-shadow .25s,border-color .25s;
}
.pain-item:hover{box-shadow:var(--shadow);border-color:rgba(var(--cyan-rgb),.2)}
.pain-dot{flex-shrink:0;width:10px;height:10px;border-radius:50%;margin-top:7px}
.pain-item h4{font-size:.95rem;margin-bottom:.28rem}
.pain-item p{font-size:.87rem;color:var(--slate);margin:0}

/* ═══════════════════════════════════════════════════════
   VALUE PROPS
═══════════════════════════════════════════════════════ */
.vp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.vp-item{text-align:center}
.vp-icon{
  width:64px;height:64px;border-radius:18px;
  background:var(--cyan);
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin:0 auto 1rem;
  transition:transform .28s var(--ease-out),box-shadow .28s;
}
.vp-icon i{color:#fff}
.vp-item:hover .vp-icon{transform:translateY(-4px);box-shadow:0 10px 28px rgba(var(--cyan-rgb),.35)}
.vp-item h4{margin-bottom:.4rem}
.vp-item p{font-size:.9rem;color:var(--slate)}

/* ═══════════════════════════════════════════════════════
   DELIVERABLES
═══════════════════════════════════════════════════════ */
.deliver-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.deliver-item{
  display:flex;align-items:flex-start;gap:12px;padding:20px;
  background:var(--canvas);border-radius:var(--radius);
  border:1px solid var(--border);
  transition:box-shadow .25s,transform .25s;
}
.deliver-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.07)}
.deliver-item .check{
  flex-shrink:0;width:22px;height:22px;
  background:var(--cyan);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;color:#fff;margin-top:1px;
}
.deliver-item p{font-size:.9rem;color:var(--slate);margin:0;line-height:1.6}

/* ═══════════════════════════════════════════════════════
   JOURNEY 30-60-90
═══════════════════════════════════════════════════════ */
.journey{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:2rem}
.journey-phase{
  padding:40px 30px;border-radius:14px;
  position:relative;overflow:hidden;
  transition:transform .28s var(--ease-out);
}
.journey-phase:hover{transform:translateY(-4px)}
.journey-phase::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .28s}
.journey-phase:hover::before{opacity:1}
.journey-phase:nth-child(1){background:rgba(var(--cyan-rgb),.07);border:1px solid rgba(var(--cyan-rgb),.2)}
.journey-phase:nth-child(2){background:rgba(var(--green-rgb),.07);border:1px solid rgba(var(--green-rgb),.2)}
.journey-phase:nth-child(3){background:rgba(139,92,246,.07);border:1px solid rgba(139,92,246,.2)}
.journey-phase:nth-child(1)::before{background:linear-gradient(135deg,rgba(var(--cyan-rgb),.08),transparent)}
.journey-phase:nth-child(2)::before{background:linear-gradient(135deg,rgba(var(--green-rgb),.08),transparent)}
.journey-phase:nth-child(3)::before{background:linear-gradient(135deg,rgba(139,92,246,.08),transparent)}
.journey-num{font-size:3.5rem;font-weight:900;line-height:1;margin-bottom:.4rem;opacity:.12;letter-spacing:-.03em}
.journey-phase:nth-child(1) .journey-num{color:var(--cyan)}
.journey-phase:nth-child(2) .journey-num{color:var(--green)}
.journey-phase:nth-child(3) .journey-num{color:#8B5CF6}
.journey-range{font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;margin-bottom:.8rem}
.journey-phase:nth-child(1) .journey-range{color:var(--cyan)}
.journey-phase:nth-child(2) .journey-range{color:var(--green)}
.journey-phase:nth-child(3) .journey-range{color:#8B5CF6}
.journey-icon{font-size:1.5rem;margin-bottom:.75rem}
.journey-icon i{color:#fff}
.journey-phase h3{font-size:1.05rem;margin-bottom:.5rem;color:var(--dark)}
.journey-phase p{font-size:.87rem;color:var(--slate);margin:0}

/* ═══════════════════════════════════════════════════════
   TABLE STYLED
═══════════════════════════════════════════════════════ */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow)}
.table-styled{width:100%;border-collapse:collapse;font-size:.92rem}
.table-styled th{background:var(--dark);color:#fff;padding:14px 20px;text-align:left;font-weight:600;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase}
.table-styled td{padding:14px 20px;border-bottom:1px solid var(--border);color:var(--dark);vertical-align:top}
.table-styled tr:last-child td{border-bottom:none}
.table-styled tr:nth-child(even) td{background:var(--canvas)}
.table-styled tr:hover td{background:rgba(var(--cyan-rgb),.03)}
.table-styled td:first-child{font-weight:600;color:var(--mid)}

/* ═══════════════════════════════════════════════════════
   PRICING
═══════════════════════════════════════════════════════ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pricing-card{
  border-radius:16px;padding:36px 28px;
  border:1px solid var(--border);background:#fff;
  transition:box-shadow .28s,transform .28s;
  position:relative;
}
.pricing-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}
.pricing-card.featured{
  border-color:var(--cyan);background:var(--dark);color:#fff;
}
.pricing-badge{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--cyan);color:#fff;
  font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:.3rem 1.1rem;border-radius:100px;white-space:nowrap;
}
.pricing-name{font-size:1.25rem;font-weight:800;margin-bottom:.5rem}
.pricing-desc{font-size:.87rem;color:var(--slate);margin-bottom:1.5rem;line-height:1.65}
.pricing-card.featured .pricing-desc{color:rgba(255,255,255,.6)}
.pricing-features{margin-bottom:2rem}
.pricing-features li{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:.55rem 0;font-size:.88rem;color:var(--slate);
  border-bottom:1px solid var(--border);
}
.pricing-card.featured .pricing-features li{color:rgba(255,255,255,.72);border-color:rgba(255,255,255,.1)}
.pricing-features li:last-child{border-bottom:none}
.pricing-features .check-icon{flex-shrink:0;color:var(--green);font-size:.85rem;margin-top:2px}
.pricing-features .check-icon i{color:var(--green)}

/* ═══════════════════════════════════════════════════════
   SERVICES (Erweiterte)
═══════════════════════════════════════════════════════ */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.service-card{
  padding:30px;border-radius:var(--radius);
  border:1px solid var(--border);background:#fff;
  transition:box-shadow .25s,transform .25s,border-color .25s;
}
.service-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:rgba(var(--cyan-rgb),.25)}
.service-card-header{display:flex;align-items:center;gap:14px;margin-bottom:1rem}
.service-card h3{font-size:.97rem;color:var(--dark)}
.service-card ul{display:flex;flex-direction:column;gap:.45rem}
.service-card li{display:flex;align-items:flex-start;gap:.6rem;font-size:.87rem;color:var(--slate)}
.service-card li i{color:var(--green);font-size:.8rem;margin-top:3px;flex-shrink:0}

/* ═══════════════════════════════════════════════════════
   MISSION / VALUES
═══════════════════════════════════════════════════════ */
.mission-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.mission-quote{
  font-size:1.2rem;font-style:italic;color:rgba(255,255,255,.9);
  padding:1.25rem 1.75rem;line-height:1.7;
  background:rgba(var(--cyan-rgb),.08);
  border-radius:12px;margin-bottom:1.5rem;
  box-shadow:inset 0 0 0 1px rgba(var(--cyan-rgb),.18);
}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.value-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:28px 20px;text-align:center;
  transition:background .25s,border-color .25s,transform .25s;
}
.value-card:hover{background:rgba(255,255,255,.07);border-color:rgba(var(--cyan-rgb),.25);transform:translateY(-3px)}
.value-card .v-icon{font-size:1.8rem;margin-bottom:.75rem}
.value-card .v-icon i{color:#fff}
.value-card h4{font-size:.93rem;color:#fff;margin-bottom:.4rem}
.value-card p{font-size:.82rem;color:rgba(255,255,255,.52);margin:0}

/* ═══════════════════════════════════════════════════════
   GARANTIES
═══════════════════════════════════════════════════════ */
.garanties-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.garantie-card{
  border-radius:14px;padding:36px 28px;text-align:center;
  transition:transform .28s,box-shadow .28s;
}
.garantie-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.garantie-card:nth-child(1){background:rgba(var(--cyan-rgb),.06);border:1px solid rgba(var(--cyan-rgb),.2)}
.garantie-card:nth-child(2){background:rgba(var(--green-rgb),.06);border:1px solid rgba(var(--green-rgb),.2)}
.garantie-card:nth-child(3){background:rgba(139,92,246,.06);border:1px solid rgba(139,92,246,.2)}
.garantie-icon{
  width:60px;height:60px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin:0 auto .9rem;
}
.garantie-icon i{color:#fff}
.garantie-card:nth-child(1) .garantie-icon{background:var(--cyan)}
.garantie-card:nth-child(2) .garantie-icon{background:var(--green)}
.garantie-card:nth-child(3) .garantie-icon{background:#8B5CF6}
.garantie-card h3{font-size:1rem;color:var(--dark);margin-bottom:.5rem}
.garantie-card p{font-size:.87rem;color:var(--slate);margin:0}

/* ═══════════════════════════════════════════════════════
   VORTEILE
═══════════════════════════════════════════════════════ */
.vorteile-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.vorteile-col h3{font-size:.82rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}
.vorteile-col li{display:flex;gap:.75rem;padding:.6rem 0;font-size:.92rem;color:var(--slate);border-bottom:1px solid var(--border);transition:color .2s}
.vorteile-col li:last-child{border-bottom:none}
.vorteile-col li i{color:var(--cyan);flex-shrink:0;margin-top:3px}
.vorteile-col li:hover{color:var(--dark)}

/* ═══════════════════════════════════════════════════════
   CTA BANNER
═══════════════════════════════════════════════════════ */
.cta-banner{
  background:linear-gradient(135deg,var(--cyan) 0%,#0082A3 100%);
  border-radius:20px;padding:72px 56px;text-align:center;color:#fff;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:'';position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,.06);
  top:-120px;right:-80px;pointer-events:none;
}
.cta-banner::after{
  content:'';position:absolute;
  width:280px;height:280px;border-radius:50%;
  background:rgba(255,255,255,.04);
  bottom:-80px;left:40px;pointer-events:none;
}
.cta-banner h2{margin-bottom:.75rem;font-size:clamp(1.5rem,2.5vw,2.1rem);position:relative;z-index:1}
.cta-banner p{font-size:1.05rem;opacity:.88;margin-bottom:2rem;position:relative;z-index:1}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ═══════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════ */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:64px;align-items:start}
.contact-info h3{font-size:1.15rem;margin-bottom:1.25rem}
.contact-detail{
  display:flex;gap:.85rem;align-items:flex-start;
  padding:.85rem 0;border-bottom:1px solid var(--border);
  font-size:.92rem;color:var(--slate);
}
.contact-detail:last-of-type{border-bottom:none}
.contact-detail .icon-box{width:38px;height:38px;border-radius:10px;font-size:1rem;flex-shrink:0}
.contact-form-wrap{background:var(--canvas);border-radius:16px;padding:44px;border:1px solid var(--border)}

/* WPForms overrides */
.wpforms-container .wpforms-field label{font-size:.87rem;font-weight:600;color:var(--dark);margin-bottom:.35rem;display:block}
.wpforms-container input[type=text],.wpforms-container input[type=email],.wpforms-container input[type=tel],.wpforms-container textarea,.wpforms-container select{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:.7rem 1rem;font-family:var(--font);font-size:.92rem;color:var(--dark);background:#fff;transition:border-color .2s,box-shadow .2s}
.wpforms-container input:focus,.wpforms-container textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(var(--cyan-rgb),.12)}
.wpforms-container .wpforms-submit{background:var(--cyan)!important;color:#fff!important;border:none!important;border-radius:8px!important;padding:.75rem 2rem!important;font-family:var(--font)!important;font-weight:600!important;font-size:.95rem!important;cursor:pointer;transition:background .2s,transform .2s!important}
.wpforms-container .wpforms-submit:hover{background:var(--cyan-d)!important;transform:translateY(-1px)!important}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.site-footer{background:var(--dark);color:rgba(255,255,255,.6);padding:72px 0 32px;border-top:1px solid rgba(255,255,255,.06)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:52px;margin-bottom:52px}
.footer-brand p{font-size:.88rem;line-height:1.72;max-width:280px;margin-top:.75rem}
.footer-brand .site-logo{margin-bottom:1rem}
.footer-brand .logo-img{height:32px;filter:brightness(0) invert(1)}
.footer-col h4{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1rem}
.footer-col li{padding:.3rem 0}
.footer-col a{color:rgba(255,255,255,.5);font-size:.87rem;transition:color .2s}
.footer-col a:hover{color:var(--cyan)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);font-size:.82rem}
.footer-bottom a{color:rgba(255,255,255,.38);transition:color .2s}
.footer-bottom a:hover{color:#fff}

/* ═══════════════════════════════════════════════════════
   PAGE HEADER
═══════════════════════════════════════════════════════ */
.page-header{
  padding:calc(var(--nav-h) + 80px) 0 80px;
  background:var(--dark);color:#fff;
  background-image:
    radial-gradient(ellipse 700px 500px at 85% 50%,rgba(var(--cyan-rgb),.11) 0%,transparent 65%),
    linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);
  background-size:auto,60px 60px,60px 60px;
  position:relative;overflow:hidden;
}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.8rem;color:rgba(255,255,255,.4);margin-bottom:1.5rem}
.breadcrumb a{color:rgba(255,255,255,.4)}
.breadcrumb a:hover{color:var(--cyan)}
.breadcrumb span{color:rgba(255,255,255,.2)}
.page-header h1{margin-bottom:1rem;max-width:700px}
.page-header>div>p{font-size:1.07rem;color:rgba(255,255,255,.68);max-width:600px}

/* ═══════════════════════════════════════════════════════
   GENERIC PAGE
═══════════════════════════════════════════════════════ */
.page-content{padding:80px 0}
.entry-content{max-width:760px}
.entry-content h2{margin:2rem 0 1rem}
.entry-content h3{margin:1.5rem 0 .75rem}
.entry-content p{color:var(--slate)}
.entry-content ul{list-style:disc;padding-left:1.5rem;color:var(--slate)}
.entry-content ul li{margin-bottom:.4rem}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .header-inner{grid-template-columns:auto auto}
  .nav-primary{display:none}
  .teaser-grid{grid-template-columns:1fr 1fr}
  .vp-grid{grid-template-columns:1fr 1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-inner{grid-template-columns:1fr}
  .hero-visual{display:none}
  .mission-block{grid-template-columns:1fr;gap:40px}
  .values-grid{grid-template-columns:1fr 1fr}
  .garanties-grid{grid-template-columns:1fr 1fr}
  .pricing-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}
  .contact-grid{grid-template-columns:1fr;gap:40px}
}
@media(max-width:768px){
  :root{--nav-h:64px}
  .section{padding:64px 0}
  .nav-toggle{display:flex}
  .header-inner{grid-template-columns:1fr auto}
  .nav-primary{
    display:flex!important;flex-direction:column;
    position:absolute;top:var(--nav-h);left:0;right:0;
    background:var(--dark);padding:1rem 24px 1.5rem;
    border-top:1px solid rgba(255,255,255,.08);
    transform:translateY(-8px);opacity:0;pointer-events:none;
    transition:transform .3s var(--ease-out),opacity .3s;
  }
  .nav-primary.open{transform:translateY(0);opacity:1;pointer-events:all}
  .nav-list{flex-direction:column;align-items:stretch}
  .nav-list li a{padding:.75rem 0;border-radius:0;border-bottom:1px solid rgba(255,255,255,.06)}
  .header-cta{display:none}
  .teaser-grid{grid-template-columns:1fr}
  .pain-grid{grid-template-columns:1fr}
  .journey{grid-template-columns:1fr}
  .deliver-grid{grid-template-columns:1fr}
  .vp-grid{grid-template-columns:1fr 1fr}
  .services-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .garanties-grid{grid-template-columns:1fr}
  .vorteile-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;gap:.75rem;text-align:center}
  .cta-banner{padding:48px 28px}
  .contact-form-wrap{padding:28px 20px}
}
@media(max-width:480px){
  .vp-grid{grid-template-columns:1fr}
  .pricing-grid{max-width:100%}
}

/* ═══════════════════════════════════════════════════════
   LANG SWITCHER
═══════════════════════════════════════════════════════ */
.lang-switcher{display:flex;align-items:center;gap:2px;margin-right:.5rem}
.lang-btn{font-size:.72rem;font-weight:600;letter-spacing:.06em;color:rgba(255,255,255,.5);padding:.25rem .45rem;border-radius:4px;text-decoration:none;transition:color .18s,background .18s;line-height:1}
.lang-btn:hover{color:#fff;background:rgba(255,255,255,.08)}
.lang-btn.active{color:#fff;background:rgba(var(--cyan-rgb),.25)}
@media(max-width:768px){.lang-switcher{display:none}}

/* ═══════════════════════════════════════════════════════
   WORDPRESS ADMIN BAR COMPATIBILITY
   La barre d'admin WP mesure 32 px (≥783px) ou 46 px (<783px)
   Le header fixe doit descendre pour ne pas se superposer
═══════════════════════════════════════════════════════ */
body.admin-bar .site-header{top:32px}
@media screen and (max-width:782px){
  body.admin-bar .site-header{top:46px}
}
