/* ============================================================
   Carange Solutions — Feuille de styles PRODUCTION (toutes pages)
   100% statique · aucune dépendance · à charger via WPCode (site-wide)
   Police Manrope limitée à 3 graisses : 400 / 600 / 700.
   Pour un score PageSpeed maximal, remplacez les .ttf par des .woff2.
   ============================================================ */
@font-face{font-family:"Manrope";src:url("assets/fonts/Manrope-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap;}
@font-face{font-family:"Manrope";src:url("assets/fonts/Manrope-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap;}
@font-face{font-family:"Manrope";src:url("assets/fonts/Manrope-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap;}

/* Munia Design System — colors and type tokens
 * Source of truth: brand/04-colors.md, brand/05-typography.md
 */

/* Manrope — uploaded brand font (replaces previous Inter substitute) */

:root {
  /* ===== Brand color tokens (technical, exact) ===== */
  --munia-noir: #252525;
  --munia-blanc: #FFFFFF;
  --munia-blanc-doux: #F3F3F3;

  /* Accents — use 1 per composition */
  --munia-vert: #65DC8A;
  --munia-bleu: #6A8BFF;
  --munia-orange: #FF9602;
  --munia-jaune: #FFD75F;
  --munia-gris-pale: #B8CAC5;
  --munia-sauge: #B8CAC5; /* nom officiel — alias de gris-pale */

  /* ===== Semantic foreground / background ===== */
  --bg: var(--munia-blanc);
  --bg-soft: var(--munia-blanc-doux);
  --bg-dark: var(--munia-noir);

  --fg: var(--munia-noir);
  --fg-muted: rgba(37, 37, 37, 0.65);
  --fg-subtle: rgba(37, 37, 37, 0.45);
  --fg-on-dark: var(--munia-blanc);
  --fg-on-dark-muted: rgba(255, 255, 255, 0.70);

  /* Lines & dividers */
  --line: rgba(37, 37, 37, 0.12);
  --line-strong: rgba(37, 37, 37, 0.30);
  --line-on-dark: rgba(255, 255, 255, 0.16);

  /* Semantic accents */
  --accent-success: var(--munia-vert);
  --accent-info: var(--munia-bleu);
  --accent-warning: var(--munia-orange);
  --accent-highlight: var(--munia-jaune);
  --accent-neutral: var(--munia-gris-pale);

  /* ===== Typography ===== */
  --font-sans: "Manrope", "Helvetica Neue", Arial, sans-serif;
  --font-display: "Manrope", "Helvetica Neue", Arial, sans-serif;

  --fw-regular: 400;
  --fw-medium: 600;
  --fw-bold: 700;

  /* Type scale (web px) */
  --fs-h1: 56px;
  --fs-h2: 36px;
  --fs-h3: 24px;
  --fs-body: 16px;
  --fs-small: 14px;
  --fs-caption: 13px;

  --lh-display: 1.1;
  --lh-heading: 1.2;
  --lh-body: 1.5;

  --tracking-display: -0.02em;
  --tracking-heading: -0.01em;
  --tracking-body: 0;

  /* ===== Spacing (4px base) ===== */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;

  /* ===== Radii ===== */
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 20px;
  --radius-xl: 28px;
  --radius-pill: 999px;

  /* ===== Elevation (subtle, brand is mostly flat) ===== */
  --shadow-1: 0 1px 0 rgba(37,37,37,0.06), 0 1px 2px rgba(37,37,37,0.04);
  --shadow-2: 0 2px 6px rgba(37,37,37,0.06), 0 8px 24px rgba(37,37,37,0.06);
  --shadow-3: 0 12px 40px rgba(37,37,37,0.10);

  /* ===== Motion ===== */
  --ease-standard: cubic-bezier(0.2, 0.7, 0.2, 1);
  --dur-fast: 120ms;
  --dur-base: 200ms;
  --dur-slow: 320ms;
}

/* ===== Base ===== */
html, body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ===== Semantic type styles ===== */
.h1, h1 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-h1);
  line-height: var(--lh-display);
  letter-spacing: var(--tracking-display);
  margin: 0;
}

.h2, h2 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-h2);
  line-height: var(--lh-heading);
  letter-spacing: var(--tracking-heading);
  margin: 0;
}

.h3, h3 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-h3);
  line-height: var(--lh-heading);
  letter-spacing: var(--tracking-heading);
  margin: 0;
}

.eyebrow {
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: 13px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--fg-muted);
}

.body, p {
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
}

.body-lead {
  font-size: 19px;
  line-height: 1.5;
  font-weight: var(--fw-regular);
}

.caption {
  font-size: var(--fs-caption);
  line-height: 1.4;
  color: var(--fg-muted);
}

.mono, code, kbd, samp {
  font-family: "JetBrains Mono", "SF Mono", ui-monospace, Menlo, monospace;
  font-size: 0.92em;
}


/* Curseur personnalisé — activé par script.js uniquement (non tactile) */
body.cursor-custom, body.cursor-custom * { cursor: none; }


/* =================== styles.css =================== */
/* ============================================================
   Carange Solutions — Landing
   Munia DS · light theme · big motion
   ============================================================ */

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  overflow-x: hidden;
}
body {  }
@media (max-width: 900px) { body { cursor: auto; } }

a { color: inherit; text-decoration: none; }
button { font-family: inherit;  }

::selection { background: var(--munia-vert); color: var(--munia-noir); }

/* ============= CUSTOM CURSOR ============= */
.cursor-dot, .cursor-ring {
  position: fixed; top: 0; left: 0;
  pointer-events: none; z-index: 9999;
  will-change: transform;
  border-radius: 999px;
  mix-blend-mode: difference;
}
.cursor-dot {
  width: 8px; height: 8px;
  background: #fff;
  transform: translate(-50%, -50%);
  transition: transform 120ms var(--ease-standard), opacity 200ms;
}
.cursor-ring {
  width: 36px; height: 36px;
  border: 1.5px solid #fff;
  transform: translate(-50%, -50%);
  transition: width 220ms var(--ease-standard), height 220ms var(--ease-standard), border-color 200ms;
}
.cursor-ring.is-hover {
  width: 72px; height: 72px;
  border-color: var(--munia-vert);
}
.cursor-ring.is-text { width: 4px; height: 24px; border-radius: 2px; }
@media (max-width: 900px) { .cursor-dot, .cursor-ring { display: none; } }

/* ============= LAYOUT ============= */
.wrap { max-width: 1440px; margin: 0 auto; padding: 0 48px; }
@media (max-width: 700px) { .wrap { padding: 0 20px; } }

.section { position: relative; padding: 140px 0; }
@media (max-width: 700px) { .section { padding: 80px 0; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--fg-muted);
}
.eyebrow::before {
  content: ""; width: 24px; height: 1px; background: currentColor;
}

/* ============= HEADER ============= */
.header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 22px 48px;
  display: flex; align-items: center; justify-content: space-between;
  transition: backdrop-filter 300ms, background 300ms, border-bottom 300ms, padding 300ms;
  border-bottom: 1px solid transparent;
}
.header.is-scrolled {
  background: rgba(243, 243, 243, 0.78);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--line);
  padding: 14px 48px;
}
.header__logo {
  display: flex; align-items: center; gap: 10px;
}
.header__logo svg { height: 24px; width: auto; }
.header__logo-text {
  font-size: 13px; font-weight: 700; letter-spacing: -0.01em;
}
.header__logo-text-sub {
  display: block; font-size: 10px; font-weight: 600;
  color: var(--fg-muted); letter-spacing: 0.08em; text-transform: uppercase;
  margin-top: -2px;
}
.header__nav {
  display: flex; align-items: center; gap: 4px;
}
/* Top-level nav links + dropdown trigger */
.header__nav > a,
.header__nav-link,
.header__nav-btn {
  font-size: 14px; font-weight: 600; padding: 10px 16px;
  border-radius: 999px;
  transition: background 200ms, color 200ms;
  position: relative;
  color: var(--fg);
}
.header__nav > a:hover,
.header__nav-link:hover,
.header__nav-btn:hover { background: rgba(37,37,37,0.06); }
.header__nav > a.is-active,
.header__nav-link.is-active { background: rgba(37,37,37,0.08); font-weight: 600; }

/* Nav trigger button reset */
.header__nav-btn {
  display: inline-flex; align-items: center; gap: 6px;
  border: none; background: transparent;
  font-family: inherit; 
}
.header__chevron {
  flex: none;
  transition: transform 200ms var(--ease-standard);
}
.header__dropdown.is-open .header__chevron { transform: rotate(180deg); }

/* ============= DROPDOWN ============= */
.header__dropdown { position: relative; }

.header__dropdown-menu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  min-width: 250px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 8px 32px rgba(37,37,37,0.10), 0 2px 6px rgba(37,37,37,0.06);
  padding: 6px;
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms var(--ease-standard), transform 180ms var(--ease-standard);
  z-index: 200;
}
.header__dropdown.is-open .header__dropdown-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.header__dropdown-menu a {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 14px; font-weight: 600;
  color: var(--fg);
  transition: background 150ms;
}
.header__dropdown-menu a:hover { background: var(--bg-soft); }
.header__dropdown-icon {
  width: 30px; height: 30px;
  border-radius: 8px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  flex: none;
}
.header__dropdown-icon svg { width: 14px; height: 14px; }

/* ============= LANG TOGGLE ============= */
.header__lang {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
  border: 1px solid var(--line-strong); padding: 6px 10px;
  border-radius: 999px; margin-left: 6px;
  background: transparent; color: var(--fg-muted);
  font-family: inherit; 
  transition: border-color 200ms;
}
.header__lang:hover { border-color: var(--munia-noir); color: var(--fg); }
.header__lang .is-active { color: var(--fg); font-weight: 700; }
.header__lang-sep { opacity: 0.35; }

/* ============= HEADER ACTIONS (signin + contact) ============= */
.header__actions {
  display: flex; align-items: center; gap: 8px;
  margin-left: 16px; flex: none;
}
.header__actions .btn {
  padding: 11px 18px;
  font-size: 13px;
}
.header__signin {
  display: inline-flex; align-items: center; gap: 7px;
}

/* ============= BURGER MOBILE ============= */
.header__burger {
  display: none;
  flex-direction: column; align-items: center; justify-content: center;
  gap: 5px;
  width: 40px; height: 40px; padding: 0;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
}
.header__burger span {
  display: block;
  width: 18px; height: 1.5px;
  background: var(--fg); border-radius: 2px;
  transition: transform 250ms var(--ease-standard), opacity 200ms;
}
.header__burger.is-open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.header__burger.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.header__burger.is-open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ============= MOBILE NAV ============= */
.header__mobile {
  position: fixed;
  top: 60px; left: 0; right: 0; bottom: 0;
  background: var(--bg);
  z-index: 99;
  overflow-y: auto;
  border-top: 1px solid var(--line);
  padding: 0 24px 32px;
  display: flex; flex-direction: column; gap: 0;
}
.header__mobile > a {
  display: block;
  font-size: 20px; font-weight: 700;
  letter-spacing: -0.02em;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  color: var(--fg);
  transition: color 200ms;
}
.header__mobile > a:hover { color: var(--munia-noir); }
.header__mobile-section {
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
  margin-bottom: 0;
}
.header__mobile-label {
  display: block;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--fg-muted);
  padding: 20px 0 6px;
}
.header__mobile-section > a {
  display: block;
  padding: 13px 0;
  font-size: 17px; font-weight: 600;
  color: var(--fg);
  letter-spacing: -0.01em;
  border-bottom: none;
}
.header__mobile-footer {
  margin-top: auto;
  padding-top: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.header__mobile-footer .header__lang { margin-left: 0; align-self: flex-start; }
.header__mobile-footer .btn { justify-content: center; }
@media (max-width: 900px) {
  .header { padding: 16px 20px; }
  .header.is-scrolled { padding: 12px 20px; }
  .header__nav { display: none; }
  .header__actions { display: none; }
  .header__burger { display: flex; }
}

/* ============= BUTTONS ============= */
.btn {
  position: relative;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 24px;
  font-size: 14px; font-weight: 600;
  border-radius: 999px;
  border: 1px solid transparent;
  transition: background 200ms var(--ease-standard), color 200ms, transform 250ms var(--ease-standard);
  
  white-space: nowrap;
}
.btn--primary {
  background: var(--munia-noir); color: var(--munia-blanc);
}
.btn--primary:hover { background: #000; }
.btn--ghost {
  background: transparent; color: var(--munia-noir);
  border-color: var(--line-strong);
}
.btn--ghost:hover { background: rgba(37,37,37,0.06); }
.btn--accent {
  background: var(--munia-vert); color: var(--munia-noir);
}
.btn--accent:hover { background: #4cc873; }
.btn__arrow {
  display: inline-flex; transition: transform 250ms var(--ease-standard);
}
.btn:hover .btn__arrow { transform: translateX(4px); }

.btn--magnetic { transition: transform 320ms var(--ease-standard); }

/* ============= HERO ============= */
.hero {
  position: relative;
  padding-top: 180px; padding-bottom: 120px;
  overflow: hidden;
  background: var(--bg-soft);
}
.hero__inner { position: relative; z-index: 2; }
.hero__eyebrow {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 32px;
}
.hero__dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--munia-vert);
  position: relative;
}
.hero__dot::before {
  content: ""; position: absolute; inset: -4px;
  border-radius: 50%; border: 2px solid var(--munia-vert);
  opacity: 0.5; animation: pulse 2s var(--ease-standard) infinite;
}
@keyframes pulse {
  0% { transform: scale(1); opacity: 0.6; }
  100% { transform: scale(2.2); opacity: 0; }
}

.hero__title {
  font-size: clamp(48px, 9vw, 156px);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.04em;
  margin: 0 0 40px;
  font-feature-settings: "ss01" on;
}
.hero__title-line {
  display: block;
  overflow: hidden;
}
.hero__title-line > span {
  display: inline-block;
  transform: translateY(110%);
  animation: rise 900ms var(--ease-standard) forwards;
}
.hero__title-line:nth-child(1) > span { animation-delay: 120ms; }
.hero__title-line:nth-child(2) > span { animation-delay: 240ms; }
.hero__title-line:nth-child(3) > span { animation-delay: 360ms; }
@keyframes rise {
  to { transform: translateY(0); }
}

.hero__rotator {
  display: inline-block;
  position: relative;
  vertical-align: top;
  height: 1em;
  overflow: hidden;
  padding: 0 0.05em;
  min-width: 0.5em;
}
.hero__rotator-track {
  display: flex; flex-direction: column;
  transition: transform 700ms var(--ease-standard);
}
.hero__rotator-item {
  height: 1em; display: block;
  white-space: nowrap;
}
.hero__rotator--accent .hero__rotator-item:nth-child(1) { color: var(--munia-vert); }
.hero__rotator--accent .hero__rotator-item:nth-child(2) { color: var(--munia-bleu); }
.hero__rotator--accent .hero__rotator-item:nth-child(3) { color: var(--munia-orange); }
.hero__rotator--accent .hero__rotator-item:nth-child(4) { color: var(--munia-jaune); filter: brightness(0.85); }
.hero__rotator--accent .hero__rotator-item:nth-child(5) { color: var(--munia-vert); }

.hero__bottom {
  display: flex; justify-content: space-between; align-items: flex-end;
  margin-top: 40px;
  gap: 48px; flex-wrap: wrap;
}
.hero__lead {
  max-width: 540px;
  font-size: clamp(17px, 1.4vw, 21px);
  line-height: 1.45;
  color: var(--fg);
  opacity: 0;
  animation: fadeUp 1s var(--ease-standard) 700ms forwards;
}
.hero__ctas {
  display: flex; gap: 12px; flex-wrap: wrap;
  opacity: 0;
  animation: fadeUp 1s var(--ease-standard) 800ms forwards;
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Hero stack — Munia assistant cards (replaces old arrow) */
.hero__stack {
  position: absolute;
  right: 4%;
  top: 260px;
  width: 320px;
  height: 460px;
  perspective: 1200px;
  cursor: pointer;
  z-index: 3;
}
.hero__stack-item {
  position: absolute;
  inset: 0;
  transition: transform 700ms var(--ease-standard), opacity 700ms var(--ease-standard), filter 700ms var(--ease-standard);
  transform-origin: 50% 100%;
  transform:
    translateY(calc(var(--depth) * -28px))
    translateX(calc(var(--depth) * 6px))
    scale(calc(1 - var(--depth) * 0.025))
    rotate(calc(var(--depth) * -1.5deg));
  filter: brightness(calc(1 - var(--depth) * 0.03));
}
.hero__stack-item:nth-child(n+5) { /* hide stuff past 5th depth */
  opacity: calc(1 - max(0, (var(--depth) - 4)) * 0.6);
  pointer-events: none;
}
.hero__stack-hint {
  position: absolute;
  bottom: -50px; left: 0;
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--fg-muted);
  opacity: 0.7;
}
@media (max-width: 1100px) {
  .hero__stack { right: -4%; width: 260px; height: 380px; top: 260px; }
}
@media (max-width: 900px) {
  .hero__stack { display: none; }
}

/* Assistant card */
.acard {
  position: relative;
  width: 100%; height: 100%;
  background: var(--munia-blanc);
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 22px;
  box-shadow: 0 24px 60px rgba(37, 37, 37, 0.10), 0 2px 6px rgba(37, 37, 37, 0.06);
  display: flex; flex-direction: column;
  gap: 18px;
  overflow: hidden;
}
.acard::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: var(--card-accent);
}
.acard__head {
  display: flex; justify-content: space-between; align-items: flex-start;
}
.acard__icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  background: color-mix(in oklab, var(--card-accent) 18%, white);
  color: var(--munia-noir);
}
.acard__icon svg { width: 22px; height: 22px; }
.acard__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--card-accent);
  position: relative;
}
.acard__dot::after {
  content: "";
  position: absolute; inset: -3px;
  border-radius: 50%;
  border: 1.5px solid var(--card-accent);
  opacity: 0.6;
}
.acard__body { display: flex; flex-direction: column; gap: 4px; }
.acard__eyebrow {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--fg-muted);
}
.acard__title {
  font-size: 22px; font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--munia-noir);
}
.acard__role {
  font-size: 12px;
  color: var(--fg-muted);
  margin-top: 2px;
}
.acard__preview {
  flex: 1;
  padding: 14px;
  background: var(--bg-soft);
  border-radius: 12px;
  display: flex; flex-direction: column; gap: 10px;
  font-size: 12px; line-height: 1.45;
  color: var(--fg);
}
.acard__preview-bar {
  display: flex; gap: 4px;
}
.acard__preview-bar span {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(37,37,37,0.18);
}
.acard__preview-text {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 10.5px;
  color: var(--fg);
  line-height: 1.5;
}
.acard__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  font-size: 11px;
}
.acard__brand {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--fg-muted);
  font-weight: 600;
}
.acard__cta {
  display: inline-flex; align-items: center; gap: 4px;
  font-weight: 600;
  color: var(--munia-noir);
}

.hero__floats {
  position: absolute; inset: 0;
  pointer-events: none;
}
.hero__float {
  position: absolute;
  border-radius: 50%;
  animation: drift 18s ease-in-out infinite alternate;
}
.hero__float--1 { width: 14px; height: 14px; background: var(--munia-bleu); top: 28%; right: 12%; animation-delay: 0s;}
.hero__float--2 { width: 8px; height: 8px; background: var(--munia-orange); top: 65%; left: 8%; animation-delay: -4s;}
.hero__float--3 { width: 22px; height: 22px; background: transparent; border: 2px solid var(--munia-noir); top: 45%; right: 36%; animation-delay: -9s;}
.hero__float--4 { width: 10px; height: 10px; background: var(--munia-jaune); bottom: 18%; right: 22%; animation-delay: -2s;}
@keyframes drift {
  0% { transform: translate(0, 0); }
  50% { transform: translate(20px, -30px); }
  100% { transform: translate(-15px, 20px); }
}

/* Hero trust bar */
.hero__trust {
  display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
  margin-top: 96px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  font-size: 13px; color: var(--fg-muted); font-weight: 600;
  opacity: 0;
  animation: fadeUp 1s var(--ease-standard) 1100ms forwards;
}
.hero__trust-item {
  display: inline-flex; align-items: center; gap: 8px;
}
.hero__trust-item svg { width: 16px; height: 16px; flex: none; }
.hero__trust-divider { width: 1px; height: 16px; background: var(--line); }

/* ============= MARQUEE ============= */
.marquee {
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  padding: 28px 0;
  background: var(--munia-noir);
  color: var(--munia-blanc);
}
.marquee__track {
  display: inline-flex; gap: 64px;
  animation: marquee 38s linear infinite;
}
.marquee__item {
  display: inline-flex; align-items: center; gap: 24px;
  font-size: 26px; font-weight: 700; letter-spacing: -0.02em;
}
.marquee__item svg { width: 22px; height: 22px; flex: none; }
@keyframes marquee {
  to { transform: translateX(-50%); }
}
.marquee--slow .marquee__track { animation-duration: 60s; }
.marquee--reverse .marquee__track { animation-direction: reverse; }

/* ============= SECTION HEADERS ============= */
.sec-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
  margin-bottom: 80px;
}
.sec-head__title {
  font-size: clamp(36px, 5vw, 84px);
  font-weight: 700; line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 0;
}
.sec-head__lead {
  font-size: 18px; line-height: 1.5;
  color: var(--fg-muted);
  max-width: 440px;
}
@media (max-width: 900px) {
  .sec-head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
}

/* ============= SERVICES ============= */
.services { background: var(--bg); }
.services__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 1100px) { .services__grid { grid-template-columns: 1fr; } }

.service-card {
  position: relative;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 40px;
  min-height: 480px;
  display: flex; flex-direction: column;
  overflow: hidden;
  transition: transform 350ms var(--ease-standard);
}
.service-card:hover { transform: translateY(-6px); }
.service-card__num {
  font-size: 13px; font-weight: 600;
  letter-spacing: 0.1em;
  color: var(--fg-muted);
}
.service-card__icon {
  width: 88px; height: 88px;
  margin: 32px 0 32px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg);
  border-radius: 24px;
  border: 1px solid var(--line);
  transition: background 350ms var(--ease-standard), border-color 350ms;
}
.service-card__icon svg { width: 48px; height: 48px; transition: transform 400ms var(--ease-standard); }
.service-card:hover .service-card__icon { background: var(--munia-noir); border-color: var(--munia-noir); }
.service-card:hover .service-card__icon svg path { stroke: var(--munia-blanc); }
.service-card:hover .service-card__icon svg { transform: rotate(-6deg) scale(1.05); }

.service-card__title {
  font-size: 28px; font-weight: 700; line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 16px;
}
.service-card__body {
  font-size: 15px; line-height: 1.55; color: var(--fg-muted);
  margin-bottom: 32px;
  flex: 1;
}
.service-card__link {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 14px; font-weight: 600;
}
.service-card__link svg { transition: transform 250ms var(--ease-standard); }
.service-card:hover .service-card__link svg { transform: translateX(6px); }

.service-card__bg {
  position: absolute;
  top: -20%; right: -20%;
  width: 320px; height: 320px;
  border-radius: 50%;
  opacity: 0;
  transition: opacity 500ms var(--ease-standard), transform 600ms var(--ease-standard);
  transform: scale(0.6);
  pointer-events: none;
}
.service-card:hover .service-card__bg {
  opacity: 0.18; transform: scale(1);
}
.service-card--vert .service-card__bg { background: var(--munia-vert); }
.service-card--bleu .service-card__bg { background: var(--munia-bleu); }
.service-card--orange .service-card__bg { background: var(--munia-orange); }

.service-card__stat {
  position: absolute;
  bottom: 40px; right: 40px;
  font-size: 56px; font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--munia-noir);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 400ms var(--ease-standard), transform 500ms var(--ease-standard);
}
.service-card:hover .service-card__stat { opacity: 0.1; transform: translateY(0); }

/* ============= REVEAL ============= */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 900ms var(--ease-standard), transform 900ms var(--ease-standard); }
.reveal.is-in { opacity: 1; transform: translateY(0); }

/* ============= DEMO ============= */
.demo { background: var(--bg-soft); }
.demo__grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 56px;
  align-items: start;
}
@media (max-width: 1100px) { .demo__grid { grid-template-columns: 1fr; } }

.demo__copy h2 {
  font-size: clamp(36px, 4.5vw, 72px);
  font-weight: 700; line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 24px;
}
.demo__copy p {
  font-size: 17px; line-height: 1.55; color: var(--fg-muted);
  max-width: 460px; margin-bottom: 32px;
}
.demo__prompts {
  display: flex; flex-direction: column; gap: 8px;
  margin-bottom: 32px;
}
.demo__prompt {
  text-align: left;
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 14px;
  font-size: 14px; font-weight: 600;
  color: var(--fg);
  transition: all 250ms var(--ease-standard);
  width: 100%;
}
.demo__prompt:hover { border-color: var(--munia-noir); transform: translateX(4px); }
.demo__prompt.is-active { background: var(--munia-noir); color: var(--munia-blanc); border-color: var(--munia-noir); }
.demo__prompt-num { font-size: 12px; color: var(--fg-muted); font-weight: 600; }
.demo__prompt.is-active .demo__prompt-num { color: var(--fg-on-dark-muted); }
.demo__prompt-arrow { margin-left: auto; opacity: 0.4; transition: opacity 250ms, transform 250ms; }
.demo__prompt:hover .demo__prompt-arrow,
.demo__prompt.is-active .demo__prompt-arrow { opacity: 1; transform: translateX(2px); }

/* Chat window */
.chat {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 28px 80px rgba(37,37,37,0.08), 0 2px 8px rgba(37,37,37,0.04);
  display: flex; flex-direction: column;
  min-height: 600px;
}
.chat__bar {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-soft);
}
.chat__bar-dots { display: flex; gap: 6px; }
.chat__bar-dot { width: 10px; height: 10px; border-radius: 50%; background: rgba(37,37,37,0.18); }
.chat__bar-title {
  font-size: 13px; font-weight: 600;
  margin-left: 8px;
}
.chat__bar-badge {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 600; color: var(--fg-muted);
  background: var(--bg);
  border: 1px solid var(--line);
  padding: 4px 10px; border-radius: 999px;
}
.chat__bar-badge::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--munia-vert);
}

.chat__body {
  flex: 1;
  padding: 24px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 18px;
}

.msg { display: flex; gap: 12px; max-width: 92%; }
.msg--bot { align-self: flex-start; }
.msg--user { align-self: flex-end; flex-direction: row-reverse; }
.msg__avatar {
  width: 32px; height: 32px; flex: none;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.msg--bot .msg__avatar {
  background: var(--munia-noir);
}
.msg--bot .msg__avatar svg { width: 18px; height: 18px; }
.msg--user .msg__avatar {
  background: var(--munia-vert);
  color: var(--munia-noir);
}
.msg__bubble {
  padding: 14px 18px;
  border-radius: 18px;
  font-size: 14.5px; line-height: 1.5;
  white-space: pre-wrap;
}
.msg--bot .msg__bubble {
  background: var(--bg-soft);
  border: 1px solid var(--line);
  color: var(--fg);
  border-top-left-radius: 4px;
}
.msg--user .msg__bubble {
  background: var(--munia-noir);
  color: var(--munia-blanc);
  border-top-right-radius: 4px;
}

.msg__sources {
  margin-top: 10px;
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.msg__source {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 10px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 12px; color: var(--fg-muted);
}
.msg__source svg { width: 12px; height: 12px; flex: none; }

/* Typing */
.typing {
  display: inline-flex; gap: 5px; padding: 6px 0;
}
.typing span {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--fg-muted);
  animation: typing 1.2s var(--ease-standard) infinite;
}
.typing span:nth-child(2) { animation-delay: 0.15s; }
.typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes typing {
  0%, 60%, 100% { transform: scale(0.7); opacity: 0.4; }
  30% { transform: scale(1); opacity: 1; }
}

.cursor-blink::after {
  content: "▍";
  display: inline-block;
  color: var(--fg);
  animation: blink 1s steps(2) infinite;
  font-weight: 400;
  margin-left: 1px;
}
@keyframes blink { 50% { opacity: 0; } }

.chat__composer {
  padding: 14px;
  border-top: 1px solid var(--line);
  display: flex; align-items: center; gap: 10px;
}
.chat__input {
  flex: 1;
  font-size: 14px;
  color: var(--fg-muted);
  background: var(--bg-soft);
  border: 1px solid var(--line);
  padding: 12px 16px;
  border-radius: 12px;
}
.chat__send {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--munia-noir);
  color: var(--munia-blanc);
  display: flex; align-items: center; justify-content: center;
}

/* ============= STATS ============= */
.stats { background: var(--bg); }
.stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .stats__grid { grid-template-columns: repeat(2, 1fr); } }
.stat {
  padding: 32px 0;
  border-top: 1px solid var(--line);
}
.stat__num {
  font-size: clamp(48px, 6vw, 96px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
  display: flex; align-items: baseline; gap: 2px;
}
.stat__suffix { font-size: 0.4em; color: var(--fg-muted); margin-left: 4px; }
.stat__label {
  margin-top: 12px;
  font-size: 14px; line-height: 1.4;
  color: var(--fg-muted);
  max-width: 220px;
}

/* ============= USE CASES ============= */
.cases { background: var(--bg-soft); }
.cases__grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.case {
  position: relative;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 28px;
  overflow: hidden;
  transition: transform 350ms var(--ease-standard), border-color 350ms;
  min-height: 260px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.case:hover { transform: translateY(-4px); border-color: var(--munia-noir); }
.case__tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--fg-muted);
  align-self: flex-start;
}
.case__title {
  font-size: 20px; font-weight: 700;
  line-height: 1.2; letter-spacing: -0.01em;
  margin-top: 16px;
}
.case__hint {
  font-size: 13px; color: var(--fg-muted);
  line-height: 1.45;
  margin-top: 8px;
}
.case--lg { grid-column: span 4; }
.case--md { grid-column: span 2; }
.case--sm { grid-column: span 2; }
@media (max-width: 900px) {
  .cases__grid { grid-template-columns: 1fr; }
  .case--lg, .case--md, .case--sm { grid-column: span 1; }
}

.case__doodle {
  margin-top: 16px;
  height: 80px;
  position: relative;
}

/* mini animated visuals inside case cards */
.case__bars { display: flex; align-items: flex-end; gap: 6px; height: 100%; }
.case__bar { flex: 1; background: var(--munia-vert); border-radius: 4px 4px 0 0; animation: barRise 2s var(--ease-standard) infinite alternate; }
.case__bar:nth-child(1) { height: 30%; animation-delay: 0s;}
.case__bar:nth-child(2) { height: 55%; animation-delay: 0.1s;}
.case__bar:nth-child(3) { height: 75%; animation-delay: 0.2s;}
.case__bar:nth-child(4) { height: 50%; animation-delay: 0.3s;}
.case__bar:nth-child(5) { height: 90%; animation-delay: 0.4s;}
.case__bar:nth-child(6) { height: 65%; animation-delay: 0.5s;}
.case__bar:nth-child(7) { height: 40%; animation-delay: 0.6s;}
@keyframes barRise { from { transform: scaleY(0.85); } to { transform: scaleY(1.1); } }

.case__lines { display: flex; flex-direction: column; gap: 8px; padding-top: 8px; }
.case__lines span { display: block; height: 8px; background: var(--bg-soft); border-radius: 4px; }
.case__lines span:nth-child(1) { width: 90%; }
.case__lines span:nth-child(2) { width: 100%; }
.case__lines span:nth-child(3) { width: 70%; background: var(--munia-bleu); }
.case__lines span:nth-child(4) { width: 85%; }

/* ============= PROCESS ============= */
.process { background: var(--bg); }
.process__list {
  position: relative;
}
.process__step {
  position: relative;
  padding: 32px 0 32px 80px;
  border-top: 1px solid var(--line);
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(0, 1fr) 60px;
  align-items: baseline;
  gap: 24px;
  transition: padding-left 350ms var(--ease-standard), background 350ms;
}
.process__step:last-child { border-bottom: 1px solid var(--line); }
.process__step:hover { padding-left: 100px; }
.process__step:hover .process__step-arrow svg { transform: translateX(8px) rotate(-2deg); }
.process__step-num {
  position: absolute; left: 0; top: 32px;
  font-size: 14px; font-weight: 600; color: var(--fg-muted);
  letter-spacing: 0.04em;
}
.process__step-title {
  font-size: clamp(24px, 2.6vw, 38px);
  font-weight: 700; letter-spacing: -0.02em;
  line-height: 1.1;
}
.process__step-desc {
  font-size: 14px; line-height: 1.5; color: var(--fg-muted);
}
.process__step-arrow svg { transition: transform 350ms var(--ease-standard); }
@media (max-width: 900px) {
  .process__step { grid-template-columns: 1fr; padding: 24px 0 24px 60px; }
  .process__step-desc, .process__step-arrow { display: none; }
}

/* ============= CLIENTS ============= */
.clients { background: var(--bg-soft); }
.clients__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  background: var(--bg);
}
.client-cell {
  padding: 40px 28px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  transition: background 250ms;
  min-height: 200px;
}
.client-cell:nth-child(4n) { border-right: none; }
.client-cell:nth-last-child(-n+4) { border-bottom: none; }
.client-cell:hover { background: var(--bg-soft); }

.client-cell__img {
  max-width: 100%;
  max-height: 110px;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: grayscale(100%);
  opacity: 0.72;
  transition: filter 350ms var(--ease-standard), opacity 350ms var(--ease-standard), transform 400ms var(--ease-standard);
}
.client-cell:hover .client-cell__img {
  filter: grayscale(0%);
  opacity: 1;
  transform: scale(1.06);
}

.client-cell--more {
  background: var(--munia-noir);
  color: var(--munia-blanc);
}
.client-cell--more:hover {
  background: var(--munia-noir);
}
.client-cell__more {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.client-cell__more-num {
  font-size: 56px; font-weight: 700;
  letter-spacing: -0.04em; line-height: 0.95;
  color: var(--munia-vert);
}
.client-cell__more-lbl {
  font-size: 13px;
  color: rgba(255,255,255,0.75);
  line-height: 1.35;
}
@media (max-width: 900px) {
  .clients__grid { grid-template-columns: repeat(2, 1fr); }
  .client-cell:nth-child(4n) { border-right: 1px solid var(--line); }
  .client-cell:nth-child(2n) { border-right: none; }
  .client-cell:nth-last-child(-n+4) { border-bottom: 1px solid var(--line); }
  .client-cell:nth-last-child(-n+2) { border-bottom: none; }
}

/* ============= TOOLS ============= */
.tools {
  background: var(--bg);
  padding: 80px 0;
}
.tools__intro {
  text-align: center;
  max-width: 720px; margin: 0 auto 56px;
}
.tools__intro h3 {
  font-size: clamp(28px, 3.6vw, 52px);
  font-weight: 700; line-height: 1.05; letter-spacing: -0.03em;
  margin-bottom: 16px;
}
.tools__intro p { color: var(--fg-muted); font-size: 17px; }

/* ============= TESTIMONIALS ============= */
.testimonials { background: var(--munia-noir); color: var(--munia-blanc); }
.testimonials .eyebrow { color: rgba(255,255,255,0.6); }
.testimonials .sec-head__title { color: var(--munia-blanc); }
.testimonials .sec-head__lead { color: rgba(255,255,255,0.7); }

.testimonials__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 900px) { .testimonials__grid { grid-template-columns: 1fr; } }

.tcard {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 24px;
  padding: 36px;
  display: flex; flex-direction: column;
  min-height: 320px;
  transition: background 250ms, transform 350ms var(--ease-standard);
}
.tcard:hover { background: rgba(255,255,255,0.06); transform: translateY(-4px); }
.tcard__stars { display: inline-flex; gap: 2px; margin-bottom: 18px; }
.tcard__quote {
  font-size: 17px; line-height: 1.55;
  font-weight: 600; flex: 1;
  margin: 0;
}
.tcard__quote::before { content: "« "; color: var(--munia-vert); }
.tcard__quote::after { content: " »"; color: var(--munia-vert); }
.tcard__author {
  margin-top: 24px;
  display: flex; align-items: center; gap: 14px;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.12);
}

/* Google badge in section head */
.google-badge {
  margin-top: 28px;
  padding: 20px 24px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 16px;
  display: flex; align-items: center;
  gap: 24px; flex-wrap: wrap;
}
.google-badge__rating {
  display: flex; align-items: center; gap: 10px;
}
.google-badge__num {
  font-size: 36px; font-weight: 700;
  letter-spacing: -0.03em; line-height: 1;
}
.google-badge__stars { display: inline-flex; gap: 2px; }
.google-badge__meta {
  display: flex; align-items: center; gap: 10px;
  font-size: 14px;
  color: rgba(255,255,255,0.85);
}
.google-badge__meta strong { color: var(--munia-blanc); font-weight: 700; }
.tcard__avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--munia-vert);
  color: var(--munia-noir);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700;
}
.tcard__name { font-size: 15px; font-weight: 600; }
.tcard__role { font-size: 13px; color: rgba(255,255,255,0.65); }

/* ============= SECURITY ============= */
.security {
  background: var(--munia-noir);
  color: var(--munia-blanc);
  padding-top: 0;
}
.security__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px; align-items: center;
}
@media (max-width: 1100px) { .security__inner { grid-template-columns: 1fr; } }

.security .eyebrow { color: rgba(255,255,255,0.6); }
.security h2 {
  font-size: clamp(36px, 5vw, 80px);
  font-weight: 700; line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 24px;
}
.security p { color: rgba(255,255,255,0.75); font-size: 17px; line-height: 1.5; max-width: 520px; }
.security__list { margin-top: 32px; display: flex; flex-direction: column; gap: 14px; }
.security__item {
  display: flex; align-items: flex-start; gap: 14px;
  font-size: 15px; color: rgba(255,255,255,0.92);
}
.security__check {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--munia-vert); color: var(--munia-noir);
  display: flex; align-items: center; justify-content: center;
  flex: none;
}

/* Security visual */
.security__visual {
  position: relative;
  aspect-ratio: 1;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 28px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.security__shield {
  width: 60%; aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.security__shield-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.15);
  animation: ringSpin 30s linear infinite;
}
.security__shield-ring:nth-child(2) { inset: 12%; animation-duration: 22s; animation-direction: reverse; }
.security__shield-ring:nth-child(3) { inset: 24%; animation-duration: 16s; }
.security__shield-ring::before {
  content: ""; position: absolute;
  top: -3px; left: 50%;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--munia-vert);
  transform: translateX(-50%);
}
.security__shield-ring:nth-child(2)::before { background: var(--munia-bleu); }
.security__shield-ring:nth-child(3)::before { background: var(--munia-orange); }
@keyframes ringSpin { to { transform: rotate(360deg); } }

.security__shield-core {
  position: relative; z-index: 2;
  width: 30%; aspect-ratio: 1;
  background: var(--munia-blanc);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.security__shield-core svg { width: 50%; height: 50%; }

.security__flag {
  position: absolute; top: 24px; right: 24px;
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.08);
  padding: 8px 14px; border-radius: 999px;
  font-size: 12px; font-weight: 600;
  border: 1px solid rgba(255,255,255,0.12);
}
.security__flag::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--munia-vert); }

/* ============= ABOUT ============= */
.about { background: var(--bg); }
.about__grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 64px; align-items: start;
}
@media (max-width: 1100px) { .about__grid { grid-template-columns: 1fr; } }

.about__title {
  font-size: clamp(36px, 5vw, 80px);
  font-weight: 700; line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 32px;
}
.about__text { font-size: 17px; line-height: 1.55; color: var(--fg); }
.about__text p { margin: 0 0 16px; max-width: 540px; }
.about__text p strong { background: var(--munia-jaune); padding: 0 4px; }
.about__meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 40px;
}
.about__meta-cell {
  padding: 24px;
  background: var(--bg-soft);
  border-radius: 16px;
  border: 1px solid var(--line);
}
.about__meta-cell .num {
  font-size: 36px; font-weight: 700; letter-spacing: -0.02em; line-height: 1;
}
.about__meta-cell .lbl { font-size: 13px; color: var(--fg-muted); margin-top: 6px; }

/* About visual — arrows converging on Munia symbol */
.about__visual {
  position: relative;
  aspect-ratio: 4/5;
  background: var(--bg-soft);
  border-radius: 28px;
  border: 1px solid var(--line);
  overflow: hidden;
  padding: 32px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.about__visual-head {
  position: relative; z-index: 3;
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px;
}
.about__visual-title {
  font-size: 36px; font-weight: 700;
  letter-spacing: -0.03em; margin-top: 12px;
  line-height: 1;
}
.about__visual-hero-arrow { flex-shrink: 0; }

.about__convergence {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

/* Real brand arrows — base (right-angle, 1:1 aspect) used in 4 corners,
   each oriented so its colored circle points toward the centered Munia mark.
   Circle in source PNG is at bottom-left → use transform-origin: 0% 100%
   to rotate around the circle anchor. */
.ab-arrow {
  position: absolute;
  width: 30%;
  height: auto;
  aspect-ratio: 1023/1015;
  opacity: 0;
  animation-duration: 7.2s;
  animation-iteration-count: infinite;
  animation-timing-function: var(--ease-standard);
  /* The colored circle sits at (15.71%, 84.04%) of the PNG, not at the corner. */
  transform-origin: 15.71% 84.04%;
}
/* Bottom-right of container: natural orientation,
   circle anchored near container center, arrowhead extends to br */
.ab-arrow--br {
  left: 50%; top: 50%;
  animation-name: ab-arrow-br;
  animation-delay: 0s;
}
/* Bottom-left: rotate 90° (circle pivot stays at center,
   arrow now extends down-left from center) */
.ab-arrow--bl {
  left: 50%; top: 50%;
  animation-name: ab-arrow-bl;
  animation-delay: 1.8s;
}
/* Top-left: rotate 180° (extends up-left) */
.ab-arrow--tl {
  left: 50%; top: 50%;
  animation-name: ab-arrow-tl;
  animation-delay: 3.6s;
}
/* Top-right: rotate 270° (extends up-right) */
.ab-arrow--tr {
  left: 50%; top: 50%;
  animation-name: ab-arrow-tr;
  animation-delay: 5.4s;
}

/* Each arrow's pivot is the colored circle (15.71%, 84.04% of the PNG).
   translate(-15.71%, -84.04%) places that circle at the parent center;
   rotate then swings the image into one of 4 quadrants around the circle. */
@keyframes ab-arrow-br {
  0%   { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(0deg) scale(0.55); }
  8%   { opacity: 1; }
  18%  { transform: translate(-15.71%, -84.04%) rotate(0deg) scale(1); }
  62%  { opacity: 1; transform: translate(-15.71%, -84.04%) rotate(0deg) scale(1); }
  82%  { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(0deg) scale(1.05); }
  100% { opacity: 0; }
}
@keyframes ab-arrow-bl {
  0%   { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(90deg) scale(0.55); }
  8%   { opacity: 1; }
  18%  { transform: translate(-15.71%, -84.04%) rotate(90deg) scale(1); }
  62%  { opacity: 1; transform: translate(-15.71%, -84.04%) rotate(90deg) scale(1); }
  82%  { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(90deg) scale(1.05); }
  100% { opacity: 0; }
}
@keyframes ab-arrow-tl {
  0%   { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(180deg) scale(0.55); }
  8%   { opacity: 1; }
  18%  { transform: translate(-15.71%, -84.04%) rotate(180deg) scale(1); }
  62%  { opacity: 1; transform: translate(-15.71%, -84.04%) rotate(180deg) scale(1); }
  82%  { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(180deg) scale(1.05); }
  100% { opacity: 0; }
}
@keyframes ab-arrow-tr {
  0%   { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(270deg) scale(0.55); }
  8%   { opacity: 1; }
  18%  { transform: translate(-15.71%, -84.04%) rotate(270deg) scale(1); }
  62%  { opacity: 1; transform: translate(-15.71%, -84.04%) rotate(270deg) scale(1); }
  82%  { opacity: 0; transform: translate(-15.71%, -84.04%) rotate(270deg) scale(1.05); }
  100% { opacity: 0; }
}

/* Central Munia symbol */
.ab-center {
  position: absolute;
  left: 50%; top: 50%;
  width: 78px; height: 78px;
  transform: translate(-50%, -50%);
  z-index: 2;
  animation: ab-pulse 3.2s var(--ease-standard) infinite;
}
.ab-center svg { width: 100%; height: 100%; }
@keyframes ab-pulse {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50% { transform: translate(-50%, -50%) scale(1.08); }
}

.about__chips {
  position: relative; z-index: 3;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.about__chip {
  padding: 14px 12px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 12px;
  text-align: center;
  font-size: 13px; font-weight: 600;
  transition: transform 250ms var(--ease-standard), border-color 250ms;
}
.about__chip:hover {
  transform: translateY(-2px);
  border-color: var(--munia-noir);
}

/* ============= CONTACT ============= */
.contact {
  background: var(--munia-noir);
  color: var(--munia-blanc);
  position: relative;
  overflow: hidden;
}
.contact__giant {
  font-size: clamp(80px, 18vw, 280px);
  font-weight: 700;
  letter-spacing: -0.06em;
  line-height: 0.85;
  margin: 0;
  text-align: center;
  white-space: nowrap;
  position: relative;
}
.contact__giant::after {
  content: "•";
  color: var(--munia-vert);
  margin-left: -10px;
}
.contact__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  margin-top: 80px;
  align-items: start;
}
@media (max-width: 1100px) { .contact__inner { grid-template-columns: 1fr; } }

.contact__copy h3 {
  font-size: 28px; font-weight: 700;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}
.contact__copy p { color: rgba(255,255,255,0.7); font-size: 17px; line-height: 1.5; max-width: 420px; }
.contact__info { margin-top: 32px; display: flex; flex-direction: column; gap: 14px; }
.contact__info-item {
  display: flex; align-items: center; gap: 14px;
  font-size: 15px;
}
.contact__info-item svg { width: 18px; height: 18px; color: rgba(255,255,255,0.5); flex: none; }
.contact__info-item a { color: var(--munia-blanc); }
.contact__info-item a:hover { color: var(--munia-vert); }

.form {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 28px;
  padding: 36px;
  display: flex; flex-direction: column; gap: 18px;
}
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 600px) { .form__row { grid-template-columns: 1fr; } }
.form__field { display: flex; flex-direction: column; gap: 8px; }
.form__label {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
}
.form__input, .form__textarea {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.16);
  color: var(--munia-blanc);
  padding: 14px 16px;
  border-radius: 12px;
  font-size: 15px;
  font-family: inherit;
  transition: border-color 200ms;
}
.form__input:focus, .form__textarea:focus {
  outline: none;
  border-color: var(--munia-vert);
}
.form__textarea { min-height: 100px; resize: vertical; }
.form__submit {
  background: var(--munia-vert);
  color: var(--munia-noir);
  border: none;
  padding: 16px 24px;
  border-radius: 999px;
  font-size: 15px; font-weight: 700;
  
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  transition: background 200ms, transform 200ms;
}
.form__submit:hover { background: #4cc873; }

/* ============= FOOTER ============= */
.footer {
  background: var(--munia-noir);
  color: rgba(255,255,255,0.6);
  border-top: 1px solid rgba(255,255,255,0.12);
  padding: 48px 0 32px;
}
.footer__top {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 48px;
}
@media (max-width: 900px) { .footer__top { grid-template-columns: 1fr 1fr; } }
.footer__brand svg { height: 28px; }
.footer__brand p { margin-top: 16px; font-size: 14px; line-height: 1.5; max-width: 280px; }
.footer__col h4 {
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--munia-blanc);
  margin-bottom: 16px;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer__col a { font-size: 14px; transition: color 200ms; }
.footer__col a:hover { color: var(--munia-vert); }
.footer__bottom {
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-top: 24px;
  border-top: 1px solid rgba(255,255,255,0.12);
  font-size: 12px;
  flex-wrap: wrap; gap: 16px;
}
.footer__bottom-left {
  display: flex; flex-direction: column; gap: 8px;
}
.footer__copyright { font-size: 12px; }
.footer__legal {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-size: 11px;
}
.footer__legal a {
  color: rgba(255,255,255,0.40);
  transition: color 200ms;
}
.footer__legal a:hover { color: var(--munia-vert); }
.footer__legal-dot { color: rgba(255,255,255,0.18); }
.footer__socials { display: flex; gap: 12px; }
.footer__social {
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background 200ms, border-color 200ms;
}
.footer__social:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.3); }
.footer__social svg { width: 16px; height: 16px; }

/* ============= TWEAKS UI placement override ============= */
[data-tweaks-panel] { z-index: 9998; }

/* ============= MOBILE RESPONSIVE HARDENING ============= */
@media (max-width: 700px) {
  /* Hero — tighten + drop trust dividers, stack CTAs */
  .hero { padding-top: 130px; padding-bottom: 80px; }
  .hero__bottom { flex-direction: column; align-items: stretch; gap: 24px; }
  .hero__lead { max-width: none; }
  .hero__ctas { flex-direction: column; align-items: stretch; }
  .hero__ctas .btn { justify-content: center; }
  .hero__trust { margin-top: 56px; gap: 12px 16px; }
  .hero__trust-divider { display: none; }

  /* Header — smaller logo */
  .header__logo-text-sub { display: none; }
  .header__logo-text { font-size: 12px; }
  .header__cta { padding: 10px 16px; font-size: 13px; }
  .btn { padding: 12px 18px; font-size: 13px; }

  /* Section padding */
  .section { padding: 64px 0; }
  .sec-head { gap: 16px; margin-bottom: 32px; }

  /* Service cards — slimmer */
  .service-card { padding: 28px; min-height: 0; }
  .service-card__title { font-size: 24px; }
  .service-card__stat { font-size: 40px; bottom: 24px; right: 24px; }

  /* Demo */
  .demo__grid { gap: 32px; }
  .chat { min-height: 480px; }
  .chat__body { padding: 18px; gap: 14px; }
  .msg__bubble { font-size: 13.5px; padding: 12px 14px; }

  /* Stats — 1 col on narrow */
  .stats__grid { grid-template-columns: 1fr; }
  .stat { padding: 24px 0; }
  .stat__label { max-width: none; }

  /* Cases */
  .case { padding: 22px; min-height: 200px; }
  .case__title { font-size: 18px; }

  /* Process */
  .process__step { padding: 24px 0 24px 48px; }
  .process__step:hover { padding-left: 48px; }
  .process__step-title { font-size: 22px; }
  .process__step-num { top: 26px; font-size: 12px; }

  /* Clients — 1 col on phone */
  .clients__grid { grid-template-columns: 1fr; }
  .client-cell { border-right: none !important; padding: 36px 24px; min-height: 120px; }
  .client-cell:not(:last-child) { border-bottom: 1px solid var(--line) !important; }

  /* Testimonials */
  .tcard { padding: 24px; min-height: 0; }
  .tcard__quote { font-size: 16px; }

  /* Security */
  .security__inner { gap: 40px; }
  .security h2 { font-size: 40px; }

  /* About */
  .about__title { font-size: 40px; }
  .about__meta { grid-template-columns: 1fr; }
  .about__meta-cell .num { font-size: 28px; }

  /* Contact giant — let it wrap & shrink hard */
  .contact__giant {
    white-space: normal;
    font-size: clamp(56px, 22vw, 120px);
    text-align: left;
    letter-spacing: -0.04em;
  }
  .contact__inner { gap: 32px; margin-top: 40px; }
  .form { padding: 24px; gap: 14px; border-radius: 22px; }
  .form__row { grid-template-columns: 1fr; gap: 14px; }

  /* Footer */
  .footer__top { grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 32px; }
  .footer__brand { grid-column: 1 / -1; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }

  /* Tools intro */
  .tools__intro p { font-size: 15px; }
  .marquee { padding: 22px 0; }
  .marquee__item { font-size: 22px; gap: 18px; }
  .marquee__track { gap: 48px; }
}

@media (max-width: 420px) {
  .header { padding: 14px 16px; }
  /* Compact CTA — keep only the arrow at very narrow widths */
  .header__cta {
    font-size: 0; padding: 0;
    width: 42px; height: 42px;
    justify-content: center; align-items: center;
  }
  .header__cta .btn__arrow {
    display: inline-flex;
    font-size: 14px;
  }
  .header__cta .btn__arrow svg { width: 16px; height: 16px; }
}


/* =================== municipalite.css =================== */
/* ============================================================
   Carange Solutions — Page Municipalité
   Munia DS · réutilise styles.css, ajoute les sections propres
   ============================================================ */

/* ============= HERO — scène isométrique animée (canvas plein écran) ============= */
.mhero {
  position: relative;
  padding: 116px 0 72px;
  background: var(--bg-soft);
  overflow: hidden;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: center;
}
.mhero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 0;
}
.mhero__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(98deg,
    rgba(243,243,243,0.97) 0%,
    rgba(243,243,243,0.93) 26%,
    rgba(243,243,243,0.58) 48%,
    rgba(243,243,243,0.12) 70%,
    rgba(243,243,243,0) 85%);
}
.mhero__inner { position: relative; z-index: 2; width: 100%; }
.mhero__content { max-width: 600px; }
.mhero__title {
  font-size: clamp(38px, 5.4vw, 86px);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: -0.04em;
  margin: 16px 0 26px;
}
.mhero__title em { font-style: normal; color: var(--accent-live, var(--munia-vert)); }
.mhero__lead {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.5;
  color: var(--fg-muted);
  max-width: 520px;
  margin: 0 0 36px;
}
.mhero__lead strong { color: var(--fg); }
.mhero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }

@media (max-width: 1000px) {
  .mhero { padding: 140px 0 80px; min-height: 0; }
  .mhero__scrim {
    background: linear-gradient(180deg,
      rgba(243,243,243,0.96) 0%,
      rgba(243,243,243,0.72) 38%,
      rgba(243,243,243,0.2) 66%,
      rgba(243,243,243,0) 100%);
  }
  .mhero__content { max-width: none; }
}

/* ============= DÉPARTEMENTS ============= */
.depts { background: var(--bg-soft); }
.depts__layout {
  display: grid;
  grid-template-columns: minmax(280px, 380px) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}
.depts__nav {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dept-tab {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  text-align: left;
  padding: 18px 22px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 14px;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
  transition: all 250ms var(--ease-standard);
}
.dept-tab:hover { border-color: var(--munia-noir); transform: translateX(4px); }
.dept-tab.is-active {
  background: var(--munia-noir);
  border-color: var(--munia-noir);
  color: var(--munia-blanc);
}
.dept-tab__num {
  font-size: 12px;
  font-weight: 600;
  color: var(--fg-muted);
  letter-spacing: 0.06em;
}
.dept-tab.is-active .dept-tab__num { color: var(--fg-on-dark-muted); }
.dept-tab__arrow {
  margin-left: auto;
  opacity: 0;
  transition: opacity 250ms, transform 250ms;
}
.dept-tab:hover .dept-tab__arrow,
.dept-tab.is-active .dept-tab__arrow { opacity: 1; transform: translateX(2px); }

.dept-panel {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 44px;
  min-height: 480px;
  display: flex;
  flex-direction: column;
}
.dept-panel__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 12px;
}
.dept-panel__title {
  font-size: clamp(26px, 2.6vw, 38px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 8px 0 0;
}
.dept-panel__desc {
  font-size: 16px;
  line-height: 1.55;
  color: var(--fg-muted);
  max-width: 560px;
  margin: 14px 0 28px;
}
.dept-panel__tasks {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
}
.dept-task {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  font-size: 15.5px;
  line-height: 1.45;
}
.dept-task:last-child { border-bottom: 1px solid var(--line); }
.dept-task__check {
  flex: none;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--accent-live, var(--munia-vert));
  color: var(--munia-noir);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translateY(3px);
}
.dept-task__gain {
  margin-left: auto;
  flex: none;
  font-size: 12px;
  font-weight: 600;
  color: var(--fg-muted);
  white-space: nowrap;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 4px 10px;
}
.dept-panel__prompt {
  margin-top: auto;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px 20px;
}
.dept-panel__prompt-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.dept-panel__prompt-label svg { width: 13px; height: 13px; }
.dept-panel__prompt-text {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 13px;
  line-height: 1.55;
  color: var(--fg);
}
@media (max-width: 1000px) {
  .depts__layout { grid-template-columns: 1fr; gap: 24px; }
  .depts__nav { flex-direction: row; flex-wrap: wrap; }
  .dept-tab { width: auto; padding: 12px 16px; font-size: 14px; border-radius: 999px; }
  .dept-tab:hover { transform: none; }
  .dept-tab__num, .dept-tab__arrow { display: none; }
  .dept-panel { padding: 28px; min-height: 0; }
  .dept-task__gain { display: none; }
}

/* ============= CALCULATEUR ============= */
.calc {
  background: var(--munia-noir);
  color: var(--munia-blanc);
}
.calc .eyebrow { color: rgba(255,255,255,0.6); }
.calc__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 80px;
  align-items: center;
}
.calc__title {
  font-size: clamp(36px, 4.6vw, 76px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 20px;
  color: var(--munia-blanc);
}
.calc__sub {
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 460px;
  margin: 0 0 48px;
}
.calc__slider-label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  margin-bottom: 18px;
}
.calc__slider-value {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -0.03em;
  text-transform: none;
  color: var(--munia-blanc);
}
.calc__slider-value span {
  font-size: 15px;
  font-weight: 600;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0;
  margin-left: 8px;
}
.calc__range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,0.18);
  outline: none;
  
}
.calc__range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--accent-live, var(--munia-vert));
  border: none;
  transition: transform 150ms var(--ease-standard);
}
.calc__range::-webkit-slider-thumb:hover { transform: scale(1.15); }
.calc__range::-moz-range-thumb {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--accent-live, var(--munia-vert));
  border: none;
}
.calc__note {
  margin-top: 28px;
  font-size: 12.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.45);
  max-width: 420px;
}
.calc__results {
  display: flex;
  flex-direction: column;
}
.calc__result {
  padding: 28px 0;
  border-top: 1px solid rgba(255,255,255,0.14);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
}
.calc__result:last-child { border-bottom: 1px solid rgba(255,255,255,0.14); }
.calc__result-num {
  font-size: clamp(44px, 4.6vw, 80px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: var(--accent-live, var(--munia-vert));
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.calc__result-num small {
  font-size: 0.38em;
  font-weight: 600;
  color: rgba(255,255,255,0.6);
  margin-left: 6px;
}
.calc__result-lbl {
  font-size: 14px;
  line-height: 1.4;
  color: rgba(255,255,255,0.7);
  max-width: 200px;
  text-align: right;
}
@media (max-width: 1000px) {
  .calc__layout { grid-template-columns: 1fr; gap: 48px; }
  .calc__result-num { font-size: 48px; }
}

/* ============= SELON VOTRE TAILLE ============= */
.sizes { background: var(--bg); }
.sizes__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.size-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 40px;
  display: flex;
  flex-direction: column;
  transition: transform 350ms var(--ease-standard), border-color 350ms;
}
.size-card:hover { transform: translateY(-6px); border-color: var(--munia-noir); }
.size-card__icon {
  width: 84px; height: 84px;
  border-radius: 50%;
  background: var(--munia-sauge);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
}
.size-card__icon img { width: 46px; height: 46px; display: block; }
.size-card__pop {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.size-card__title {
  font-size: 26px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 8px 0 24px;
}
.size-card__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.size-card__item {
  padding: 12px 0;
  border-top: 1px solid var(--line);
  font-size: 14.5px;
  line-height: 1.45;
  color: var(--fg-muted);
  display: flex;
  gap: 12px;
  align-items: baseline;
}
.size-card__item::before {
  content: "";
  flex: none;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent-live, var(--munia-vert));
  transform: translateY(-1px);
}
@media (max-width: 1000px) {
  .sizes__grid { grid-template-columns: 1fr; }
  .size-card { padding: 28px; }
}

/* ============= FAQ ============= */
.mfaq { background: var(--bg-soft); }
.mfaq__layout {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(0, 1.4fr);
  gap: 64px;
  align-items: start;
}
.mfaq__title {
  font-size: clamp(36px, 4.6vw, 72px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 24px;
}
.mfaq__sub {
  font-size: 16px;
  line-height: 1.5;
  color: var(--fg-muted);
  max-width: 380px;
}
.mfaq__list { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--line-strong); }
.faq-item:last-child { border-bottom: 1px solid var(--line-strong); }
.faq-item__q {
  width: 100%;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 24px 0;
  background: none;
  border: none;
  font-size: clamp(17px, 1.6vw, 21px);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--fg);
  font-family: inherit;
}
.faq-item__plus {
  flex: none;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--line-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform 300ms var(--ease-standard), background 250ms, border-color 250ms;
}
.faq-item.is-open .faq-item__plus {
  transform: rotate(45deg);
  background: var(--munia-noir);
  border-color: var(--munia-noir);
  color: var(--munia-blanc);
}
.faq-item__a {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 350ms var(--ease-standard);
}
.faq-item.is-open .faq-item__a { grid-template-rows: 1fr; }
.faq-item__a-inner { overflow: hidden; }
.faq-item__a-inner p {
  margin: 0;
  padding: 0 56px 28px 0;
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--fg-muted);
  max-width: 640px;
}
@media (max-width: 1000px) {
  .mfaq__layout { grid-template-columns: 1fr; gap: 32px; }
}

/* ============= CTA FINAL ============= */
.mcta {
  background: var(--munia-noir);
  color: var(--munia-blanc);
  text-align: center;
}
.mcta .eyebrow { color: rgba(255,255,255,0.6); justify-content: center; }
.mcta__title {
  font-size: clamp(40px, 6.4vw, 110px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin: 20px auto 24px;
  max-width: 18ch;
  color: var(--munia-blanc);
}
.mcta__title em {
  font-style: normal;
  color: var(--accent-live, var(--munia-vert));
}
.mcta__sub {
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 480px;
  margin: 0 auto 40px;
}
.mcta__ctas {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.mcta .btn--ghost {
  color: var(--munia-blanc);
  border-color: rgba(255,255,255,0.3);
}
.mcta .btn--ghost:hover { background: rgba(255,255,255,0.08); }
.mcta__meta {
  margin-top: 48px;
  font-size: 13px;
  color: rgba(255,255,255,0.45);
}

/* Nav — état actif */
.header__nav a.is-active {
  background: rgba(37,37,37,0.08);
  font-weight: 700;
}


/* =================== integration.css =================== */
/* ============================================================
   Carange Solutions — Page Intégration de l'IA
   Munia DS · réutilise styles.css, ajoute les sections propres
   ============================================================ */

/* ============= HERO ============= */
.ihero {
  position: relative;
  padding-top: 200px;
  padding-bottom: 90px;
  background: var(--bg);
  overflow: hidden;
}
.ihero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: 64px;
  align-items: center;
}
.ihero__title {
  font-size: clamp(42px, 6vw, 100px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin: 24px 0 32px;
}
.ihero__title em {
  font-style: normal;
  color: var(--accent-live, var(--munia-vert));
}
.ihero__lead {
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.5;
  color: var(--fg-muted);
  max-width: 520px;
  margin: 0 0 36px;
}
.ihero__lead strong { color: var(--fg); }
.ihero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* ====== SCÈNE ANIMÉE DU HÉROS — flèches Munia convergentes ====== */
.ihero__stage {
  position: relative;
  width: min(480px, 100%);
  margin-left: auto;
  aspect-ratio: 1;
  border-radius: var(--radius-xl, 24px);
  background: var(--bg-soft);
  border: 1px solid var(--line);
  overflow: hidden;
  isolation: isolate;
  --tiltx: 0deg;
  --tilty: 0deg;
  perspective: 900px;
}
.ihero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  transform: rotateX(var(--tiltx)) rotateY(var(--tilty));
  transition: transform 400ms var(--ease-standard);
}
/* anneaux-guides concentriques très discrets */
.ihero__orbits {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
  transform: rotateX(var(--tiltx)) rotateY(var(--tilty));
  transition: transform 400ms var(--ease-standard);
}
.ihero__orbit {
  position: absolute;
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 50%;
  opacity: 1;
}
.ihero__orbit--1 { width: 40%; height: 40%; }
.ihero__orbit--2 { width: 64%; height: 64%; animation: orbitBreath 7s var(--ease-standard) infinite alternate; }
.ihero__orbit--3 { width: 88%; height: 88%; border-style: dashed; opacity: 0.4; animation: orbitSpin 60s linear infinite; }
@keyframes orbitBreath { to { transform: scale(1.04); } }
@keyframes orbitSpin { to { transform: rotate(360deg); } }

/* cœur : disque noir + symbole Munia, avec ondes de pulsation */
.ihero__core {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
  transform: translateZ(40px);
}
.ihero__core-disc {
  position: relative;
  width: 27%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle at 38% 32%, #ffffff, #eef2f0 62%, #d8e0dc);
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.5), 0 0 40px rgba(255,255,255,0.45), 0 0 90px rgba(101,220,138,0.45), 0 0 150px rgba(106,139,255,0.30);
  z-index: 2;
  animation: coreFloat 6s var(--ease-standard) infinite alternate;
}
.ihero__core-disc svg { width: 54%; height: 54%; display: block; }
.ihero__core-disc svg path { fill: #1f2a25; }
@keyframes coreFloat { to { transform: translateY(-7px); } }
.ihero__pulse {
  position: absolute;
  width: 27%;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1.5px solid var(--accent-live, var(--munia-vert));
  opacity: 0;
  animation: corePulse 3.2s var(--ease-standard) infinite;
}
.ihero__pulse--2 { animation-delay: 1.6s; }
@keyframes corePulse {
  0% { transform: scale(1); opacity: 0.55; }
  70% { opacity: 0; }
  100% { transform: scale(2.9); opacity: 0; }
}

/* étiquettes flottantes des 3 niveaux de solution */
.ihero__chip {
  position: absolute;
  z-index: 3;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.01em;
  padding: 7px 14px;
  border-radius: var(--radius-pill, 999px);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16);
  color: #fff;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  box-shadow: 0 6px 24px rgba(0,0,0,0.35);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
  animation: chipFloat 5s var(--ease-standard) infinite alternate;
}
.ihero__chip::before {
  content: "";
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--chip-dot, var(--munia-vert));
}
.ihero__chip--vert   { top: 15%;  left: 8%;  --chip-dot: var(--munia-vert);   animation-delay: 0s; }
.ihero__chip--bleu   { top: 44%;  right: 5%; --chip-dot: var(--munia-bleu);   animation-delay: -1.6s; }
.ihero__chip--orange { bottom: 16%; left: 13%; --chip-dot: var(--munia-orange); animation-delay: -3.1s; }
@keyframes chipFloat { to { transform: translateY(-9px); } }

@media (prefers-reduced-motion: reduce) {
  .ihero__orbit, .ihero__core-disc, .ihero__pulse, .ihero__chip { animation: none; }
  .ihero__pulse { display: none; }
}
@media (max-width: 1000px) {
  .ihero__stage { margin: 0 auto; width: min(420px, 86vw); }
}

/* Stat band sous le héros */
.ihero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 88px;
  padding-top: 36px;
  border-top: 1px solid var(--line);
}
.ihero__stat-num {
  font-size: clamp(36px, 3.6vw, 64px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
}
.ihero__stat-num small {
  font-size: 0.42em;
  font-weight: 600;
  color: var(--fg-muted);
  margin-left: 4px;
}
.ihero__stat-lbl {
  margin-top: 10px;
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--fg-muted);
  max-width: 240px;
}
@media (max-width: 1000px) {
  .ihero { padding-top: 150px; padding-bottom: 64px; }
  .ihero__inner { grid-template-columns: 1fr; gap: 48px; }
  .ihero__stats { grid-template-columns: 1fr; gap: 20px; margin-top: 56px; }
}

/* ============= CITATION ============= */
.iquote {
  background: var(--bg);
  padding: 40px 0 130px;
}
.iquote__text {
  font-size: clamp(26px, 3.4vw, 56px);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -0.03em;
  max-width: 22ch;
  margin: 0 auto;
  text-align: center;
}
.iquote__text mark {
  background: var(--accent-live, var(--munia-vert));
  padding: 0 8px;
  color: var(--munia-noir);
}
.iquote__text::before { content: "« "; color: var(--accent-live, var(--munia-vert)); }
.iquote__text::after { content: " »"; color: var(--accent-live, var(--munia-vert)); }

/* ============= NIVEAUX ============= */
.levels { background: var(--bg-soft); }
.levels__list { display: flex; flex-direction: column; }
.level {
  display: grid;
  grid-template-columns: 140px minmax(0, 1.1fr) minmax(0, 1.4fr);
  gap: 40px;
  align-items: start;
  padding: 48px 0;
  border-top: 1px solid var(--line-strong);
  transition: padding-left 350ms var(--ease-standard);
}
.level:last-child { border-bottom: 1px solid var(--line-strong); }
.level:hover { padding-left: 16px; }
.level__num {
  font-size: clamp(48px, 5vw, 88px);
  font-weight: 700;
  letter-spacing: -0.05em;
  line-height: 0.9;
  color: var(--munia-noir);
  opacity: 0.14;
  transition: opacity 350ms, color 350ms;
}
.level:hover .level__num { opacity: 1; color: var(--accent-live, var(--munia-vert)); }
.level__title {
  font-size: clamp(24px, 2.4vw, 36px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 14px;
}
.level__desc {
  font-size: 15.5px;
  line-height: 1.55;
  color: var(--fg-muted);
  max-width: 420px;
  margin: 0;
}
.level__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-content: flex-start;
}
.level__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 13.5px;
  font-weight: 600;
  transition: border-color 250ms, transform 250ms var(--ease-standard);
}
.level__chip:hover { border-color: var(--munia-noir); transform: translateY(-2px); }
.level__chip--key {
  background: var(--munia-noir);
  border-color: var(--munia-noir);
  color: var(--munia-blanc);
}
@media (max-width: 1000px) {
  .level { grid-template-columns: 1fr; gap: 18px; padding: 32px 0; }
  .level:hover { padding-left: 0; }
  .level__num { font-size: 40px; opacity: 1; color: var(--accent-live, var(--munia-vert)); }
}

/* ============= ACCOMPAGNEMENT (sombre) — parcours interactif ============= */
.accomp { background: var(--munia-noir); color: var(--munia-blanc); }
.accomp .eyebrow { color: rgba(255,255,255,0.6); }
.accomp__title {
  font-size: clamp(36px, 4.6vw, 76px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 20px;
  color: var(--munia-blanc);
}
.accomp__sub {
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 640px;
  margin: 0;
}

/* parcours : rail + panneaux */
.journey {
  display: grid;
  grid-template-columns: minmax(260px, 360px) minmax(0, 1fr);
  gap: 56px;
  margin-top: 64px;
  align-items: start;
}
.journey__rail {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  --prog: 0%;
  --node: var(--munia-vert);
}
.journey__rail::before,
.journey__rail::after {
  content: "";
  position: absolute;
  left: 13px;
  top: 30px;
  width: 2px;
  z-index: 0;
}
.journey__rail::before { bottom: 30px; background: rgba(255,255,255,0.12); }
.journey__rail::after {
  height: var(--prog);
  max-height: calc(100% - 60px);
  background: var(--node);
  transition: height 600ms var(--ease-standard), background 400ms;
}
.journey__node {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: 12px 12px 12px 0;
  color: rgba(255,255,255,0.5);
  transition: color 250ms var(--ease-standard);
}
.journey__node-dot {
  position: relative;
  flex: none;
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.22);
  background: var(--munia-noir);
  display: grid;
  place-items: center;
  transition: border-color 300ms var(--ease-standard), transform 300ms var(--ease-standard);
}
.journey__node-dot::after {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
  transition: background 300ms, width 300ms, height 300ms;
}
.journey__node:hover { color: rgba(255,255,255,0.85); }
.journey__node.is-active { color: var(--munia-blanc); }
.journey__node.is-active .journey__node-dot { border-color: var(--node); transform: scale(1.12); }
.journey__node.is-active .journey__node-dot::after { background: var(--node); width: 12px; height: 12px; }
.journey__node-num {
  display: block;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.7;
}
.journey__node-name { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }

.journey__stage { position: relative; }
.journey__panel { display: none; }
.journey__panel.is-active { display: block; animation: journeyIn 500ms var(--ease-standard); }
@keyframes journeyIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.journey__panel-top { display: flex; align-items: center; gap: 18px; margin-bottom: 8px; }
.journey__panel-num {
  font-size: clamp(40px, 5vw, 72px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--node);
  font-variant-numeric: tabular-nums;
}
.journey__tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 7px 13px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.22);
  color: var(--munia-blanc);
}
.journey__panel-title {
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 0 0 16px;
}
.journey__panel-desc {
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,0.72);
  max-width: 620px;
  margin: 0 0 28px;
}
.journey__list { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; }
.journey__list li {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,0.12);
  font-size: 15px;
  line-height: 1.5;
  color: rgba(255,255,255,0.9);
}
.journey__list li:last-child { border-bottom: 1px solid rgba(255,255,255,0.12); }
.journey__list li::before {
  content: "";
  flex: none;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--node);
  margin-top: 7px;
}
.journey__result { display: flex; align-items: baseline; gap: 14px; flex-wrap: wrap; }
.journey__result-lbl { font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); }
.journey__result-val { font-size: 18px; font-weight: 700; letter-spacing: -0.01em; color: var(--node); }

/* trois piliers */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 72px; }
.pillar {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 20px;
  padding: 32px;
  transition: border-color 300ms, transform 400ms var(--ease-standard);
}
.pillar:hover { border-color: rgba(255,255,255,0.3); transform: translateY(-4px); }
.pillar__icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: var(--node);
  color: var(--munia-noir);
  margin-bottom: 20px;
}
.pillar__icon svg { width: 24px; height: 24px; }
.pillar__title { font-size: 19px; font-weight: 700; letter-spacing: -0.01em; margin: 0 0 10px; }
.pillar__desc { font-size: 14px; line-height: 1.6; color: rgba(255,255,255,0.7); margin: 0; }

/* toujours inclus */
.accomp__included {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 40px;
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.12);
}
.accomp__included-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.5);
  margin-right: 6px;
}
.accomp__chip {
  font-size: 13px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.14);
  color: rgba(255,255,255,0.9);
}

@media (max-width: 980px) {
  .journey { grid-template-columns: 1fr; gap: 36px; }
  .journey__rail { flex-direction: row; flex-wrap: wrap; gap: 8px; }
  .journey__rail::before, .journey__rail::after { display: none; }
  .journey__node { width: auto; padding: 8px 14px; border: 1px solid rgba(255,255,255,0.16); border-radius: 999px; gap: 10px; }
  .journey__node-dot { width: 14px; height: 14px; }
  .journey__node-num { display: none; }
  .pillars { grid-template-columns: 1fr; }
}

/* ====== (ancien bloc approche — conservé pour compat, masqué) ====== */
.approach {
  background: var(--munia-noir);
  color: var(--munia-blanc);
}
.approach .eyebrow { color: rgba(255,255,255,0.6); }
.approach__title {
  font-size: clamp(36px, 4.6vw, 76px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.03em;
  margin: 16px 0 20px;
  color: var(--munia-blanc);
}
.approach__sub {
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 480px;
  margin: 0 0 56px;
}
.approach__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(300px, 1fr);
  gap: 72px;
  align-items: start;
}
.approach__steps { display: flex; flex-direction: column; }
.approach__step {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 24px;
  padding: 26px 0;
  border-top: 1px solid rgba(255,255,255,0.14);
}
.approach__step:last-child { border-bottom: 1px solid rgba(255,255,255,0.14); }
.approach__step-num {
  font-size: 14px;
  font-weight: 600;
  color: var(--accent-live, var(--munia-vert));
  letter-spacing: 0.04em;
  padding-top: 4px;
}
.approach__step-title {
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 0 0 8px;
  color: var(--munia-blanc);
}
.approach__step-desc {
  font-size: 14.5px;
  line-height: 1.5;
  color: rgba(255,255,255,0.65);
  margin: 0;
  max-width: 520px;
}
.approach__included {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 24px;
  padding: 36px;
  position: sticky;
  top: 110px;
}
.approach__included-title {
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
  color: var(--munia-blanc);
}
.approach__included-sub {
  font-size: 13.5px;
  color: rgba(255,255,255,0.55);
  margin: 0 0 24px;
  line-height: 1.5;
}
.approach__included-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.approach__included-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-size: 14.5px;
  line-height: 1.45;
  color: rgba(255,255,255,0.92);
}
.approach__included-check {
  flex: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--accent-live, var(--munia-vert));
  color: var(--munia-noir);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1000px) {
  .approach__layout { grid-template-columns: 1fr; gap: 40px; }
  .approach__included { position: static; padding: 28px; }
}

/* ============= RÉFLEXE IA ============= */
.reflex { background: var(--bg); }
.reflex__intro {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 64px;
}
.reflex__q {
  padding: 28px 0;
  border-top: 1px solid var(--line-strong);
}
.reflex__q-num {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--fg-muted);
}
.reflex__q-text {
  font-size: clamp(19px, 1.8vw, 26px);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 12px 0 0;
}
.reflex__solutions-label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: 24px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.reflex__solutions-label::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--line);
}
.reflex__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.sol-card {
  position: relative;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 30px;
  min-height: 230px;
  display: flex;
  flex-direction: column;
  transition: transform 350ms var(--ease-standard), border-color 350ms;
}
.sol-card:hover { transform: translateY(-6px); border-color: var(--munia-noir); }
.sol-card__dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--sol-accent, var(--munia-vert));
  margin-bottom: 22px;
}
.sol-card__effort {
  position: absolute;
  top: 30px; right: 30px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.sol-card__title {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0 0 10px;
}
.sol-card__desc {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--fg-muted);
  margin: 0;
  flex: 1;
}
.sol-card__ex {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 12px;
  line-height: 1.45;
  color: var(--fg-muted);
}
.sol-card__ex strong {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 4px;
  color: var(--fg);
}
@media (max-width: 1100px) {
  .reflex__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1000px) {
  .reflex__intro { grid-template-columns: 1fr; gap: 0; margin-bottom: 40px; }
}
@media (max-width: 600px) {
  .reflex__grid { grid-template-columns: 1fr; }
  .sol-card { min-height: 0; }
}


/* =================== accomplissements.css =================== */
/* ============================================================
   Carange Solutions — Page Accomplissements
   Munia DS · héros sombre, trajectoire scrollée, presse, preuves
   ============================================================ */

/* ============= HÉROS (sombre) ============= */
.ahero {
  position: relative;
  background: var(--munia-noir);
  color: var(--munia-blanc);
  padding: 220px 0 100px;
  overflow: hidden;
}
.ahero .eyebrow { color: rgba(255,255,255,0.6); }
.ahero__title {
  font-size: clamp(48px, 8vw, 140px);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.04em;
  margin: 28px 0 32px;
  max-width: 12ch;
}
.ahero__title em {
  font-style: normal;
  color: var(--accent-live, var(--munia-vert));
}
.ahero__lead {
  font-size: clamp(16px, 1.4vw, 20px);
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 600px;
  margin: 0;
}
.ahero__lead strong { color: var(--munia-blanc); }

/* compteurs */
.ahero__counters {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-top: 96px;
  padding-top: 40px;
  border-top: 1px solid rgba(255,255,255,0.14);
}
.ahero__counter-num {
  font-size: clamp(36px, 3.8vw, 68px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
  font-variant-numeric: tabular-nums;
  color: var(--munia-blanc);
}
.ahero__counter-num .stat__suffix { color: rgba(255,255,255,0.5); }
.ahero__counter:nth-child(1) .ahero__counter-num { color: var(--munia-vert); }
.ahero__counter:nth-child(2) .ahero__counter-num { color: var(--munia-bleu); }
.ahero__counter:nth-child(3) .ahero__counter-num { color: var(--munia-orange); }
.ahero__counter:nth-child(4) .ahero__counter-num { color: var(--munia-jaune); }
.ahero__counter-lbl {
  margin-top: 12px;
  font-size: 13.5px;
  line-height: 1.45;
  color: rgba(255,255,255,0.65);
  max-width: 230px;
}
.ahero__floats { position: absolute; inset: 0; pointer-events: none; }
.ahero__float {
  position: absolute;
  border-radius: 50%;
  animation: drift 18s ease-in-out infinite alternate;
}
.ahero__float--1 { width: 12px; height: 12px; background: var(--munia-vert); top: 24%; right: 14%; }
.ahero__float--2 { width: 8px; height: 8px; background: var(--munia-orange); top: 60%; right: 6%; animation-delay: -6s; }
.ahero__float--3 { width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.4); top: 38%; right: 32%; animation-delay: -11s; }
@media (max-width: 900px) {
  .ahero { padding: 150px 0 70px; }
  .ahero__counters { grid-template-columns: repeat(2, 1fr); gap: 28px; margin-top: 56px; }
}

/* ============= TRAJECTOIRE ============= */
.traj { background: var(--bg); position: relative; }
.traj__body {
  position: relative;
  margin-top: 24px;
}
.traj__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  overflow: visible;
}
.traj__path-ghost {
  fill: none;
  stroke: rgba(37,37,37,0.10);
  stroke-width: 2;
  stroke-dasharray: 3 7;
  stroke-linecap: round;
}
.traj__path {
  fill: none;
  stroke: var(--munia-noir);
  stroke-width: 3;
  stroke-linecap: round;
}
.traj__tip {
  fill: var(--accent-live, var(--munia-vert));
  stroke: var(--bg);
  stroke-width: 3;
}

.tl-row {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 140px minmax(0, 1fr);
  align-items: center;
  z-index: 2;
  padding: 44px 0;
}
.tl-node {
  grid-column: 2;
  justify-self: center;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--line-strong);
  transition: background 350ms var(--ease-standard), border-color 350ms, transform 450ms var(--ease-standard), box-shadow 350ms;
  position: relative;
  z-index: 3;
}
.tl-node.is-lit {
  background: var(--tl-accent, var(--munia-vert));
  border-color: var(--munia-noir);
  transform: scale(1.25);
}
.tl-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 32px 36px;
  max-width: 520px;
  transition: border-color 400ms, transform 500ms var(--ease-standard), opacity 500ms var(--ease-standard);
  opacity: 0.45;
  transform: translateY(10px);
}
.tl-row.is-lit .tl-card {
  opacity: 1;
  transform: translateY(0);
  border-color: var(--munia-noir);
}
.tl-row--left .tl-card { grid-column: 1; grid-row: 1; justify-self: end; text-align: right; }
.tl-row--right .tl-card { grid-column: 3; grid-row: 1; justify-self: start; }
.tl-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.tl-card__tag::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--tl-accent, var(--munia-vert));
}
.tl-row--left .tl-card__tag { flex-direction: row-reverse; }
.tl-card__title {
  font-size: clamp(20px, 2vw, 28px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 12px 0 10px;
}
.tl-card__desc {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--fg-muted);
  margin: 0;
}
@media (max-width: 900px) {
  .tl-row {
    grid-template-columns: 56px minmax(0, 1fr);
    padding: 24px 0;
  }
  .tl-node { grid-column: 1; grid-row: 1; }
  .tl-row--left .tl-card, .tl-row--right .tl-card {
    grid-column: 2; grid-row: 1;
    justify-self: start;
    text-align: left;
    max-width: none;
    padding: 24px;
  }
  .tl-row--left .tl-card__tag { flex-direction: row; }
}

/* ============= PRESSE ============= */
.press { background: var(--bg-soft); }
.press__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.press-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 40px;
  min-height: 380px;
  transition: transform 350ms var(--ease-standard), border-color 350ms;
  overflow: hidden;
}
.press-card:hover { transform: translateY(-6px); border-color: var(--munia-noir); }
.press-card__masthead {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 20px;
  border-bottom: 2px solid var(--munia-noir);
  margin-bottom: 24px;
}
.press-card__brand {
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.press-card__date {
  font-size: 12px;
  color: var(--fg-muted);
  font-weight: 600;
  text-align: right;
}
.press-card__kicker {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-live, var(--munia-vert));
  filter: brightness(0.8);
  margin-bottom: 10px;
}
.press-card__title {
  font-size: clamp(22px, 2.2vw, 32px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.12;
  margin: 0 0 16px;
}
.press-card__quote {
  font-size: 15px;
  line-height: 1.55;
  color: var(--fg-muted);
  margin: 0 0 24px;
  flex: 1;
}
.press-card__quote::before { content: "« "; color: var(--munia-noir); font-weight: 700; }
.press-card__quote::after { content: " »"; color: var(--munia-noir); font-weight: 700; }
.press-card__link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  align-self: flex-start;
}
.press-card__link svg { transition: transform 250ms var(--ease-standard); }
.press-card:hover .press-card__link svg { transform: translateX(5px); }
@media (max-width: 900px) {
  .press__grid { grid-template-columns: 1fr; }
  .press-card { min-height: 0; padding: 28px; }
}

/* ============= RÉSULTATS MESURÉS (sombre) ============= */
.results { background: var(--munia-noir); color: var(--munia-blanc); }
.results .eyebrow { color: rgba(255,255,255,0.6); }
.results .sec-head__title { color: var(--munia-blanc); }
.results .sec-head__lead { color: rgba(255,255,255,0.7); }
.results__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, 1fr);
  gap: 72px;
  align-items: start;
}
.rbar { padding: 20px 0; border-top: 1px solid rgba(255,255,255,0.12); }
.rbar:last-child { border-bottom: 1px solid rgba(255,255,255,0.12); }
.rbar__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 24px;
  margin-bottom: 12px;
}
.rbar__label { font-size: 15px; font-weight: 600; }
.rbar__num {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
  color: var(--rbar-accent, var(--munia-vert));
  white-space: nowrap;
}
.rbar__track {
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  overflow: hidden;
}
.rbar__fill {
  height: 100%;
  width: 0;
  border-radius: 999px;
  background: var(--rbar-accent, var(--munia-vert));
  transition: width 1200ms var(--ease-standard);
}
.reveal.is-in .rbar__fill { width: var(--w); }

.results__aside {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: sticky;
  top: 110px;
}
.results__money {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 24px;
  padding: 36px;
}
.results__money-num {
  font-size: clamp(40px, 4vw, 64px);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: var(--accent-live, var(--munia-vert));
  font-variant-numeric: tabular-nums;
}
.results__money-lbl {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
}
.results__green {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,0.55);
  padding: 0 8px;
}
.results__green svg { flex: none; width: 18px; height: 18px; margin-top: 2px; color: var(--munia-vert); }
.results__source {
  font-size: 12.5px;
  color: rgba(255,255,255,0.45);
  padding: 0 8px;
}
.results__source a {
  color: rgba(255,255,255,0.8);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.results__source a:hover { color: var(--munia-vert); }
@media (max-width: 1000px) {
  .results__layout { grid-template-columns: 1fr; gap: 40px; }
  .results__aside { position: static; }
}

/* ============= RECONNAISSANCES ============= */
.recog { background: var(--bg); }
.recog__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.recog-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: transform 350ms var(--ease-standard), border-color 350ms;
}
.recog-card:hover { transform: translateY(-5px); border-color: var(--munia-noir); }
.recog-card__logo {
  height: 88px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-soft);
  border-radius: 12px;
  overflow: hidden;
}
.recog-card__logo image-slot { width: 100%; height: 100%; }
.recog-card__type {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.recog-card__name {
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 4px 0 0;
}
.recog-card__desc {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--fg-muted);
  margin: 0;
  flex: 1;
}
.recog-card__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
}
.recog-card__link svg { transition: transform 250ms var(--ease-standard); }
.recog-card:hover .recog-card__link svg { transform: translateX(4px); }

/* Mascouche — primo-adoptant, carte large */
.primo {
  margin-top: 24px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 40px;
  align-items: center;
  background: var(--munia-sauge);
  border-radius: 24px;
  padding: 44px 48px;
}
.primo__badge {
  width: 120px; height: 120px;
  border-radius: 50%;
  background: var(--munia-noir);
  color: var(--munia-blanc);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  text-align: center;
  flex: none;
}
.primo__badge-num {
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--munia-jaune);
}
.primo__badge-lbl {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}
.primo__type {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(37,37,37,0.6);
}
.primo__title {
  font-size: clamp(24px, 2.6vw, 38px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 8px 0 10px;
}
.primo__desc {
  font-size: 15px;
  line-height: 1.5;
  color: rgba(37,37,37,0.75);
  margin: 0;
  max-width: 560px;
}
.primo image-slot { width: 180px; height: 90px; flex: none; }
@media (max-width: 1100px) { .recog__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 900px) {
  .primo { grid-template-columns: 1fr; gap: 24px; padding: 32px; }
  .primo__badge { width: 96px; height: 96px; }
  .primo__badge-num { font-size: 32px; }
}
@media (max-width: 600px) { .recog__grid { grid-template-columns: 1fr; } }

/* ============= AVIS GOOGLE ============= */
.gband {
  background: var(--bg-soft);
  text-align: center;
}
.gband__stars {
  display: inline-flex;
  gap: 8px;
  margin-bottom: 28px;
}
.gband__star {
  opacity: 0;
  transform: scale(0.4);
  transition: opacity 400ms var(--ease-standard), transform 500ms var(--ease-standard);
}
.reveal.is-in .gband__star { opacity: 1; transform: scale(1); }
.reveal.is-in .gband__star:nth-child(1) { transition-delay: 100ms; }
.reveal.is-in .gband__star:nth-child(2) { transition-delay: 220ms; }
.reveal.is-in .gband__star:nth-child(3) { transition-delay: 340ms; }
.reveal.is-in .gband__star:nth-child(4) { transition-delay: 460ms; }
.reveal.is-in .gband__star:nth-child(5) { transition-delay: 580ms; }
.gband__num {
  font-size: clamp(100px, 16vw, 260px);
  font-weight: 700;
  letter-spacing: -0.06em;
  line-height: 0.85;
  font-variant-numeric: tabular-nums;
}
.gband__num small {
  font-size: 0.25em;
  font-weight: 700;
  color: var(--fg-muted);
  letter-spacing: -0.02em;
}
.gband__lbl {
  margin-top: 24px;
  font-size: clamp(16px, 1.6vw, 21px);
  font-weight: 600;
  color: var(--fg);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.gband__lbl svg { width: 22px; height: 22px; }
.gband__sub {
  margin-top: 10px;
  font-size: 14px;
  color: var(--fg-muted);
}


/* ============================================================
   PAGE INTÉGRATION PERSONNALISÉE — dev sur mesure / console d'ops
   ============================================================ */
.cxhero { position:relative; background:var(--bg-soft); padding:170px 0 70px; overflow:hidden; }
.cxhero__inner { max-width:820px; }
.cxhero__title { font-size:clamp(40px,5.6vw,92px); font-weight:700; line-height:0.96; letter-spacing:-0.04em; margin:18px 0 24px; }
.cxhero__title em { font-style:normal; color:var(--accent-live,var(--munia-vert)); }
.cxhero__lead { font-size:clamp(16px,1.35vw,20px); line-height:1.55; color:var(--fg-muted); max-width:600px; margin:0 0 34px; }
.cxhero__lead strong { color:var(--fg); }
.cxhero__ctas { display:flex; gap:12px; flex-wrap:wrap; }
.cxhero__meta { margin-top:40px; padding-top:32px; border-top:1px solid var(--line); display:flex; gap:48px; flex-wrap:wrap; }
.cxhero__meta-n { font-size:clamp(20px,2vw,26px); font-weight:700; letter-spacing:-0.02em; }
.cxhero__meta-l { font-size:13px; color:var(--fg-muted); margin-top:4px; max-width:200px; }

/* ----- Console d'opérations (sombre) ----- */
.ops { background:var(--munia-noir); color:var(--munia-blanc); }
.ops .eyebrow { color:rgba(255,255,255,0.6); }
.ops .sec-head__title { color:#fff; }
.ops .sec-head__lead { color:rgba(255,255,255,0.7); }
.opswin { margin-top:44px; border:1px solid rgba(255,255,255,0.14); border-radius:16px; overflow:hidden; background:#1b1b1b; box-shadow:0 40px 90px -40px rgba(0,0,0,0.6); }
.opswin__bar { display:flex; align-items:center; gap:14px; padding:13px 18px; border-bottom:1px solid rgba(255,255,255,0.1); background:#151515; }
.opswin__dots { display:flex; gap:7px; }
.opswin__dot { width:11px; height:11px; border-radius:50%; background:rgba(255,255,255,0.18); }
.opswin__title { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12.5px; color:rgba(255,255,255,0.55); letter-spacing:0.02em; }
.opswin__live { margin-left:auto; display:flex; align-items:center; gap:8px; font-size:11px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:rgba(255,255,255,0.5); }
.opswin__live i { width:7px; height:7px; border-radius:50%; background:var(--munia-vert); box-shadow:0 0 9px var(--munia-vert); animation:opsblink 1.4s infinite; }
@keyframes opsblink { 50% { opacity:0.25; } }
.opswin__body { display:grid; grid-template-columns:248px minmax(0,1fr); min-height:460px; }
.opswin__rail { border-right:1px solid rgba(255,255,255,0.1); padding:14px; display:flex; flex-direction:column; gap:8px; }
.opstab { display:flex; flex-direction:column; gap:5px; text-align:left; background:none; border:1px solid transparent; border-radius:11px; padding:13px 15px; color:rgba(255,255,255,0.6); font-family:inherit; transition:background 200ms,border-color 200ms,color 200ms; }
.opstab:hover { background:rgba(255,255,255,0.04); }
.opstab.is-active { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.18); color:#fff; }
.opstab__k { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(255,255,255,0.4); }
.opstab__n { font-size:14.5px; font-weight:600; letter-spacing:-0.01em; }
.opstab__s { font-size:11.5px; color:rgba(255,255,255,0.45); }
.opsmain { padding:20px 24px 22px; display:flex; flex-direction:column; gap:16px; }
.opsmain__head { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; letter-spacing:0.04em; color:rgba(255,255,255,0.45); }
.opssteps { display:flex; flex-direction:column; gap:9px; }
.opsstep { display:flex; align-items:center; gap:13px; font-size:13.5px; color:rgba(255,255,255,0.5); transition:color 250ms; }
.opsstep__dot { flex:none; width:16px; height:16px; border-radius:50%; border:1.5px solid rgba(255,255,255,0.25); display:grid; place-items:center; transition:all 250ms; }
.opsstep__dot svg { width:9px; height:9px; opacity:0; }
.opsstep__label { flex:1; }
.opsstep__badge { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:9.5px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; padding:3px 9px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); color:rgba(255,255,255,0.45); white-space:nowrap; }
.opsstep.is-run { color:#fff; }
.opsstep.is-run .opsstep__dot { border-color:var(--munia-jaune); animation:opsspin 1s linear infinite; border-top-color:transparent; }
.opsstep.is-run .opsstep__badge { color:var(--munia-jaune); border-color:rgba(255,215,95,0.5); }
@keyframes opsspin { to { transform:rotate(360deg); } }
.opsstep.is-done { color:rgba(255,255,255,0.92); }
.opsstep.is-done .opsstep__dot { background:var(--munia-vert); border-color:var(--munia-vert); }
.opsstep.is-done .opsstep__dot svg { opacity:1; }
.opsstep.is-done .opsstep__badge { color:var(--munia-vert); border-color:rgba(101,220,138,0.5); }
.opslog { margin-top:auto; background:#101010; border:1px solid rgba(255,255,255,0.08); border-radius:11px; padding:14px 16px; height:158px; overflow:hidden; font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; line-height:1.75; color:rgba(255,255,255,0.62); }
.opslog .ln { white-space:pre-wrap; word-break:break-word; }
.opslog .ts { color:rgba(255,255,255,0.28); }
.opslog .ok { color:var(--munia-vert); }
.opsout { display:flex; align-items:center; gap:12px; padding:13px 16px; border:1px solid rgba(101,220,138,0.4); border-radius:11px; background:rgba(101,220,138,0.07); font-size:13.5px; color:#fff; opacity:0; transform:translateY(6px); transition:opacity 350ms,transform 350ms; }
.opsout.is-show { opacity:1; transform:none; }
.opsout__icon { flex:none; width:26px; height:26px; border-radius:50%; background:var(--munia-vert); color:var(--munia-noir); display:grid; place-items:center; }
@media (max-width:900px){
  .opswin__body { grid-template-columns:1fr; }
  .opswin__rail { flex-direction:row; overflow-x:auto; border-right:none; border-bottom:1px solid rgba(255,255,255,0.1); }
  .opstab { min-width:170px; }
}

/* ----- Pipeline (clair) ----- */
.flow__track { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:48px; position:relative; }
.flownode { position:relative; background:var(--bg); border:1px solid var(--line); border-radius:16px; padding:24px 18px; text-align:center; transition:border-color 300ms,transform 400ms var(--ease-standard); }
.flownode:hover { border-color:var(--munia-noir); transform:translateY(-4px); }
.flownode__icon { width:44px; height:44px; margin:0 auto 14px; border-radius:12px; background:var(--munia-sauge); display:grid; place-items:center; }
.flownode__icon svg { width:22px; height:22px; }
.flownode__k { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:var(--fg-muted); }
.flownode__t { font-size:15px; font-weight:700; letter-spacing:-0.01em; margin:6px 0 0; }
.flownode__d { font-size:12.5px; line-height:1.45; color:var(--fg-muted); margin:8px 0 0; }
.flownode::after { content:""; position:absolute; top:50%; right:-11px; width:8px; height:8px; border-top:2px solid var(--line-strong); border-right:2px solid var(--line-strong); transform:translateY(-50%) rotate(45deg); z-index:2; }
.flownode:last-child::after { display:none; }
@media (max-width:900px){
  .flow__track { grid-template-columns:1fr; gap:12px; }
  .flownode::after { top:auto; bottom:-11px; right:50%; transform:translateX(50%) rotate(135deg); }
}

/* ----- Cartes de processus (clair) ----- */
.procs__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; }
.proc { display:flex; flex-direction:column; background:var(--bg); border:1px solid var(--line); border-radius:20px; padding:30px; transition:border-color 300ms,transform 400ms var(--ease-standard); }
.proc:hover { border-color:var(--munia-noir); transform:translateY(-5px); }
.proc__tag { align-self:flex-start; font-size:10.5px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--fg-muted); border:1px solid var(--line); border-radius:999px; padding:5px 11px; }
.proc__title { font-size:21px; font-weight:700; letter-spacing:-0.02em; line-height:1.12; margin:18px 0 10px; }
.proc__desc { font-size:14px; line-height:1.55; color:var(--fg-muted); margin:0 0 20px; flex:1; }
.proc__io { font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:11.5px; color:var(--fg); background:var(--bg-soft); border:1px solid var(--line); border-radius:10px; padding:11px 13px; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.proc__io b { font-weight:700; }
.proc__io span { color:var(--accent-live,var(--munia-vert)); filter:brightness(0.78); }
.proc__gain { margin-top:14px; font-size:13px; font-weight:600; color:var(--fg); display:flex; align-items:center; gap:8px; }
.proc__gain svg { width:15px; height:15px; color:var(--munia-vert); }
@media (max-width:980px){ .procs__grid { grid-template-columns:1fr; } }

/* ----- Crédibilité (clair) ----- */
.creds__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:48px; }
.cred { background:var(--bg-soft); border:1px solid var(--line); border-radius:20px; padding:30px; }
.cred__icon { width:46px; height:46px; border-radius:12px; background:var(--munia-noir); color:#fff; display:grid; place-items:center; margin-bottom:18px; }
.cred__icon svg { width:23px; height:23px; }
.cred__title { font-size:18px; font-weight:700; letter-spacing:-0.01em; margin:0 0 10px; }
.cred__desc { font-size:13.5px; line-height:1.55; color:var(--fg-muted); margin:0; }
@media (max-width:980px){ .creds__grid { grid-template-columns:1fr; } }

/* ===== FIX dropdown : pont invisible pour ne pas perdre le survol entre le bouton et le menu ===== */
.header__dropdown.is-open .header__dropdown-menu::before{content:"";position:absolute;left:0;right:0;top:-14px;height:16px;}

/* ===== Hero Accomplissements : fond canvas interactif (constellation reactive a la souris) ===== */
.ahero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
.ahero .wrap{position:relative;z-index:1;}
.ahero__floats{z-index:1;}

/* ===== FIX burger mobile : quand le menu est ouvert, retirer le backdrop-filter du header
   (sinon il devient le bloc conteneur des enfants position:fixed et casse le menu plein ecran une fois scrolle) ===== */
.header.is-mobile-open{-webkit-backdrop-filter:none !important;backdrop-filter:none !important;}

/* ===== Logos des reconnaissances / presse / primo-adoptant (page Accomplissements) ===== */
.recog-card__logo-img{max-width:82%;max-height:54px;width:auto;height:auto;object-fit:contain;}
.primo__logo{display:flex;align-items:center;justify-content:center;}
.primo__logo-img{max-width:180px;max-height:84px;width:auto;height:auto;object-fit:contain;}
.press-card__brand-logo{height:24px;width:auto;max-width:160px;display:block;object-fit:contain;}

/* Conseil de l'innovation : logo carré plus grand pour la lisibilité du texte */
.recog-card__logo-img--xl{max-width:96%;max-height:78px;border-radius:8px;}


/* ============ PAGE MUNIA (ajout) ============ */
/* ============= CTA FINAL ============= */
.mcta {
  background: var(--munia-noir);
  color: var(--munia-blanc);
  text-align: center;
}
.mcta .eyebrow { color: rgba(255,255,255,0.6); justify-content: center; }
.mcta__title {
  font-size: clamp(40px, 6.4vw, 110px);
  font-weight: 700;
  line-height: 0.95;
  letter-spacing: -0.04em;
  margin: 20px auto 24px;
  max-width: 18ch;
  color: var(--munia-blanc);
}
.mcta__title em {
  font-style: normal;
  color: var(--accent-live, var(--munia-vert));
}
.mcta__sub {
  font-size: 17px;
  line-height: 1.5;
  color: rgba(255,255,255,0.7);
  max-width: 480px;
  margin: 0 auto 40px;
}
.mcta__ctas {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.mcta .btn--ghost {
  color: var(--munia-blanc);
  border-color: rgba(255,255,255,0.3);
}
.mcta .btn--ghost:hover { background: rgba(255,255,255,0.08); }
.mcta__meta {
  margin-top: 48px;
  font-size: 13px;
  color: rgba(255,255,255,0.45);
}

/* Nav — état actif */
.mnhero { position:relative; background:var(--bg-soft); overflow:hidden; padding:150px 0 90px; }
.mnhero__mesh { position:absolute; inset:0; width:100%; height:100%; z-index:0; display:block; }
.mnhero__inner { position:relative; z-index:2; display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.02fr); gap:56px; align-items:center; }
.mnhero__badge { display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:600; letter-spacing:0.04em; padding:7px 14px; border-radius:999px; background:var(--bg); border:1px solid var(--line); }
.mnhero__badge i { width:7px; height:7px; border-radius:50%; background:var(--munia-vert); box-shadow:0 0 0 4px rgba(101,220,138,0.2); }
.mnhero__title { font-size:clamp(42px,5.6vw,90px); font-weight:700; line-height:0.95; letter-spacing:-0.04em; margin:22px 0 24px; }
.mnhero__title em { font-style:normal; color:var(--accent-live,var(--munia-vert)); }
.mnhero__lead { font-size:clamp(16px,1.35vw,20px); line-height:1.55; color:var(--fg-muted); max-width:540px; margin:0 0 32px; }
.mnhero__lead strong { color:var(--fg); }
.mnhero__ctas { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:32px; }
.mnhero__trust { display:flex; gap:22px; flex-wrap:wrap; font-size:13px; color:var(--fg-muted); }
.mnhero__trust span { display:inline-flex; align-items:center; gap:8px; }
.mnhero__trust svg { width:16px; height:16px; color:var(--munia-vert); }

/* fenêtre produit (mockup LibreChat/Munia) */
.mnwin { position:relative; background:var(--bg); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:var(--shadow-2,0 30px 80px -40px rgba(37,37,37,0.35)); transform:perspective(1400px) rotateY(-7deg) rotateX(3deg); transform-style:preserve-3d; transition:transform 300ms var(--ease-standard); will-change:transform; }
.mnwin__bar { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--line); background:var(--bg-soft); }
.mnwin__dots { display:flex; gap:6px; }
.mnwin__dots i { width:10px; height:10px; border-radius:50%; background:rgba(37,37,37,0.16); }
.mnwin__url { flex:1; text-align:center; font-size:11.5px; color:var(--fg-muted); font-family:ui-monospace,Menlo,monospace; }
.mnwin__body { display:grid; grid-template-columns:128px minmax(0,1fr); min-height:332px; }
.mnwin__side { border-right:1px solid var(--line); background:var(--bg-soft); padding:14px 12px; display:flex; flex-direction:column; gap:7px; }
.mnwin__side-h { font-size:9px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--fg-muted); margin:2px 0 4px; }
.mnwin__side-i { display:flex; align-items:center; gap:8px; font-size:11.5px; color:var(--fg); padding:6px 8px; border-radius:8px; }
.mnwin__side-i b { width:16px; height:16px; border-radius:5px; flex:none; display:inline-block; }
.mnwin__side-i.is-on { background:var(--bg); border:1px solid var(--line); font-weight:600; }
.mnwin__chat { padding:16px; display:flex; flex-direction:column; gap:12px; }
.mnbub { max-width:88%; font-size:12.5px; line-height:1.5; padding:11px 13px; border-radius:13px; }
.mnbub--u { align-self:flex-end; background:var(--munia-noir); color:#fff; border-bottom-right-radius:4px; }
.mnbub--b { align-self:flex-start; background:var(--bg-soft); border:1px solid var(--line); border-bottom-left-radius:4px; }
.mnbub--b b { color:var(--fg); }
.mnwin__compose { display:flex; align-items:center; gap:8px; padding:10px 12px; border-top:1px solid var(--line); }
.mnwin__compose .f { flex:1; font-size:12px; color:var(--fg-muted); background:var(--bg-soft); border:1px solid var(--line); border-radius:999px; padding:9px 14px; }
.mnwin__compose .s { width:32px; height:32px; flex:none; border-radius:50%; background:var(--munia-vert); display:grid; place-items:center; }
.mnwin__compose .s svg { width:15px; height:15px; }
@media (max-width:1000px){
  .mnhero { padding:120px 0 64px; }
  .mnhero__inner { grid-template-columns:1fr; gap:44px; }
  .mnwin { transform:none; }
}

/* ----- ASSISTANTS interactifs ----- */
.mnassist__bar { display:flex; flex-wrap:wrap; gap:8px; margin:0 0 28px; }
.mnchip { font-size:13px; font-weight:600; padding:9px 16px; border-radius:999px; background:var(--bg); border:1px solid var(--line); color:var(--fg-muted); transition:all 200ms var(--ease-standard); }
.mnchip:hover { border-color:var(--munia-noir); color:var(--fg); }
.mnchip.is-active { background:var(--munia-noir); border-color:var(--munia-noir); color:#fff; }
.mnassist__layout { display:grid; grid-template-columns:minmax(0,1.4fr) minmax(300px,1fr); gap:24px; align-items:start; }
.mnassist__grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.mncard { text-align:left; background:var(--bg); border:1px solid var(--line); border-radius:16px; padding:18px; transition:all 250ms var(--ease-standard); cursor:pointer; display:flex; flex-direction:column; gap:10px; }
.mncard:hover { border-color:var(--munia-noir); transform:translateY(-3px); }
.mncard.is-active { border-color:var(--node,var(--munia-vert)); box-shadow:0 0 0 1px var(--node,var(--munia-vert)); }
.mncard__ic { width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:var(--node,var(--munia-vert)); color:var(--munia-noir); }
.mncard__ic svg { width:20px; height:20px; }
.mncard__n { font-size:14px; font-weight:700; letter-spacing:-0.01em; line-height:1.2; }
.mncard__c { font-size:11px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--fg-muted); }
.mncard--more { align-items:center; justify-content:center; text-align:center; background:var(--bg-soft); border-style:dashed; cursor:default; }
.mncard--more:hover { transform:none; border-color:var(--line-strong); }
.mncard--more .n { font-size:30px; font-weight:700; letter-spacing:-0.03em; }
.mncard--more .l { font-size:12px; color:var(--fg-muted); }
/* panneau de prévisualisation */
.mnpreview { position:sticky; top:100px; background:var(--munia-noir); color:#fff; border-radius:20px; padding:28px; min-height:360px; display:flex; flex-direction:column; }
.mnpreview__top { display:flex; align-items:center; gap:14px; margin-bottom:18px; }
.mnpreview__ic { width:48px; height:48px; flex:none; border-radius:13px; display:grid; place-items:center; background:var(--node,var(--munia-vert)); color:var(--munia-noir); }
.mnpreview__ic svg { width:26px; height:26px; }
.mnpreview__cat { font-size:10.5px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.5); }
.mnpreview__name { font-size:22px; font-weight:700; letter-spacing:-0.02em; margin-top:2px; }
.mnpreview__desc { font-size:14px; line-height:1.6; color:rgba(255,255,255,0.75); margin:0 0 20px; }
.mnpreview__demo { margin-top:auto; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.12); border-radius:13px; padding:14px 16px; }
.mnpreview__q { font-size:12px; color:rgba(255,255,255,0.55); font-family:ui-monospace,Menlo,monospace; }
.mnpreview__a { font-size:13px; line-height:1.55; color:#fff; margin-top:8px; padding-top:10px; border-top:1px solid rgba(255,255,255,0.1); }
@media (max-width:980px){
  .mnassist__layout { grid-template-columns:1fr; }
  .mnassist__grid { grid-template-columns:repeat(2,1fr); }
  .mnpreview { position:static; }
}
@media (max-width:540px){ .mnassist__grid { grid-template-columns:1fr; } }

/* ----- SOUVERAINETÉ (sombre) ----- */
.mndata { background:var(--munia-noir); color:#fff; }
.mndata .eyebrow { color:rgba(255,255,255,0.6); }
.mndata__layout { display:grid; grid-template-columns:minmax(0,1fr) minmax(300px,0.85fr); gap:64px; align-items:center; }
.mndata__title { font-size:clamp(34px,4.2vw,68px); font-weight:700; line-height:0.98; letter-spacing:-0.03em; margin:16px 0 20px; color:#fff; }
.mndata__title em { font-style:normal; color:var(--munia-vert); }
.mndata__lead { font-size:17px; line-height:1.6; color:rgba(255,255,255,0.72); max-width:520px; margin:0 0 30px; }
.mndata__list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.mndata__list li { display:flex; gap:14px; align-items:flex-start; padding:14px 0; border-top:1px solid rgba(255,255,255,0.12); font-size:14.5px; line-height:1.5; }
.mndata__list li:last-child { border-bottom:1px solid rgba(255,255,255,0.12); }
.mndata__list svg { flex:none; width:20px; height:20px; color:var(--munia-vert); margin-top:1px; }
.mndata__list b { color:#fff; }
/* écusson serveur Québec */
.mnshield { position:relative; aspect-ratio:1; display:grid; place-items:center; }
.mnshield__ring { position:absolute; border:1px solid rgba(255,255,255,0.12); border-radius:50%; }
.mnshield__core { position:relative; width:54%; aspect-ratio:1; border-radius:50%; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.16); display:grid; place-items:center; }
.mnshield__core svg { width:42%; height:42%; color:var(--munia-vert); }
.mnshield__flag { position:absolute; bottom:8%; left:50%; transform:translateX(-50%); display:inline-flex; align-items:center; gap:8px; font-size:12px; font-weight:600; background:var(--bg); color:var(--munia-noir); padding:7px 14px; border-radius:999px; white-space:nowrap; }
@media (max-width:980px){ .mndata__layout { grid-template-columns:1fr; gap:40px; } .mnshield { max-width:340px; margin:0 auto; } }

/* ----- COMPARATIF ----- */
.mncompare { background:var(--bg); }
.mntable { margin-top:48px; border:1px solid var(--line); border-radius:20px; overflow:hidden; }
.mntable__row { display:grid; grid-template-columns:minmax(0,1.5fr) minmax(0,1fr) minmax(0,1fr); align-items:center; border-top:1px solid var(--line); }
.mntable__row:first-child { border-top:none; }
.mntable__row--head { background:var(--bg-soft); }
.mntable__cell { padding:18px 22px; font-size:14.5px; }
.mntable__cell--feat { font-weight:600; color:var(--fg); }
.mntable__cell--munia { background:rgba(101,220,138,0.07); border-left:1px solid rgba(101,220,138,0.3); border-right:1px solid rgba(101,220,138,0.3); text-align:center; }
.mntable__cell--rival { text-align:center; color:var(--fg-muted); }
.mnbrandcell { display:flex; flex-direction:column; align-items:center; gap:6px; padding:22px; }
.mnbrandcell--munia { background:rgba(101,220,138,0.1); border-left:1px solid rgba(101,220,138,0.3); border-right:1px solid rgba(101,220,138,0.3); }
.mnbrandcell__logo { display:inline-flex; align-items:center; gap:8px; font-size:18px; font-weight:700; letter-spacing:-0.02em; }
.mnbrandcell__logo svg { width:24px; height:24px; }
.mnbrandcell__rivallogo { width:88px; height:26px; display:grid; place-items:center; background:var(--bg-soft); border:1px solid var(--line); border-radius:6px; font-size:11px; color:var(--fg-muted); font-weight:600; }
.mnbrandcell__tag { font-size:11px; font-weight:600; letter-spacing:0.06em; text-transform:uppercase; color:var(--fg-muted); }
.mntable__yes { display:inline-flex; align-items:center; gap:7px; font-weight:700; color:#1f9d57; }
.mntable__yes svg { width:17px; height:17px; }
.mntable__no { display:inline-flex; align-items:center; gap:7px; color:var(--fg-muted); }
.mntable__no svg { width:16px; height:16px; opacity:0.5; }
@media (max-width:760px){
  .mntable__cell, .mnbrandcell { padding:13px 12px; font-size:12.5px; }
  .mntable__cell--feat { font-size:12.5px; }
  .mnbrandcell__logo { font-size:14px; }
  .mnbrandcell__rivallogo { width:64px; font-size:10px; }
}

/* ----- NIVEAUX de plateforme ----- */
.mnlevels { background:var(--bg-soft); }
.mnlevels__grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:48px; counter-reset:lvl; }
.mnlevel { position:relative; background:var(--bg); border:1px solid var(--line); border-radius:18px; padding:26px 22px; display:flex; flex-direction:column; transition:all 300ms var(--ease-standard); overflow:hidden; }
.mnlevel:hover { border-color:var(--munia-noir); transform:translateY(-5px); }
.mnlevel__lvl { font-family:ui-monospace,Menlo,monospace; font-size:11px; font-weight:700; letter-spacing:0.1em; color:var(--node,var(--munia-vert)); filter:brightness(0.82); }
.mnlevel__t { font-size:18px; font-weight:700; letter-spacing:-0.01em; line-height:1.15; margin:10px 0 10px; }
.mnlevel__d { font-size:13px; line-height:1.5; color:var(--fg-muted); margin:0 0 18px; }
.mnlevel__chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; }
.mnlevel__chip { font-size:11px; font-weight:600; padding:5px 10px; border-radius:999px; background:var(--bg-soft); border:1px solid var(--line); color:var(--fg); }
.mnlevel__bar { position:absolute; top:0; left:0; right:0; height:4px; background:var(--node,var(--munia-vert)); }
@media (max-width:980px){ .mnlevels__grid { grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .mnlevels__grid { grid-template-columns:1fr; } }

/* ===== Bannière de consentement cookies (Loi 25) — site statique ===== */
.ccons{position:fixed;left:16px;right:16px;bottom:16px;z-index:10000;max-width:760px;margin:0 auto;background:var(--munia-noir);color:#fff;border-radius:16px;padding:18px 20px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;box-shadow:0 12px 40px rgba(0,0,0,.28);transform:translateY(140%);opacity:0;transition:transform .4s var(--ease-standard),opacity .4s var(--ease-standard);}
.ccons.is-in{transform:translateY(0);opacity:1;}
.ccons__txt{flex:1;min-width:240px;font-size:13.5px;line-height:1.5;color:rgba(255,255,255,.82);}
.ccons__txt a{color:var(--munia-vert);text-decoration:underline;}
.ccons__btns{display:flex;gap:10px;flex-shrink:0;}
.ccons__btn{border:0;border-radius:999px;padding:11px 22px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}
.ccons__btn--ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3);}
.ccons__btn--ghost:hover{background:rgba(255,255,255,.08);}
.ccons__btn--accept{background:var(--munia-vert);color:var(--munia-noir);}
.ccons__btn--accept:hover{background:#4cc873;}
@media (max-width:600px){.ccons{flex-direction:column;align-items:stretch;}.ccons__btns{justify-content:flex-end;}}
