/* =========================================================
   DASRWET — Feuille de style principale
   Site vitrine statique (HTML/CSS/JS) — déployable sur OVH mutualisé
   Charte : dégradés de bleu royal (#0b3a86) + accent turquoise (#1ec4b4) — d'après le logo
   ========================================================= */

:root{
  /* Charte alignée sur le logo Dasrwet : dégradés de bleu royal + accent cyan */
  --navy:#0b3a86;          /* bleu royal (corps du logo) */
  --navy-deep:#04204f;     /* bleu nuit (fonds sombres) */
  --navy-light:#1f6fc4;    /* bleu clair (reflets du logo) */
  --cyan:#1ec4b4;          /* accent turquoise */
  --cyan-dark:#0fa394;
  /* alias historiques -> remappés sur le cyan (compat des classes existantes) */
  --gold:var(--cyan);
  --gold-dark:var(--cyan-dark);
  --ink:#15233f;
  --text:#3a4458;
  --muted:#6b7280;
  --line:#e1e8f3;
  --bg:#ffffff;
  --bg-alt:#f3f7fc;
  --bg-soft:#e9f1fb;
  --success:#2e7d32;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 4px 24px rgba(11,58,134,.08);
  --shadow-lg:0 18px 50px rgba(11,58,134,.16);
  --maxw:1140px;
  --teal:#15a89a;          /* turquoise profond pour les fonds */
  --teal-deep:#0c6f86;
  /* Dégradé sombre signature : bleu nuit -> bleu royal -> turquoise */
  --grad-dark:linear-gradient(145deg,var(--navy-deep) 0%,var(--navy) 42%,var(--teal-deep) 80%,var(--teal) 100%);
  --font:'Inter',system-ui,-apple-system,'Segoe UI','Helvetica Neue',Arial,sans-serif;
  --font-head:'Space Grotesk','Inter',system-ui,-apple-system,'Segoe UI',Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--text);
  font-size:16px;
  line-height:1.65;
  background:var(--bg);
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--navy-light);text-decoration:none;transition:color .2s}
a:hover{color:var(--navy)}
h1,h2,h3,h4{color:var(--ink);line-height:1.18;font-weight:700;font-family:var(--font-head);letter-spacing:-.015em}
.brand{font-family:var(--font-head)}
.hero-stats .stat .num,.kpi .v,.stat-band .num,.badge-num,.mission .m-ic,.eyebrow{font-family:var(--font-head)}
ul{list-style:none}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:84px 0}
.section--alt{background:var(--bg-alt)}
.section--soft{background:var(--bg-soft)}

/* ---------- Boutons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 26px;border-radius:var(--radius-sm);
  font-weight:700;font-size:.95rem;cursor:pointer;border:none;
  transition:transform .15s,box-shadow .15s,background .2s;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:linear-gradient(120deg,var(--cyan) 0%,var(--navy-light) 100%);color:#fff;box-shadow:0 8px 22px rgba(30,196,180,.38)}
.btn-gold:hover{background:linear-gradient(120deg,var(--cyan-dark) 0%,var(--navy) 100%);color:#fff;box-shadow:0 10px 26px rgba(30,196,180,.5)}
.btn-navy{background:linear-gradient(120deg,var(--navy) 0%,var(--navy-light) 100%);color:#fff;box-shadow:0 8px 22px rgba(11,58,134,.3)}
.btn-navy:hover{filter:brightness(1.08);color:#fff}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55)}
.btn-outline:hover{background:rgba(255,255,255,.12);color:#fff}
.btn-ghost{background:#fff;color:var(--navy);border:2px solid var(--line)}
.btn-ghost:hover{border-color:var(--gold);color:var(--navy)}

/* ---------- En-têtes de section ---------- */
.eyebrow{
  display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--gold-dark);margin-bottom:14px;
}
.section-head{max-width:720px;margin:0 auto 52px;text-align:center}
.section-head h2{font-size:2.1rem;margin-bottom:14px}
.section-head p{color:var(--muted);font-size:1.05rem}
.section-head--left{margin-left:0;text-align:left}

/* =========================================================
   HEADER / NAVIGATION
   ========================================================= */
.site-header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;color:var(--navy);font-size:1.25rem;letter-spacing:.02em}
.brand-logo{height:46px;width:auto;display:block}
.brand .mark{
  width:38px;height:38px;border-radius:9px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--navy) 0%,var(--navy-light) 100%);
  color:var(--gold);font-weight:800;font-size:1rem;flex-shrink:0;
}
.brand b{color:var(--gold-dark)}
/* Logo du footer : pastille blanche pour garder le logo couleur lisible sur fond sombre */
.footer-about .brand{display:inline-flex}
.footer-about .brand-logo{height:40px;background:#fff;padding:8px 14px;border-radius:12px;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--ink);font-weight:600;font-size:.95rem}
.nav-links a:hover{color:var(--gold-dark)}
.nav-links a.active{color:var(--gold-dark)}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;overflow:hidden;color:#fff;
  background:
    radial-gradient(circle at 1px 1px,rgba(255,255,255,.07) 1px,transparent 0) 0 0/26px 26px,
    var(--grad-dark);
}
.hero::after{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--gold)}
.hero::before{
  content:"";position:absolute;top:-120px;right:-120px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(30,196,180,.18) 0%,transparent 62%);
}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center;padding:90px 0 100px}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;padding:7px 15px;border-radius:30px;
  background:rgba(30,196,180,.14);border:1px solid rgba(30,196,180,.4);
  color:var(--gold);font-size:.82rem;font-weight:600;margin-bottom:22px;
}
.hero h1{color:#fff;font-size:3rem;line-height:1.12;margin-bottom:20px}
.hero h1 .accent{color:var(--gold)}
.hero p.lead{font-size:1.18rem;color:rgba(255,255,255,.86);max-width:560px;margin-bottom:32px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:38px}
.hero-stats{display:flex;gap:34px;flex-wrap:wrap}
.hero-stats .stat .num{font-size:1.9rem;font-weight:800;color:var(--gold)}
.hero-stats .stat .lbl{font-size:.85rem;color:rgba(255,255,255,.7)}

.hero-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:18px;padding:28px;backdrop-filter:blur(6px);
}
.hero-card h3{color:#fff;font-size:1.1rem;margin-bottom:18px;display:flex;align-items:center;gap:10px}
.hero-card .pillar{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.hero-card .pillar:last-child{border-bottom:none}
.hero-card .pillar .ic{font-size:1.4rem;flex-shrink:0}
.hero-card .pillar b{color:#fff;display:block;font-size:.96rem}
.hero-card .pillar span{color:rgba(255,255,255,.7);font-size:.85rem}

/* ---------- Bandeau de confiance ---------- */
.trust{background:var(--navy-deep);padding:22px 0}
.trust-inner{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:18px 40px;color:rgba(255,255,255,.62);font-size:.9rem;font-weight:600}
.trust-inner .t-item{display:flex;align-items:center;gap:9px}
.trust-inner .t-item .dot{width:7px;height:7px;border-radius:50%;background:var(--gold)}

/* =========================================================
   CARTES GÉNÉRIQUES
   ========================================================= */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 30px;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(30,196,180,.5)}
.card .ic-box{
  width:54px;height:54px;border-radius:13px;display:grid;place-items:center;font-size:1.6rem;
  background:var(--bg-soft);margin-bottom:18px;
}
.card h3{font-size:1.25rem;margin-bottom:10px}
.card p{color:var(--muted);font-size:.96rem;margin-bottom:14px}
.card .feat{display:flex;flex-direction:column;gap:8px}
.card .feat li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;color:var(--text)}
.card .feat li::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);margin-top:8px;flex-shrink:0}

/* ---------- À propos ---------- */
.about{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about .lead-txt{font-size:1.12rem;color:var(--ink);font-weight:600;margin-bottom:16px}
.about p{margin-bottom:14px;color:var(--text)}
.about-panel{
  background:linear-gradient(155deg,var(--navy) 0%,var(--navy-light) 100%);
  color:#fff;border-radius:18px;padding:36px;position:relative;overflow:hidden;
}
.about-panel::after{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:radial-gradient(circle,rgba(30,196,180,.2),transparent 65%)}
.about-panel h3{color:var(--gold);font-size:1.1rem;margin-bottom:20px;position:relative}
.about-panel .kv{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.12);position:relative}
.about-panel .kv:last-child{border-bottom:none}
.about-panel .kv .k{color:rgba(255,255,255,.7);font-size:.9rem}
.about-panel .kv .v{color:#fff;font-weight:700;font-size:.92rem;text-align:right}

/* ---------- Secteurs ---------- */
.sectors{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.sector{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:22px 18px;text-align:center;transition:.18s;
}
.sector:hover{border-color:var(--gold);transform:translateY(-3px)}
.sector .ic{font-size:1.7rem;margin-bottom:10px}
.sector b{display:block;color:var(--ink);font-size:.92rem}

/* ---------- Démarche / étapes ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step .n{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--navy);color:var(--gold);font-weight:800;font-size:1.15rem;margin-bottom:16px;
}
.step h4{font-size:1.08rem;margin-bottom:8px}
.step p{color:var(--muted);font-size:.92rem}

/* =========================================================
   ACTUALITÉS
   ========================================================= */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.news{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;
}
.news:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.news .thumb{
  height:160px;display:grid;place-items:center;color:#fff;font-size:2.6rem;position:relative;
}
.news .thumb.cdc{background:linear-gradient(150deg,#06143a,#1a3a8a)}
.news .thumb.douane{background:linear-gradient(150deg,#0d2461,#3949ab)}
.news .thumb.acad{background:linear-gradient(150deg,#1b5e20,#2e7d32)}
.news .thumb .tag{
  position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--navy);
  font-size:.72rem;font-weight:700;padding:5px 11px;border-radius:20px;letter-spacing:.04em;text-transform:uppercase;
}
.news .body{padding:24px;display:flex;flex-direction:column;flex:1}
.news .date{font-size:.82rem;color:var(--muted);margin-bottom:8px;font-weight:600}
.news h3{font-size:1.18rem;margin-bottom:10px;line-height:1.3}
.news p{color:var(--text);font-size:.94rem;margin-bottom:18px;flex:1}
.news .link{color:var(--gold-dark);font-weight:700;font-size:.9rem;display:inline-flex;align-items:center;gap:6px}
.news .link:hover{gap:10px}

/* Article détaillé (page actualités) */
.article{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:38px 40px;margin-bottom:30px;box-shadow:var(--shadow);
}
.article .meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:18px}
.article .chip{font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:20px;background:var(--bg-soft);color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.article .chip.gold{background:rgba(30,196,180,.18);color:var(--gold-dark)}
.article .chip.green{background:#e8f5e9;color:var(--success)}
.article h2{font-size:1.7rem;margin-bottom:14px}
.article p{margin-bottom:14px;color:var(--text)}
.article ul.bullets{margin:6px 0 18px}
.article ul.bullets li{display:flex;gap:10px;margin-bottom:9px;font-size:.96rem}
.article ul.bullets li::before{content:"\2713";color:var(--gold-dark);font-weight:800;flex-shrink:0}
.article .kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin:22px 0}
.article .kpi{background:var(--bg-alt);border-radius:var(--radius-sm);padding:18px;text-align:center;border-top:3px solid var(--gold)}
.article .kpi .v{font-size:1.7rem;font-weight:800;color:var(--navy)}
.article .kpi .l{font-size:.82rem;color:var(--muted);margin-top:4px}

/* =========================================================
   CTA + CONTACT
   ========================================================= */
.cta-band{
  background:
    radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0) 0 0/24px 24px,
    var(--grad-dark);
  color:#fff;border-radius:22px;padding:54px 50px;text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;top:-80px;left:-40px;width:300px;height:300px;background:radial-gradient(circle,rgba(30,196,180,.16),transparent 65%)}
.cta-band h2{color:#fff;font-size:2rem;margin-bottom:12px;position:relative}
.cta-band p{color:rgba(255,255,255,.85);font-size:1.08rem;max-width:560px;margin:0 auto 28px;position:relative}
.cta-band .hero-actions{justify-content:center;margin-bottom:0;position:relative}

.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:46px;align-items:start}
.contact-info .ci-item{display:flex;gap:16px;margin-bottom:26px}
.contact-info .ci-item .ic{width:46px;height:46px;border-radius:11px;background:var(--bg-soft);display:grid;place-items:center;font-size:1.3rem;flex-shrink:0}
.contact-info .ci-item b{display:block;color:var(--ink);margin-bottom:2px}
.contact-info .ci-item span,.contact-info .ci-item a{color:var(--muted);font-size:.95rem}

.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.86rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);
  font-family:inherit;font-size:.95rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(30,196,180,.15);
}
.field textarea{resize:vertical;min-height:120px}
.form .note{font-size:.82rem;color:var(--muted);margin-top:12px}

/* =========================================================
   PIED DE PAGE
   ========================================================= */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.7);padding:60px 0 28px;border-top:3px solid var(--teal)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;margin-bottom:40px}
.footer-grid .brand{color:#fff;margin-bottom:16px}
.footer-col h4{color:#fff;font-size:.92rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.footer-col ul li{margin-bottom:11px}
.footer-col a{color:rgba(255,255,255,.7);font-size:.93rem}
.footer-col a:hover{color:var(--gold)}
.footer-about p{font-size:.92rem;line-height:1.7;margin-bottom:14px}
.footer-social{display:flex;gap:12px}
.footer-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;font-size:1rem}
.footer-social a:hover{background:var(--gold);color:var(--navy)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;font-size:.85rem;color:rgba(255,255,255,.55)}
.footer-bottom a{color:rgba(255,255,255,.7)}

/* ---------- En-tête de page interne ---------- */
.page-hero{
  background:
    radial-gradient(circle at 1px 1px,rgba(255,255,255,.06) 1px,transparent 0) 0 0/24px 24px,
    var(--grad-dark);
  color:#fff;padding:64px 0;position:relative;
}
.page-hero::after{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--gold)}
.page-hero h1{color:#fff;font-size:2.4rem;margin-bottom:12px}
.page-hero p{color:rgba(255,255,255,.82);font-size:1.08rem;max-width:640px}
.breadcrumb{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:18px}
.breadcrumb a{color:rgba(255,255,255,.75)}

/* ---------- Contenu légal ---------- */
.legal{max-width:820px;margin:0 auto}
.legal h2{font-size:1.35rem;margin:32px 0 12px;padding-left:14px;border-left:4px solid var(--gold)}
.legal p,.legal li{color:var(--text);margin-bottom:10px}
.legal ul{list-style:disc;margin-left:22px}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:64px 0 76px}
  .hero h1{font-size:2.4rem}
  .about{grid-template-columns:1fr;gap:34px}
  .grid-3,.news-grid{grid-template-columns:repeat(2,1fr)}
  .sectors{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr;gap:34px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:680px){
  .section{padding:60px 0}
  .nav-links{
    position:fixed;top:78px;left:0;right:0;background:#fff;flex-direction:column;
    align-items:flex-start;gap:0;padding:8px 24px 22px;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow);transform:translateY(-140%);transition:transform .3s;height:auto;max-height:calc(100vh - 78px);overflow-y:auto;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:13px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:12px}
  .nav-cta .btn{display:none}
  .nav-toggle{display:flex}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .grid-3,.grid-2,.news-grid,.sectors,.steps{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:26px}
  .hero h1{font-size:2rem}
  .section-head h2,.cta-band h2,.page-hero h1{font-size:1.7rem}
  .cta-band{padding:40px 26px}
  .article{padding:28px 24px}
}

/* =========================================================
   ENRICHISSEMENTS — dégradés stylés, méga-menu, images
   ========================================================= */

/* ---------- Utilitaires dégradés ---------- */
.grad-text{
  background:linear-gradient(110deg,var(--navy-light) 0%,var(--cyan) 90%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-stats .stat .num,.kpi .v,.stat-band .num{
  background:linear-gradient(110deg,#7fe3d6,var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---------- Méga-menu / navigation déroulante ---------- */
.nav-links{position:relative}
.nav-item{position:relative;display:flex;align-items:center}
.nav-item > a{color:var(--ink);font-weight:600;font-size:.95rem;display:inline-flex;align-items:center;gap:7px;padding:10px 0}
.nav-item > a:hover{color:var(--cyan-dark)}
.nav-item.has-mega > a::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.55;transition:transform .25s}
.nav-item.has-mega:hover > a::after{transform:rotate(225deg) translateY(2px);opacity:.9}

.mega{
  position:absolute;top:100%;left:0;margin-top:12px;
  background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);
  padding:18px;display:grid;gap:8px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:opacity .22s ease,transform .22s ease,visibility .22s;z-index:300;
}
/* pont invisible pour ne pas perdre le survol entre le lien et le menu */
.mega::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px}
.mega-3{grid-template-columns:repeat(3,minmax(210px,1fr));width:700px}
.mega-2{grid-template-columns:repeat(2,minmax(230px,1fr));width:500px}
/* le 2e méga-menu (Offres) est plus à droite : on l'aligne par la droite */
.nav-item:nth-of-type(2) .mega{left:auto;right:0}
.nav-item.has-mega:hover .mega{opacity:1;visibility:visible;transform:translateY(0)}

.mega-col{padding:6px}
.mega-col + .mega-col{border-left:1px solid var(--line)}
.mega-col h5{font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--cyan-dark);font-weight:700;margin:0 0 8px;padding:0 12px}
.mega-col a{display:block;padding:9px 12px;border-radius:9px;color:var(--text);font-size:.9rem;font-weight:500;line-height:1.3;transition:background .15s,color .15s}
.mega-col a:hover{background:var(--bg-soft);color:var(--navy)}
.nav-mobile-cta{display:none}

/* ---------- HERO enrichi avec visuel ---------- */
.hero-visual{position:relative}
.hero-visual .frame{
  border-radius:22px;overflow:hidden;border:1px solid rgba(255,255,255,.18);
  box-shadow:0 30px 70px rgba(2,12,36,.5);position:relative;
}
.hero-visual .frame img{width:100%;height:100%;object-fit:cover;display:block}
.hero-visual .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 40%,rgba(11,58,134,.45))}
.hero-visual .float-card{
  position:absolute;bottom:-22px;left:-22px;background:rgba(255,255,255,.95);backdrop-filter:blur(6px);
  border-radius:14px;padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;max-width:230px;
}
.hero-visual .float-card .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:1.3rem;background:linear-gradient(135deg,var(--cyan),var(--navy-light));color:#fff;flex-shrink:0}
.hero-visual .float-card b{display:block;color:var(--ink);font-size:.92rem}
.hero-visual .float-card span{font-size:.8rem;color:var(--muted)}
.hero-visual .blob{position:absolute;width:300px;height:300px;border-radius:50%;filter:blur(60px);z-index:-1}
.hero-visual .blob.c1{background:rgba(30,196,180,.35);top:-40px;right:-30px}
.hero-visual .blob.c2{background:rgba(31,111,196,.3);bottom:-40px;left:20px}

/* ---------- Bande de statistiques ---------- */
.stat-band{
  background:var(--grad-dark);
  border-radius:20px;padding:40px;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  position:relative;overflow:hidden;
}
.stat-band::before{content:"";position:absolute;top:-60px;right:-40px;width:260px;height:260px;background:radial-gradient(circle,rgba(30,196,180,.25),transparent 65%)}
.stat-band .s{text-align:center;position:relative;color:#fff}
.stat-band .num{font-size:2.4rem;font-weight:800;line-height:1}
.stat-band .lbl{font-size:.9rem;color:rgba(255,255,255,.72);margin-top:8px}

/* ---------- Expertises : lignes alternées image / texte ---------- */
.xp-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;margin-bottom:60px}
.xp-row:last-child{margin-bottom:0}
.xp-row.flip .xp-media{order:2}
.xp-media{border-radius:20px;overflow:hidden;position:relative;box-shadow:var(--shadow-lg);min-height:300px}
.xp-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.xp-media::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,rgba(11,58,134,.15),rgba(4,32,79,.45))}
.xp-body .eyebrow{margin-bottom:10px}
.xp-body h3{font-size:1.6rem;margin-bottom:14px}
.xp-body .sub{font-size:1.05rem;color:var(--navy);font-weight:600;margin-bottom:14px}
.xp-body p{color:var(--text);margin-bottom:14px}

/* Sous-cartes d'expertise (3 par pôle) */
.pole{margin-bottom:64px}
.pole:last-child{margin-bottom:0}
.pole-head{display:flex;align-items:center;gap:16px;margin-bottom:26px}
.pole-head .badge-num{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:linear-gradient(135deg,var(--cyan),var(--navy-light));color:#fff;flex-shrink:0}
.pole-head h2{font-size:1.7rem;margin:0}
.pole-head p{color:var(--muted);font-size:.95rem;margin:2px 0 0}

/* ---------- Cartes blog / webinaires ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.post .ph{height:180px;overflow:hidden;position:relative}
.post .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post:hover .ph img{transform:scale(1.06)}
.post .ph .cat{position:absolute;top:14px;left:14px;background:linear-gradient(120deg,var(--cyan),var(--navy-light));color:#fff;font-size:.72rem;font-weight:700;padding:5px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}
.post .body{padding:22px;flex:1;display:flex;flex-direction:column}
.post .body .date{font-size:.8rem;color:var(--muted);font-weight:600;margin-bottom:8px}
.post .body h3{font-size:1.12rem;margin-bottom:10px;line-height:1.3}
.post .body p{color:var(--text);font-size:.92rem;flex:1;margin-bottom:14px}
.post .body .link{color:var(--cyan-dark);font-weight:700;font-size:.88rem}

/* ---------- Partenaires (logos) ---------- */
.logo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.logo-cell{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);height:110px;display:grid;place-items:center;padding:18px;transition:.18s}
.logo-cell:hover{border-color:var(--cyan);box-shadow:var(--shadow);transform:translateY(-3px)}
.logo-cell img{max-height:64px;max-width:100%;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.2s}
.logo-cell:hover img{filter:grayscale(0);opacity:1}
.logo-strip{display:flex;flex-wrap:wrap;gap:30px 44px;align-items:center;justify-content:center;opacity:.75}
.logo-strip img{max-height:46px;filter:grayscale(1);transition:.2s}
.logo-strip img:hover{filter:grayscale(0)}

/* ---------- Section title à gauche + lien ---------- */
.head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:40px;flex-wrap:wrap}
.head-row .section-head{margin:0;text-align:left;max-width:640px}

/* ---------- Image ronde "à propos" ---------- */
.about-media{position:relative;border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);min-height:360px}
.about-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about-media .tagchip{position:absolute;bottom:18px;left:18px;right:18px;background:rgba(4,32,79,.78);backdrop-filter:blur(6px);color:#fff;border-radius:12px;padding:14px 18px;font-size:.9rem}
.about-media .tagchip b{color:var(--cyan)}

/* ---------- Responsive enrichissements ---------- */
@media(max-width:980px){
  .stat-band{grid-template-columns:repeat(2,1fr);gap:24px}
  .xp-row{grid-template-columns:1fr;gap:26px}
  .xp-row.flip .xp-media{order:0}
  .xp-media{min-height:220px}
  .logo-grid{grid-template-columns:repeat(3,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  /* Navigation mobile : on masque les méga-menus, liens de 1er niveau seulement */
  .nav-item{width:100%;border-bottom:1px solid var(--line)}
  .nav-item > a{width:100%;padding:13px 0}
  .nav-item.has-mega > a::after{margin-left:auto}
  .mega{display:none !important}
  .stat-band{grid-template-columns:1fr 1fr;padding:28px 20px}
  .stat-band .num{font-size:1.9rem}
  .blog-grid,.logo-grid{grid-template-columns:1fr 1fr}
  .hero-visual .float-card{left:0}
  .nav-mobile-cta{display:inline-flex;margin-top:16px;width:100%;justify-content:center}
  .head-row .section-head{text-align:center}
}

/* ---------- À la une : IA & Gouvernance ---------- */
.spotlight{
  position:relative;overflow:hidden;color:#fff;border-radius:24px;
  background:
    radial-gradient(circle at 1px 1px,rgba(255,255,255,.05) 1px,transparent 0) 0 0/24px 24px,
    var(--grad-dark);
  display:grid;grid-template-columns:1.25fr .75fr;gap:40px;align-items:center;padding:46px 48px;
}
.spotlight::before{content:"";position:absolute;top:-90px;right:-60px;width:340px;height:340px;background:radial-gradient(circle,rgba(30,196,180,.28),transparent 65%)}
.spotlight .sp-body{position:relative}
.ribbon{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(120deg,var(--cyan),var(--navy-light));color:#fff;font-weight:700;font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;padding:7px 15px;border-radius:30px;margin-bottom:16px}
.spotlight h2{color:#fff;font-size:1.95rem;margin-bottom:12px}
.spotlight p{color:rgba(255,255,255,.85);margin-bottom:22px;max-width:560px}
.sp-feats{display:grid;gap:12px;position:relative}
.sp-feat{display:flex;gap:13px;align-items:center;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:13px;padding:14px 16px}
.sp-feat .ic{font-size:1.45rem;flex-shrink:0}
.sp-feat b{display:block;font-size:.96rem;color:#fff}
.sp-feat span{font-size:.82rem;color:rgba(255,255,255,.72)}
@media(max-width:860px){
  .spotlight{grid-template-columns:1fr;gap:28px;padding:34px 26px}
  .spotlight h2{font-size:1.6rem}
}

/* =========================================================
   ICÔNES SVG MAISON
   ========================================================= */
.svg-ic{width:1em;height:1em;display:inline-block;vertical-align:middle;fill:none;stroke:currentColor;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}

/* Tuile d'icône en dégradé (cartes d'expertise, etc.) */
.ic-box{
  background:linear-gradient(135deg,var(--cyan) 0%,var(--navy-light) 100%);
  color:#fff;box-shadow:0 10px 22px rgba(30,196,180,.32);
}
.ic-box .svg-ic{width:28px;height:28px;stroke-width:1.7}
.badge-num .svg-ic{width:27px;height:27px;stroke-width:1.7}
.float-card .ic .svg-ic{width:22px;height:22px}
.hero-card .pillar .ic{color:var(--cyan)}
.hero-card .pillar .ic .svg-ic{width:24px;height:24px}
.sp-feat .ic{color:var(--cyan)}
.sp-feat .ic .svg-ic{width:24px;height:24px}

/* Secteurs : pastille d'icône ronde en dégradé doux */
.sector .ic{
  width:54px;height:54px;margin:0 auto 12px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(circle at 35% 30%,rgba(30,196,180,.18),rgba(31,111,196,.12));
  color:var(--cyan-dark);
}
.sector .ic .svg-ic{width:26px;height:26px;stroke-width:1.8}

/* =========================================================
   CARTES MISSION (réalisations société)
   ========================================================= */
.missions{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.mission{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;
  box-shadow:var(--shadow);transition:transform .18s,box-shadow .18s,border-color .18s;display:flex;flex-direction:column;overflow:hidden;
}
.mission::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(120deg,var(--cyan),var(--navy-light));opacity:0;transition:opacity .2s}
.mission:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(30,196,180,.5)}
.mission:hover::before{opacity:1}
.mission .top{display:flex;align-items:center;gap:14px;margin-bottom:15px}
.mission .m-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,var(--cyan),var(--navy-light));color:#fff;flex-shrink:0;box-shadow:0 8px 18px rgba(30,196,180,.3)}
.mission .m-ic .svg-ic{width:27px;height:27px;stroke-width:1.7}
.mission .tag{display:block;font-size:.71rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan-dark);margin-bottom:3px}
.mission h3{font-size:1.14rem;line-height:1.25;margin:0}
.mission .client{font-size:.84rem;color:var(--muted);margin-top:3px}
.mission p{color:var(--text);font-size:.92rem;margin:13px 0 15px;flex:1}
.mission .chips{display:flex;flex-wrap:wrap;gap:6px}
.mission .chips span{font-size:.7rem;background:var(--bg-soft);color:var(--navy);padding:4px 10px;border-radius:20px;font-weight:600}
.mission .kpi-line{margin-top:15px;padding-top:14px;border-top:1px solid var(--line);font-size:.86rem;color:var(--muted);display:flex;align-items:center;gap:8px}
.mission .kpi-line .svg-ic{width:18px;height:18px;color:var(--cyan-dark)}
.mission .kpi-line b{color:var(--ink)}

/* Mission mise en avant (large, sur 2 colonnes) */
.mission.feature{grid-column:span 2;background:var(--grad-dark);color:#fff;border:none}
.mission.feature .tag{color:var(--cyan)}
.mission.feature h3{color:#fff;font-size:1.5rem}
.mission.feature .client{color:rgba(255,255,255,.7)}
.mission.feature p{color:rgba(255,255,255,.85);font-size:.98rem}
.mission.feature .m-ic{background:rgba(255,255,255,.14)}
.mission.feature .chips span{background:rgba(255,255,255,.12);color:#fff}
.mission.feature .kpi-line{border-top-color:rgba(255,255,255,.18);color:rgba(255,255,255,.8)}
.mission.feature .kpi-line b{color:#fff}
.mission.feature::before{display:none}

/* Bandeau "en partenariat" */
.partner-note{
  display:flex;align-items:center;gap:12px;background:var(--bg-soft);border:1px solid var(--line);
  border-left:4px solid var(--cyan);border-radius:12px;padding:14px 18px;font-size:.92rem;color:var(--text);margin:6px 0 26px;
}
.partner-note .svg-ic{width:22px;height:22px;color:var(--cyan-dark)}
.partner-note b{color:var(--navy)}

/* Icône inline dans les titres d'articles */
.article h2{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.h-ic{display:inline-grid;place-items:center;width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--cyan),var(--navy-light));color:#fff;flex-shrink:0;box-shadow:0 8px 18px rgba(30,196,180,.3)}
.h-ic .svg-ic{width:23px;height:23px;stroke-width:1.7}

/* Bandeau de références (track record) */
.refs{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.refs span{background:#fff;border:1px solid var(--line);border-radius:30px;padding:9px 18px;font-size:.86rem;font-weight:600;color:var(--navy);transition:.18s}
.refs span:hover{border-color:var(--cyan);color:var(--cyan-dark)}

@media(max-width:980px){
  .missions{grid-template-columns:repeat(2,1fr)}
  .mission.feature{grid-column:span 2}
}
@media(max-width:680px){
  .missions{grid-template-columns:1fr}
  .mission.feature{grid-column:span 1}
}
