/* === Minimal modern reset === */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; min-height: 100svh; line-height: 1.5; }
img, picture, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; }
a { color: inherit; }

/* === Variables design === */
:root {
  --fi-bg: #0A1C34;                /* couleur d'origine elementor-kit-8 */
  --fi-bg-soft: #06183a;
  --fi-ink: #eef6ff;
  --fi-muted: rgba(238, 246, 255, 0.78);
  --fi-line: rgba(181, 214, 255, 0.24);
  --fi-accent: #77bfff;
  --fi-accent-hover: #bfe3ff;
  --fi-danger: #ff4d6d;
  --fi-content-max: 1200px;
  --fi-card-max: 947px;             /* largeur "carte" intérieure (depuis Elementor --content-width) */
}

/* === Body / base typography === */
html, body {
  color: var(--fi-ink);
  font-family: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Fond global : couleur unie. Reproduit post-217.css :
   `body.elementor-page-217 { background-color:#0A1C34; }`. Pas d'image
   ni de dégradé sur body — Elementor les posait sur des conteneurs. */
body {
  background-color: #0a1c34;
  min-height: 100svh;
}

/* Image circuits — appliquée UNIQUEMENT sur le bloc hero de chaque page,
   exactement comme le faisait Elementor sur element-132718c (container
   frère du header). Breakout pour franchir le max-width de main. */
.fi-counter-wrap,
.fi-stx-wrap,
.fi-faq-banner-wrap,
.fi-contact-banner-wrap {
  background-image: url('/uploads/2026/03/Background-Fuites-Infos-recensements-fuites-de-donnees-france-.webp');
  background-repeat: repeat;
  background-size: auto;
  background-position: top center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

/* === Layout principal — wrapper centré pour le contenu de chaque page ===
   Pas de carte stylée ici : chaque page applique son propre habillage
   (.cb-legal, .cb-fi, .fi-counter-wrap, etc.) qui a déjà ses bordures et
   ombres propres. */
main {
  display: block;
  width: min(100%, var(--fi-content-max));
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 24px);
  box-sizing: border-box;
}
/* === Header (anciennement inline sur chaque page) === */
body.fi-no-scroll {
    overflow: hidden;
  }

  .fi-header {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: clamp(26px, 4.4vw, 52px) 16px;
    box-sizing: border-box;
    position: relative;
    isolation: isolate;
    background-color: #0a1c34;
    background-image: linear-gradient(
      to bottom,
      rgba(170, 215, 255, 0.12) 0%,
      rgba(120, 185, 255, 0.05) 26%,
      rgba(0, 0, 0, 0.2) 66%,
      rgba(0, 0, 0, 0.52) 100%
    );
  }

  .fi-inner {
    width: min(1200px, 100%);
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .fi-brand-link {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(6px, 0.8vw, 10px);
    max-width: 100%;
    text-decoration: none;
  }

  .fi-subline {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: auto;
    align-self: center;
    margin-top: 2px;
  }

  .fi-brand-link:focus-visible,
  .fi-menu-toggle:focus-visible,
  .fi-mobile-close:focus-visible {
    outline: 2px solid rgba(140, 214, 255, 0.92);
    outline-offset: 4px;
    border-radius: 10px;
  }

  .fi-title-row {
    display: inline-flex;
    align-items: center;
    gap: clamp(8px, 1vw, 14px);
  }

  .fi-arrow {
    width: clamp(36px, 4.2vw, 62px);
    height: auto;
    flex: 0 0 auto;
  }

  .fi-title {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(34px, 7vw, 82px);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 0.95;
    background: linear-gradient(90deg, #b7e7ff 0%, #82cfff 46%, #4e8eff 78%, #335eff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    white-space: nowrap;
    text-shadow:
      0 0 1px rgba(180, 232, 255, 0.6),
      0 0 6px rgba(92, 190, 255, 0.45),
      0 0 12px rgba(58, 122, 255, 0.3);
  }

  .fi-subtitle {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(12px, 1.25vw, 18px);
    font-style: italic;
    font-weight: 500;
    line-height: 1.35;
    letter-spacing: 0.01em;
    color: rgba(239, 247, 255, 0.96);
    text-shadow: 0 0 6px rgba(46, 110, 255, 0.14);
    text-align: center;
  }

  .fi-drop {
    width: clamp(44px, 5.8vw, 92px);
    height: auto;
    max-height: clamp(56px, 7.2vw, 124px);
    object-fit: contain;
    flex: 0 0 auto;
    filter:
      drop-shadow(0 0 7px rgba(105, 215, 255, 0.85))
      drop-shadow(0 0 20px rgba(45, 106, 255, 0.45));
  }

  .fi-nav-wrap {
    margin-top: clamp(28px, 3.1vw, 42px);
    width: 100%;
    display: flex;
    justify-content: center;
  }

  .fi-nav {
    --fi-ind-x: 6px;
    --fi-ind-w: 112px;
    position: relative;
    list-style: none;
    margin: 0;
    padding: 6px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border-radius: 999px;
    background: rgba(12, 34, 66, 0.28);
    border: 1px solid rgba(155, 211, 255, 0.16);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    box-shadow:
      inset 0 1px 0 rgba(225, 245, 255, 0.14),
      0 10px 28px rgba(3, 10, 20, 0.24);
  }

  .fi-nav::before {
    content: "";
    position: absolute;
    top: 6px;
    left: var(--fi-ind-x);
    width: var(--fi-ind-w);
    height: calc(100% - 12px);
    border-radius: 999px;
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.24) 0%, rgba(164, 220, 255, 0.14) 45%, rgba(83, 140, 255, 0.18) 100%);
    border: 1px solid rgba(196, 236, 255, 0.34);
    box-shadow:
      inset 0 1px 2px rgba(255, 255, 255, 0.22),
      inset 0 -8px 20px rgba(44, 95, 220, 0.26),
      0 0 14px rgba(121, 203, 255, 0.25);
    transition:
      left 0.34s cubic-bezier(0.22, 1, 0.36, 1),
      width 0.34s cubic-bezier(0.22, 1, 0.36, 1);
    pointer-events: none;
  }

  .fi-nav.is-init::before {
    transition: none;
  }

  .fi-nav-item {
    position: relative;
    z-index: 1;
  }

  .fi-nav-item--return {
    margin-left: clamp(8px, 1vw, 12px);
    padding-left: clamp(8px, 1vw, 12px);
  }

  .fi-nav-item--return::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 1px;
    height: 56%;
    background: linear-gradient(to bottom, rgba(184, 230, 255, 0), rgba(184, 230, 255, 0.52), rgba(184, 230, 255, 0));
    pointer-events: none;
  }

  .fi-nav-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 clamp(14px, 1.5vw, 20px);
    border-radius: 999px;
    text-decoration: none;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(13px, 0.95vw, 15px);
    font-weight: 600;
    letter-spacing: 0.01em;
    color: rgba(228, 242, 255, 0.88);
    transition: color 0.2s ease, transform 0.2s ease;
    white-space: nowrap;
  }

  .fi-nav-link--return {
    color: rgba(194, 229, 255, 0.96);
  }

  .fi-nav-item.is-active .fi-nav-link {
    color: #f8fcff;
  }

  .fi-nav-link:hover {
    color: #ffffff;
  }

  .fi-nav-link:active {
    transform: translateY(1px);
  }

  .fi-menu-toggle {
    display: none;
    margin-top: 0;
    width: 44px;
    height: 44px;
    border: 1px solid rgba(185, 230, 255, 0.32);
    border-radius: 12px;
    background: rgba(14, 35, 65, 0.42);
    box-shadow:
      inset 0 1px 0 rgba(235, 249, 255, 0.2),
      0 6px 16px rgba(3, 10, 20, 0.24);
    color: #d9efff;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    gap: 0;
    transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  }

  .fi-menu-toggle svg {
    width: 24px;
    height: 24px;
  }

  .fi-menu-toggle-text {
    display: none;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: 0.01em;
    color: currentColor;
  }

  .fi-menu-toggle:hover,
  .fi-menu-toggle:active,
  .fi-menu-toggle:focus-visible {
    background: rgba(150, 216, 255, 0.38) !important;
    border-color: rgba(184, 232, 255, 0.9) !important;
    color: #0b355e !important;
    box-shadow: none !important;
  }

  .fi-mobile-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(1, 7, 16, 0.66);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.28s ease;
    z-index: 9998;
  }

  .fi-mobile-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: min(90vw, 380px);
    height: 100dvh;
    padding: 18px 16px 24px;
    box-sizing: border-box;
    background:
      linear-gradient(
        to bottom,
        rgba(170, 215, 255, 0.12) 0%,
        rgba(120, 185, 255, 0.05) 26%,
        rgba(0, 0, 0, 0.2) 66%,
        rgba(0, 0, 0, 0.52) 100%
      ),
      #0a1c34;
    border-left: 1px solid rgba(149, 218, 255, 0.24);
    box-shadow: -22px 0 38px rgba(0, 0, 0, 0.5);
    transform: translateX(100%);
    transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1);
    z-index: 9999;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
  }

  body.fi-menu-open .fi-mobile-panel {
    transform: translateX(0);
  }

  body.fi-menu-open .fi-mobile-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  .fi-mobile-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 20px;
  }

  .fi-mobile-close {
    width: 34px;
    height: 34px;
    border-radius: 6px;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none;
    color: rgba(235, 247, 255, 0.96);
    cursor: pointer;
    flex: 0 0 auto;
    padding: 0;
    margin-top: 2px;
    -webkit-appearance: none;
    appearance: none;
    -webkit-tap-highlight-color: transparent;
  }

  .fi-mobile-close svg {
    width: 22px;
    height: 22px;
  }

  .fi-mobile-brand {
    text-decoration: none;
    display: inline-flex;
    flex-direction: column;
    gap: 10px;
    color: inherit;
    min-width: 0;
    flex: 1 1 auto;
  }

  .fi-mobile-brand-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
  }

  .fi-mobile-title-row {
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-width: 0;
  }

  .fi-mobile-arrow {
    width: 42px;
    height: auto;
    filter:
      drop-shadow(0 0 4px rgba(117, 208, 255, 0.45))
      drop-shadow(0 0 10px rgba(57, 116, 255, 0.2));
  }

  .fi-mobile-title {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(26px, 8.4vw, 38px);
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.02em;
    background: linear-gradient(90deg, #b7e7ff 0%, #82cfff 46%, #4e8eff 78%, #335eff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    white-space: nowrap;
  }

  .fi-mobile-drop {
    width: 36px;
    height: auto;
    filter:
      drop-shadow(0 0 5px rgba(105, 215, 255, 0.82))
      drop-shadow(0 0 14px rgba(45, 106, 255, 0.34));
    flex: 0 0 auto;
  }

  .fi-mobile-subtitle {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 14px;
    font-style: italic;
    line-height: 1.38;
    color: rgba(239, 247, 255, 0.95);
    max-width: 31ch;
  }

  .fi-mobile-close:hover {
    color: #ffffff;
    background: transparent !important;
    box-shadow: none;
  }

  .fi-mobile-close:active,
  .fi-mobile-close:focus,
  .fi-mobile-close:focus-visible {
    background: transparent !important;
    color: #ffffff !important;
    box-shadow: none !important;
    border: 0 !important;
  }

  .fi-mobile-nav {
    list-style: none;
    margin: 6px 0 0;
    padding: 0;
    display: grid;
    gap: 8px;
  }

  .fi-mobile-link {
    display: block;
    padding: 12px 14px;
    border-radius: 12px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.01em;
    text-decoration: none;
    color: #ffffff;
    border: 1px solid rgba(159, 220, 255, 0.18);
    background: rgba(11, 31, 58, 0.34);
  }

  .fi-mobile-link:visited,
  .fi-mobile-link:hover,
  .fi-mobile-link:active,
  .fi-mobile-link:focus,
  .fi-mobile-link:focus-visible {
    color: #ffffff !important;
  }

  .fi-mobile-link.is-active {
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.24) 0%, rgba(164, 220, 255, 0.14) 45%, rgba(83, 140, 255, 0.18) 100%);
    border-color: rgba(196, 236, 255, 0.34);
    color: #ffffff;
    box-shadow:
      inset 0 1px 2px rgba(255, 255, 255, 0.2),
      0 0 12px rgba(121, 203, 255, 0.22);
  }

  .fi-mobile-item--return {
    margin-top: 8px;
    padding-top: 10px;
    border-top: 1px solid rgba(180, 226, 255, 0.26);
  }

  .fi-mobile-link--return {
    color: #ffffff !important;
    border-color: rgba(171, 224, 255, 0.3);
    background: rgba(20, 43, 75, 0.46);
  }

  .fi-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
    white-space: nowrap;
  }

  @media (max-width: 960px) {
    .fi-title {
      font-size: clamp(32px, 8.4vw, 62px);
    }

    .fi-subtitle {
      font-size: clamp(11px, 2.8vw, 15px);
      max-width: 35ch;
    }

    .fi-nav-wrap {
      display: none;
    }

    .fi-menu-toggle {
      display: inline-flex;
      position: static;
      width: clamp(180px, 30vw, 250px);
      max-width: none;
      height: 50px;
      margin-top: 12px;
      padding: 0 14px;
      justify-content: center;
      gap: 8px;
      border-radius: 14px;
      background: rgba(10, 29, 54, 0.72);
      border: 1px solid rgba(144, 218, 255, 0.32);
      box-shadow: none;
    }

    .fi-menu-toggle-text {
      display: inline;
    }

    .fi-menu-toggle svg {
      width: 22px;
      height: 22px;
    }
  }

  @media (max-width: 767px) {
    .fi-header {
      padding-top: 22px;
      padding-bottom: 30px;
    }

    .fi-inner {
      align-items: center;
    }

    .fi-brand-link {
      align-items: center;
      width: 100%;
      max-width: 420px;
      padding: 10px 12px;
      box-sizing: border-box;
      background: rgba(11, 31, 58, 0.72);
      border: 1px solid rgba(146, 219, 255, 0.34);
      border-radius: 16px;
      box-shadow: none;
      gap: 0;
    }

    .fi-subline {
      justify-content: center;
      width: 100%;
      max-width: 420px;
      align-self: center;
      margin-top: 14px;
    }

    .fi-arrow {
      width: 34px;
    }

    .fi-title-row {
      width: 100%;
      justify-content: center;
      gap: 10px;
    }

    .fi-title {
      font-size: 40px;
      text-align: center;
      white-space: nowrap;
    }

    .fi-subtitle {
      text-align: center;
      font-size: 16px;
      max-width: 34ch;
      width: min(92vw, 34ch);
      margin: 0 auto;
      line-height: 1.28;
    }

    .fi-drop {
      width: 24px;
      max-height: none;
      filter:
        drop-shadow(0 0 3px rgba(105, 215, 255, 0.62))
        drop-shadow(0 0 8px rgba(45, 106, 255, 0.2));
    }

    .fi-menu-toggle {
      position: static;
      width: clamp(160px, 48vw, 220px);
      max-width: none;
      height: 50px;
      margin-top: 12px;
      padding: 0 14px;
      justify-content: center;
      gap: 8px;
      border-radius: 14px;
      background: rgba(10, 29, 54, 0.72);
      border: 1px solid rgba(144, 218, 255, 0.32);
      box-shadow: none;
    }

    .fi-menu-toggle-text {
      display: inline;
    }

    .fi-menu-toggle svg {
      width: 22px;
      height: 22px;
    }
  }
/* === Footer (anciennement inline) === */
.fi-footer{
    margin-top: 42px;
    padding: 18px 20px;
    border-top: 1px solid rgba(255,255,255,.14);
  }
  .fi-footer__inner{
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px 20px;
    text-align: center;
    color: rgba(242,247,255,.82);
    font: 800 13px/1.5 "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  }
  .fi-footer a{
    color: #bfe3ff;
    text-decoration: none;
  }
  .fi-footer a:hover{ text-decoration: underline; }
  .fi-footer__sep{ opacity: .45; }

  @media (max-width: 680px){
    .fi-footer{ margin-top: 34px; padding: 16px 14px; }
    .fi-footer__inner{ gap: 8px 12px; font-size: 12.5px; }
    .fi-footer__sep{ display: none; }
  }

/* === Lightbox image (clic Source) === */
.fi-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.85);
  display: flex; align-items: center; justify-content: center;
  padding: 32px;
  cursor: zoom-out;
}
.fi-lightbox[hidden] { display: none; }
.fi-lightbox__img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 8px 32px rgba(0,0,0,.5);
  cursor: default;
}
.fi-lightbox__close {
  position: absolute; top: 20px; right: 20px;
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  border-radius: 50%;
  cursor: pointer;
  transition: background 150ms ease, border-color 150ms ease, transform 150ms ease;
}
.fi-lightbox__close:hover { background: rgba(255,255,255,.22); border-color: rgba(255,255,255,.32); }
.fi-lightbox__close:active { transform: scale(.95); }
.fi-lightbox__close:focus-visible { outline: 2px solid #fff; outline-offset: 3px; }
.fi-lightbox__close-icon { width: 18px; height: 18px; display: block; }

/* === Pages — CSS spécifiques fusionnés (Phase 3.5) === */
/* --- mentions-legales --- */
img:is([sizes=auto i],[sizes^="auto," i]){contain-intrinsic-size:3000px 1500px}
/*# sourceURL=img-auto-sizes-contain-inline-css */

/* --- mentions-legales --- */

  .cb-legal {
    --ink: #eef6ff;
    --muted: rgba(238, 246, 255, 0.78);
    --line: rgba(181, 214, 255, 0.24);
    --bg-1: #06183a;
    --bg-2: #030f29;

    font-family: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color: var(--ink);
    width: 100%;
    margin-top: clamp(20px, 4vw, 40px);
    padding: clamp(10px, 1.6vw, 16px);
    border-radius: 20px;
    border: 1px solid var(--line);
    background:
      radial-gradient(980px 340px at 8% 0%, rgba(92, 168, 255, .2), transparent 62%),
      radial-gradient(760px 300px at 96% 14%, rgba(128, 255, 224, .09), transparent 64%),
      linear-gradient(180deg, var(--bg-1), var(--bg-2));
    box-shadow: 0 14px 44px rgba(0,0,0,.30), inset 0 1px 0 rgba(255,255,255,.06);
  }
  .cb-legal, .cb-legal * { box-sizing: border-box; }
  .cb-legal a { color: #77bfff !important; text-decoration: none !important; }
  .cb-legal a:hover { text-decoration: underline !important; }

  .cb-legal__hero {
    border-radius: 16px;
    border: 1px solid rgba(181, 214, 255, .3);
    background: rgba(2, 10, 26, .52);
    padding: clamp(12px, 1.5vw, 16px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
  }

  .cb-legal__title {
    margin: 0;
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: clamp(28px, 3.2vw, 44px);
    font-weight: 800;
    letter-spacing: -.02em;
    line-height: 1.08;
  }

  .cb-legal__subtitle {
    margin: 6px 0 0;
    max-width: 980px;
    color: var(--muted);
    font-size: clamp(14px, 1.2vw, 17px);
    font-weight: 700;
    line-height: 1.5;
  }

  .cb-legal__panel {
    margin-top: 10px;
    border-radius: 16px;
    border: 1px solid rgba(181, 214, 255, .22);
    background: rgba(2, 9, 23, .54);
    padding: clamp(12px, 1.5vw, 16px);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  }

  .cb-legal__lead {
    margin: 0 0 10px;
    font-size: clamp(15px, 1.4vw, 18px);
    line-height: 1.55;
    color: rgba(236, 246, 255, .94);
    font-weight: 700;
  }

  .cb-legal__section {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid rgba(181,214,255,.16);
  }

  .cb-legal__section:first-of-type {
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
  }

  .cb-legal__h {
    margin: 0 0 6px;
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: clamp(16px, 1.4vw, 20px);
    font-weight: 700;
    letter-spacing: .02em;
    text-transform: uppercase;
    color: rgba(236, 246, 255, .98);
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .cb-legal__h::before {
    content: "";
    width: 6px;
    height: 14px;
    border-radius: 8px;
    background: linear-gradient(180deg, #c7a7ff, #7dffd4);
    box-shadow: 0 0 18px rgba(125,255,212,.35);
    flex: 0 0 auto;
  }

  .cb-legal p {
    margin: 0 0 8px;
    font-size: clamp(14px, 1.15vw, 17px);
    line-height: 1.55;
    color: rgba(232, 243, 255, .92);
    font-weight: 700;
  }

  .cb-legal strong { color: #ffffff; }

  .cb-legal__email {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
  }

  .cb-legal__email-btn {
    appearance: none;
    border: 1px solid rgba(181, 214, 255, .34);
    background: rgba(120, 191, 255, .12);
    color: #eaf5ff;
    border-radius: 9999px;
    padding: 7px 12px;
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    cursor: pointer;
  }
  .cb-legal__email-btn:hover {
    filter: brightness(1.06);
  }

  .cb-legal__email-value {
    font-weight: 700;
    color: rgba(232, 243, 255, .95);
    word-break: break-all;
  }

  @media (max-width: 900px) {
    .cb-legal__title { font-size: clamp(24px, 7.2vw, 34px); }
    .cb-legal__subtitle { font-size: 14px; }
    .cb-legal p { font-size: 14px; }
    .cb-legal__h { font-size: 16px; }
  }

/* --- application --- */

  .cb-app {
    --bg-1: #071d43;
    --bg-2: #04132f;
    --card: rgba(10, 18, 36, 0.82);
    --line: rgba(176, 214, 255, 0.24);
    --ink: #eef6ff;
    --muted: rgba(238, 246, 255, 0.76);
    --accent: #79c8ff;

    font-family: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color: var(--ink);
    width: 100%;
    margin-top: clamp(20px, 4vw, 40px);
    padding: clamp(14px, 2.1vw, 24px);
    border-radius: 24px;
    border: 1px solid var(--line);
    background:
      radial-gradient(850px 320px at 8% 0%, rgba(70, 154, 255, 0.20), transparent 62%),
      radial-gradient(700px 280px at 96% 14%, rgba(111, 255, 220, 0.08), transparent 64%),
      linear-gradient(180deg, var(--bg-1), var(--bg-2));
    box-shadow: 0 20px 70px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.07);
  }

  .cb-app, .cb-app * { box-sizing: border-box; }

  .cb-app__layout {
    max-width: 1080px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(180px, 260px);
    align-items: center;
    gap: clamp(16px, 2.4vw, 28px);
  }

  .cb-app__content {
    min-width: 0;
  }

  .cb-app__title {
    margin: 0 0 10px;
    text-align: left;
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: clamp(25px, 2.8vw, 40px);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.08;
  }

  .cb-app__subtitle {
    margin: 0 0 16px;
    max-width: 680px;
    text-align: left;
    color: var(--muted);
    font-size: clamp(14px, 1.6vw, 18px);
    font-weight: 700;
  }

  .cb-app__actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
    max-width: 660px;
  }

  .cb-app__btn {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    min-height: 58px;
    padding: 10px 16px;
    border-radius: 9999px;
    text-decoration: none !important;
    border: 1px solid rgba(255,255,255,.25);
    color: #091228 !important;
    background: rgba(255,255,255,.96);
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: clamp(16px, 1.8vw, 22px);
    font-weight: 800;
    line-height: 1;
    box-shadow: 0 12px 34px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.62);
    transition: transform .16s ease, filter .2s ease;
  }

  .cb-app__btn:hover {
    transform: translateY(-2px);
    filter: brightness(1.02);
  }

  .cb-app__btn img {
    width: clamp(22px, 2vw, 30px);
    height: clamp(22px, 2vw, 30px);
    object-fit: contain;
    flex: 0 0 auto;
  }

  .cb-app__btn-text {
    display: inline-flex;
    align-items: center;
    gap: 10px;
  }

  .cb-app__btn--ios {
    color: #ffffff !important;
    background: #000000;
    border-color: rgba(255,255,255,.18);
    box-shadow: 0 12px 34px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.12);
  }

  .cb-app__btn--ios:hover {
    filter: brightness(1.15);
  }

.cb-app__preview {
    margin: 0;
    width: 100%;
    max-width: 250px;
    justify-self: center;
    border-radius: 30px;
    border: 1px solid rgba(255,255,255,.16);
    background: var(--card);
    box-shadow: 0 18px 56px rgba(0, 0, 0, 0.34);
    overflow: hidden;
  }

  .cb-app__preview img {
    width: 100%;
    height: auto;
    max-height: 510px;
    display: block;
    object-fit: cover;
    object-position: top center;
  }

  @media (max-width: 900px) {
    .cb-app__layout {
      grid-template-columns: 1fr;
    }
    .cb-app__content {
      text-align: center;
    }
    .cb-app__title,
    .cb-app__subtitle {
      text-align: center;
      margin-left: auto;
      margin-right: auto;
    }
    .cb-app__actions {
      width: 100%;
      max-width: 620px;
      margin: 0 auto;
    }
    .cb-app__preview {
      max-width: 220px;
    }
  }

  .cb-app-apk {
    margin-top: 18px;
    padding: clamp(14px, 1.9vw, 22px);
    border-radius: 18px;
    border: 1px solid rgba(176, 214, 255, 0.22);
    background:
      repeating-linear-gradient(
        0deg,
        rgba(140, 196, 255, 0.035) 0,
        rgba(140, 196, 255, 0.035) 1px,
        transparent 1px,
        transparent 26px
      ),
      radial-gradient(760px 240px at 0% 0%, rgba(70, 154, 255, 0.15), transparent 60%),
      rgba(8, 16, 34, 0.7);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.05);
  }

  .cb-app-apk__title {
    margin: 0;
    font-family: "Oxanium", system-ui, sans-serif;
    font-size: clamp(20px, 2.2vw, 28px);
    font-weight: 800;
    letter-spacing: -0.01em;
    color: #eef6ff;
  }

  .cb-app-apk__subtitle {
    margin: 6px 0 12px;
    font-size: 13px;
    font-weight: 700;
    color: rgba(238, 246, 255, 0.76);
  }

  .cb-app-apk__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .cb-app-release {
    border-radius: 14px;
    border: 1px solid rgba(176, 214, 255, 0.24);
    background:
      linear-gradient(180deg, rgba(5, 11, 24, 0.82), rgba(4, 9, 20, 0.74));
    padding: 12px;
  }

  .cb-app-release__head {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 10px;
    margin-bottom: 10px;
  }

  .cb-app-release__name {
    margin: 0;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.35;
    color: #ecf6ff;
  }

  .cb-app-release__meta {
    margin: 3px 0 0;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 11px;
    letter-spacing: .03em;
    text-transform: uppercase;
    color: rgba(147, 206, 255, 0.88);
  }

  .cb-app-release__download {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    padding: 7px 12px;
    text-decoration: none !important;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 12px;
    font-weight: 700;
    border: 1px solid rgba(125, 197, 255, .4);
    color: #dff1ff !important;
    background: linear-gradient(180deg, rgba(22, 53, 92, .95), rgba(12, 34, 62, .95));
    white-space: nowrap;
  }

  .cb-app-release__table-wrap {
    border-radius: 10px;
    border: 1px solid rgba(176, 214, 255, 0.2);
    background: rgba(3, 8, 18, 0.55);
    overflow: hidden;
  }

  .cb-app-release__table {
    width: 100%;
    table-layout: fixed;
    border-collapse: collapse;
  }

  .cb-app-release__table th,
  .cb-app-release__table td {
    padding: 9px 8px;
    text-align: left;
    vertical-align: top;
    border-right: 1px solid rgba(176, 214, 255, 0.14);
    border-bottom: 1px solid rgba(176, 214, 255, 0.14);
    overflow-wrap: anywhere;
  }

  .cb-app-release__table th:last-child,
  .cb-app-release__table td:last-child {
    border-right: 0;
  }

  .cb-app-release__table tbody tr:last-child td {
    border-bottom: 0;
  }

  .cb-app-release__table th {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: rgba(146, 205, 255, 0.92);
  }

  .cb-app-release__table td {
    font-size: 12.5px;
    font-weight: 700;
    color: rgba(245, 249, 255, 0.96);
    line-height: 1.38;
  }

  .cb-app-release__mono {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 11.5px;
    color: #dff1ff;
    word-break: break-all;
    white-space: normal;
  }

  .cb-app-release__file {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
    font-size: 11.5px;
    color: #e8f3ff;
  }

  .cb-app-release__date {
    color: #d1e6ff;
    font-weight: 800;
  }

  .cb-app-release__td-download {
    width: 120px;
    white-space: nowrap;
  }

  .cb-app-release__table th:nth-child(1),
  .cb-app-release__table td:nth-child(1){ width: 12%; }
  .cb-app-release__table th:nth-child(2),
  .cb-app-release__table td:nth-child(2){ width: 9%; }
  .cb-app-release__table th:nth-child(3),
  .cb-app-release__table td:nth-child(3){ width: 7%; }
  .cb-app-release__table th:nth-child(4),
  .cb-app-release__table td:nth-child(4){ width: 10%; }
  .cb-app-release__table th:nth-child(5),
  .cb-app-release__table td:nth-child(5){ width: 11%; }
  .cb-app-release__table th:nth-child(6),
  .cb-app-release__table td:nth-child(6){ width: 21%; }
  .cb-app-release__table th:nth-child(7),
  .cb-app-release__table td:nth-child(7){ width: 6%; }
  .cb-app-release__table th:nth-child(8),
  .cb-app-release__table td:nth-child(8){ width: 24%; }

  @media (max-width: 900px) {
    .cb-app-apk {
      margin-top: 14px;
    }
    .cb-app-release__name {
      font-size: 14px;
    }
    .cb-app-release__table-wrap {
      overflow: visible;
      border: 0;
      background: transparent;
    }
    .cb-app-release__table {
      display: block;
      table-layout: auto;
    }
    .cb-app-release__table thead {
      display: none;
    }
    .cb-app-release__table tbody {
      display: block;
    }
    .cb-app-release__table tr {
      display: block;
      border: 1px solid rgba(176, 214, 255, 0.2);
      border-radius: 10px;
      overflow: hidden;
      background: rgba(3, 8, 18, 0.55);
      margin-bottom: 10px;
    }
    .cb-app-release__table td {
      display: flex;
      gap: 8px;
      align-items: flex-start;
      justify-content: space-between;
      width: 100% !important;
      padding: 8px 10px;
      border-bottom: 1px solid rgba(176, 214, 255, 0.14);
      font-size: 12px;
      line-height: 1.35;
      word-break: break-word;
    }
    .cb-app-release__table td:last-child {
      border-bottom: 0;
    }
    .cb-app-release__table td::before {
      content: attr(data-label);
      flex: 0 0 44%;
      max-width: 44%;
      font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: .04em;
      text-transform: uppercase;
      color: rgba(146, 205, 255, 0.92);
    }
    .cb-app-release__td-download .cb-app-release__download {
      width: 100%;
      max-width: 160px;
      justify-content: center;
    }
    .cb-app-release__mono,
    .cb-app-release__file {
      font-size: 11px;
    }
  }

/* --- faq --- */
.fi-faq-banner-wrap {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    display: flex;
    justify-content: center;
    padding: clamp(18px, 3vw, 38px) 16px clamp(12px, 2.4vw, 24px);
    box-sizing: border-box;
  }

  .fi-faq-banner {
    width: min(980px, 100%);
    text-align: center;
    margin: 0 auto;
  }

  .fi-faq-title {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(30px, 5vw, 58px);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: -0.02em;
    color: #eaf6ff;
    text-shadow:
      0 0 1px rgba(214, 240, 255, 0.45),
      0 0 16px rgba(80, 167, 255, 0.22);
  }

  .fi-faq-title::after {
    content: "";
    display: block;
    width: clamp(78px, 10vw, 118px);
    height: 3px;
    margin: clamp(8px, 1.2vw, 12px) auto 0;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(160, 218, 255, 0.25), rgba(185, 232, 255, 0.95), rgba(160, 218, 255, 0.25));
  }

  .fi-faq-text {
    margin: clamp(10px, 1.4vw, 16px) auto 0;
    max-width: 860px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(15px, 1.3vw, 21px);
    font-weight: 500;
    line-height: 1.48;
    color: rgba(225, 240, 252, 0.97);
    text-wrap: balance;
  }

  @media (max-width: 767px) {
    .fi-faq-banner-wrap {
      padding-top: 14px;
      padding-bottom: 10px;
    }

    .fi-faq-title {
      font-size: clamp(30px, 9vw, 44px);
    }

    .fi-faq-text {
      max-width: 100%;
      font-size: clamp(15px, 4.2vw, 18px);
      line-height: 1.42;
    }
  }

/* --- faq --- */

  .fi-faq-page-wrap {
    --fi-faq-text: rgba(233, 243, 255, 0.95);
    --fi-faq-title: #f2f8ff;
    --fi-faq-link: #9ed4ff;
    --fi-faq-border: rgba(134, 178, 234, 0.44);
    --fi-faq-border-strong: rgba(173, 211, 255, 0.7);
    --fi-faq-card-bg:
      radial-gradient(145% 140% at 0% 0%, rgba(148, 198, 255, 0.2), transparent 58%),
      linear-gradient(160deg, rgba(11, 24, 46, 0.94), rgba(7, 16, 31, 0.96));
    width: 100%;
    display: flex;
    justify-content: center;
    padding: clamp(14px, 2.6vw, 28px) 16px clamp(30px, 4.4vw, 58px);
    box-sizing: border-box;
  }

  .fi-faq-page-shell {
    width: min(1160px, 100%);
    display: grid;
    gap: clamp(26px, 3vw, 38px);
  }

  .fi-faq-toc {
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .fi-faq-toc-title {
    margin: 0 0 10px;
    font-family: "Oxanium", "Segoe UI", sans-serif;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: rgba(227, 240, 255, 0.92);
  }

  .fi-faq-toc-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
  }

  .fi-faq-toc-list a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 7px 13px;
    border-radius: 999px;
    border: 1px solid rgba(108, 151, 210, 0.4);
    background: rgba(4, 10, 18, 0.82);
    box-shadow: inset 0 0 0 1px rgba(78, 124, 185, 0.2);
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: rgba(238, 246, 255, 0.96);
    text-decoration: none;
    transition: border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
  }

  .fi-faq-toc-list a:hover {
    color: #ffffff;
    border-color: rgba(166, 205, 255, 0.75);
    transform: translateY(-1px);
  }

  .fi-faq-section {
    padding: 0;
  }

  .fi-faq-section h3 {
    margin: 0 0 24px;
    font-family: "Oxanium", "Segoe UI", sans-serif;
    font-size: clamp(23px, 2.1vw, 34px);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.01em;
    color: var(--fi-faq-title);
    text-shadow: 0 0 18px rgba(76, 160, 250, 0.24);
  }

  .fi-faq-section h3::before {
    content: "➜";
    display: inline-block;
    margin-right: 12px;
    color: rgba(178, 219, 255, 0.98);
    text-shadow: 0 0 12px rgba(76, 160, 250, 0.44);
    font-weight: 700;
    transform: translateY(-1px);
  }

  .fi-faq-item[hidden] {
    display: none !important;
  }

  .fi-faq-cards-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    margin-top: 2px;
  }

  .fi-faq-cards-grid > * {
    min-width: 0;
  }

  .fi-faq-card {
    position: relative;
    border: 1px solid var(--fi-faq-border);
    border-radius: 18px;
    background: var(--fi-faq-card-bg);
    box-shadow:
      inset 0 1px 0 rgba(205, 228, 255, 0.14),
      inset 0 0 0 1px rgba(45, 92, 151, 0.24),
      0 16px 28px rgba(4, 10, 21, 0.3);
    padding: 16px 14px 14px;
    text-align: center;
    white-space: normal;
    color: var(--fi-faq-title);
    min-height: 166px;
    height: auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
    justify-content: flex-start;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
    cursor: pointer;
  }

  .fi-faq-card::after {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    pointer-events: none;
    box-shadow:
      inset 0 0 0 1px rgba(194, 225, 255, 0.34),
      0 0 0 1px rgba(11, 84, 201, 0.7);
    opacity: 0.95;
  }

  .fi-faq-card:hover {
    transform: translateY(-3px);
    border-color: rgba(194, 225, 255, 0.9);
    box-shadow:
      inset 0 1px 0 rgba(220, 236, 255, 0.22),
      inset 0 0 0 1px rgba(76, 129, 192, 0.32),
      0 18px 30px rgba(3, 9, 20, 0.36);
  }

  .fi-faq-card:focus-visible {
    outline: 2px solid rgba(181, 215, 255, 0.95);
    outline-offset: 2px;
  }

  .fi-faq-card-title {
    display: block;
    width: 100%;
    min-width: 0;
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: clamp(16px, 0.95vw, 18px);
    font-weight: 800;
    line-height: 1.26;
    letter-spacing: -0.01em;
    white-space: normal !important;
    text-wrap: balance;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
    margin: 0;
  }

  .fi-faq-card-cta {
    align-self: center;
    margin-top: auto;
    flex-shrink: 0;
    min-height: 28px;
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(133, 176, 236, 0.42);
    background: rgba(16, 32, 52, 0.58);
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: rgba(225, 238, 255, 0.92);
  }

  .fi-faq-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    padding: 16px;
    background: rgba(2, 7, 15, 0.72);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: none;
    align-items: center;
    justify-content: center;
  }

  .fi-faq-modal.is-open {
    display: flex;
  }

  .fi-faq-modal-panel {
    width: min(980px, 100%);
    max-height: min(88vh, 920px);
    border: 1px solid var(--fi-faq-border);
    border-radius: 20px;
    background:
      radial-gradient(140% 140% at 0% -10%, rgba(151, 199, 255, 0.16), transparent 60%),
      linear-gradient(165deg, rgba(9, 20, 38, 0.97), rgba(7, 15, 28, 0.97));
    box-shadow:
      inset 0 1px 0 rgba(210, 230, 255, 0.16),
      0 26px 50px rgba(2, 7, 16, 0.5);
    overflow: hidden;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr);
  }

  .fi-faq-modal-head {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: space-between;
    padding: 16px 18px;
    border-bottom: 1px solid rgba(134, 177, 233, 0.24);
  }

  .fi-faq-modal-title {
    margin: 0;
    font-family: "Oxanium", "Segoe UI", sans-serif;
    font-size: clamp(21px, 2.1vw, 30px);
    line-height: 1.15;
    color: var(--fi-faq-title);
    letter-spacing: -0.01em;
  }

  .fi-faq-modal-close {
    border: 1px solid rgba(130, 172, 228, 0.38);
    background: rgba(18, 34, 56, 0.58);
    color: rgba(232, 243, 255, 0.97);
    width: 38px;
    height: 38px;
    border-radius: 999px;
    cursor: pointer;
    font-size: 22px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .fi-faq-modal-close:hover {
    border-color: rgba(176, 212, 255, 0.7);
  }

  .fi-faq-modal-body {
    overflow: auto;
    padding: 20px 20px 22px;
  }

  .fi-faq-modal-body p,
  .fi-faq-modal-body li,
  .fi-faq-modal-body blockquote {
    margin: 0 0 16px;
    font-family: "Manrope", "Segoe UI", sans-serif;
    font-size: clamp(17px, 1.08vw, 20px);
    line-height: 1.74;
    color: var(--fi-faq-text);
    text-wrap: pretty;
  }

  .fi-faq-modal-body p:last-child,
  .fi-faq-modal-body ul:last-child,
  .fi-faq-modal-body ol:last-child,
  .fi-faq-modal-body blockquote:last-child {
    margin-bottom: 0;
  }

  .fi-faq-modal-body ul,
  .fi-faq-modal-body ol {
    margin: 0 0 16px;
    padding-left: 26px;
  }

  .fi-faq-modal-body a {
    color: var(--fi-faq-link);
    text-decoration: underline;
    text-decoration-color: rgba(160, 211, 255, 0.62);
    text-underline-offset: 2px;
    word-break: break-word;
  }

  .fi-faq-modal-body a:hover {
    color: #dbf1ff;
    text-decoration-color: rgba(219, 241, 255, 0.86);
  }

  .fi-faq-modal-body blockquote {
    padding: 12px 14px;
    border-left: 3px solid rgba(162, 201, 250, 0.72);
    background: rgba(18, 33, 54, 0.48);
    border-radius: 9px;
  }

  .fi-faq-modal-body strong {
    font-weight: 800;
    color: #ffffff;
  }

  .fi-faq-modal-body pre {
    margin: 14px 0;
    padding: 14px;
    border-radius: 10px;
    border: 1px solid rgba(126, 168, 222, 0.45);
    background: rgba(8, 15, 28, 0.92);
    color: rgba(239, 246, 255, 0.99);
    font-family: "SFMono-Regular", Menlo, Consolas, Monaco, "Liberation Mono", monospace;
    font-size: 14px;
    line-height: 1.55;
    overflow-x: auto;
    white-space: pre-wrap;
  }

  .fi-faq-modal-body .fi-faq-video-embed {
    width: min(920px, 100%);
    aspect-ratio: 16 / 9;
    margin: 12px 0 16px;
    border-radius: 12px;
    border: 1px solid rgba(120, 165, 224, 0.42);
    overflow: hidden;
    background: rgba(8, 15, 29, 0.9);
    box-shadow: 0 8px 20px rgba(4, 9, 20, 0.32);
  }

  .fi-faq-modal-body .fi-faq-video-embed iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
  }

  body.fi-faq-modal-open {
    overflow: hidden;
  }

  @media (max-width: 980px) {
    .fi-faq-cards-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (max-width: 767px) {
    .fi-faq-page-wrap {
      padding-top: 18px;
      padding-bottom: 32px;
    }

    .fi-faq-page-shell {
      gap: 28px;
    }

    .fi-faq-toc {
      padding: 18px 16px;
    }

    .fi-faq-toc-list {
      gap: 8px;
    }

    .fi-faq-toc-list a {
      width: 100%;
      justify-content: center;
      font-size: 13px;
    }

    .fi-faq-section {
      text-align: center;
    }

    .fi-faq-section h3 {
      font-size: clamp(21px, 7vw, 30px);
      margin: 0 0 22px;
      text-align: center;
    }

    .fi-faq-section h3::before {
      display: block;
      margin: 0 auto 6px;
    }

    .fi-faq-cards-grid {
      grid-template-columns: 1fr;
      gap: 16px;
    }

    .fi-faq-card {
      min-height: 0;
      height: auto;
      border-radius: 16px;
      padding: 22px 18px;
      gap: 16px;
    }

    .fi-faq-card-title {
      font-size: 17px;
      line-height: 1.35;
    }

    .fi-faq-modal {
      padding: 10px;
    }

    .fi-faq-modal-panel {
      border-radius: 14px;
      max-height: 92vh;
    }

    .fi-faq-modal-head {
      padding: 12px;
    }

    .fi-faq-modal-body {
      padding: 14px 12px 16px;
    }

    .fi-faq-modal-body p,
    .fi-faq-modal-body li,
    .fi-faq-modal-body blockquote {
      font-size: 16px;
      line-height: 1.66;
    }
  }

/* --- signaler --- */
.fi-contact-form-wrap {
  display: flex;
  justify-content: center;
  padding: clamp(28px, 5vw, 56px) clamp(16px, 3vw, 24px) clamp(36px, 6vw, 72px);
}
#fi-contact-block {
  --fi-label: #e6e6f0;
  --fi-text: #b8b8c8;
  --fi-input-bg: #ffffff;
  --fi-input-fg: #1a1a2e;
  --fi-border: rgba(255,255,255,0.18);
  --fi-radius: 10px;
  --fi-gap: 26px;
  --fi-accent: #ff4d6d;
  --fi-accent-hover: #e6395a;
  width: 100%;
  max-width: 760px;
  background:
    radial-gradient(720px 280px at 8% 0%, rgba(92, 168, 255, 0.10), transparent 62%),
    linear-gradient(180deg, #06122a, #03081b);
  border: 1px solid rgba(176, 214, 255, 0.18);
  border-radius: 22px;
  padding: clamp(22px, 3.4vw, 38px) clamp(20px, 3vw, 32px);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.04);
}
#fi-contact-form .fi-form-row { margin-bottom: var(--fi-gap); }
#fi-contact-form .fi-form-row-last { margin-bottom: 0; }
#fi-contact-form .fi-form-label {
  display: block;
  color: var(--fi-label);
  font-weight: 600;
  font-size: 0.95rem;
  margin-bottom: 10px;
  letter-spacing: 0.01em;
}
#fi-contact-form .fi-form-required { color: var(--fi-accent); margin-left: 2px; }
#fi-contact-form .fi-form-input,
#fi-contact-form .fi-form-select--field,
#fi-contact-form .fi-form-textarea {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid transparent;
  border-radius: var(--fi-radius);
  font: inherit;
  background: var(--fi-input-bg);
  color: var(--fi-input-fg);
  box-sizing: border-box;
  transition: border-color 150ms, box-shadow 150ms;
}
#fi-contact-form .fi-form-input:focus,
#fi-contact-form .fi-form-select--field:focus,
#fi-contact-form .fi-form-textarea:focus {
  outline: none;
  border-color: var(--fi-accent);
  box-shadow: 0 0 0 3px rgba(255,77,109,0.18);
}
#fi-contact-form .fi-form-textarea {
  min-height: 160px;
  resize: vertical;
  font-family: inherit;
}

/* Champ fichier custom */
#fi-attachment-wrap {
  display: flex; flex-direction: column; gap: 12px;
}
#fi-attachment-drop {
  border: 1.5px dashed var(--fi-border);
  border-radius: var(--fi-radius);
  padding: 22px 18px;
  text-align: center;
  background: rgba(255,255,255,0.04);
  color: var(--fi-text);
  cursor: pointer;
  transition: background 150ms, border-color 150ms;
}
#fi-attachment-drop:hover, #fi-attachment-drop.is-drag {
  background: rgba(255,255,255,0.08);
  border-color: var(--fi-accent);
  color: var(--fi-label);
}
#fi-attachment-drop strong { color: var(--fi-label); }
#fi-attachment-drop small { display: block; margin-top: 6px; font-size: 0.85rem; opacity: 0.75; }
/* Masquage accessible standard, sans pointer-events:none qui peut casser le label sur Safari */
#fi-attachment {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
#fi-attachment-list { display: flex; flex-direction: column; gap: 8px; }
#fi-attachment-list:empty { display: none; }
.fi-att-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--fi-border);
  border-radius: 8px;
  color: var(--fi-text);
  font-size: 0.9rem;
}
.fi-att-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--fi-label); }
.fi-att-size { flex-shrink: 0; opacity: 0.7; font-variant-numeric: tabular-nums; }
.fi-att-remove {
  flex-shrink: 0;
  width: 28px; height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0; background: transparent;
  color: #ffb1bf;
  cursor: pointer;
  font-size: 1.3rem;
  line-height: 1;
  border-radius: 6px;
}
.fi-att-remove:hover { color: var(--fi-accent); background: rgba(255,77,109,0.1); }

/* Consentement */
#fi-contact-form .fi-form-checkbox {
  display: flex; align-items: flex-start; gap: 12px;
  cursor: pointer;
  color: var(--fi-text);
  font-size: 0.92rem;
  line-height: 1.55;
}
#fi-contact-form .fi-form-checkbox input[type=checkbox] {
  flex-shrink: 0;
  margin-top: 3px;
  width: 18px; height: 18px;
  accent-color: var(--fi-accent);
}
#fi-contact-form .fi-form-checkbox-box { display: none; }
#fi-contact-form .fi-form-consent__label { display: block; }

/* Bouton submit */
#fi-contact-form .fi-form-button-submit {
  background: var(--fi-accent);
  color: #fff;
  padding: 14px 36px;
  border: 0;
  border-radius: var(--fi-radius);
  font-weight: 600;
  font-size: 1rem;
  cursor: pointer;
  transition: background 150ms, transform 100ms;
}
#fi-contact-form .fi-form-button-submit:hover { background: var(--fi-accent-hover); }
#fi-contact-form .fi-form-button-submit:active { transform: translateY(1px); }
#fi-contact-form .fi-form-button-submit:disabled { opacity: 0.55; cursor: wait; }

/* Feedback */
#fi-contact-feedback {
  padding: 14px 18px;
  border-radius: var(--fi-radius);
  margin-bottom: var(--fi-gap);
  font-size: 0.95rem;
  line-height: 1.5;
}
#fi-contact-feedback.fi-form-success {
  background: rgba(40, 200, 110, 0.12);
  color: #82eaa6;
  border: 1px solid rgba(40, 200, 110, 0.3);
}
#fi-contact-feedback.fi-form-error {
  background: rgba(255, 77, 109, 0.12);
  color: #ffb1bf;
  border: 1px solid rgba(255, 77, 109, 0.3);
}

/* --- signaler --- */
.fi-contact-banner-wrap {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    display: flex;
    justify-content: center;
    padding: clamp(18px, 3vw, 38px) 16px clamp(12px, 2.4vw, 24px);
    box-sizing: border-box;
  }

  .fi-contact-banner {
    width: min(980px, 100%);
    text-align: center;
    margin: 0 auto;
  }

  .fi-contact-title {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(30px, 5vw, 58px);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: -0.02em;
    color: #eaf6ff;
    text-shadow:
      0 0 1px rgba(214, 240, 255, 0.45),
      0 0 16px rgba(80, 167, 255, 0.22);
  }

  .fi-contact-title::after {
    content: "";
    display: block;
    width: clamp(78px, 10vw, 118px);
    height: 3px;
    margin: clamp(8px, 1.2vw, 12px) auto 0;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(160, 218, 255, 0.25), rgba(185, 232, 255, 0.95), rgba(160, 218, 255, 0.25));
  }

  .fi-contact-text {
    margin: clamp(10px, 1.4vw, 16px) auto 0;
    max-width: 860px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(15px, 1.3vw, 21px);
    font-weight: 500;
    line-height: 1.48;
    color: rgba(225, 240, 252, 0.97);
    text-wrap: balance;
  }

  @media (max-width: 767px) {
    .fi-contact-banner-wrap {
      padding-top: 14px;
      padding-bottom: 10px;
    }

    .fi-contact-title {
      font-size: clamp(30px, 9vw, 44px);
    }

    .fi-contact-text {
      max-width: 100%;
      font-size: clamp(15px, 4.2vw, 18px);
      line-height: 1.42;
    }
  }

/* --- statistiques --- */
.fi-stx-wrap {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    display: flex;
    justify-content: center;
    padding: clamp(22px, 4vw, 48px) 16px clamp(36px, 5vw, 72px);
    box-sizing: border-box;
  }

  .fi-stx-shell {
    width: min(1160px, 100%);
    display: grid;
    gap: clamp(14px, 1.8vw, 20px);
    overflow-x: clip;
  }

  .fi-stx-intro h2 {
    margin: 0 0 6px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(21px, 2.2vw, 30px);
    font-weight: 800;
    letter-spacing: -0.01em;
    color: rgba(234, 247, 255, 0.98);
  }

  .fi-stx-intro p {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(13px, 1.05vw, 15px);
    line-height: 1.45;
    color: rgba(208, 232, 252, 0.9);
  }

  .fi-stx-updated {
    margin-top: 6px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: rgba(183, 223, 251, 0.92);
  }

  .fi-stx-updated::before {
    content: "⟳";
    font-size: 13px;
    opacity: 0.9;
  }

  .fi-stx-panel {
    border: 1px solid rgba(149, 215, 255, 0.22);
    border-radius: 18px;
    background:
      radial-gradient(120% 120% at 8% 0%, rgba(97, 164, 255, 0.18), transparent 58%),
      linear-gradient(180deg, rgba(10, 27, 57, 0.72), rgba(5, 16, 36, 0.66));
    box-shadow:
      inset 0 1px 0 rgba(220, 245, 255, 0.08),
      0 16px 40px rgba(0, 6, 20, 0.3);
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
    padding: clamp(14px, 1.6vw, 20px);
    min-width: 0;
  }

  .fi-stx-panel-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
  }

  .fi-stx-panel-title {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(15px, 1.2vw, 18px);
    font-weight: 700;
    color: rgba(233, 246, 255, 0.98);
  }

  .fi-stx-panel-note {
    margin: 6px 0 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
    line-height: 1.4;
    color: rgba(196, 226, 251, 0.8);
  }

  .fi-stx-toggle-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .fi-stx-toggle-row--center {
    justify-content: center;
  }

  .fi-stx-toggle {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px;
    border-radius: 999px;
    border: 1px solid rgba(136, 202, 246, 0.3);
    background: rgba(11, 34, 66, 0.45);
  }

  .fi-stx-toggle button {
    border: 0;
    border-radius: 999px;
    padding: 7px 11px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
    font-weight: 600;
    color: rgba(204, 230, 250, 0.95);
    background: transparent;
    cursor: pointer;
  }

  .fi-stx-toggle button.is-active {
    color: #eef9ff;
    background: linear-gradient(180deg, rgba(93, 167, 255, 0.34), rgba(45, 109, 236, 0.38));
    box-shadow: 0 0 0 1px rgba(159, 223, 255, 0.28) inset;
  }

  .fi-stx-time-chart {
    position: relative;
    border: 1px solid rgba(124, 196, 246, 0.22);
    border-radius: 14px;
    padding: clamp(12px, 1.6vw, 18px) clamp(10px, 1.2vw, 16px) 10px;
    background:
      linear-gradient(180deg, rgba(11, 33, 63, 0.62), rgba(5, 20, 40, 0.58));
    min-height: 292px;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    scrollbar-color: rgba(115, 204, 255, 0.72) rgba(16, 46, 84, 0.55);
    transition: height 260ms cubic-bezier(0.22, 1, 0.36, 1), opacity 220ms ease;
  }

  .fi-stx-time-chart.is-accordion {
    opacity: 0.98;
  }

  .fi-stx-time-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(66px, 1fr);
    align-items: end;
    gap: clamp(8px, 1vw, 14px);
    min-height: 252px;
    min-width: max-content;
  }

  .fi-stx-time-col {
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 8px;
    align-items: end;
    min-width: 0;
  }

  .fi-stx-time-value {
    text-align: center;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 11px;
    font-weight: 700;
    color: rgba(176, 224, 253, 0.98);
    line-height: 1;
  }

  .fi-stx-time-bar-shell {
    height: 210px;
    border-radius: 10px;
    background:
      linear-gradient(180deg, rgba(41, 78, 128, 0.26), rgba(15, 41, 75, 0.42));
    box-shadow: inset 0 0 0 1px rgba(106, 183, 241, 0.18);
    overflow: hidden;
    display: flex;
    align-items: flex-end;
  }

  .fi-stx-time-bar-fill {
    width: 100%;
    height: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(106, 199, 255, 0.9), rgba(72, 128, 243, 0.92));
    box-shadow:
      inset 0 0 0 1px rgba(161, 223, 255, 0.22),
      0 0 12px rgba(83, 174, 255, 0.36);
    transition: height 280ms cubic-bezier(0.2, 0.75, 0.25, 1);
  }

  .fi-stx-time-label {
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 11px;
    color: rgba(206, 232, 252, 0.9);
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .fi-stx-bars {
    display: grid;
    gap: 10px;
    max-height: 420px;
    overflow: auto;
    padding-right: 2px;
    scrollbar-width: thin;
    scrollbar-color: rgba(115, 204, 255, 0.72) rgba(16, 46, 84, 0.55);
    scrollbar-gutter: stable;
  }

  .fi-stx-bar-row {
    display: grid;
    gap: 6px;
  }

  .fi-stx-bar-meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
  }

  .fi-stx-bar-label {
    font-size: 12px;
    font-weight: 600;
    color: rgba(220, 238, 255, 0.93);
  }

  .fi-stx-bar-value {
    font-size: 12px;
    font-weight: 700;
    color: rgba(172, 222, 255, 0.96);
  }

  .fi-stx-bar-track {
    height: 9px;
    border-radius: 999px;
    background: rgba(19, 58, 103, 0.68);
    overflow: hidden;
    box-shadow: inset 0 0 0 1px rgba(108, 186, 243, 0.17);
  }

  .fi-stx-bar-fill {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #6cd5ff 0%, #4b9eff 52%, #3f6dff 100%);
    box-shadow: 0 0 10px rgba(83, 174, 255, 0.4);
  }

  .fi-stx-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
  }

  .fi-stx-kpi {
    border: 1px solid rgba(136, 200, 247, 0.22);
    border-radius: 14px;
    padding: 12px;
    background: linear-gradient(180deg, rgba(10, 32, 63, 0.64), rgba(5, 18, 38, 0.56));
    min-height: 106px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 5px;
  }

  .fi-stx-kpi-kicker {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: rgba(184, 223, 250, 0.9);
    text-transform: uppercase;
  }

  .fi-stx-kpi-value {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(22px, 2.4vw, 30px);
    font-weight: 800;
    line-height: 1.04;
    letter-spacing: -0.01em;
    background: linear-gradient(90deg, #d1f0ff 0%, #8ed8ff 45%, #63a7ff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
  }

  .fi-stx-kpi-sub {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
    line-height: 1.35;
    color: rgba(202, 228, 249, 0.88);
  }

  .fi-stx-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }

  .fi-stx-grid--single {
    grid-template-columns: 1fr;
  }

  .fi-stx-mini-list {
    display: grid;
    gap: 7px;
  }

  .fi-stx-donut-layout {
    display: grid;
    grid-template-columns: 210px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
  }

  .fi-stx-panel--status .fi-stx-donut-layout {
    grid-template-columns: minmax(250px, 320px) minmax(260px, 380px);
    justify-content: center;
    gap: 30px;
    margin-top: 8px;
  }

  .fi-stx-panel--status .fi-stx-donut {
    width: min(320px, 100%);
    margin: 0 auto;
  }

  .fi-stx-panel--status .fi-stx-donut-center {
    display: none;
  }

  .fi-stx-panel--status .fi-stx-panel-head {
    justify-content: center;
    text-align: center;
    margin-bottom: 10px;
  }

  .fi-stx-panel--status .fi-stx-panel-head > div {
    width: 100%;
  }

  .fi-stx-panel--status .fi-stx-toggle {
    width: min(380px, 100%);
    justify-content: center;
  }

  .fi-stx-panel--status .fi-stx-toggle-row {
    margin-bottom: 24px;
  }

  .fi-stx-panel--status .fi-stx-donut-legend {
    width: 100%;
    max-width: 380px;
    gap: 10px;
    padding-top: 8px;
  }

  .fi-stx-panel--status .fi-stx-status-row {
    display: grid;
    gap: 6px;
    padding: 8px 10px;
    border-radius: 12px;
    border: 1px solid rgba(127, 197, 245, 0.18);
    background: rgba(10, 34, 66, 0.5);
  }

  .fi-stx-panel--status .fi-stx-donut-item {
    gap: 10px;
  }

  .fi-stx-panel--status .fi-stx-donut-label {
    font-size: 13px;
  }

  .fi-stx-panel--status .fi-stx-donut-pct {
    min-width: 52px;
    text-align: right;
    font-size: 13px;
    font-variant-numeric: tabular-nums;
  }

  .fi-stx-status-track {
    height: 6px;
    border-radius: 999px;
    background: rgba(20, 57, 99, 0.7);
    box-shadow: inset 0 0 0 1px rgba(107, 186, 243, 0.14);
    overflow: hidden;
  }

  .fi-stx-status-fill {
    display: block;
    height: 100%;
    border-radius: inherit;
    box-shadow: 0 0 8px rgba(95, 184, 255, 0.35);
  }

  .fi-stx-donut-layout--stack {
    grid-template-columns: 1fr;
    justify-items: center;
    align-items: start;
  }

  .fi-stx-donut-layout--stack .fi-stx-donut-legend {
    width: 100%;
    margin-top: 4px;
  }

  .fi-stx-donut {
    width: min(210px, 100%);
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    position: relative;
    background: conic-gradient(
      #7ad8ff 0deg 120deg,
      #4ba1ff 120deg 220deg,
      #5676ff 220deg 300deg,
      #6be0c9 300deg 360deg
    );
    box-shadow:
      inset 0 0 0 1px rgba(160, 220, 252, 0.22),
      0 14px 34px rgba(2, 10, 30, 0.42);
  }

  .fi-stx-donut--segmented {
    box-shadow:
      inset 0 0 0 1px rgba(165, 223, 252, 0.22),
      0 14px 34px rgba(2, 10, 30, 0.46);
  }

  .fi-stx-donut.fi-stx-donut--segmented::after {
    inset: 30%;
    background:
      radial-gradient(100% 100% at 36% 30%, rgba(20, 59, 104, 0.24), rgba(6, 23, 47, 0.88));
    box-shadow: inset 0 0 0 1px rgba(127, 201, 246, 0.15);
  }

  .fi-stx-donut--no-center .fi-stx-donut-center {
    display: none;
  }

  .fi-stx-donut::after {
    content: "";
    position: absolute;
    inset: 21%;
    border-radius: 50%;
    background:
      radial-gradient(100% 100% at 38% 28%, rgba(25, 72, 126, 0.4), rgba(5, 22, 46, 0.95));
    box-shadow: inset 0 0 0 1px rgba(140, 210, 248, 0.18);
  }

  .fi-stx-donut-center {
    position: absolute;
    z-index: 1;
    inset: 30% 30%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    pointer-events: none;
    font-family: "Montserrat", "Segoe UI", sans-serif;
  }

  .fi-stx-donut-center b {
    font-size: 18px;
    color: rgba(230, 246, 255, 0.98);
    line-height: 1.1;
  }

  .fi-stx-donut-center span {
    margin-top: 2px;
    font-size: 11px;
    color: rgba(189, 225, 248, 0.88);
    line-height: 1.2;
  }

  .fi-stx-donut-legend {
    display: grid;
    gap: 6px;
  }

  .fi-stx-donut-item {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 8px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
    color: rgba(215, 236, 252, 0.94);
  }

  .fi-stx-donut-dot {
    width: 9px;
    height: 9px;
    border-radius: 50%;
    box-shadow: 0 0 8px rgba(108, 199, 255, 0.6);
  }

  .fi-stx-donut-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .fi-stx-donut-pct {
    font-weight: 700;
    color: rgba(170, 220, 251, 0.98);
  }

  .fi-stx-donut-item-note {
    font-size: 11px;
    color: rgba(178, 216, 245, 0.82);
  }

  .fi-stx-type-lines {
    display: grid;
    gap: 9px;
  }

  .fi-stx-type-row {
    display: grid;
    gap: 5px;
  }

  .fi-stx-type-meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 10px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
  }

  .fi-stx-type-label {
    font-size: 12px;
    color: rgba(220, 238, 255, 0.94);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .fi-stx-type-value {
    font-size: 12px;
    font-weight: 700;
    color: rgba(176, 224, 253, 0.98);
    white-space: nowrap;
  }

  .fi-stx-type-track {
    height: 8px;
    border-radius: 999px;
    background: rgba(18, 55, 97, 0.66);
    box-shadow: inset 0 0 0 1px rgba(109, 188, 244, 0.16);
    overflow: hidden;
  }

  .fi-stx-type-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #6cd5ff 0%, #3f6dff 100%);
    box-shadow: 0 0 8px rgba(85, 178, 255, 0.35);
  }

  .fi-stx-mini-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    font-family: "Montserrat", "Segoe UI", sans-serif;
  }

  .fi-stx-mini-item .label {
    font-size: 12px;
    color: rgba(220, 238, 255, 0.92);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .fi-stx-mini-item .value {
    font-size: 12px;
    font-weight: 700;
    color: rgba(174, 220, 252, 0.97);
  }

  .fi-stx-table-wrap {
    overflow: auto;
    border-radius: 12px;
    border: 1px solid rgba(126, 197, 244, 0.22);
    scrollbar-width: thin;
    scrollbar-color: rgba(115, 204, 255, 0.72) rgba(16, 46, 84, 0.55);
    scrollbar-gutter: stable;
  }

  .fi-stx-bars::-webkit-scrollbar,
  .fi-stx-time-chart::-webkit-scrollbar,
  .fi-stx-table-wrap::-webkit-scrollbar {
    width: 10px;
    height: 10px;
  }

  .fi-stx-bars::-webkit-scrollbar-track,
  .fi-stx-time-chart::-webkit-scrollbar-track,
  .fi-stx-table-wrap::-webkit-scrollbar-track {
    background: rgba(16, 46, 84, 0.52);
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px rgba(108, 186, 243, 0.16);
  }

  .fi-stx-bars::-webkit-scrollbar-thumb,
  .fi-stx-time-chart::-webkit-scrollbar-thumb,
  .fi-stx-table-wrap::-webkit-scrollbar-thumb {
    border-radius: 999px;
    border: 2px solid rgba(9, 32, 63, 0.9);
    background: linear-gradient(180deg, rgba(125, 214, 255, 0.95), rgba(70, 142, 246, 0.95));
    box-shadow:
      0 0 8px rgba(87, 179, 255, 0.45),
      inset 0 0 0 1px rgba(202, 241, 255, 0.22);
  }

  .fi-stx-bars::-webkit-scrollbar-thumb:hover,
  .fi-stx-time-chart::-webkit-scrollbar-thumb:hover,
  .fi-stx-table-wrap::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, rgba(146, 224, 255, 0.98), rgba(84, 160, 255, 0.98));
  }

  .fi-stx-bars::-webkit-scrollbar-corner,
  .fi-stx-time-chart::-webkit-scrollbar-corner,
  .fi-stx-table-wrap::-webkit-scrollbar-corner {
    background: transparent;
  }

  .fi-stx-table {
    width: 100%;
    border-collapse: collapse;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
  }

  .fi-stx-table th,
  .fi-stx-table td {
    text-align: left;
    padding: 8px 10px;
    border-bottom: 1px solid rgba(116, 189, 240, 0.16);
    color: rgba(215, 236, 253, 0.93);
    vertical-align: top;
  }

  .fi-stx-table th {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: rgba(174, 220, 251, 0.86);
    background: rgba(16, 46, 84, 0.45);
    position: sticky;
    top: 0;
    z-index: 1;
  }

  .fi-stx-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 11px;
    font-weight: 700;
    border-radius: 999px;
    border: 1px solid rgba(143, 209, 250, 0.25);
    padding: 4px 8px;
    color: rgba(214, 239, 255, 0.95);
    background: rgba(24, 63, 110, 0.45);
  }

  .fi-stx-pill-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }

  .fi-stx-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 9px;
    border-radius: 999px;
    border: 1px solid rgba(137, 204, 247, 0.23);
    background: rgba(14, 46, 86, 0.46);
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 11px;
    color: rgba(214, 236, 252, 0.94);
  }

  .fi-stx-progress-row {
    display: grid;
    gap: 4px;
  }

  .fi-stx-progress-meta {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 12px;
    color: rgba(218, 237, 252, 0.93);
  }

  .fi-stx-progress-track {
    height: 8px;
    border-radius: 999px;
    background: rgba(17, 51, 92, 0.67);
    box-shadow: inset 0 0 0 1px rgba(101, 182, 238, 0.17);
    overflow: hidden;
  }

  .fi-stx-progress-fill {
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #5ed1ff 0%, #488fff 100%);
  }

  .fi-stx-empty,
  .fi-stx-error {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: 13px;
    line-height: 1.4;
    color: rgba(205, 231, 250, 0.9);
  }

  .fi-stx-error {
    color: rgba(255, 191, 191, 0.95);
  }

  @media (max-width: 1024px) {
    .fi-stx-kpi-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .fi-stx-grid {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 767px) {
    .fi-stx-wrap {
      padding-top: 18px;
    }

    .fi-stx-panel {
      border-radius: 14px;
    }

    .fi-stx-kpi-grid {
      grid-template-columns: 1fr;
    }

    .fi-stx-table th,
    .fi-stx-table td {
      padding: 7px 8px;
    }

    .fi-stx-toggle-row {
      width: 100%;
    }

    .fi-stx-toggle {
      display: flex;
      width: 100%;
      max-width: 100%;
    }

    .fi-stx-toggle button {
      flex: 1 1 0;
      min-width: 0;
      padding: 7px 6px;
      font-size: clamp(11px, 3.6vw, 12px);
      text-align: center;
      white-space: nowrap;
    }

    .fi-stx-time-chart {
      min-height: 252px;
      padding: 10px 8px 8px;
    }

    .fi-stx-time-grid {
      min-height: 220px;
      grid-auto-columns: minmax(52px, 1fr);
    }

    .fi-stx-time-bar-shell {
      height: 176px;
    }

    .fi-stx-time-label {
      font-size: 10px;
    }

    .fi-stx-donut-layout {
      grid-template-columns: 1fr;
    }

    .fi-stx-donut {
      width: min(220px, 72vw);
      margin: 0 auto;
    }

    .fi-stx-panel--status .fi-stx-donut {
      width: min(260px, 82vw);
    }

    .fi-stx-panel--status .fi-stx-donut-layout {
      grid-template-columns: 1fr;
      gap: 14px;
    }

    .fi-stx-panel--status .fi-stx-donut-legend {
      max-width: 100%;
    }
  }

/* --- accueil --- */
.fi-counter-wrap {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    display: flex;
    justify-content: center;
    padding: clamp(36px, 6vw, 84px) 16px;
    box-sizing: border-box;
  }

  .fi-counter {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: clamp(10px, 1.4vw, 16px);
    text-align: center;
  }

  .fi-counter-value {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(40px, 8.2vw, 108px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.02em;
    display: inline-flex;
    align-items: flex-end;
    gap: clamp(1px, 0.25vw, 4px);
    white-space: nowrap;
    text-shadow:
      0 0 1px rgba(188, 236, 255, 0.65),
      0 0 8px rgba(101, 199, 255, 0.45),
      0 0 18px rgba(58, 122, 255, 0.28);
    font-variant-numeric: tabular-nums;
  }

  .fi-odo-digit {
    position: relative;
    display: inline-block;
    width: 0.66em;
    height: 1em;
    overflow: hidden;
    vertical-align: bottom;
  }

  .fi-odo-strip {
    display: flex;
    flex-direction: column;
    transform: translateY(0);
    will-change: transform;
  }

  .fi-odo-strip .fi-odo-glyph {
    display: block;
    height: 1em;
    line-height: 1em;
    flex-shrink: 0;
  }

  .fi-odo-sep {
    display: inline-block;
    min-width: 0.22em;
    text-align: center;
  }

  .fi-odo-glyph {
    background: linear-gradient(90deg, #b7e7ff 0%, #83d2ff 42%, #5fb5ff 72%, #4b8bff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
  }

  .fi-counter-label {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(14px, 1.7vw, 24px);
    font-style: italic;
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.3;
    color: rgba(234, 246, 255, 0.97);
    text-shadow: 0 0 8px rgba(52, 122, 255, 0.18);
  }

  .fi-counter-since {
    margin: -2px 0 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(11px, 1.05vw, 14px);
    font-weight: 500;
    letter-spacing: 0.01em;
    line-height: 1.3;
    color: rgba(210, 234, 255, 0.82);
  }

  .fi-stats-grid {
    width: min(1120px, 100%);
    margin-top: clamp(28px, 4.2vw, 54px);
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(12px, 1.8vw, 20px);
  }

  .fi-stat-card {
    position: relative;
    border-radius: 20px;
    border: 1px solid rgba(154, 218, 255, 0.28);
    background:
      radial-gradient(120% 100% at 12% 0%, rgba(113, 164, 255, 0.2), transparent 62%),
      linear-gradient(180deg, rgba(12, 31, 60, 0.72), rgba(6, 20, 42, 0.64));
    box-shadow:
      inset 0 1px 0 rgba(218, 244, 255, 0.1),
      0 16px 48px rgba(0, 6, 20, 0.36);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: clamp(16px, 2.2vw, 24px);
    min-height: clamp(132px, 17vw, 178px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
  }

  .fi-stat-value {
    margin: 0 0 8px;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.01em;
    background: linear-gradient(90deg, #c4ebff 0%, #86d2ff 50%, #549eff 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    text-shadow:
      0 0 1px rgba(188, 236, 255, 0.58),
      0 0 12px rgba(75, 172, 255, 0.28);
  }

  .fi-stat-label {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(14px, 1.25vw, 18px);
    font-weight: 600;
    line-height: 1.35;
    color: rgba(234, 246, 255, 0.92);
  }

  .fi-stat-copy {
    align-items: flex-start;
    text-align: left;
  }

  .fi-stat-copy p {
    margin: 0;
    font-family: "Montserrat", "Segoe UI", sans-serif;
    font-size: clamp(14px, 1.1vw, 16px);
    line-height: 1.55;
    color: rgba(233, 246, 255, 0.93);
  }

  @media (max-width: 767px) {
    .fi-counter-wrap {
      padding-top: 28px;
      padding-bottom: 44px;
    }

    .fi-counter-label {
      max-width: 24ch;
    }

    .fi-stats-grid {
      margin-top: 24px;
      grid-template-columns: 1fr;
      gap: 12px;
    }

    .fi-stat-card {
      min-height: 120px;
      border-radius: 16px;
    }

    .fi-stat-copy {
      text-align: center;
      align-items: center;
    }
  }

/* --- accueil --- */

  /* =========================
      FUITES INFOS — LISTE (scoped)
  ========================== */
  .cb-fi{
    --frame-max: 1160px;
    --frame-gutter: clamp(12px, 2vw, 20px);
    --ink:#f2f7ff;
    --muted:rgba(242,247,255,.74);
    --line:rgba(255,255,255,.12);

    /* Dégradé bleu "PP" */
    --pp-a:#bfe3ff;
    --pp-b:#66c1ff;
    --pp-c:#2a7bff;
    --pp-d:#1b44ff;

    /* Badges statut */
    --st-confirm:#3CFF8F;
    --st-claim:#FFB347;

    font-family:"Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
    color:var(--ink);
    margin-top: 16px;
    position: relative;
    display: flex;
    justify-content: center;
    width: 100%;
    padding-inline: var(--frame-gutter);
  }
  .cb-fi, .cb-fi *{ box-sizing:border-box; }
  .cb-fi a{ color: inherit; text-decoration: none !important; }
  .cb-fi svg{ display:block; }

  .cb-fi-card{
    position:relative;
    width: min(var(--frame-max), 100%);
    margin: 0 auto;
    border-radius: 0;
    padding: 0;
    overflow: visible;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  .cb-fi-grid{
    display: none;
  }

  /* ===== Barre outils (recherche + filtres) ===== */
  .cb-fi-tools{
    position: relative;
    z-index: 1;
    display:flex;
    gap: 12px;
    align-items:center;
    justify-content: center;
    flex-wrap: nowrap;
    margin: 0 auto 16px;
    width: 100%;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid rgba(255,255,255,.10);
    background:
      radial-gradient(760px 300px at 8% 0%, rgba(56,138,255,.14), transparent 62%),
      radial-gradient(620px 280px at 96% 12%, rgba(126,255,214,.05), transparent 64%),
      linear-gradient(180deg, rgba(9,14,28,.88), rgba(8,12,24,.76));
    box-shadow: 0 16px 56px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.1);
    overflow: visible;
  }
  .cb-fi-tools::before{
    content: "";
    position: absolute;
    inset: 0;
    padding: 1.2px;
    border-radius: 18px;
    background: linear-gradient(90deg, var(--pp-a), var(--pp-b), var(--pp-c), var(--pp-d));
    -webkit-mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    opacity: .78;
  }

  .cb-fi-tools__left{
    display:flex;
    gap: 10px;
    align-items:center;
    justify-content: center;
    flex-wrap: nowrap;
    min-width: 0;
    width: auto;
    max-width: 100%;
  }
  .cb-fi-options{
    display:flex;
    gap: 10px;
    align-items:center;
    justify-content: center;
    flex-wrap: nowrap;
  }
  .cb-fi-view{
    display:inline-flex;
    align-items:center;
    gap: 4px;
    height: 36px;
    padding: 3px;
    border-radius: 9999px;
    border: 1px solid rgba(95, 134, 183, 0.48);
    background: rgba(3, 8, 15, 0.94);
    box-shadow: inset 0 0 0 1px rgba(62, 109, 168, 0.18);
  }
  .cb-fi-viewbtn{
    border: 0;
    outline: 0;
    border-radius: 9999px;
    height: 28px;
    padding: 0 12px;
    background: transparent;
    color: rgba(242,247,255,.72);
    font-weight: 900;
    font-size: 11px;
    letter-spacing: .02em;
    text-transform: uppercase;
    cursor: pointer;
  }
  .cb-fi-viewbtn.is-active{
    background: linear-gradient(135deg, rgba(191,227,255,.20), rgba(42,123,255,.18));
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(191,227,255,.20);
  }
  .cb-fi-mobile-toggle{
    display:none;
    align-items:center;
    justify-content:center;
    gap: 8px;
    padding: 7px 12px;
    min-height: 36px;
    border-radius: 6px;
    border: 1px solid rgba(95, 134, 183, 0.48);
    background: rgba(3, 8, 15, 0.94);
    box-shadow: inset 0 0 0 1px rgba(62, 109, 168, 0.18);
    color: #eef6ff;
    font-weight: 900;
    font-size: 12px;
    cursor: pointer;
  }

  .cb-fi-kicker{
    display:inline-flex;
    align-items:center;
    gap:10px;
    font-family:"Oxanium", system-ui, sans-serif;
    font-weight:700;
    font-size: 12px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(242,247,255,.90);
    padding: 10px 14px;
    border-radius: 9999px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
  }

  .cb-fi-search{
    display:flex;
    align-items:center;
    gap: 10px;
    padding: 6px 10px;
    height: 36px;
    border-radius: 6px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(95, 134, 183, 0.48);
    box-shadow: inset 0 0 0 1px rgba(62, 109, 168, 0.18);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    flex: 0 1 300px;
    min-width: 220px;
    min-height: 36px;
  }
  .cb-fi-search svg{ width:16px; height:16px; opacity:1; color:#d9e9ff; }
  .cb-fi-search input{
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: rgba(242,247,255,.96);
    font-weight: 800;
    letter-spacing: .01em;
    font-size: 12px;
  }
  .cb-fi-search input::placeholder{ color: rgba(242,247,255,.55); font-weight: 800; }

  .cb-fi-select{
    display:inline-flex;
    align-items:center;
    gap: 10px;
    padding: 6px 10px;
    height: 36px;
    border-radius: 6px;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(95, 134, 183, 0.48);
    box-shadow: inset 0 0 0 1px rgba(62, 109, 168, 0.18);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    min-height: 36px;
  }
  .cb-fi-select label{
    font-weight: 900;
    color: rgba(242,247,255,.85);
    font-size: 11px;
    letter-spacing: .01em;
  }
  .cb-fi-select select{
    border:0;
    outline:0;
    background: transparent;
    color: #eef6ff;
    font-weight: 900;
    cursor: pointer;
    font-size: 12px;
  }
  .cb-fi-select option{
    color: #eef6ff;
    background: #05090f;
  }
  .cb-fi-select--sort{
    position: relative;
    height: 36px;
    min-width: 36px;
    width: 36px;
    padding: 0;
    justify-content: center;
    gap: 0;
  }
  .cb-fi-select--sort label{
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }
  .cb-fi-sort-icon{
    width: 16px;
    height: 16px;
    opacity: .95;
    color: #d9e9ff;
    pointer-events: none;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
  }
  .cb-fi-select--sort select{
    position: absolute;
    inset: 0;
    width: 100%;
    min-width: 0;
    opacity: 0;
    appearance: none;
    -webkit-appearance: none;
  }
  .cb-fi-select--sort.is-active{
    border-color: rgba(191,227,255,.35);
    box-shadow: inset 0 0 0 1px rgba(112, 170, 242, 0.34);
  }

  .cb-fi-date{
    position: relative;
  }
  .cb-fi-datebtn{
    display:inline-flex;
    align-items:center;
    justify-content: center;
    gap: 0;
    height: 36px;
    width: 36px;
    min-width: 36px;
    padding: 0;
    min-height: 36px;
    border-radius: 6px;
    border: 1px solid rgba(95, 134, 183, 0.48);
    background: rgba(255,255,255,.04);
    box-shadow: inset 0 0 0 1px rgba(62, 109, 168, 0.18);
    color: #eef6ff;
    font-weight: 900;
    font-size: 12px;
    cursor: pointer;
  }
  .cb-fi-datebtn svg{ width: 15px; height: 15px; opacity:.95; }
  .cb-fi-datebtn__label{
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
    border: 0;
  }
  .cb-fi-datebtn.is-active{
    border-color: rgba(191,227,255,.35);
    box-shadow: inset 0 0 0 1px rgba(112, 170, 242, 0.34);
  }

  .cb-fi-datepanel{
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    z-index: 20;
    min-width: 280px;
    padding: 10px;
    border-radius: 10px;
    border: 1px solid rgba(95, 134, 183, 0.42);
    background: rgba(8,12,24,.96);
    box-shadow: 0 18px 42px rgba(0,0,0,.38), inset 0 0 0 1px rgba(62,109,168,.2);
  }
  .cb-fi-datepanel[hidden]{ display:none; }
  .cb-fi-dategrid{
    display:grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .cb-fi-datefield{
    display:flex;
    flex-direction: column;
    gap: 5px;
  }
  .cb-fi-datefield span{
    font-size: 11px;
    font-weight: 900;
    color: rgba(242,247,255,.80);
  }
  .cb-fi-datefield input[type="date"]{
    width: 100%;
    min-height: 34px;
    border-radius: 6px;
    border: 1px solid rgba(95, 134, 183, 0.46);
    background: rgba(3, 8, 15, 0.96);
    color: #eef6ff;
    font-size: 12px;
    font-weight: 900;
    padding: 6px 8px;
    outline: 0;
  }
  .cb-fi-datefield input[type="date"]::-webkit-calendar-picker-indicator{
    filter: invert(1) brightness(1.2);
    opacity: .9;
    cursor: pointer;
  }
  .cb-fi-dateactions{
    margin-top: 8px;
    display:flex;
    justify-content: flex-end;
  }
  .cb-fi-dateclear{
    border: 1px solid rgba(255,255,255,.16);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.9);
    border-radius: 9999px;
    padding: 6px 10px;
    font-size: 11px;
    font-weight: 900;
    cursor: pointer;
  }
  /* Couleurs des options du select status (support variable selon navigateur) */
  #cbFiStatus option[value="confirmed"]{ color:#10B981; }
  #cbFiStatus option[value="claimed"]{ color:#F59E0B; }

  .cb-fi-tools__right{
    margin-left: 0;
    font-weight: 800;
    color: rgba(242,247,255,.75);
    font-size: 13px;
    width: auto;
    text-align: center;
    white-space: nowrap;
    padding-left: 2px;
  }
  .cb-fi-tools__right b{ color:#fff; }

  /* ===== Sections par année (affichage par défaut) ===== */
  .cb-fi-year{ margin-top: 56px; }

  .cb-fi-year__head{
    display:flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin: 0 2px 46px;
    text-align: center;
  }

  .cb-fi-year__title{
    margin:0;
    font-weight: 950;
    letter-spacing: -0.02em;
    font-size: clamp(18px, 2.2vw, 26px);
  }

  .cb-fi-year__badge{
    display:inline-flex;
    align-items:center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.86);
    font-weight: 900;
    font-size: 12px;
  }

  /* ===== Bandeau années (recherche / filtres actifs) ===== */
  .cb-fi-years-inline{
    display:flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    margin: 56px 2px 46px;
    text-align: center;
  }
  .cb-fi-years-inline--tight{
    margin-bottom: 14px;
  }

  .cb-fi-year-chip{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    padding: 7px 12px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.86);
    font-weight: 900;
    font-size: 12px;
    letter-spacing: .03em;
  }

  /* ===== Index textuel SEO ===== */
  .cb-fi-seo{
    margin-top: 18px;
    padding: 12px 14px;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(255,255,255,.03);
  }
  .cb-fi-seo details{ margin: 0; }
  .cb-fi-seo summary{
    cursor: pointer;
    font-weight: 900;
    font-size: 12px;
    color: rgba(242,247,255,.90);
    letter-spacing: .02em;
  }
  .cb-fi-seo p{
    margin: 10px 0 0;
    color: rgba(242,247,255,.72);
    font-size: 12px;
    font-weight: 800;
  }
  .cb-fi-seo ul{
    margin: 10px 0 0;
    padding-left: 18px;
    columns: 2;
    column-gap: 24px;
  }
  .cb-fi-seo li{
    margin: 0 0 6px;
    break-inside: avoid;
    color: rgba(242,247,255,.84);
    font-size: 12px;
    line-height: 1.45;
    font-weight: 800;
  }
  .cb-fi-seo a{
    color: #cce6ff !important;
    text-decoration: none !important;
  }
  .cb-fi-seo a:hover{ text-decoration: underline !important; }

  /* ===== Grille des cartes ===== */
  .cb-fi-list{
    display:grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    align-items: stretch; /* meme hauteur par ligne (desktop) */
    width: 100%;
    margin: 0 auto;
  }
  .cb-fi-rows{
    display:flex;
    flex-direction: column;
    gap: 12px;
    width: min(1120px, 100%);
    margin: 0 auto;
  }
  .cb-fi-row{
    position: relative;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.10);
    background:
      radial-gradient(680px 260px at 0% 0%, rgba(56,138,255,.10), transparent 62%),
      linear-gradient(180deg, rgba(9,14,28,.86), rgba(8,12,24,.74));
    box-shadow: 0 14px 48px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.10);
    overflow: hidden;
    scroll-margin-top: 110px;
  }
  .cb-fi-row::before{
    content:"";
    position:absolute; inset:0;
    padding: 1px;
    border-radius: 16px;
    background: linear-gradient(90deg, rgba(191,227,255,.72), rgba(42,123,255,.78), rgba(27,68,255,.78));
    -webkit-mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    opacity: .72;
  }
  .cb-fi-row:target,
  .cb-fi-row.cb-fi-target{
    outline: 2px solid rgba(191,227,255,.55);
    outline-offset: 5px;
  }
  .cb-fi-row__inner{
    position: relative;
    z-index: 1;
    display:grid;
    align-items: center;
    grid-template-columns: 72px minmax(220px, 1.45fr) minmax(130px, .9fr) minmax(220px, 1.2fr) auto;
    gap: 12px;
    padding: 10px 12px;
  }
  .cb-fi-row__logo{
    width: 72px;
    height: 52px;
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(0,0,0,.24);
    display:grid;
    place-items:center;
    overflow:hidden;
  }
  .cb-fi-row__logo img{
    width:100%;
    height:100%;
    object-fit: contain;
    background: rgba(255,255,255,.92);
    display:block;
    padding: 5px;
  }
  .cb-fi-row__logo span{
    font-family:"Oxanium", system-ui, sans-serif;
    font-weight: 900;
    letter-spacing: -0.02em;
    color: #eef6ff;
  }
  .cb-fi-row__name{
    font-family:"Oxanium", system-ui, sans-serif;
    font-weight: 800;
    font-size: 16px;
    line-height: 1.15;
    color: var(--pp-b, #66c1ff) !important;
  }
  .cb-fi-row__type{
    margin-top: 2px;
    font-size: 12px;
    font-style: italic;
    font-weight: 800;
    color: rgba(242,247,255,.72);
  }
  .cb-fi-row__mobilemeta{
    display: none;
    align-items: center;
    gap: 6px;
    margin-top: 5px;
    min-width: 0;
    flex-wrap: wrap;
  }
  .cb-fi-row__mobilechip{
    display: inline-flex;
    align-items: center;
    max-width: 100%;
    padding: 4px 8px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.88);
    font-size: 10.5px;
    font-weight: 900;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .cb-fi-row__meta{
    display:flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
  }
  .cb-fi-row__countwrap{
    min-width: 0;
    display:flex;
    align-items:center;
    justify-content:flex-start;
  }
  .cb-fi-row__countwrap .cb-fi-count{
    margin: 0;
    padding: 7px 10px;
    border-radius: 12px;
    gap: 8px;
  }
  .cb-fi-row__countwrap .cb-fi-count__num{ font-size: 15px; }
  .cb-fi-row__countwrap .cb-fi-count__suffix{ font-size: 11px; }
  .cb-fi-row__countwrap .cb-fi-count--ns{
    font-size: 12px;
    padding: 7px 10px;
    white-space: nowrap;
  }
  .cb-fi-row__label{
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: rgba(242,247,255,.58);
  }
  .cb-fi-row__value{
    font-size: 13px;
    font-weight: 900;
    color: rgba(242,247,255,.92);
    overflow-wrap: anywhere;
    line-height: 1.35;
  }
  .cb-fi-row__more{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255,255,255,.18);
    border-radius: 9999px;
    background: linear-gradient(135deg, rgba(191,227,255,.16), rgba(42,123,255,.14));
    color: #fff;
    font-size: 12px;
    font-weight: 950;
    padding: 9px 12px;
    cursor: pointer;
    white-space: nowrap;
  }
  .cb-fi-row__more:hover{
    filter: brightness(1.06);
    border-color: rgba(255,255,255,.28);
  }
  @media (max-width: 980px){
    .cb-fi-tools{ justify-content:center; flex-wrap: wrap; padding: 12px; }
    .cb-fi-tools__left{ justify-content:center; flex-wrap: wrap; }
    .cb-fi-tools__right{ width: 100%; text-align:center; margin-left: 0; }
    .cb-fi-options{ justify-content:center; flex-wrap: wrap; }
    .cb-fi-list{
      grid-template-columns: repeat(2, minmax(0, 1fr));
      align-items: start; /* en mobile/tablette: evite l'etirement quand une card se deplie */
    }
    .cb-fi-year{ margin-top: 44px; }
    .cb-fi-year__head{ margin-bottom: 34px; }
    .cb-fi-years-inline{ margin-top: 44px; margin-bottom: 34px; }
    .cb-fi-years-inline--tight{ margin-bottom: 12px; }
    .cb-fi-seo ul{ columns: 1; }
    .cb-fi-row__inner{
      grid-template-columns: 68px minmax(160px, 1fr) minmax(140px, 1fr) auto;
      grid-template-areas:
        "logo identity date more"
        "logo identity count more";
      gap: 8px 12px;
    }
    .cb-fi-row__logo{ grid-area: logo; width: 68px; height: 50px; }
    .cb-fi-row__identity{ grid-area: identity; }
    .cb-fi-row__meta--date{ grid-area: date; }
    .cb-fi-row__meta--count{ grid-area: count; }
    .cb-fi-row__more{
      grid-area: more;
      align-self: center;
      justify-self: end;
    }
  }
  @media (max-width: 680px){
    .cb-fi{ --frame-gutter: 10px; }
    .cb-fi-tools{ padding: 10px; border-radius: 14px; }
    .cb-fi-tools::before{ border-radius: 14px; }
    .cb-fi-list{ grid-template-columns: 1fr; }
    .cb-fi-year{ margin-top: 34px; }
    .cb-fi-year__head{ margin-bottom: 26px; }
    .cb-fi-years-inline{ margin-top: 34px; margin-bottom: 26px; }
    .cb-fi-years-inline--tight{ margin-bottom: 10px; }
    .cb-fi-mobile-toggle{
      display:flex;
      width: 100%;
      max-width: 560px;
    }
    .cb-fi-options{
      display:none;
      width: 100%;
      max-width: 560px;
      flex-direction: column;
      align-items: stretch;
      justify-content: flex-start;
      gap: 8px;
    }
    .cb-fi-options.is-open{ display:flex; }
    .cb-fi-view{
      width: 100%;
      max-width: 560px;
    }
    .cb-fi-viewbtn{
      flex: 1 1 auto;
      text-align: center;
    }
    .cb-fi-row__inner{
      grid-template-columns: 56px minmax(0, 1fr) auto;
      grid-template-areas:
        "logo identity more";
      padding: 9px 10px;
      gap: 8px;
      align-items: center;
    }
    .cb-fi-row__logo{
      width: 56px;
      height: 42px;
    }
    .cb-fi-row__identity{
      min-width: 0;
    }
    .cb-fi-row__name{
      font-size: 15px;
    }
    .cb-fi-row__type{
      font-size: 11px;
      margin-top: 1px;
    }
    .cb-fi-row__mobilemeta{
      display: flex;
    }
    .cb-fi-row__meta--date,
    .cb-fi-row__meta--count{
      display: none;
    }
    .cb-fi-row__more{
      justify-self: end;
      align-self: center;
      font-size: 11px;
      padding: 7px 10px;
    }
  }

  /* ===== Carte fuite ===== */
  .cb-fi-item{
    position: relative;
    border-radius: 20px;
    overflow:hidden;
    --status-badge-space: 34px; /* reserve verticale quand un status est present */
    height: 100%;

    /* Fond plus sombre (comme l'exemple) */
    background:
      radial-gradient(820px 360px at 10% 0%, rgba(56,138,255,.16), transparent 60%),
      radial-gradient(700px 340px at 95% 18%, rgba(126,255,214,.07), transparent 62%),
      linear-gradient(180deg, rgba(9,14,28,.9), rgba(8,12,24,.76));
    border: 1px solid rgba(255,255,255,.10);
    box-shadow: 0 18px 70px rgba(0,0,0,.46), inset 0 1px 0 rgba(255,255,255,.11);
    backdrop-filter: blur(12px) saturate(150%);
    -webkit-backdrop-filter: blur(12px) saturate(150%);

    display:flex;
    flex-direction: column;
    transition: transform .18s ease, box-shadow .22s ease, filter .2s ease;

    /* IMPORTANT : permet d’éviter que le header sticky masque la card */
    scroll-margin-top: 110px;
  }
  .cb-fi-item:hover{
    transform: translateY(-4px);
    box-shadow: 0 24px 86px rgba(0,0,0,.52), inset 0 1px 0 rgba(255,255,255,.13);
    filter: brightness(1.03);
  }
  @media (max-width: 980px){
    .cb-fi-item{ height: auto; }
  }
  @media (prefers-reduced-motion: reduce){
    .cb-fi-item,
    .cb-fi-item:hover{
      transition: none;
      transform: none;
      filter: none;
    }
  }

  /* ===== Carte publicitaire – Proton VPN ===== */
  .cb-fi-ad{
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    height: 100%;
    background:
      radial-gradient(820px 360px at 10% 0%, rgba(139,92,246,.24), transparent 60%),
      radial-gradient(700px 340px at 95% 18%, rgba(192,132,252,.14), transparent 62%),
      linear-gradient(180deg, rgba(13,9,28,.94), rgba(10,7,24,.82));
    border: 1px solid rgba(167,139,250,.18);
    box-shadow: 0 18px 70px rgba(0,0,0,.46), inset 0 1px 0 rgba(167,139,250,.15);
    backdrop-filter: blur(12px) saturate(150%);
    -webkit-backdrop-filter: blur(12px) saturate(150%);
    display: flex;
    flex-direction: column;
    transition: transform .18s ease, box-shadow .22s ease, filter .2s ease;
    scroll-margin-top: 110px;
  }
  .cb-fi-ad:hover{
    transform: translateY(-4px);
    box-shadow: 0 24px 86px rgba(0,0,0,.52), inset 0 1px 0 rgba(167,139,250,.22);
    filter: brightness(1.04);
  }
  .cb-fi-ad::before{
    content: "";
    position: absolute; inset: 0;
    padding: 1.3px;
    border-radius: 20px;
    background: linear-gradient(135deg, #c084fc, #a855f7, #7c3aed, #6d28d9);
    -webkit-mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
    opacity: .92;
  }
  .cb-fi-ad__inner{
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 24px 20px 22px;
    gap: 14px;
    flex: 1;
  }
.cb-fi-ad__logo{
    width: 260px;
    height: 86px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border-radius: 16px;
    background: rgba(255,255,255,.96);
    padding: 12px 20px;
  }
  .cb-fi-ad__logo img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
  }
  .cb-fi-ad__text{
    margin: 0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.48;
    color: rgba(242,237,255,.90);
    max-width: 230px;
  }
  .cb-fi-ad__btn{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 22px;
    border-radius: 9999px;
    background: linear-gradient(135deg, #a855f7, #7c3aed);
    color: #fff !important;
    font-size: 13px;
    font-weight: 900;
    letter-spacing: .01em;
    border: 0;
    cursor: pointer;
    text-decoration: none !important;
    box-shadow: 0 4px 20px rgba(139,92,246,.44);
    transition: filter .18s ease, transform .15s ease;
  }
  .cb-fi-ad__btn:hover{
    filter: brightness(1.12);
    transform: translateY(-1px);
  }
  @media (max-width: 980px){
    .cb-fi-ad{ height: auto; }
  }

  /* Liseré gradient bleu */
  .cb-fi-item::before{
    content:"";
    position:absolute; inset:0;
    padding: 1.3px;
    border-radius: 20px;
    background: linear-gradient(90deg, var(--pp-a), var(--pp-b), var(--pp-c), var(--pp-d));
    -webkit-mask:
      linear-gradient(#000 0 0) content-box,
      linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events:none;
    opacity: .85;
  }

  /* Surbrillance quand on arrive via #hash */
  .cb-fi-item:target{
    outline: 2px solid rgba(191,227,255,.55);
    outline-offset: 6px;
    box-shadow: 0 26px 110px rgba(0,0,0,.52), inset 0 1px 0 rgba(255,255,255,.12);
  }
  .cb-fi-item.cb-fi-target{
    outline: 2px solid rgba(191,227,255,.55);
    outline-offset: 6px;
  }

  /* ===== Badge status (version app) =====
     - parent: .cb-fi-item est deja position:relative
     - badge: position absolute top-right
  */
  .status-badge{
    position:absolute;
    top: 0;
    right: 0;
    z-index: 3;
    display:flex;
    align-items:center;
    padding: 6px 10px;
    border-top-right-radius: 20px;
    border-bottom-left-radius: 12px;
    pointer-events: none;
  }
  .status-badge .dot{
    width: 8px;
    height: 8px;
    border-radius: 9999px;
    flex: 0 0 auto;
  }
  .status-badge .label{
    margin-left: 6px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    line-height: 1;
  }
  .status-badge.confirmed{
    background: rgba(16,185,129,0.10);
  }
  .status-badge.confirmed .dot{
    background: #10B981;
    box-shadow: 0 0 4px 1px rgba(16,185,129,0.60);
  }
  .status-badge.confirmed .label{
    color: #10B981;
  }
  .status-badge.claimed{
    background: rgba(245,158,11,0.10);
  }
  .status-badge.claimed .dot{
    background: #F59E0B;
    box-shadow: 0 0 4px 1px rgba(245,158,11,0.60);
  }
  .status-badge.claimed .label{
    color: #F59E0B;
  }

  .cb-fi-item__top{
    display:flex;
    gap: 14px;
    padding: 14px 14px 10px;
    align-items:flex-start;
    position: relative;
    z-index: 1;
    min-height: 110px;
  }
  .cb-fi-item--has-status .cb-fi-item__top{
    padding-top: calc(14px + var(--status-badge-space));
  }

  .cb-fi-logo{
    width: 84px;
    height: 62px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(0,0,0,.24);
    display:grid;
    place-items:center;
    overflow:hidden;
    flex: 0 0 auto;
  }
  .cb-fi-logo img{
    width: 100%;
    height: 100%;
    object-fit: contain;
    background: rgba(255,255,255,.92);
    display:block;
    padding: 6px;
  }
  .cb-fi-logo span{
    font-weight: 950;
    letter-spacing: -0.02em;
    opacity:.92;
    font-family:"Oxanium", system-ui, sans-serif;
  }

  .cb-fi-item__title{
    margin:0;
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.12;
    font-family:"Oxanium", system-ui, sans-serif;
    color: var(--pp-b, #66c1ff);
    text-shadow: 0 10px 30px rgba(0,0,0,.25);
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  /* Lien titre (permalien) */
  .cb-fi-titlelink{
    display:inline-flex;
    align-items:center;
    gap: 8px;
  }
  .cb-fi-titlelink:hover{ opacity:.95; }

  .cb-fi-item__date{
    margin-top: 6px;
    font-size: 13.5px;
    font-weight: 900;
    letter-spacing: .01em;
    font-family:"Oxanium", system-ui, sans-serif;
    color: rgba(242,247,255,.92);
  }

  .cb-fi-item__stype{
    margin-top: 4px;
    font-size: 13px;
    font-style: italic;
    font-weight: 800;
    color: rgba(242,247,255,.72);
  }

  .cb-fi-item__mid{
    padding: 0 14px 12px;
    display:flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-start;
    justify-content: flex-start;
    position: relative;
    z-index: 1;
    min-height: 80px;
  }

  .cb-fi-count{
    display:flex;
    align-items: baseline;
    gap: 10px;
    flex-wrap: wrap;

    font-family:"Oxanium", system-ui, sans-serif;
    font-weight: 900;
    letter-spacing: -0.01em;
    line-height: 1.1;

    padding: 10px 12px;
    border-radius: 14px;
    border: 1px solid rgba(191,227,255,.22);
    background: linear-gradient(135deg, rgba(191,227,255,.14), rgba(42,123,255,.12));
    color: #fff;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.10);
  }

  .cb-fi-count__num{ font-size: 18px; }

  .cb-fi-count__suffix{
    font-family:"Manrope", system-ui, sans-serif;
    font-size: 13px;
    font-weight: 900;
    color: rgba(242,247,255,.86);
    white-space: nowrap;
  }

  .cb-fi-count--ns{
    border-color: rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.86);
    font-family:"Manrope", system-ui, sans-serif;
    font-weight: 900;
  }

  .cb-fi-item__bottom{
    margin-top: auto;
    padding: 12px 14px 14px;
    border-top: 1px solid rgba(255,255,255,.08);
    position: relative;
    z-index: 1;
  }

  .cb-fi-details{
    border-radius: 16px;
    border: 1px solid rgba(191,227,255,.16);
    background: rgba(255,255,255,.04);
    overflow:hidden;
  }

  .cb-fi-details summary{
    list-style: none;
    cursor: pointer;
    padding: 12px 12px;
    display:flex;
    align-items:center;
    justify-content: space-between;
    gap: 10px;
    font-weight: 950;
    color: rgba(242,247,255,.92);
  }
  .cb-fi-details summary::-webkit-details-marker{ display:none; }

  .cb-fi-details summary .cb-fi-more{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    padding: 9px 12px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.14);
    background: rgba(255,255,255,.06);
    font-size: 12px;
    font-weight: 950;
    transition: transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  }

  .cb-fi-details summary:hover .cb-fi-more{
    transform: translateY(-1px);
    background: linear-gradient(135deg, rgba(191,227,255,.18), rgba(42,123,255,.14));
    border-color: rgba(255,255,255,.22);
    box-shadow: 0 14px 40px rgba(0,0,0,.22);
    color:#fff !important;
  }

  .cb-fi-details__body{
    padding: 12px;
    color: rgba(242,247,255,.82);
    font-weight: 800;
    font-size: 15px;
    line-height: 1.55;
  }
  .cb-fi-details__body b{ color:#fff; }
  .cb-fi-types{
    margin: 6px 0 0;
    padding-left: 18px;
    list-style: disc;
  }
  .cb-fi-types li{ margin: 6px 0; }

  .cb-fi-links{
    display:flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 12px;
  }

  .cb-fi-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap: 8px;
    padding: 11px 14px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.18);
    background: linear-gradient(135deg, rgba(191,227,255,.14), rgba(42,123,255,.12));
    font-weight: 950;
    font-size: 13px;
    color: #fff !important;
    box-shadow: 0 16px 55px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.10);
    transition: transform .15s ease, filter .2s ease, box-shadow .2s ease, border-color .2s ease;
    cursor: pointer;
  }
  .cb-fi-link:hover{
    transform: translateY(-2px);
    filter: brightness(1.06);
    border-color: rgba(255,255,255,.28);
    box-shadow: 0 22px 80px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.14);
  }
  .cb-fi-link--site{
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.14);
  }
  .cb-fi-link--perma{
    background: rgba(255,255,255,.06);
    border-color: rgba(191,227,255,.22);
  }

  @media (max-width: 680px){
    .cb-fi-card{ padding: 0; }
    .cb-fi-tools__left{ justify-content:center; }
    .cb-fi-kicker{ margin: 0 auto; }
    .cb-fi-search{ width: 100%; max-width: 560px; }
    .cb-fi-options .cb-fi-select{ width: 100%; max-width: 560px; justify-content: space-between; }
    .cb-fi-options .cb-fi-select--sort{
      min-width: 0;
      width: 100%;
      gap: 10px;
      padding: 6px 10px;
    }
    .cb-fi-options .cb-fi-select--sort label{
      position: static;
      width: auto;
      height: auto;
      margin: 0;
      overflow: visible;
      clip: auto;
      clip-path: none;
      white-space: normal;
    }
    .cb-fi-options .cb-fi-sort-icon{ display: none; }
    .cb-fi-options .cb-fi-select--sort select{
      position: static;
      inset: auto;
      min-width: 118px;
      opacity: 1;
      appearance: auto;
      -webkit-appearance: menulist;
    }
    .cb-fi-options .cb-fi-date{ width: 100%; max-width: 560px; }
    .cb-fi-datebtn{
      width: 100%;
      gap: 8px;
      padding: 6px 10px;
      justify-content: center;
    }
    .cb-fi-datebtn__label{
      position: static;
      width: auto;
      height: auto;
      margin: 0;
      overflow: visible;
      clip: auto;
      clip-path: none;
      white-space: normal;
    }
    .cb-fi-datepanel{
      position: static;
      margin-top: 6px;
      min-width: 0;
      background: rgba(20, 28, 50, 0.98);
      border-color: rgba(102, 193, 255, 0.35);
      box-shadow: 0 8px 24px rgba(0,0,0,.5), inset 0 0 0 1px rgba(102,193,255,.18);
    }
    .cb-fi-datefield input[type="date"]{
      min-height: 40px;
      background: rgba(12, 18, 36, 0.98);
      border-color: rgba(102, 193, 255, 0.30);
      font-size: 14px;
    }
    .cb-fi-item__top{ align-items:flex-start; }
    .cb-fi-logo{ width: 92px; height: 66px; }
  }

  .cb-fi-empty{
    padding: 18px 16px;
    border-radius: 18px;
    border: 1px dashed rgba(255,255,255,.18);
    background: rgba(255,255,255,.04);
    color: rgba(242,247,255,.78);
    font-weight: 850;
    text-align:center;
  }

  /* ===== Popup "Voir plus" (modal) ===== */
  html.cb-fi-modal-open{ overflow:hidden; }

  .cb-fi-modal{
    position: fixed;
    inset: 0;
    z-index: 999999;
    display: grid;
    place-items: center;
    /* Un peu de marge pour que le bouton de fermeture "hors cadre" reste visible */
    padding: 34px 28px;
  }
  .cb-fi-modal[hidden]{ display:none; }

  .cb-fi-modal__backdrop{
    position:absolute; inset:0;
    background: rgba(0,0,0,.62);
    backdrop-filter: blur(8px) saturate(120%);
    -webkit-backdrop-filter: blur(8px) saturate(120%);
  }

  .cb-fi-modal__panelwrap{
    position: relative;
    width: min(980px, 100%);
  }

  .cb-fi-modal__panel{
    position: relative;
    max-height: min(86vh, 920px);
    overflow: hidden;
    border-radius: 24px;
    box-shadow: 0 40px 140px rgba(0,0,0,.62);
    outline: 1px solid rgba(255,255,255,.12);
    background:
      radial-gradient(900px 420px at 10% 0%, rgba(42,123,255,.14), transparent 60%),
      radial-gradient(740px 380px at 92% 18%, rgba(110,255,200,.06), transparent 62%),
      linear-gradient(180deg, rgba(7,10,20,.94), rgba(7,10,18,.82));
    transform: translateY(6px) scale(.985);
    opacity: 0;
    animation: cbFiModalIn .18s ease forwards;
  }
  @keyframes cbFiModalIn{
    to{ transform: translateY(0) scale(1); opacity: 1; }
  }

  .cb-fi-modal__scroller{
    max-height: min(86vh, 920px);
    overflow: auto;
    overscroll-behavior: contain;
    padding: 14px 16px 18px;
    scrollbar-width: thin;
    scrollbar-color: rgba(242,247,255,.22) transparent;
  }
  .cb-fi-modal__scroller::-webkit-scrollbar{ width: 12px; }
  .cb-fi-modal__scroller::-webkit-scrollbar-track{ background: transparent; }
  .cb-fi-modal__scroller::-webkit-scrollbar-thumb{
    background: rgba(242,247,255,.22);
    border-radius: 9999px;
    border: 3px solid transparent;
    background-clip: content-box;
  }

  .cb-fi-modal__close{
    position: absolute;
    top: -12px;
    right: -12px;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 9999px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.06);
    color: rgba(242,247,255,.92);
    cursor: pointer;
    box-shadow: 0 16px 55px rgba(0,0,0,.22), inset 0 1px 0 rgba(255,255,255,.10);
  }
  .cb-fi-modal__close:hover{
    background: linear-gradient(135deg, rgba(191,227,255,.18), rgba(42,123,255,.14));
    border-color: rgba(255,255,255,.26);
    color:#fff;
  }

  .cb-fi-modal__content{
    padding: 0;
  }
  .cb-fi-item--modal{
    box-shadow: none;
    border-color: rgba(255,255,255,.10);
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
  .cb-fi-item--modal:hover{
    transform: none !important;
    filter: none !important;
    box-shadow: none !important;
  }
  .cb-fi-item--modal::before{ opacity: .95; }
  .cb-fi-item--modal .cb-fi-item__top{ padding-top: 16px; }
  .cb-fi-item--modal .cb-fi-item__mid{ padding-bottom: 14px; }
  .cb-fi-item--modal .cb-fi-item__bottom{
    margin-top: 0;
    padding: 14px 14px 16px;
  }


/* === Page 404 === */
.fi-404 {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding: clamp(48px, 9vw, 120px) clamp(16px, 3vw, 24px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  font-family: "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
.fi-404__code {
  margin: 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: clamp(96px, 18vw, 200px);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, rgba(196, 236, 255, 0.92) 0%, rgba(83, 140, 255, 0.55) 70%, rgba(40, 80, 160, 0.3) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 6px 30px rgba(83, 140, 255, 0.18);
}
.fi-404__title {
  margin: 14px 0 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: clamp(22px, 2.6vw, 36px);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #f2f8ff;
}
.fi-404__text {
  margin: 14px 0 0;
  max-width: 56ch;
  font-size: clamp(14px, 1.5vw, 17px);
  font-weight: 600;
  color: rgba(228, 242, 255, 0.84);
  line-height: 1.55;
}
.fi-404__actions {
  margin-top: clamp(28px, 4vw, 44px);
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.fi-404__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(12, 34, 66, 0.4);
  border: 1px solid rgba(155, 211, 255, 0.22);
  color: rgba(228, 242, 255, 0.92);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
.fi-404__btn:hover {
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.4);
  color: #ffffff;
}
.fi-404__btn--primary {
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.22) 0%, rgba(164, 220, 255, 0.14) 45%, rgba(83, 140, 255, 0.22) 100%);
  border-color: rgba(196, 236, 255, 0.4);
  color: #ffffff;
}

/* === Page Ransomware — hero, KPIs, filtres, liste de cards === */
.fi-rw-banner-wrap {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  display: flex;
  justify-content: center;
  padding: clamp(18px, 3vw, 38px) 16px clamp(12px, 2.4vw, 24px);
  box-sizing: border-box;
  background-image: url('/uploads/2026/03/Background-Fuites-Infos-recensements-fuites-de-donnees-france-.webp');
  background-repeat: repeat;
  background-size: auto;
  background-position: top center;
}
.fi-rw-banner {
  width: min(980px, 100%);
  text-align: center;
  padding: clamp(22px, 4vw, 56px) clamp(14px, 2vw, 22px);
}
.fi-rw-title {
  margin: 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: clamp(34px, 6vw, 80px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: #f6fbff;
  text-shadow: 0 6px 30px rgba(83, 140, 255, 0.18);
}
.fi-rw-title::after {
  content: "";
  display: block;
  width: clamp(120px, 20%, 260px);
  height: 3px;
  margin: 14px auto 0;
  background: linear-gradient(90deg, transparent, rgba(196, 236, 255, 0.6), transparent);
  border-radius: 999px;
}
.fi-rw-text {
  margin: clamp(14px, 2vw, 22px) auto 0;
  max-width: 64ch;
  font-family: "Manrope", system-ui, sans-serif;
  font-size: clamp(15px, 1.7vw, 19px);
  font-weight: 600;
  color: rgba(238, 246, 255, 0.92);
  line-height: 1.5;
}
.fi-rw-text strong { color: #ffffff; }
.fi-rw-attribution {
  margin: 14px auto 0;
  max-width: 64ch;
  font-size: 13px;
  color: rgba(238, 246, 255, 0.66);
}
.fi-rw-attribution a { color: #79c8ff; text-decoration: none; }
.fi-rw-attribution a:hover { text-decoration: underline; }

.fi-rw {
  margin-top: clamp(20px, 3vw, 36px);
}
.fi-rw-shell {
  width: 100%;
}

.fi-rw-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 12px;
  margin: clamp(16px, 2.5vw, 28px) 0 clamp(20px, 3vw, 32px);
  padding: 0;
  list-style: none;
}
.fi-rw-kpi {
  display: block;
  padding: 16px 18px;
  border-radius: 16px;
  border: 1px solid rgba(176, 214, 255, 0.22);
  background-color: #0e1d3a;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}
.fi-rw-kpi-kicker {
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #92cdff;
}
.fi-rw-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.fi-rw-kpi .fi-rw-icon {
  width: 15px;
  height: 15px;
  color: rgba(196, 236, 255, 0.85);
}
.fi-rw-card__meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.fi-rw-card__meta .fi-rw-icon {
  color: rgba(146, 205, 255, 0.78);
}
.fi-rw-kpi-value {
  margin: 6px 0 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #f2f8ff;
}
.fi-rw-kpi-sub {
  margin: 4px 0 0;
  font-size: 12.5px;
  color: rgba(238, 246, 255, 0.68);
}

.fi-rw-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(176, 214, 255, 0.18);
  background: rgba(3, 8, 18, 0.55);
}
.fi-rw-search {
  flex: 1 1 260px;
  display: flex;
}
.fi-rw-search input,
.fi-rw-toolbar select {
  width: 100%;
  height: 40px;
  padding: 0 14px;
  border-radius: 10px;
  border: 1px solid rgba(176, 214, 255, 0.22);
  background: rgba(8, 16, 34, 0.7);
  color: #eaf3ff;
  font-family: "Manrope", system-ui, sans-serif;
  font-size: 14px;
  box-sizing: border-box;
}
.fi-rw-search input::placeholder { color: rgba(228, 242, 255, 0.46); }
.fi-rw-search input:focus,
.fi-rw-toolbar select:focus {
  outline: none;
  border-color: rgba(146, 205, 255, 0.6);
  background: rgba(12, 22, 44, 0.8);
}
.fi-rw-toolbar select {
  width: auto;
  min-width: 180px;
  padding-right: 32px;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, rgba(146, 205, 255, 0.7) 50%),
                    linear-gradient(135deg, rgba(146, 205, 255, 0.7) 50%, transparent 50%);
  background-position: calc(100% - 14px) 18px, calc(100% - 9px) 18px;
  background-size: 5px 5px;
  background-repeat: no-repeat;
}
.fi-rw-status {
  margin-left: auto;
  font-size: 12.5px;
  font-weight: 600;
  color: rgba(238, 246, 255, 0.78);
  white-space: nowrap;
}

.fi-rw-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
}
.fi-rw-card {
  display: flex;
  flex-direction: column;
  gap: 0;
  border-radius: 16px;
  border: 1px solid rgba(176, 214, 255, 0.2);
  background:
    radial-gradient(420px 180px at 0% 0%, rgba(120, 60, 220, 0.10), transparent 60%),
    linear-gradient(180deg, rgba(8, 16, 34, 0.85), rgba(3, 8, 18, 0.92));
  overflow: hidden;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.fi-rw-card:hover {
  transform: translateY(-2px);
  border-color: rgba(196, 236, 255, 0.35);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}
.fi-rw-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 16px 16px 10px;
  border-left: 3px solid rgba(196, 236, 255, 0.4);
}
.fi-rw-card__name {
  margin: 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: 19px;
  font-weight: 800;
  color: #ffffff;
  line-height: 1.2;
  letter-spacing: -0.01em;
  word-break: break-word;
  text-shadow: 0 2px 8px rgba(83, 140, 255, 0.18);
}
.fi-rw-card__group {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 77, 109, 0.18);
  color: #ffb1bf;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 11px;
  font-weight: 700;
  text-transform: lowercase;
  letter-spacing: 0.02em;
  white-space: nowrap;
  border: 1px solid rgba(255, 77, 109, 0.3);
}
.fi-rw-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 14px;
  padding: 0 14px 12px;
  font-size: 12.5px;
  color: rgba(228, 242, 255, 0.78);
}
.fi-rw-card__meta b { color: #cee6ff; font-weight: 700; }
.fi-rw-card__desc {
  margin: 0;
  padding: 0 14px 14px;
  font-size: 13.5px;
  font-weight: 600;
  color: rgba(228, 242, 255, 0.88);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fi-rw-card__shot {
  display: block;
  margin: 12px 14px 14px;
  border-radius: 10px;
  border: 1px solid rgba(176, 214, 255, 0.14);
  background: rgba(3, 8, 18, 0.6);
  cursor: zoom-in;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}
.fi-rw-card__shot img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  opacity: 0.88;
  transition: opacity 0.2s ease;
}
.fi-rw-card__shot:hover img { opacity: 1; }
.fi-rw-card__links {
  display: flex;
  gap: 8px;
  padding: 12px 14px;
  margin-top: auto;
  border-top: 1px solid rgba(176, 214, 255, 0.14);
}
.fi-rw-card__link {
  display: inline-flex;
  align-items: center;
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(12, 34, 66, 0.5);
  border: 1px solid rgba(155, 211, 255, 0.22);
  color: rgba(228, 242, 255, 0.92);
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12.5px;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
}
.fi-rw-card__link:hover {
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.4);
  color: #ffffff;
}

.fi-rw-loadmore {
  display: block;
  margin: 22px auto 0;
  padding: 12px 24px;
  border-radius: 999px;
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.18) 0%, rgba(164, 220, 255, 0.10) 45%, rgba(83, 140, 255, 0.22) 100%);
  border: 1px solid rgba(196, 236, 255, 0.4);
  color: #ffffff;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.fi-rw-loadmore:hover { transform: translateY(-1px); box-shadow: 0 10px 28px rgba(83, 140, 255, 0.22); }
.fi-rw-empty {
  padding: 40px 20px;
  text-align: center;
  color: rgba(228, 242, 255, 0.7);
  font-size: 14px;
  font-weight: 600;
}

/* === Page Ransomware — responsive mobile === */
@media (max-width: 900px) {
  .fi-rw-kpis {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  .fi-rw-kpi-value { font-size: clamp(20px, 4vw, 24px); }
  .fi-rw-toolbar {
    padding: 10px;
  }
  .fi-rw-toolbar select {
    flex: 1 1 calc(50% - 5px);
    min-width: 0;
    width: auto;
  }
  .fi-rw-search { flex: 1 1 100%; }
  .fi-rw-status {
    margin-left: 0;
    flex: 1 1 100%;
    text-align: right;
  }
  .fi-rw-list {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .fi-rw-banner {
    padding: 28px 14px 32px;
  }
  .fi-rw-card__head { padding: 14px 14px 8px; }
  .fi-rw-card__name { font-size: 17px; }
}

@media (max-width: 480px) {
  .fi-rw-kpis {
    grid-template-columns: 1fr;
  }
  .fi-rw-toolbar select {
    flex: 1 1 100%;
  }
  .fi-rw-card__meta {
    flex-direction: column;
    gap: 6px;
  }
}

/* =====================================================================
   Articles SEO — page liste + page article (thème sombre marine)
   ===================================================================== */

/* ---- Liste des articles ---- */
.fi-art {
  margin-top: clamp(20px, 3vw, 36px);
  margin-bottom: clamp(40px, 6vw, 80px);
}
.fi-art-shell {
  width: min(var(--fi-content-max), 100%);
  margin: 0 auto;
  padding: 0 clamp(14px, 2vw, 22px);
  box-sizing: border-box;
}
.fi-art-empty {
  text-align: center;
  color: var(--fi-muted);
  padding: 40px 0;
  font-size: 15px;
}
.fi-art-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: clamp(14px, 2vw, 22px);
}

/* Card — réplique l'identité visuelle de .fi-rw-card (fond radial sombre,
   bordure bleue subtile, hover qui élève la card). */
.fi-art-card {
  display: flex;
  flex-direction: column;
  border-radius: 16px;
  border: 1px solid rgba(176, 214, 255, 0.2);
  background:
    radial-gradient(420px 180px at 0% 0%, rgba(120, 60, 220, 0.10), transparent 60%),
    linear-gradient(180deg, rgba(8, 16, 34, 0.85), rgba(3, 8, 18, 0.92));
  overflow: hidden;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.fi-art-card:hover {
  transform: translateY(-2px);
  border-color: rgba(196, 236, 255, 0.35);
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
}
.fi-art-card-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}
.fi-art-card-cover {
  display: block;
  border-bottom: 1px solid rgba(176, 214, 255, 0.14);
  background: rgba(3, 8, 18, 0.6);
}
.fi-art-card-cover img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1200 / 360;
  object-fit: cover;
}
.fi-art-card-body {
  padding: 16px 18px 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1 1 auto;
}
.fi-art-card-title {
  margin: 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: 18.5px;
  font-weight: 800;
  line-height: 1.28;
  letter-spacing: -0.01em;
  color: #f6fbff;
  text-shadow: 0 2px 8px rgba(83, 140, 255, 0.18);
}
.fi-art-card-excerpt {
  margin: 0;
  font-family: "Manrope", system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: rgba(228, 242, 255, 0.82);
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.fi-art-card-meta {
  margin: auto 0 0;
  padding-top: 4px;
  font-size: 12.5px;
  color: rgba(196, 236, 255, 0.62);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.fi-art-sep { color: rgba(196, 236, 255, 0.3); }

/* ---- Page article individuelle ---- */
.fi-article {
  width: min(820px, 100%);
  margin: 0 auto;
  padding: clamp(20px, 3vw, 36px) clamp(16px, 2vw, 22px) clamp(40px, 6vw, 80px);
  box-sizing: border-box;
}
.fi-article-cover {
  margin-bottom: clamp(20px, 3vw, 32px);
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(176, 214, 255, 0.2);
  box-shadow: 0 10px 36px rgba(0, 0, 0, 0.28);
}
.fi-article-cover img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1200 / 360;
  object-fit: cover;
  background: rgba(3, 8, 18, 0.6);
}
.fi-article-head {
  text-align: center;
  margin-bottom: clamp(20px, 3vw, 30px);
}
.fi-article-title {
  margin: 0 0 12px;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: clamp(26px, 4.2vw, 40px);
  font-weight: 800;
  line-height: 1.18;
  letter-spacing: -0.02em;
  color: #f6fbff;
  text-shadow: 0 6px 30px rgba(83, 140, 255, 0.18);
}
.fi-article-meta {
  margin: 0;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  color: rgba(196, 236, 255, 0.7);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.fi-article-meta-sep { margin: 0 6px; color: rgba(196, 236, 255, 0.3); }

/* Ligne « date + boutons suivre/partager » sous le titre */
.fi-article-meta-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.fi-article-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}

/* Corps Markdown rendu — couleurs claires sur fond sombre, texte justifié */
.fi-article-body {
  font-family: "Manrope", system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.72;
  color: rgba(238, 246, 255, 0.92);
  text-align: justify;
  hyphens: auto;
  -webkit-hyphens: auto;
}
.fi-article-body h2,
.fi-article-body h3 {
  margin-top: 32px;
  margin-bottom: 12px;
  color: #f6fbff;
  font-family: "Oxanium", system-ui, sans-serif;
  letter-spacing: -0.01em;
}
.fi-article-body h2 { font-size: 22px; font-weight: 800; }
.fi-article-body h3 { font-size: 18px; font-weight: 700; }
.fi-article-body p {
  margin: 0 0 16px;
}
.fi-article-body strong {
  color: #ffffff;
  font-weight: 700;
}
.fi-article-body em { color: rgba(228, 242, 255, 0.95); }
.fi-article-body ul,
.fi-article-body ol {
  margin: 0 0 18px 22px;
  padding: 0;
  text-align: left;
}
.fi-article-body li { margin-bottom: 6px; }
.fi-article-body a {
  color: var(--fi-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  word-break: break-word;
}
.fi-article-body a:hover { color: var(--fi-accent-hover); }
.fi-article-body code {
  background: rgba(83, 140, 255, 0.14);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 0.92em;
  color: #cee6ff;
}
.fi-article-body blockquote {
  margin: 0 0 18px;
  padding: 8px 18px;
  border-left: 3px solid rgba(196, 236, 255, 0.5);
  background: rgba(12, 34, 66, 0.4);
  border-radius: 0 8px 8px 0;
  color: rgba(228, 242, 255, 0.86);
}

/* Footer article : seulement le bloc source/site (les boutons suivre+partager
   sont remontés à côté de la date, dans .fi-article-meta-row). */
.fi-article-footer {
  margin-top: clamp(28px, 4vw, 48px);
  padding-top: clamp(20px, 3vw, 28px);
  border-top: 1px solid rgba(176, 214, 255, 0.18);
}

/* Boutons « suivre + partager » — utilisés dans .fi-article-meta-row */
.fi-rs-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border-radius: 999px;
  text-decoration: none;
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 12.5px;
  border: 1px solid rgba(155, 211, 255, 0.28);
  background: rgba(12, 34, 66, 0.5);
  color: rgba(228, 242, 255, 0.92);
  cursor: pointer;
  transition: transform 0.15s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}
.fi-rs-btn:hover {
  transform: translateY(-1px);
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.45);
  color: #ffffff;
}
.fi-rs-btn svg { flex-shrink: 0; }

/* Bouton Partager — gradient bleu identique au logo fi-arrow du header
   (a8ebff → 68c8ff → 2e63ff). Distinct des deux pills suivre. */
.fi-rs-btn--share {
  background: linear-gradient(90deg, #a8ebff 0%, #68c8ff 46%, #4e8eff 78%, #2e63ff 100%);
  color: #061027;
  border-color: transparent;
  box-shadow: 0 6px 20px rgba(83, 140, 255, 0.30);
}
.fi-rs-btn--share:hover {
  color: #061027;
  background: linear-gradient(90deg, #bff2ff 0%, #88d6ff 46%, #6aa3ff 78%, #4978ff 100%);
  border-color: transparent;
  box-shadow: 0 8px 26px rgba(83, 140, 255, 0.45);
}
.fi-rs-btn--share.is-copied {
  background: linear-gradient(90deg, #aef0c5 0%, #76d29c 60%, #3aa86c 100%);
  color: #052418;
}

.fi-article-mentions {
  background: rgba(12, 34, 66, 0.5);
  border: 1px solid rgba(176, 214, 255, 0.18);
  border-radius: 12px;
  padding: 16px 18px;
  font-size: 13.5px;
  color: rgba(228, 242, 255, 0.82);
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  line-height: 1.55;
}
.fi-article-mentions p { margin: 0 0 6px; }
.fi-article-mentions p:last-child { margin-bottom: 0; }
.fi-article-mentions-lbl {
  color: #cee6ff;
  font-weight: 700;
  margin-right: 4px;
}
.fi-article-mentions a {
  color: var(--fi-accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  word-break: break-all;
}
.fi-article-mentions a:hover { color: var(--fi-accent-hover); }

@media (max-width: 600px) {
  .fi-article-body { font-size: 16px; line-height: 1.65; }
  .fi-art-card-title { font-size: 17.5px; }
}

/* Header plus compact sur la page liste des articles (override de .fi-rw-banner-wrap
   uniquement quand on est sur /articles/ — ne touche pas ransomware/, faq/, etc.). */
.page-articles .fi-rw-banner-wrap {
  padding-top:    clamp(10px, 1.6vw, 22px);
  padding-bottom: clamp(8px,  1.4vw, 18px);
}
.page-articles .fi-rw-banner {
  padding: clamp(8px, 1.4vw, 18px) clamp(12px, 1.6vw, 20px);
}
.page-articles .fi-rw-title {
  font-size: clamp(26px, 4vw, 48px);
}
.page-articles .fi-rw-title::after {
  margin-top: 8px;
  height: 2px;
  width: clamp(80px, 14%, 160px);
}
.page-articles .fi-rw-text {
  margin-top: clamp(8px, 1.2vw, 14px);
  font-size: clamp(14px, 1.4vw, 16px);
}

/* Bouton retour aux articles — pill discret centré en bas de l'article */
.fi-article-back-nav {
  margin-top: clamp(20px, 3vw, 28px);
  text-align: center;
}
.fi-article-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  border-radius: 999px;
  border: 1px solid rgba(155, 211, 255, 0.28);
  background: rgba(12, 34, 66, 0.5);
  color: rgba(228, 242, 255, 0.92);
  font-family: "Montserrat", system-ui, sans-serif;
  font-weight: 700;
  font-size: 13.5px;
  text-decoration: none;
  transition: transform 0.15s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.fi-article-back:hover {
  transform: translateX(-2px);
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.45);
  color: #ffffff;
}
.fi-article-back svg { flex-shrink: 0; }

/* =====================================================================
   Dialog « Partager cet article » — popup avec grille de RS
   ===================================================================== */
.fi-share-dialog {
  /* <dialog> par défaut : padding/border navigateur. On reset. */
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  max-width: 100%;
  max-height: 100%;
  overflow: visible;
}
.fi-share-dialog::backdrop {
  background: rgba(3, 8, 18, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.fi-share-card {
  width: min(480px, calc(100vw - 24px));
  max-height: calc(100vh - 24px);
  overflow-y: auto;
  margin: 0 auto;
  padding: 22px 22px 18px;
  border-radius: 18px;
  border: 1px solid rgba(176, 214, 255, 0.22);
  background:
    radial-gradient(420px 220px at 0% 0%, rgba(120, 60, 220, 0.12), transparent 60%),
    linear-gradient(180deg, rgba(14, 26, 50, 0.96), rgba(6, 14, 30, 0.98));
  color: var(--fi-ink);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
}
.fi-share-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.fi-share-head h2 {
  margin: 0;
  font-family: "Oxanium", system-ui, sans-serif;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #f6fbff;
}
.fi-share-close {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(155, 211, 255, 0.22);
  background: rgba(12, 34, 66, 0.5);
  color: rgba(228, 242, 255, 0.85);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.fi-share-close:hover {
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.45);
  color: #ffffff;
}

.fi-share-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.fi-share-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 12px 6px 10px;
  border-radius: 12px;
  border: 1px solid rgba(155, 211, 255, 0.18);
  background: rgba(12, 34, 66, 0.45);
  color: rgba(228, 242, 255, 0.92);
  text-decoration: none;
  font-family: "Montserrat", system-ui, sans-serif;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.15s ease, background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.fi-share-item:hover {
  transform: translateY(-2px);
  background: rgba(83, 140, 255, 0.18);
  border-color: rgba(196, 236, 255, 0.45);
  color: #ffffff;
}
.fi-share-icon {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  color: currentColor;
}
.fi-share-item--x        .fi-share-icon { color: #ffffff; background: rgba(15, 20, 25, 0.65); }
.fi-share-item--linkedin .fi-share-icon { color: #0a66c2; background: rgba(10, 102, 194, 0.12); }
.fi-share-item--facebook .fi-share-icon { color: #1877f2; background: rgba(24, 119, 242, 0.12); }
.fi-share-item--whatsapp .fi-share-icon { color: #25d366; background: rgba(37, 211, 102, 0.12); }
.fi-share-item--telegram .fi-share-icon { color: #29b5e8; background: rgba(41, 181, 232, 0.12); }
.fi-share-item--bluesky  .fi-share-icon { color: #1185fe; background: rgba(17, 133, 254, 0.12); }
.fi-share-item--email    .fi-share-icon { color: #a8ebff; background: rgba(168, 235, 255, 0.10); }
.fi-share-item--copy     .fi-share-icon { color: #c4ecff; background: rgba(196, 236, 255, 0.10); }
.fi-share-item--copy.is-copied { color: #aef0c5; border-color: rgba(174, 240, 197, 0.45); }
.fi-share-item--copy.is-copied .fi-share-icon { color: #aef0c5; background: rgba(174, 240, 197, 0.12); }

.fi-share-name { line-height: 1; }

.fi-share-more {
  display: block;
  width: 100%;
  margin-top: 14px;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px dashed rgba(155, 211, 255, 0.32);
  background: transparent;
  color: rgba(196, 236, 255, 0.85);
  font: inherit;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.fi-share-more:hover {
  background: rgba(83, 140, 255, 0.10);
  border-color: rgba(196, 236, 255, 0.55);
  color: #ffffff;
}

@media (max-width: 420px) {
  .fi-share-grid { grid-template-columns: repeat(3, 1fr); }
  .fi-share-icon { width: 34px; height: 34px; }
}
