/* Langaz Sécurité Privée – Main Stylesheet */

/* devanagari */

/* devanagari */

/* devanagari */

/* devanagari */

/* devanagari */

/* devanagari */

/* ---------- Variables (palette dérivée du logo LSP) ---------- */
    :root {
      --navy:        #08090F;        /* near-black, fond logo */
      --navy-2:      #101218;
      --navy-3:      #181B24;
      --navy-line:   #262A36;
      --orange:      #FF7A1A;        /* orange logo */
      --orange-2:    #ff9347;
      --magenta:     #E5208A;        /* rose/magenta logo */
      --magenta-2:   #FF4DA8;
      --cyan:        #1FCDD8;        /* cyan/teal logo */
      --cyan-2:      #48E0EA;
      --ink:         #0A0B11;
      --slate:       #4B5563;
      --slate-2:     #6B7280;
      --gray:        #F5F5F7;
      --gray-2:      #ECEEF1;
      --line:        #E5E7EB;
      --white:       #FFFFFF;
      --grad:        linear-gradient(135deg, #FF7A1A 0%, #E5208A 50%, #1FCDD8 100%);

      --r-card:      16px;
      --r-btn:       8px;
      --r-pill:      999px;
      --shadow-s:    0 4px 14px rgba(15,24,34,0.08);
      --shadow-m:    0 8px 24px rgba(15,24,34,0.12);
      --shadow-l:    0 24px 60px rgba(15,24,34,0.22);
      --ease:        cubic-bezier(.2,.7,.2,1);
    }

    /* ---------- Reset ---------- */
    * { box-sizing: border-box; }
    html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
    body {
      margin: 0;
      font-family: "Inter", system-ui, sans-serif;
      font-size: 17px;
      line-height: 1.7;
      color: var(--ink);
      background: #fff;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
    }
    img, svg { display: block; max-width: 100%; }
    a { color: inherit; text-decoration: none; }
    button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
    h1, h2, h3, h4 {
      font-family: "Poppins", system-ui, sans-serif;
      font-weight: 700;
      line-height: 1.1;
      letter-spacing: -0.01em;
      margin: 0;
    }
    p { margin: 0; }
    .mono { font-family: "JetBrains Mono", ui-monospace, monospace; }

    /* ---------- Layout ---------- */
    .wrap { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 28px; }
    section { padding: 120px 0; }
    @media (max-width: 768px) {
      section { padding: 80px 0; }
      body { font-size: 16px; }
    }

    /* ---------- Buttons ---------- */
    .btn {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      padding: 16px 32px;
      border-radius: var(--r-btn);
      font-family: "Poppins", sans-serif;
      font-weight: 600;
      font-size: 15px;
      letter-spacing: 0.02em;
      transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .2s, color .2s, border-color .2s;
      white-space: nowrap;
    }
    .btn .arrow { transition: transform .25s var(--ease); }
    .btn:hover .arrow { transform: translateX(4px); }
    .btn-orange {
      background: var(--orange);
      color: #fff;
      box-shadow: 0 10px 24px rgba(255,107,53,0.28);
    }
    .btn-orange:hover {
      background: var(--orange-2);
      transform: translateY(-2px);
      box-shadow: 0 14px 32px rgba(255,107,53,0.38);
    }
    .btn-ghost-light {
      color: #fff;
      border: 1.5px solid rgba(255,255,255,0.5);
      background: transparent;
    }
    .btn-ghost-light:hover {
      background: rgba(255,255,255,0.08);
      border-color: #fff;
      transform: translateY(-2px);
    }
    .btn-neon {
      background: var(--cyan);
      color: var(--navy);
      border-radius: var(--r-pill);
      padding: 12px 22px;
      font-weight: 700;
      font-size: 14px;
      box-shadow: 0 0 0 0 rgba(31,205,216,0.0);
    }
    .btn-neon:hover {
      background: var(--cyan-2);
      box-shadow: 0 0 0 6px rgba(31,205,216,0.22);
      transform: translateY(-1px);
    }
    .btn-grad {
      background: var(--grad);
      color: #fff;
      border-radius: var(--r-pill);
      padding: 12px 22px;
      font-weight: 700;
      font-size: 14px;
      box-shadow: 0 10px 30px rgba(229,32,138,0.30);
    }
    .btn-grad:hover { transform: translateY(-2px); box-shadow: 0 14px 36px rgba(229,32,138,0.45); }
    .btn-pill-light {
      background: #fff;
      color: var(--navy);
      border-radius: var(--r-pill);
      padding: 12px 22px;
      font-weight: 600;
      font-size: 14px;
    }
    .btn-pill-light:hover { background: var(--gray-2); }

    /* ---------- Navbar ---------- */
    .nav {
      position: fixed;
      inset: 0 0 auto 0;
      z-index: 50;
      transition: background .3s var(--ease), box-shadow .3s var(--ease), color .3s var(--ease);
      color: #fff;
    }
    .nav-inner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 18px 28px;
      max-width: 1240px;
      margin: 0 auto;
    }
    .logo {
      display: flex;
      align-items: center;
      gap: 12px;
      font-family: "Poppins", sans-serif;
      font-weight: 800;
      letter-spacing: 0.08em;
      font-size: 14px;
    }
    .logo-mark {
      width: 40px; height: 40px;
      display: grid; place-items: center;
      flex: 0 0 auto;
    }
    .logo-mark img { width: 100%; height: 100%; object-fit: contain; display:block; }
    .logo-text { line-height: 1; }
    .logo-text small { display:block; font-weight: 400; font-size: 10px; opacity: .65; letter-spacing: 0.16em; margin-top: 4px; }

    .nav-links {
      display: flex;
      gap: 4px;
      align-items: center;
      background: rgba(255,255,255,0.06);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,0.08);
      padding: 6px;
      border-radius: var(--r-pill);
    }
    .nav-links a {
      padding: 9px 18px;
      border-radius: var(--r-pill);
      font-size: 14px;
      font-weight: 500;
      opacity: .8;
      transition: background .2s, opacity .2s;
    }
    .nav-links a:hover { opacity: 1; background: rgba(255,255,255,0.06); }
    .nav-links a.active { opacity: 1; background: rgba(255,255,255,0.12); }

    .nav.scrolled {
      background: rgba(255,255,255,0.92);
      backdrop-filter: blur(14px);
      box-shadow: 0 4px 24px rgba(15,24,34,0.06);
      color: var(--navy);
    }
    .nav.scrolled .nav-links {
      background: rgba(15,24,34,0.04);
      border-color: rgba(15,24,34,0.06);
    }
    .nav.scrolled .nav-links a:hover { background: rgba(15,24,34,0.06); }
    .nav.scrolled .nav-links a.active { background: var(--navy); color: #fff; opacity: 1; }

    .nav-cta { display: flex; align-items: center; gap: 12px; }
    .nav-phone {
      font-family: "JetBrains Mono", monospace;
      font-size: 13px;
      opacity: .75;
    }
    @media (max-width: 900px) {
      .nav-links, .nav-phone { display: none; }
    }

    /* ---------- HERO ---------- */
    .hero {
      position: relative;
      min-height: 100vh;
      padding: 0;
      color: #fff;
      background: var(--navy);
      overflow: hidden;
      isolation: isolate;
    }
    .hero-bg {
      position: absolute; inset: 0; z-index: 0;
      background:
        radial-gradient(1200px 600px at 70% 40%, rgba(31,205,216,0.12) 0%, transparent 60%),
        radial-gradient(900px 500px at 20% 80%, rgba(255,122,26,0.10) 0%, transparent 60%),
        radial-gradient(700px 400px at 50% 20%, rgba(229,32,138,0.08) 0%, transparent 60%),
        linear-gradient(180deg, #0b0d14 0%, #101218 60%, #06070b 100%);
    }
    /* subtle scanline + grain */
    .hero-bg::after {
      content: "";
      position: absolute; inset: 0;
      background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.025) 0, rgba(255,255,255,0.025) 1px, transparent 1px, transparent 4px);
      mix-blend-mode: overlay;
      opacity: .4;
      pointer-events: none;
    }

    /* Hero photo (vraie photo d'équipe LSP en mission nocturne) */
    .hero-photo {
      position: absolute;
      inset: 0;
      z-index: 1;
      overflow: hidden;
    }
    .hero-photo img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: 70% 50%;
      filter: saturate(0.9) contrast(1.1) brightness(0.32);
    }
    /* overlays: voile noir + dégradés pour faire ressortir le texte */
    .hero-photo::before {
      content: "";
      position: absolute; inset: 0;
      background:
        /* gradient latéral noir compact côté gauche */
        linear-gradient(95deg, rgba(0,0,0,0.96) 0%, rgba(0,0,0,0.88) 40%, rgba(0,0,0,0.75) 70%, rgba(0,0,0,0.82) 100%),
        /* gradient haut/bas */
        linear-gradient(180deg, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.60) 30%, rgba(0,0,0,0.60) 60%, rgba(0,0,0,0.98) 100%),
        /* voile noir uniforme fort */
        rgba(0,0,0,0.65);
      pointer-events: none;
    }
    .hero-photo::after {
      content: "";
      position: absolute; inset: 0;
      background:
        radial-gradient(900px 500px at 88% 20%, rgba(31,205,216,0.18), transparent 60%),
        radial-gradient(700px 400px at 10% 90%, rgba(229,32,138,0.14), transparent 60%);
      mix-blend-mode: screen;
      pointer-events: none;
    }
    /* fine grain to bind photo + design */
    .hero-photo .grain {
      position: absolute; inset: 0;
      background-image: repeating-linear-gradient(0deg, rgba(255,255,255,0.02) 0 1px, transparent 1px 4px);
      mix-blend-mode: overlay;
      opacity: .5;
      pointer-events: none;
    }
    /* Photo caption pill bottom-right of hero */
    .hero-photo-caption {
      position: absolute;
      bottom: 140px;
      right: 32px;
      z-index: 5;
      display: flex; align-items: center; gap: 10px;
      padding: 10px 16px;
      background: rgba(8,9,15,0.55);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: var(--r-pill);
      color: #fff;
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }
    .hero-photo-caption .live-dot {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--cyan); box-shadow: 0 0 10px var(--cyan);
      animation: pulse 1.6s infinite;
    }
    @media (max-width: 900px) {
      .hero-photo img { object-position: 65% 50%; }
      .hero-photo-caption { display: none; }
    }

    .hero-grid {
      position: relative;
      z-index: 3;
      max-width: 1240px;
      margin: 0 auto;
      padding: 120px 28px 180px;
      min-height: 100vh;
      display: grid;
      grid-template-columns: 1fr;
      align-content: end;
      gap: 32px;
    }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      align-self: start;
      font-family: "JetBrains Mono", monospace;
      font-size: 12px;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--cyan);
      padding: 8px 14px;
      border: 1px solid rgba(31,205,216,0.35);
      border-radius: var(--r-pill);
      background: rgba(31,205,216,0.06);
      width: max-content;
    }
    .hero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--magenta); box-shadow: 0 0 12px var(--magenta); animation: pulse 1.6s infinite; }
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

    .hero-title {
      font-family: "Poppins", sans-serif;
      font-weight: 800;
      font-size: clamp(64px, 14vw, 200px);
      line-height: .85;
      letter-spacing: -0.04em;
      color: transparent;
      -webkit-text-stroke: 1.5px rgba(255,255,255,0.85);
      margin: 0;
      text-transform: uppercase;
    }
    @media (max-width: 700px) { .hero-title { -webkit-text-stroke-width: 1px; } }
    .hero-subtitle {
      font-family: "Poppins", sans-serif;
      font-weight: 500;
      font-size: clamp(32px, 5vw, 64px);
      line-height: 1;
      letter-spacing: -0.02em;
      color: #fff;
      margin-top: -8px;
    }
    .hero-subtitle .sep { color: var(--magenta); }

    .hero-baseline {
      font-size: clamp(15px, 1.6vw, 19px);
      color: rgba(255,255,255,0.7);
      max-width: 540px;
      line-height: 1.6;
    }
    .hero-baseline strong { color: #fff; font-weight: 500; }

    .hero-foot {
      display: grid;
      grid-template-columns: auto 1fr auto;
      align-items: end;
      gap: 40px;
      margin-top: 16px;
    }
    @media (max-width: 900px) {
      .hero-foot { grid-template-columns: 1fr; gap: 28px; }
    }

    .hero-kpi {
      border-left: 2px solid var(--cyan);
      padding-left: 18px;
    }
    .hero-kpi-num {
      font-family: "Poppins", sans-serif;
      font-weight: 800;
      font-size: 56px;
      line-height: 1;
      color: var(--cyan);
      letter-spacing: -0.03em;
    }
    .hero-kpi-label {
      font-size: 13px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: rgba(255,255,255,0.6);
      margin-top: 8px;
    }

    .hero-bullets {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 8px 24px;
      align-self: end;
    }
    .hero-bullets li {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 15px;
      color: rgba(255,255,255,0.85);
    }
    .hero-bullets li::before {
      content: "";
      width: 6px; height: 6px;
      background: var(--cyan);
      border-radius: 50%;
      box-shadow: 0 0 10px rgba(31,205,216,0.6);
    }
    @media (max-width: 600px) { .hero-bullets { grid-template-columns: 1fr; } }

    .hero-ctas {
      display: flex;
      gap: 14px;
      flex-wrap: wrap;
    }

    /* Floating badge top-right (rond gradient brand) */
    .hero-badge {
      position: absolute;
      top: 120px;
      right: 40px;
      width: 130px; height: 130px;
      border-radius: 50%;
      background: var(--grad);
      color: #fff;
      display: grid;
      place-items: center;
      text-align: center;
      font-family: "Poppins", sans-serif;
      font-weight: 800;
      font-size: 13px;
      letter-spacing: 0.08em;
      z-index: 4;
      box-shadow: 0 0 0 6px rgba(229,32,138,0.18), 0 30px 60px rgba(229,32,138,0.30);
      transform: rotate(-8deg);
      animation: float 6s ease-in-out infinite;
    }
    .hero-badge small { font-size: 10px; opacity: .7; display:block; margin-top: 2px; letter-spacing: 0.14em; }
    @keyframes float { 0%,100%{transform: rotate(-8deg) translateY(0)} 50%{transform: rotate(-8deg) translateY(-8px)} }
    @media (max-width: 900px) { .hero-badge { display: none; } }

    /* Wave transition */
    .wave {
      position: absolute;
      left: 0; right: 0; bottom: -1px;
      z-index: 2;
      line-height: 0;
    }
    .wave svg { width: 100%; height: 110px; }

    /* ---------- Section labels ---------- */
    .eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-family: "JetBrains Mono", monospace;
      font-size: 12px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--orange);
      margin-bottom: 18px;
    }
    .eyebrow::before {
      content: ""; width: 28px; height: 1.5px; background: var(--orange);
    }

    h2.section-title {
      font-size: clamp(34px, 4.4vw, 56px);
      color: var(--navy-2);
      max-width: 16ch;
      text-wrap: balance;
    }
    .section-title.center { margin-left:auto; margin-right:auto; text-align: center; max-width: 22ch; }
    .section-sub {
      color: var(--slate);
      max-width: 60ch;
      font-size: 18px;
      margin-top: 16px;
    }
    .section-sub.center { margin-left:auto; margin-right:auto; text-align: center; }

    /* ---------- Section: Intro ---------- */
    .intro-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 64px;
      align-items: center;
      max-width: 1100px;
      margin: 0 auto;
    }
    @media (max-width: 900px) { .intro-grid { grid-template-columns: 1fr; gap: 40px; } }

    .photo-frame {
      position: relative;
      aspect-ratio: 4/5;
      border-radius: var(--r-card);
      overflow: hidden;
      box-shadow: var(--shadow-m);
      background: var(--navy-2);
    }
    .photo-frame > img, .why-photo > img {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
    }
    .photo-frame::after, .why-photo::after {
      content: "";
      position: absolute; inset: 0;
      background: linear-gradient(180deg, transparent 50%, rgba(8,9,15,0.45) 100%);
      pointer-events: none;
    }
    .photo-corner-tag {
      position: absolute;
      top: 16px; left: 16px;
      z-index: 2;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      padding: 8px 14px;
      border-radius: var(--r-pill);
      background: rgba(8,9,15,0.7);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,0.12);
      color: #fff;
      font-family: "JetBrains Mono", monospace;
      font-size: 10.5px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }
    .photo-corner-tag .dot {
      width: 7px; height: 7px;
      border-radius: 50%;
      background: var(--cyan);
      box-shadow: 0 0 10px var(--cyan);
      animation: pulse 1.6s infinite;
    }
    .photo-frame .ph-label {
      position: absolute;
      top: 16px; left: 16px;
      font-family: "JetBrains Mono", monospace;
      font-size: 11px;
      letter-spacing: 0.12em;
      color: rgba(255,255,255,0.7);
      background: rgba(0,0,0,0.45);
      backdrop-filter: blur(6px);
      padding: 6px 10px;
      border-radius: 6px;
      z-index: 2;
    }

    /* placeholder stripe fills */
    .ph-fill {
      position: absolute; inset: 0;
      background:
        repeating-linear-gradient(45deg, rgba(255,255,255,0.04) 0 14px, rgba(255,255,255,0.0) 14px 28px),
        linear-gradient(160deg, #1f2c3d 0%, #0e1620 100%);
    }
    .ph-fill.warm {
      background:
        repeating-linear-gradient(45deg, rgba(255,255,255,0.06) 0 14px, rgba(255,255,255,0.0) 14px 28px),
        linear-gradient(160deg, #2b3a4f 0%, #14202e 100%);
    }
    .ph-team {
      position: absolute; inset: 0;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 2px;
    }
    .ph-team > div { position: relative; overflow: hidden; }
    .ph-silhouette {
      position: absolute; bottom: 0; left: 50%;
      transform: translateX(-50%);
      width: 70%;
      filter: drop-shadow(0 10px 20px rgba(0,0,0,0.4));
    }

    .check-list { list-style: none; padding: 0; margin: 20px 0 28px; display: grid; gap: 10px; }
    .check-list li {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 16px;
      color: var(--ink);
    }
    .check-list li svg { flex: 0 0 22px; }
    .check-circle {
      width: 22px; height: 22px;
      border-radius: 50%;
      background: rgba(255,107,53,0.12);
      color: var(--orange);
      display: grid; place-items: center;
      flex: 0 0 auto;
    }

    .intro-body p { color: var(--slate); margin-top: 18px; max-width: 52ch; }

    /* ---------- Section: Services ---------- */
    .services { background: var(--gray); }
    .services-head { text-align: center; margin-bottom: 56px; }
    .services-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }
    @media (max-width: 1000px) { .services-grid { grid-template-columns: 1fr; max-width: 520px; margin: 0 auto; } }

    .service-card {
      background: var(--navy-3);
      color: #fff;
      padding: 40px 36px;
      border-radius: var(--r-card);
      position: relative;
      overflow: hidden;
      transition: transform .35s var(--ease), box-shadow .35s var(--ease);
      border: 1px solid rgba(255,255,255,0.04);
    }
    .service-card:hover {
      transform: translateY(-8px);
      box-shadow: 0 30px 60px rgba(15,24,34,0.25);
    }
    .service-card::before {
      content: "";
      position: absolute;
      inset: -1px;
      border-radius: var(--r-card);
      background: linear-gradient(135deg, rgba(31,205,216,0.0) 0%, rgba(31,205,216,0.0) 100%);
      pointer-events: none;
      transition: background .35s;
    }
    .service-card:hover::before {
      background: linear-gradient(135deg, rgba(31,205,216,0.4) 0%, rgba(31,205,216,0.0) 60%);
      mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
      -webkit-mask: linear-gradient(#000,#000) content-box, linear-gradient(#000,#000);
      mask-composite: exclude;
      padding: 1px;
    }
    .service-icon {
      width: 56px; height: 56px;
      border-radius: 14px;
      display: grid; place-items: center;
      background: rgba(255,255,255,0.06);
      border: 1px solid rgba(255,255,255,0.08);
      margin-bottom: 28px;
      color: #fff;
    }
    .service-card h3 {
      font-size: 24px;
      margin-bottom: 12px;
    }
    .service-card p {
      color: rgba(255,255,255,0.65);
      font-size: 15px;
      line-height: 1.7;
    }
    .service-num {
      position: absolute;
      top: 32px; right: 32px;
      font-family: "JetBrains Mono", monospace;
      font-size: 12px;
      color: rgba(255,255,255,0.3);
      letter-spacing: 0.1em;
    }
    .chip {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 6px 12px;
      border-radius: var(--r-pill);
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.04em;
      margin-top: 24px;
    }
    .chip-neon { background: var(--cyan); color: var(--navy); }
    .chip-orange { background: var(--orange); color: #fff; }
    .chip-ghost { background: rgba(255,255,255,0.08); color: #fff; border: 1px solid rgba(255,255,255,0.12); }

    .service-meta {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-top: 28px;
      padding-top: 24px;
      border-top: 1px solid rgba(255,255,255,0.08);
      font-size: 13px;
      color: rgba(255,255,255,0.55);
    }
    .service-meta a { color: #fff; font-weight: 600; }
    .service-meta a:hover { color: var(--cyan); }

    /* ---------- Section: Pourquoi LSP ---------- */
    .why-grid {
      display: grid;
      grid-template-columns: 1.2fr 1fr;
      gap: 80px;
      align-items: center;
    }
    @media (max-width: 1000px) { .why-grid { grid-template-columns: 1fr; gap: 48px; } }
    .why-photo {
      position: relative;
      aspect-ratio: 4/5;
      border-radius: var(--r-card);
      overflow: hidden;
      box-shadow: var(--shadow-l);
    }
    .why-photo .ph-label { z-index: 2; position: absolute; top:16px; left:16px; }
    .stat-bubble {
      position: absolute;
      bottom: 24px; left: 24px;
      padding: 18px 22px;
      border-radius: 14px;
      background: rgba(15,24,34,0.85);
      backdrop-filter: blur(10px);
      color: #fff;
      border: 1px solid rgba(255,255,255,0.08);
      display: flex;
      gap: 14px;
      align-items: center;
    }
    .stat-bubble .num { font-family: "Poppins"; font-weight: 800; font-size: 28px; color: var(--cyan); line-height: 1; }
    .stat-bubble .lbl { font-size: 12px; color: rgba(255,255,255,0.7); line-height: 1.4; max-width: 16ch; }

    .why-list {
      list-style: none; padding: 0; margin: 24px 0 32px;
      display: grid; gap: 14px;
    }
    .why-list li {
      display: flex; align-items: center; gap: 14px;
      padding: 14px 18px;
      background: var(--gray);
      border-radius: 10px;
      font-weight: 500;
    }
    .why-list li .check-circle { background: var(--orange); color: #fff; }

    /* ---------- Section: Sur le terrain (mosaïque équipe) ---------- */
    .field-section {
      background: var(--navy);
      color: #fff;
      position: relative;
      overflow: hidden;
      padding: 100px 0 120px;
    }
    .field-section::before {
      content: "";
      position: absolute; inset: 0;
      background:
        radial-gradient(800px 400px at 0% 0%, rgba(229,32,138,0.10), transparent 60%),
        radial-gradient(800px 400px at 100% 100%, rgba(31,205,216,0.10), transparent 60%);
      pointer-events: none;
    }
    .field-head {
      display: flex;
      align-items: end;
      justify-content: space-between;
      gap: 40px;
      margin-bottom: 48px;
      position: relative;
    }
    @media (max-width: 800px) { .field-head { flex-direction: column; align-items: start; gap: 20px; } }
    .field-head h2 { color: #fff; max-width: 18ch; }
    .field-head .lede { color: rgba(255,255,255,0.65); max-width: 44ch; font-size: 17px; }

    .field-grid {
      display: grid;
      grid-template-columns: 1.4fr 1fr 1fr;
      grid-template-rows: 220px 220px;
      gap: 16px;
      position: relative;
    }
    @media (max-width: 900px) {
      .field-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
    }
    @media (max-width: 540px) {
      .field-grid { grid-template-columns: 1fr; grid-template-rows: repeat(4, 220px); }
    }
    .field-tile {
      position: relative;
      overflow: hidden;
      border-radius: 14px;
      background: var(--navy-2);
      border: 1px solid rgba(255,255,255,0.06);
    }
    .field-tile img {
      width: 100%; height: 100%;
      object-fit: cover;
      transition: transform .6s var(--ease);
    }
    .field-tile:hover img { transform: scale(1.06); }
    .field-tile::after {
      content: "";
      position: absolute; inset: 0;
      background: linear-gradient(180deg, transparent 40%, rgba(8,9,15,0.85) 100%);
      pointer-events: none;
    }
    .field-tile .caption {
      position: absolute;
      bottom: 16px; left: 16px; right: 16px;
      z-index: 2;
      color: #fff;
    }
    .field-tile .caption .label {
      font-family: "JetBrains Mono", monospace;
      font-size: 10.5px;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--cyan);
      margin-bottom: 4px;
    }
    .field-tile .caption .title {
      font-family: "Poppins", sans-serif;
      font-weight: 700;
      font-size: 17px;
      line-height: 1.3;
    }
    .field-tile.big { grid-row: span 2; }
    .field-tile.big .caption .title { font-size: 22px; }
    @media (max-width: 900px) {
      .field-tile.big { grid-row: span 1; grid-column: span 2; }
    }
    @media (max-width: 540px) {
      .field-tile.big { grid-column: span 1; }
    }

    .field-meta {
      margin-top: 36px;
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 16px;
      padding-top: 36px;
      border-top: 1px solid rgba(255,255,255,0.08);
    }
    @media (max-width: 800px) { .field-meta { grid-template-columns: repeat(2, 1fr); } }
    .field-stat .num {
      font-family: "Poppins", sans-serif;
      font-weight: 800;
      font-size: 38px;
      line-height: 1;
      letter-spacing: -0.02em;
      background: var(--grad);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
    }
    .field-stat .lbl {
      margin-top: 8px;
      color: rgba(255,255,255,0.65);
      font-size: 13px;
      max-width: 22ch;
      line-height: 1.5;
    }

    /* ---------- Section: T\u00e9moignages / Clients ---------- */
    .clients {
      background: var(--navy-2);
      color: #fff;
      position: relative;
      overflow: hidden;
    }
    .clients::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(800px 400px at 80% 0%, rgba(31,205,216,0.08), transparent 60%),
        radial-gradient(800px 400px at 0% 100%, rgba(255,107,53,0.06), transparent 60%);
      pointer-events: none;
    }
    .clients-head { text-align: center; margin-bottom: 56px; position: relative; }
    .clients-head h2 { color: #fff; }
    .client-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 20px;
      max-width: 1000px;
      margin: 0 auto 80px;
      position: relative;
    }
    @media (max-width: 800px) { .client-grid { grid-template-columns: repeat(2, 1fr); } }
    .client-card {
      padding: 28px;
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: 12px;
      display: grid;
      place-items: center;
      gap: 8px;
      text-align: center;
      transition: all .25s;
      opacity: .6;
    }
    .client-card:hover { opacity: 1; border-color: var(--cyan); background: rgba(31,205,216,0.04); }
    .client-card .name {
      font-family: "Poppins"; font-weight: 700; font-size: 17px;
      color: #fff;
    }
    .client-card .type { font-size: 12px; color: rgba(255,255,255,0.55); letter-spacing: 0.08em; text-transform: uppercase; }

    .testimonial {
      max-width: 820px;
      margin: 0 auto;
      background: rgba(255,255,255,0.04);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: 20px;
      padding: 48px;
      text-align: center;
      position: relative;
    }
    .testimonial .quote-mark {
      position: absolute; top: -24px; left: 50%; transform: translateX(-50%);
      width: 48px; height: 48px; border-radius: 50%;
      background: var(--grad); color: #fff;
      display: grid; place-items: center;
      font-family: "Poppins"; font-size: 28px; font-weight: 800;
      line-height: 1;
    }
    .testimonial blockquote {
      font-family: "Poppins", sans-serif;
      font-weight: 400;
      font-size: 22px;
      line-height: 1.5;
      font-style: italic;
      margin: 0 0 24px;
      color: #fff;
    }
    .testimonial .sig {
      font-size: 14px;
      color: rgba(255,255,255,0.65);
    }
    .stars {
      display: inline-flex; gap: 4px;
      color: var(--orange);
      margin-top: 14px;
    }

    /* ---------- Avis Google ---------- */
    .reviews-head {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 18px;
      margin: 80px auto 40px;
      flex-wrap: wrap;
      position: relative;
    }
    .google-badge {
      display: inline-flex;
      align-items: center;
      gap: 12px;
      padding: 14px 22px;
      border-radius: var(--r-pill);
      background: rgba(255,255,255,0.05);
      border: 1px solid rgba(255,255,255,0.12);
      backdrop-filter: blur(10px);
    }
    .google-badge .g-logo { width: 26px; height: 26px; flex: 0 0 auto; }
    .google-badge .g-score { font-family: "Poppins"; font-weight: 800; font-size: 22px; color: #fff; line-height: 1; }
    .google-badge .g-stars { display: inline-flex; gap: 2px; color: #FBBC05; margin-top: 3px; }
    .google-badge .g-meta { font-size: 12px; color: rgba(255,255,255,0.6); margin-top: 3px; }
    .google-badge .g-text { display: grid; }

    .reviews-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 20px;
      position: relative;
      max-width: 760px;
      margin: 0 auto;
    }
    @media (max-width: 720px) { .reviews-grid { grid-template-columns: 1fr; max-width: 480px; } }

    .review-card {
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.09);
      border-radius: 16px;
      padding: 26px;
      transition: transform .3s var(--ease), border-color .3s, background .3s;
    }
    .review-card:hover {
      transform: translateY(-4px);
      border-color: rgba(255,255,255,0.2);
      background: rgba(255,255,255,0.06);
    }
    .review-top {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .review-avatar {
      width: 44px; height: 44px;
      border-radius: 50%;
      display: grid; place-items: center;
      font-family: "Poppins"; font-weight: 700;
      font-size: 18px;
      color: #fff;
      flex: 0 0 auto;
    }
    .review-id { flex: 1; min-width: 0; }
    .review-name {
      font-family: "Poppins"; font-weight: 600;
      font-size: 16px; color: #fff;
      line-height: 1.2;
    }
    .review-src {
      display: inline-flex; align-items: center; gap: 5px;
      font-size: 12.5px; color: rgba(255,255,255,0.55);
      margin-top: 3px;
    }
    .review-src svg { width: 14px; height: 14px; }
    .review-dots { color: rgba(255,255,255,0.35); font-size: 20px; letter-spacing: 1px; align-self: start; }

    .review-rating {
      display: flex; align-items: center; gap: 10px;
      margin: 16px 0 12px;
    }
    .review-rating .r-stars { display: inline-flex; gap: 2px; color: #FBBC05; }
    .review-rating .r-stars svg { width: 16px; height: 16px; }
    .review-rating .r-when { font-size: 12.5px; color: rgba(255,255,255,0.5); }
    .review-new {
      font-family: "JetBrains Mono", monospace;
      font-size: 10px; letter-spacing: 0.12em;
      font-weight: 500;
      padding: 3px 8px;
      border-radius: 5px;
      border: 1px solid rgba(255,255,255,0.18);
      color: rgba(255,255,255,0.7);
      text-transform: uppercase;
    }
    .review-text {
      color: rgba(255,255,255,0.82);
      font-size: 15px;
      line-height: 1.65;
      margin: 0;
    }
    .review-visit {
      margin-top: 16px;
      font-size: 12.5px;
      color: rgba(255,255,255,0.4);
    }
    .reviews-cta {
      text-align: center;
      margin-top: 36px;
    }

    /* ---------- Cookie consent ---------- */
    .cookie-banner {
      position: fixed;
      left: 24px; bottom: 24px;
      z-index: 200;
      width: min(420px, calc(100vw - 48px));
      background: var(--navy-2);
      color: #fff;
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: 18px;
      box-shadow: 0 30px 70px rgba(0,0,0,0.45);
      padding: 26px 26px 22px;
      transform: translateY(140%);
      opacity: 0;
      transition: transform .5s var(--ease), opacity .4s var(--ease);
    }
    .cookie-banner.show { transform: translateY(0); opacity: 1; }
    .cookie-banner .cookie-top {
      display: flex; align-items: center; gap: 12px;
      margin-bottom: 12px;
    }
    .cookie-banner .cookie-ic {
      width: 40px; height: 40px;
      border-radius: 11px;
      display: grid; place-items: center;
      background: var(--grad);
      color: #fff;
      flex: 0 0 auto;
    }
    .cookie-banner h4 {
      font-family: "Poppins"; font-weight: 700;
      font-size: 17px; color: #fff;
    }
    .cookie-banner p {
      font-size: 14px;
      line-height: 1.6;
      color: rgba(255,255,255,0.7);
      margin: 0 0 18px;
    }
    .cookie-banner p a { color: var(--cyan); border-bottom: 1px solid currentColor; }
    .cookie-actions { display: flex; gap: 10px; flex-wrap: wrap; }
    .cookie-actions .btn-c {
      flex: 1 1 auto;
      padding: 13px 18px;
      border-radius: var(--r-pill);
      font-family: "Poppins"; font-weight: 600;
      font-size: 14px;
      text-align: center;
      transition: transform .2s var(--ease), background .2s, border-color .2s, color .2s;
      white-space: nowrap;
    }
    .cookie-actions .btn-c:hover { transform: translateY(-1px); }
    .btn-c.accept { background: var(--orange); color: #fff; }
    .btn-c.accept:hover { background: var(--orange-2); }
    .btn-c.refuse {
      background: transparent; color: #fff;
      border: 1.5px solid rgba(255,255,255,0.25);
    }
    .btn-c.refuse:hover { border-color: rgba(255,255,255,0.6); }
    @media (max-width: 540px) {
      .cookie-banner { left: 12px; right: 12px; bottom: 12px; width: auto; padding: 22px; }
    }

    /* ---------- Menu multi-pages (dropdown + burger) ---------- */
    .nav-drop { position: relative; }
    .nav-drop-btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--r-pill); font-size:14px; font-weight:500; font-family:inherit; color:inherit; opacity:.8; cursor:pointer; background:none; border:0; }
    .nav-drop-btn:hover, .nav-drop.open .nav-drop-btn { opacity:1; background:rgba(255,255,255,0.06); }
    .nav.scrolled .nav-drop-btn:hover, .nav.scrolled .nav-drop.open .nav-drop-btn { background:rgba(15,24,34,0.06); }
    .nav-drop .caret { font-size:10px; transition:transform .2s; }
    .nav-drop.open .caret { transform:rotate(180deg); }
    .nav-drop-menu { position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%) translateY(8px); min-width:300px; background:#fff; border:1px solid var(--line); border-radius:14px; box-shadow:0 24px 60px rgba(15,24,34,0.18); padding:8px; display:grid; gap:2px; opacity:0; visibility:hidden; transition:.22s var(--ease); z-index:60; }
    .nav-drop.open .nav-drop-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
    .nav-drop-menu a { padding:11px 14px; border-radius:9px; font-size:14px; font-weight:500; color:var(--navy-2); opacity:1; background:none; }
    .nav-drop-menu a:hover { background:var(--gray); }
    @media (hover:hover) and (min-width:901px) {
      .nav-drop:hover .nav-drop-menu { opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
      .nav-drop:hover .caret { transform:rotate(180deg); }
    }
    .nav-burger { display:none; width:42px; height:42px; border-radius:10px; align-items:center; justify-content:center; background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.12); cursor:pointer; color:#fff; }
    .nav.scrolled .nav-burger { background:rgba(15,24,34,0.05); border-color:rgba(15,24,34,0.1); color:var(--navy); }
    .nav-burger span, .nav-burger span::before, .nav-burger span::after { content:""; display:block; width:18px; height:2px; background:currentColor; border-radius:2px; }
    .nav-burger span { position:relative; }
    .nav-burger span::before, .nav-burger span::after { position:absolute; left:0; }
    .nav-burger span::before { top:-6px; } .nav-burger span::after { top:6px; }
    @media (max-width:900px) {
      .nav-burger { display:inline-flex; }
      .nav-phone { display:none; }
      .nav-links { display:none; position:absolute; top:100%; left:12px; right:12px; margin-top:10px; flex-direction:column; align-items:stretch; gap:4px; background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:0 24px 60px rgba(15,24,34,0.18); padding:12px; }
      .nav.nav-open .nav-links { display:flex; }
      .nav-links a, .nav-drop-btn { color:var(--navy-2); opacity:1; text-align:left; width:100%; justify-content:flex-start; }
      .nav-links a:hover { background:var(--gray); }
      .nav-drop { width:100%; }
      .nav-drop-menu { position:static; transform:none; opacity:1; visibility:visible; box-shadow:none; border:0; padding:2px 0 6px 14px; min-width:0; display:none; background:transparent; }
      .nav-drop.open .nav-drop-menu { display:grid; }
    }

    /* footer 5 colonnes (sitemap prestations) */
    .foot-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; }
    @media (max-width: 1000px) { .foot-grid { grid-template-columns: 1fr 1fr 1fr; } }
    @media (max-width: 760px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
    @media (max-width: 480px) { .foot-grid { grid-template-columns: 1fr; } }

    /* ---------- Logo cloud (clients / partenaires) ---------- */
    .logos-band {
      background: #fff;
      padding: 72px 0;
      border-top: 1px solid var(--line);
      border-bottom: 1px solid var(--line);
      overflow: hidden;
    }
    .logos-band .label {
      text-align: center;
      font-family: "JetBrains Mono", monospace;
      font-size: 12px;
      letter-spacing: 0.2em;
      text-transform: uppercase;
      color: var(--slate-2);
      margin-bottom: 44px;
    }
    .marquee {
      position: relative;
      overflow: hidden;
      -webkit-mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
      mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
    }
    .marquee-track {
      display: flex;
      align-items: center;
      gap: 72px;
      width: max-content;
      animation: marquee 36s linear infinite;
    }
    .logos-band:hover .marquee-track { animation-play-state: paused; }
    @keyframes marquee {
      from { transform: translateX(0); }
      to   { transform: translateX(-50%); }
    }
    .marquee-track img {
      height: 56px;
      width: auto;
      object-fit: contain;
      opacity: 0.55;
      filter: grayscale(100%);
      transition: opacity .3s var(--ease), filter .3s var(--ease);
      flex: 0 0 auto;
    }
    /* logos verticaux/carrés réduits pour équilibrer la ligne optique */
    .marquee-track img.tall { height: 92px; }
    /* logo sur fond sombre : tuile arrondie pour s'intégrer au bandeau blanc */
    .marquee-track img.chip {
      height: 88px;
      border-radius: 12px;
      padding: 0;
      background: #0b0b0d;
    }
    .marquee-track img:hover {
      opacity: 1;
      filter: grayscale(0%);
    }
    @media (prefers-reduced-motion: reduce) {
      .marquee-track { animation: none; flex-wrap: wrap; justify-content: center; width: auto; }
    }
    @media (max-width: 640px) {
      .marquee-track { gap: 48px; }
      .marquee-track img { height: 44px; }
      .marquee-track img.tall { height: 72px; }
    }

    /* ---------- Section: Certifications ---------- */
    .certifs { background: var(--gray); }
    .certifs-head { text-align: center; margin-bottom: 56px; }
    .certif-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 24px;
    }
    @media (max-width: 900px) { .certif-grid { grid-template-columns: repeat(2, 1fr); } }
    .certif-card {
      background: #fff;
      border-radius: var(--r-card);
      padding: 32px 24px;
      text-align: center;
      border: 1.5px solid transparent;
      transition: all .25s var(--ease);
      box-shadow: var(--shadow-s);
    }
    .certif-card:hover {
      border-color: var(--orange);
      transform: translateY(-4px);
      box-shadow: var(--shadow-m);
    }
    .certif-badge {
      width: 80px; height: 80px;
      border-radius: 50%;
      margin: 0 auto 18px;
      display: grid; place-items: center;
      background: var(--navy-2);
      color: var(--cyan);
      box-shadow: 0 0 0 6px rgba(15,24,34,0.04);
    }
    .certif-card h4 {
      font-family: "Poppins"; font-weight: 800;
      font-size: 22px;
      color: var(--navy-2);
      letter-spacing: -0.01em;
    }
    .certif-card .sub { font-size: 13px; color: var(--slate-2); margin-top: 6px; }
    .certif-card .ref { font-family: "JetBrains Mono", monospace; font-size: 11px; color: var(--slate-2); margin-top: 10px; letter-spacing: 0.04em; word-break: break-all; }

    /* ---------- Section: Contact ---------- */
    .contact-head { text-align: center; margin-bottom: 48px; }
    .form {
      max-width: 760px;
      margin: 0 auto;
      background: #fff;
      border: 1px solid var(--line);
      border-radius: 20px;
      padding: 40px;
      box-shadow: var(--shadow-s);
    }
    .form-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 20px;
    }
    @media (max-width: 700px) { .form-grid { grid-template-columns: 1fr; } .form { padding: 28px; } }
    .field { position: relative; }
    .field.full { grid-column: 1 / -1; }
    .field label {
      display: block;
      font-size: 12px;
      font-weight: 600;
      color: var(--slate);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      margin-bottom: 8px;
    }
    .field input, .field select, .field textarea {
      width: 100%;
      padding: 14px 16px;
      border: 1.5px solid var(--line);
      border-radius: 10px;
      font: inherit;
      font-size: 15px;
      background: #fff;
      color: var(--ink);
      transition: border-color .2s, box-shadow .2s;
    }
    .field textarea { resize: vertical; min-height: 110px; }
    .field input:focus, .field select:focus, .field textarea:focus {
      outline: 0;
      border-color: var(--orange);
      box-shadow: 0 0 0 4px rgba(255,107,53,0.12);
    }
    .form .submit {
      width: 100%;
      padding: 18px 24px;
      background: var(--orange);
      color: #fff;
      font-family: "Poppins", sans-serif;
      font-weight: 700;
      font-size: 16px;
      letter-spacing: 0.04em;
      border-radius: 10px;
      margin-top: 8px;
      transition: all .25s;
      display: inline-flex; align-items: center; justify-content: center; gap: 10px;
      box-shadow: 0 12px 30px rgba(255,107,53,0.25);
    }
    .form .submit:hover { background: var(--orange-2); transform: translateY(-2px); box-shadow: 0 18px 36px rgba(255,107,53,0.35); }
    .form .submit.success { background: var(--cyan); color: var(--navy); box-shadow: 0 18px 36px rgba(31,205,216,0.3); }

    .contact-meta {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      max-width: 760px;
      margin: 32px auto 0;
    }
    @media (max-width: 700px) { .contact-meta { grid-template-columns: 1fr; } }
    .meta-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: var(--r-card);
      padding: 26px;
      display: flex; align-items: center; gap: 18px;
      transition: all .2s;
    }
    .meta-card:hover { border-color: var(--orange); transform: translateY(-2px); }
    .meta-icon {
      width: 50px; height: 50px;
      border-radius: 12px;
      background: rgba(255,107,53,0.12);
      color: var(--orange);
      display: grid; place-items: center;
      flex: 0 0 auto;
    }
    .meta-card .label { font-size: 12px; color: var(--slate-2); text-transform: uppercase; letter-spacing: 0.1em; }
    .meta-card .value { font-family: "Poppins"; font-weight: 700; font-size: 20px; color: var(--navy-2); margin-top: 2px; }
    .meta-card .sub { font-size: 13px; color: var(--slate); margin-top: 4px; }

    /* ---------- Footer ---------- */
    footer {
      background: var(--navy);
      color: rgba(255,255,255,0.7);
      padding: 80px 0 32px;
    }
    .foot-grid {
      display: grid;
      grid-template-columns: 1.5fr 1fr 1fr 1fr;
      gap: 48px;
    }
    @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
    @media (max-width: 540px) { .foot-grid { grid-template-columns: 1fr; } }
    footer h5 {
      font-family: "Poppins"; font-weight: 700;
      color: #fff;
      font-size: 15px;
      letter-spacing: 0.02em;
      margin: 0 0 16px;
    }
    footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; font-size: 14px; }
    footer a:hover { color: var(--cyan); }
    .foot-base {
      margin-top: 56px;
      padding-top: 24px;
      border-top: 1px solid rgba(255,255,255,0.08);
      display: flex;
      justify-content: space-between;
      align-items: center;
      gap: 24px;
      flex-wrap: wrap;
      font-size: 13px;
    }
    .foot-base .mono { color: rgba(255,255,255,0.4); letter-spacing: 0.06em; }

    /* ---------- Animations ---------- */
    /* Le contenu n'est masqué que si le JS est actif (html.js). Sans JS, tout reste visible. */
    .js .reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
    .reveal.in { opacity: 1; transform: none; }
    .reveal.delay-1 { transition-delay: .08s; }
    .reveal.delay-2 { transition-delay: .16s; }
    .reveal.delay-3 { transition-delay: .24s; }
    .reveal.delay-4 { transition-delay: .32s; }

    /* Tag / floating accents */
    .floating-tag {
      position: absolute;
      padding: 8px 16px;
      border-radius: var(--r-pill);
      font-family: "Poppins"; font-weight: 700;
      font-size: 12px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      box-shadow: var(--shadow-m);
    }
    .tag-neon { background: var(--cyan); color: var(--navy); }
    .tag-orange { background: var(--orange); color: #fff; }
    .tag-dark { background: var(--navy-2); color: #fff; }

  

    /* utilitaire SEO + titrage hero (additif, ne modifie pas le design) */
    .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
    .hero-headline{margin:0;display:block;font-weight:inherit;letter-spacing:inherit}
    .hero-headline .hero-title,.hero-headline .hero-subtitle{display:block}
    .hero-headline .hero-subtitle{max-width:20ch}
  

/* ========== WordPress Nav Menu Override ========== */
.nav-links ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 4px;
  align-items: center;
}
.nav-links ul li {
  position: relative;
}
.nav-links ul li a {
  display: block;
  padding: 9px 18px;
  border-radius: var(--r-pill);
  font-size: 14px;
  font-weight: 500;
  opacity: .8;
  transition: background .2s, opacity .2s;
}
.nav-links ul li a:hover {
  opacity: 1;
  background: rgba(255,255,255,0.06);
}
.nav-links ul li.current-menu-item > a,
.nav-links ul li.current-page-ancestor > a {
  opacity: 1;
  background: rgba(255,255,255,0.12);
}
.nav-links ul li ul {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: rgba(15,18,24,0.96);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 8px;
  min-width: 240px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.4);
  z-index: 100;
  flex-direction: column;
  gap: 2px;
}
.nav-links ul li:hover > ul {
  display: flex;
}
.nav-links ul li ul li a {
  padding: 12px 18px;
  font-size: 14px;
  white-space: nowrap;
  border-radius: 8px;
  opacity: 1;
  color: rgba(255,255,255,0.8);
}
.nav-links ul li ul li a:hover {
  background: rgba(255,255,255,0.08);
  color: #fff;
}
.nav.scrolled .nav-links ul li ul {
  background: rgba(255,255,255,0.97);
  border-color: rgba(15,24,34,0.08);
}
.nav.scrolled .nav-links ul li ul li a {
  color: var(--navy);
}
.nav.scrolled .nav-links ul li ul li a:hover {
  background: rgba(15,24,34,0.06);
}
.nav-links ul li.menu-item-has-children > a::after {
  content: " ▾";
  font-size: 11px;
  opacity: 0.65;
}

/* ========== Mobile Menu ========== */
@media (max-width: 900px) {
  .nav-links {
    display: none;
    position: fixed;
    inset: 70px 16px auto 16px;
    background: rgba(8,9,15,0.97);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    padding: 16px;
    z-index: 49;
    flex-direction: column;
    box-shadow: 0 24px 60px rgba(0,0,0,0.5);
  }
  .nav-links.mobile-open {
    display: flex !important;
  }
  .nav-links ul {
    flex-direction: column;
    gap: 2px;
    width: 100%;
  }
  .nav-links ul li {
    width: 100%;
  }
  .nav-links ul li a {
    display: block;
    padding: 14px 18px;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 500;
    color: rgba(255,255,255,0.85);
    opacity: 1;
  }
  .nav-links ul li a:hover {
    background: rgba(255,255,255,0.06);
    color: #fff;
  }
  .nav-links ul li ul {
    display: none;
    position: static;
    background: rgba(255,255,255,0.04);
    border: none;
    border-radius: 8px;
    box-shadow: none;
    padding: 4px 8px;
    margin-top: 4px;
  }
  .nav-links ul li.open > ul {
    display: flex;
  }
  .nav-links ul li ul li a {
    font-size: 14px;
    padding: 10px 14px;
    color: rgba(255,255,255,0.7);
  }
  .nav-burger {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    padding: 8px;
  }
  .nav-burger span,
  .nav-burger span::before,
  .nav-burger span::after {
    display: block;
    width: 22px;
    height: 2px;
    background: currentColor;
    border-radius: 2px;
    content: '';
    transition: transform .25s ease;
  }
  .nav-burger span {
    position: relative;
  }
}

/* ========== Prose (single post) ========== */
.prose {
  max-width: 760px;
  margin: 0 auto;
}
.prose h2 { font-size: 1.6rem; margin-top: 2.5rem; margin-bottom: .75rem; }
.prose h3 { font-size: 1.25rem; margin-top: 2rem; margin-bottom: .5rem; }
.prose p  { margin-bottom: 1.2em; line-height: 1.75; }
.prose ul, .prose ol { padding-left: 1.5em; margin-bottom: 1.2em; }
.prose li { margin-bottom: .4em; line-height: 1.7; }
.prose a  { color: var(--cyan); text-decoration: underline; }
.prose strong { color: var(--navy); font-weight: 700; }

/* Post thumbnail in blog grid */
.post-thumb {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  border-radius: 12px 12px 0 0;
}
.post-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ========== Formulaire devis – alertes ========== */
.form-alert {
  padding: 14px 20px;
  border-radius: 12px;
  font-weight: 600;
  margin-bottom: 24px;
  text-align: center;
}
.form-alert.is-success {
  background: rgba(22,163,74,0.12);
  color: #16a34a;
  border: 1px solid rgba(22,163,74,0.3);
}
.form-alert.is-error {
  background: rgba(239,68,68,0.10);
  color: #ef4444;
  border: 1px solid rgba(239,68,68,0.3);
}

/* ============================================================
   CSS DES SOUS-PAGES (services, blog) — subhero, prose, tarifs
   ============================================================ */

    /* ---------- Pages internes (additif) ---------- */
    .subhero{position:relative;background:var(--navy);color:#fff;overflow:hidden;padding:160px 0 92px}
    .subhero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 460px at 82% 16%,rgba(31,205,216,0.12),transparent 60%),radial-gradient(820px 420px at 6% 100%,rgba(229,32,138,0.12),transparent 60%);pointer-events:none}
    .subhero .wrap{position:relative;z-index:2}
    .crumbs{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);margin-bottom:22px}
    .crumbs a{color:rgba(255,255,255,.5)} .crumbs a:hover{color:#fff}
    .subhero h1{font-size:clamp(34px,5vw,60px);letter-spacing:-0.02em;max-width:20ch;text-wrap:balance}
    .subhero .lede{margin-top:20px;font-size:19px;line-height:1.7;color:rgba(255,255,255,.72);max-width:64ch}
    .subhero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
    .subhero-meta{display:flex;gap:36px;flex-wrap:wrap;margin-top:42px;padding-top:28px;border-top:1px solid rgba(255,255,255,.1)}
    .subhero-meta .m .n{font-family:"Poppins";font-weight:800;font-size:22px;color:#fff;line-height:1}
    .subhero-meta .m .l{font-size:12.5px;color:rgba(255,255,255,.6);letter-spacing:.04em;margin-top:6px}
    .prose-section{padding:96px 0}
    .prose-section.alt{background:var(--gray)}
    .lead-2{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:start}
    @media(max-width:900px){.lead-2{grid-template-columns:1fr;gap:36px}}
    .prose h2{font-size:clamp(28px,3.4vw,42px);color:var(--navy-2);margin-bottom:18px;max-width:20ch;text-wrap:balance}
    .prose p{color:var(--slate);font-size:17px;line-height:1.8;margin:0 0 16px;max-width:64ch}
    .prose p strong{color:var(--navy-2);font-weight:600}
    .side-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:30px;box-shadow:var(--shadow-s)}
    .side-card .badge{display:inline-flex;align-items:center;gap:8px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:18px}
    .side-card .badge .d{width:7px;height:7px;border-radius:50%;background:var(--cyan)}
    .target-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:8px}
    @media(max-width:520px){.target-grid{grid-template-columns:1fr}}
    .target{display:flex;align-items:center;gap:12px;padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:12px;font-weight:500;color:var(--navy-2)}
    .target .ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:rgba(255,122,26,.12);color:var(--orange);flex:0 0 auto}
    .zones{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
    .zone-chip{padding:10px 16px;border-radius:var(--r-pill);background:#fff;border:1px solid var(--line);font-weight:600;font-size:14px;color:var(--navy-2)}
    .zone-chip.strong{background:var(--navy-2);color:#fff;border-color:var(--navy-2)}
    .faq{max-width:860px;margin:0 auto}
    .faq details{border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:12px}
    .faq details[open]{border-color:var(--orange)}
    .faq summary{list-style:none;cursor:pointer;padding:20px 22px;font-family:"Poppins";font-weight:600;font-size:17px;color:var(--navy-2);display:flex;justify-content:space-between;align-items:center;gap:16px}
    .faq summary::-webkit-details-marker{display:none}
    .faq summary .plus{flex:0 0 auto;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:.25s;color:var(--slate-2)}
    .faq details[open] summary .plus{transform:rotate(45deg);border-color:var(--orange);color:var(--orange)}
    .faq .a{padding:0 22px 22px;color:var(--slate);line-height:1.78;max-width:70ch}
    .also-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
    @media(max-width:800px){.also-grid{grid-template-columns:1fr}}
    .also{display:block;padding:26px;border:1px solid var(--line);border-radius:14px;background:#fff;transition:.25s}
    .also:hover{transform:translateY(-4px);border-color:var(--orange);box-shadow:var(--shadow-m)}
    .also .k{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:10px}
    .also .t{font-family:"Poppins";font-weight:700;font-size:18px;color:var(--navy-2);margin-bottom:6px}
    .also .d{font-size:14px;color:var(--slate);line-height:1.6}
    .cta-band{background:var(--navy);color:#fff;text-align:center;position:relative;overflow:hidden;padding:92px 0}
    .cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(720px 360px at 50% 0%,rgba(255,122,26,.16),transparent 60%);pointer-events:none}
    .cta-band h2{font-size:clamp(28px,3.6vw,44px);color:#fff;max-width:22ch;margin:0 auto 14px;position:relative;text-wrap:balance}
    .cta-band p{color:rgba(255,255,255,.7);position:relative;margin:0 auto 28px;max-width:56ch}
    .cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}
    .sec-head{margin-bottom:48px}
    /* tarifs */
    .price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
    @media(max-width:800px){.price-grid{grid-template-columns:1fr}}
    .price-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:var(--shadow-s)}
    .price-card.feat{border-color:var(--orange);box-shadow:0 18px 40px rgba(255,122,26,.14)}
    .price-card .pk{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:12px}
    .price-card .pv{font-family:"Poppins";font-weight:800;font-size:30px;color:var(--navy-2);letter-spacing:-.02em}
    .price-card .pv small{font-size:14px;font-weight:500;color:var(--slate-2)}
    .price-card .pd{margin-top:12px;color:var(--slate);font-size:14.5px;line-height:1.65}
    .price-note{margin-top:20px;font-size:13px;color:var(--slate-2);max-width:60ch}
    /* article / blog */
    .article{max-width:760px;margin:0 auto}
    .article p{color:var(--ink);font-size:17.5px;line-height:1.85;margin:0 0 20px}
    .article h2{font-size:clamp(24px,3vw,34px);color:var(--navy-2);margin:40px 0 16px;text-wrap:balance}
    .article h3{font-size:20px;color:var(--navy-2);margin:28px 0 10px}
    .article ul{margin:0 0 20px;padding-left:22px;color:var(--ink)}
    .article li{margin-bottom:10px;line-height:1.7}
    .article strong{color:var(--navy-2)}
    .article .lead{font-size:20px;line-height:1.7;color:var(--slate);margin-bottom:28px}
    .post-meta{display:flex;gap:14px;align-items:center;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;color:var(--slate-2);text-transform:uppercase;margin-bottom:14px}
    .post-meta .tag{color:var(--orange)}
    .blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
    @media(max-width:900px){.blog-grid{grid-template-columns:1fr}}
    .post-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:16px;padding:28px;transition:.25s}
    .post-card:hover{transform:translateY(-5px);border-color:var(--orange);box-shadow:var(--shadow-m)}
    .post-card .pt{font-family:"Poppins";font-weight:700;font-size:20px;color:var(--navy-2);margin:6px 0 10px;line-height:1.3}
    .post-card .pe{color:var(--slate);font-size:15px;line-height:1.65;flex:1}
    .post-card .pl{margin-top:16px;color:var(--orange);font-weight:600;font-size:14px}
    .callout{background:var(--gray);border-left:3px solid var(--orange);border-radius:0 12px 12px 0;padding:20px 24px;margin:24px 0;color:var(--navy-2);font-size:15.5px;line-height:1.7}
    .subhero{isolation:isolate}
    .subhero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 28%;z-index:0}
    .subhero-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,9,15,.82) 0%,rgba(8,9,15,.6) 55%,rgba(6,7,11,.93) 100%),linear-gradient(95deg,rgba(8,9,15,.9) 0%,rgba(8,9,15,.32) 70%);pointer-events:none}
    .photo-strip{position:relative;height:clamp(320px,42vw,480px);overflow:hidden}
    .photo-strip img{width:100%;height:100%;object-fit:cover;object-position:center 35%}
    .photo-strip::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,9,15,.15) 0%,transparent 35%,rgba(8,9,15,.9) 100%);pointer-events:none}
    .photo-strip .ps-cap{position:absolute;left:0;right:0;bottom:0;max-width:1240px;margin:0 auto;padding:0 28px 40px;color:#fff;z-index:2}
    .photo-strip .ps-cap .k{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);display:inline-flex;align-items:center;gap:8px;margin-bottom:10px}
    .photo-strip .ps-cap .k::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cyan)}
    .photo-strip .ps-cap .t{font-family:"Poppins",sans-serif;font-weight:700;font-size:clamp(20px,2.6vw,30px);max-width:28ch;line-height:1.25;text-wrap:balance}
  

/* ============================================================
   CSS DES PAGES LÉGALES (mentions, confidentialité)
   ============================================================ */
/* ---- Page header ---- */
.page-head{
  background:var(--navy);
  color:#fff;
  padding:80px 0 100px;
  position:relative;
  overflow:hidden;
}
.page-head::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 80% 20%,rgba(31,205,216,0.10),transparent 60%),
    radial-gradient(800px 400px at 0% 100%,rgba(229,32,138,0.10),transparent 60%);
  pointer-events:none;
}
.page-head .crumbs{
  position:relative;
  font-family:"JetBrains Mono",monospace;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--cyan);
  margin-bottom:20px;
}
.page-head .crumbs a{color:rgba(255,255,255,0.5)}
.page-head .crumbs a:hover{color:#fff}
.page-head h1{
  position:relative;
  font-size:clamp(40px,5.5vw,72px);
  letter-spacing:-0.02em;
  max-width:18ch;
}
.page-head p.lede{
  position:relative;
  margin-top:18px;
  font-size:18px;
  color:rgba(255,255,255,0.7);
  max-width:60ch;
}
/* ---- Legal content ---- */
.legal-wrap{
  max-width:900px;
  margin:0 auto;
  padding:80px 28px 100px;
  display:grid;
  grid-template-columns:240px 1fr;
  gap:64px;
}
@media (max-width:900px) {
  .legal-wrap{grid-template-columns:1fr;gap:32px;padding:56px 28px 80px}
}
.toc{
  position:sticky;
  top:96px;
  align-self:start;
  font-size:14px;
  border-left:2px solid var(--gray-2);
  padding-left:20px;
}
.toc .toc-title{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--slate-2);
  margin-bottom:14px;
}
.toc ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.toc a{color:var(--slate);font-size:14px;transition:color .2s}
.toc a:hover{color:var(--navy)}
.toc .updated{
  margin-top:24px;padding-top:18px;border-top:1px solid var(--gray-2);
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.1em;
  color:var(--slate-2);
}
@media (max-width:900px) {
  .toc{position:static;border-left:0;padding-left:0}
  .toc ul{display:flex;flex-wrap:wrap;gap:6px 12px}
}
.legal-body section{margin-bottom:48px;scroll-margin-top:96px}
.legal-body h2{
  font-size:26px;
  color:var(--navy);
  margin-bottom:18px;
  padding-bottom:14px;
  border-bottom:1px solid var(--gray-2);
}
.legal-body h2 .num{
  font-family:"JetBrains Mono",monospace;
  font-size:13px;
  color:var(--magenta);
  margin-right:10px;
  letter-spacing:.1em;
}
.legal-body h3{font-size:18px;margin:24px 0 10px;color:var(--navy)}
.legal-body p{margin:0 0 14px;color:var(--ink)}
.legal-body p.muted{color:var(--slate)}
.legal-body ul{margin:0 0 18px;padding-left:22px;color:var(--ink)}
.legal-body ul li{margin-bottom:8px;line-height:1.65}
.legal-body strong{color:var(--navy);font-weight:600}
.legal-body a.link{color:var(--orange);font-weight:500;border-bottom:1px solid currentColor}
.legal-body a.link:hover{color:var(--magenta)}
.info-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin:18px 0 24px;
}
@media (max-width:600px) {
  .info-grid{grid-template-columns:1fr}
}
.info-card{
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px;
  background:#fff;
}
.info-card .label{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--slate-2);
  margin-bottom:6px;
}
.info-card .value{
  font-family:"Poppins",sans-serif;
  font-weight:600;
  font-size:15px;
  color:var(--navy);
  word-break:break-word;
}
.info-card .value.mono{font-family:"JetBrains Mono",monospace;font-weight:500;font-size:13px}

/* ============================================================
   CORRECTIONS MENU — lisibilité & espacement (v1.6)
   ============================================================ */

/* 1) Décale la barre sous l'admin-bar WordPress (sinon le menu est
      collé/caché tout en haut quand on est connecté en admin). */
.admin-bar .nav { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .nav { top: 46px; }
}

/* 2) Un peu plus d'air en haut + voile sombre dégradé derrière le menu
      desktop pour qu'il reste lisible même sur une photo claire. */
.nav-inner { padding-top: 22px; padding-bottom: 22px; }
.nav { position: fixed; }
.nav:not(.scrolled)::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(to bottom, rgba(8,9,15,0.60), rgba(8,9,15,0));
}

/* 3) MENU MOBILE : fond totalement opaque + texte plein blanc,
      pour qu'il reste lisible au-dessus de n'importe quelle section. */
@media (max-width: 900px) {
  .nav-links {
    background: #0b0e14 !important;          /* solide, zéro transparence */
    border: 1px solid rgba(255,255,255,0.14) !important;
    box-shadow: 0 24px 60px rgba(0,0,0,0.65) !important;
  }
  .nav-links ul li > a {
    color: #ffffff !important;
    opacity: 1 !important;
  }
  .nav-links ul li.menu-item-has-children > a::after {
    opacity: .8;
  }
  .nav-links ul li ul {
    background: rgba(255,255,255,0.07) !important;
  }
  .nav-links ul li ul li a {
    color: rgba(255,255,255,0.92) !important;
  }
}

/* ============================================================
   BLOG — étiquettes, méta cliquable, articles suggérés (v1.8)
   ============================================================ */
/* Catégories/étiquettes cliquables dans la méta d'article */
a.tag { text-decoration: none; transition: opacity .2s, background .2s; }
a.tag:hover { opacity: .85; }

/* Étiquettes en bas d'article */
.post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 36px;
  padding-top: 24px;
  border-top: 1px solid var(--line, rgba(15,24,34,0.1));
}
.post-tags .tag {
  background: rgba(15,24,34,0.06);
  color: var(--navy, #0f1822);
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
}
.post-tags .tag:hover { background: rgba(15,24,34,0.12); }

/* Pagination interne d'article (wp_link_pages) */
.page-links { margin-top: 28px; font-weight: 600; display: flex; gap: 8px; align-items: center; }
.page-links a, .page-links > span { padding: 4px 12px; border-radius: 8px; background: rgba(15,24,34,0.06); text-decoration: none; }

/* Pagination de la liste d'articles (the_posts_pagination) */
.pagination, nav.pagination { margin-top: 48px; display: flex; justify-content: center; }
.pagination .nav-links { display: flex; gap: 6px; background: none; border: none; padding: 0; backdrop-filter: none; }
.pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 42px; height: 42px; padding: 0 12px;
  border-radius: 10px; background: rgba(15,24,34,0.05);
  color: var(--navy, #0f1822); text-decoration: none; font-weight: 600;
}
.pagination .page-numbers.current { background: var(--navy, #0f1822); color: #fff; }
.pagination .page-numbers:hover { background: rgba(15,24,34,0.12); }
