/* =========================================================================
   MWB — app_v3.css (unifié & harmonisé)
   - Palette, typographie, layout responsive
   - Header (topbar + brandbar) desktop & mobile (drawer)
   - Hero / carousel
   - Sections (services, KPI, timeline, callout, documents, trust, testimonials, CTA)
   - Formulaires & utilitaires
   - A11y & préférences (reduced motion)
   ========================================================================= */

/* Variables (surclassables par :root inline dans layout.php) */
:root{
  --mwb-primary: #0b2a4a;
  --mwb-accent:  #ff7a00;
  --mwb-ink:     #0b1220;
  --mwb-ink-2:   #112135;
  --mwb-muted:   #667792;
  --mwb-ring:    #e6eef6;
  --mwb-bg:      #f6f8fb;
  --mwb-bg-soft: #fff;
  --mwb-radius:  16px;
  --mwb-container: 1180px;
  --mwb-font: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* Reset de base */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--mwb-font);color:var(--mwb-ink);background:var(--mwb-bg);line-height:1.6}
a{color:var(--mwb-primary);text-decoration:none}
img{max-width:100%;display:block}

/* Conteneur */
.container{max-width:var(--mwb-container);margin-inline:auto;padding:0 16px}

/* Boutons */
.btn{display:inline-block;padding:.65rem 1rem;border-radius:999px;text-decoration:none;cursor:pointer}
.btn-primary{background:var(--mwb-accent);color:#fff}
.btn-outline{background:#fff;color:var(--mwb-ink-2);border:1px solid var(--mwb-ring)}
.btn:hover{filter:brightness(1.02)}

/* Sections */
.section{padding:72px 0}
.section.alt{background:#fff}

/* Grid utilitaires */
.grid{display:grid;gap:22px}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:980px){
  .grid.two,.grid.three{grid-template-columns:1fr}
}

/* Cartes */
.card{background:#fff;border:1px solid var(--mwb-ring);border-radius:var(--mwb-radius);padding:14px;box-shadow:0 6px 22px rgba(9,26,48,.05)}
.card-link{display:block}
.card-link img{width:100%;height:180px;object-fit:cover;border-radius:10px}

/* Kicker / lead / pills / chips */
.kicker{letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:#7e8aa1}
.lead{color:var(--mwb-muted);max-width:75ch}
.list-pill{display:flex;flex-wrap:wrap;gap:10px;list-style:none;margin:12px 0 0 0;padding:0}
.pill,.chip{display:inline-block;border-radius:999px;padding:.45rem .75rem;border:1px solid var(--mwb-ring);background:#fff;color:#0f213a;font-size:.95rem;line-height:1.2}

/* =========================================================================
   HEADER
   ========================================================================= */
header.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--mwb-ring);box-shadow:0 4px 18px rgba(0,0,0,.035)}
.topbar{background:#0b2a4a;color:#cfe3ff;font-size:13px}
.topbar a{color:#fff}
.topbar .container{display:flex;align-items:center;justify-content:space-between;padding:8px 16px}
.lang a{opacity:.7;margin-left:10px}
.lang a.active{opacity:1;font-weight:600}

/* Brandbar + menus */
.brandbar{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:#111}
.brand img{height:46px}
.brand__name{display:none} /* logo seul */

/* Desktop nav */
nav.mainnav{display:none}
nav.mainnav ul{display:flex;gap:22px;list-style:none;margin:0;padding:0}
nav.mainnav a{color:#112135;text-decoration:none;font-weight:500;padding:8px;border-radius:10px}
nav.mainnav a:hover{background:#f5f7fb}

/* Mobile nav */
.nav-mobile-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--mwb-ring);border-radius:10px;background:#fff;cursor:pointer}
.nav-mobile-toggle span{display:block;width:20px;height:2px;background:#0b2a4a;position:relative}
.nav-mobile-toggle span::before,.nav-mobile-toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:#0b2a4a}
.nav-mobile-toggle span::before{top:-6px}.nav-mobile-toggle span::after{top:6px}

.mobile-drawer{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none}
.mobile-drawer__panel{position:absolute;top:0;left:0;width:min(86%,360px);height:100%;background:#fff;box-shadow:0 0 30px rgba(0,0,0,.15);display:flex;flex-direction:column}
[dir="rtl"] .mobile-drawer__panel{left:auto;right:0}
.mobile-drawer__head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--mwb-ring)}
.mobile-drawer__brand img{height:36px}
.mobile-drawer__close{width:40px;height:40px;border:1px solid var(--mwb-ring);border-radius:10px;background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}
.mobile-drawer__body{padding:10px 14px;overflow:auto}
.mobile-drawer nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.mobile-drawer nav a{display:block;padding:10px 8px;border-radius:10px;color:#0f213a}
.mobile-drawer nav a:hover{background:#f5f7fb}
.mobile-lang{display:flex;gap:8px;margin-top:12px}
.mobile-lang a{display:inline-block;padding:.35rem .6rem;border:1px solid var(--mwb-ring);border-radius:999px;color:#0f213a}
.mobile-contacts{margin-top:10px;color:#667792;font-size:.92rem}

/* Desktop breakpoint */
@media (min-width:980px){
  .nav-mobile-toggle{display:none}
  nav.mainnav{display:block}
  .mobile-drawer{display:none!important}
}

/* =========================================================================
   HERO / CAROUSEL
   ========================================================================= */
.hero--carousel{padding:0;background:#081e35;color:#fff}
.hero--carousel .container{position:relative}
.carousel__inner{position:relative}
.carousel__slide{display:none;min-height:72vh;background-size:cover;background-position:center;border-radius:16px;position:relative;margin-top:16px}
.carousel__slide:first-child{display:block}
.carousel__slide::before{content:"";position:absolute;inset:0;border-radius:16px;background:linear-gradient(90deg,rgba(8,30,53,.75),rgba(8,30,53,.2))}

.hero__copy{position:absolute;left:40px;bottom:40px;max-width:760px;background:rgba(255,255,255,.86);backdrop-filter:blur(8px);padding:24px;border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.2)}
.hero__copy h1{margin:6px 0;font-size:32px;color:#0b2a4a}
.hero__copy p{margin:0 0 8px 0;color:#112135}
.chip{display:inline-block;background:rgba(11,42,74,.08);border:1px solid rgba(11,42,74,.15);border-radius:999px;padding:6px 10px;margin:4px 6px 0 0;font-size:12px}

.carousel__dots{position:absolute;left:40px;bottom:16px;display:flex;gap:6px;z-index:5}
.carousel__dots b{display:block;width:10px;height:10px;border-radius:999px;background:rgba(255,255,255,.6);border:1px solid #fff;cursor:pointer}
.carousel__dots b.active{background:var(--mwb-accent)}

/* =========================================================================
   BLOCS / COMPOSANTS
   ========================================================================= */
.ribbon{background:linear-gradient(90deg,var(--mwb-primary),#133a63);color:#fff}
.kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.kpi{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:var(--mwb-radius);padding:14px;text-align:center}
.kpi-label{opacity:.9;font-size:13px}
.kpi-value{font-weight:800;font-size:20px}

.timeline{position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:12px;top:0;bottom:0;width:2px;background:var(--mwb-ring)}
[dir="rtl"] .timeline{padding-left:0;padding-right:28px}
[dir="rtl"] .timeline::before{left:auto;right:12px}
.tl-item{position:relative;margin:12px 0;display:flex;gap:12px;align-items:flex-start}
.tl-index{flex:0 0 auto;width:24px;height:24px;border-radius:999px;background:#fff;border:1px solid var(--mwb-ring);color:#0b2a4a;font-weight:700;font-size:.9rem;line-height:24px;text-align:center;box-shadow:0 6px 22px rgba(9,26,48,.05);margin-left:-16px}
[dir="rtl"] .tl-index{margin-left:0;margin-right:-16px}
.tl-title{color:#0f213a;font-weight:600;line-height:1.25}
.tl-sub{color:#667792;font-size:.95rem;line-height:1.35;margin-top:.15rem;max-width:75ch}

.section.callout{background:#fff7ef;border-top:1px solid #ffe1c2;border-bottom:1px solid #ffe1c2}

.testi{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
.testi__item{background:#fff;border:1px solid var(--mwb-ring);border-radius:var(--mwb-radius);padding:14px;display:flex;gap:12px;align-items:flex-start;box-shadow:0 6px 22px rgba(9,26,48,.05)}
.testi__avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}
@media (max-width:900px){.testi{grid-template-columns:1fr}}

.cta-band{background:linear-gradient(90deg,#fff,#fef6ee)}
.cta-band__inner{display:flex;align-items:center;justify-content:space-between;gap:16px}

.trust-logos{display:grid;gap:18px 22px;grid-template-columns:repeat(6,minmax(0,1fr));align-items:center;margin-top:10px}
@media (max-width:1200px){.trust-logos{grid-template-columns:repeat(5,1fr)}}
@media (max-width:1000px){.trust-logos{grid-template-columns:repeat(4,1fr)}}
@media (max-width:800px){ .trust-logos{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){ .trust-logos{grid-template-columns:repeat(2,1fr)}}
.trust-logos__item{display:flex;align-items:center;justify-content:center;padding:10px;border:1px solid var(--mwb-ring);border-radius:12px;background:#fff;min-height:72px;box-shadow:0 6px 22px rgba(9,26,48,.05)}
.trust-logo{max-width:100%;max-height:44px;filter:grayscale(25%);opacity:.9;transition:opacity .2s,filter .2s,transform .2s}
.trust-logos__item:hover .trust-logo{filter:grayscale(0%);opacity:1;transform:translateY(-1px)}

.services-block .svc-icon,
.services-alt .svc-icon{width:40px;height:40px;border-radius:10px;background:#f4f7fb;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.services-block .svc-icon img,
.services-alt .svc-icon img{max-width:24px;max-height:24px}

.documents-block .list-pill .pill{box-shadow:0 6px 22px rgba(9,26,48,.05)}

/* =========================================================================
   FORMULAIRES
   ========================================================================= */
form label{display:block;font-weight:600;color:#0f213a}
input,textarea,select{width:100%;margin-top:6px;border:1px solid var(--mwb-ring);border-radius:10px;padding:.65rem .8rem;background:#fff;color:#0f213a}
textarea{min-height:140px;resize:vertical}
.hint{display:block;font-size:.85rem;color:#7e8aa1;margin-top:4px}
.flash{background:#e8f7ed;border:1px solid #b7e5c4;color:#135d2e;padding:12px;border-radius:10px;margin-top:10px}

/* =========================================================================
   FOOTER
   ========================================================================= */
footer.site-footer{margin-top:60px;background:#071829;color:#c0d0e4;padding:28px 0}
footer.site-footer a{color:#fff;text-decoration:underline}
footer .cols{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:24px;padding:30px 0}
footer h4{margin:0 0 8px 0;color:#fff}
@media (max-width:900px){footer .cols{grid-template-columns:1fr}}

/* =========================================================================
   ACCESSIBILITÉ & PRÉFÉRENCES
   ========================================================================= */
@media (prefers-reduced-motion: reduce){
  *{animation: none!important; transition: none!important}
}
