.nqh-complement, .nqh-complement * , .nqh-complement *::before, .nqh-complement *::after { box-sizing: border-box; }
  .nqh-complement :is(svg,img){ display:block; max-width:100%; height:auto; }

  .nqh-complement{
    /* Palette : Landau in der Pfalz, énergie solaire */
    --ink:#000000;          /* texte principal */
    --muted:#5b6a72;        /* texte secondaire */
    --paper:#FFFFFF;        /* cartes */
    --bg:#FFFFFF;           /* fond blanc */
    --line:#10367A;         /* couleur primaire */
    --accent:#FE5716;       /* couleur d'accent */
    --secondary:#D3D3D3;    /* couleur secondaire */
    --shadow:0 18px 48px rgba(173, 216, 230, .14); /* ombre subtile */
    --r:18px;

    color:var(--ink);
    background:
      radial-gradient(100% 70% at 12% 0%, #E0F2F7 0%, transparent 55%), /* léger bleu clair */
      radial-gradient(100% 70% at 100% 0%, #E3F2FD 0%, transparent 55%), /* autre bleu clair */
      var(--bg);
    font:15px/1.6 ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
    position:relative; isolation:isolate; overflow:hidden;
    padding: clamp(28px, 6vw, 64px) 16px;
  }

  /* halo décor */
  .nqh-ambient{ position:absolute; inset:-18% -10% auto -10%; height:62%; z-index:0; pointer-events:none; }
  .nqh-ambient::before{
    content:""; position:absolute; inset:-15%;
    background: conic-gradient(from 0deg, rgba(254,87,22,.18), rgba(16,54,122,.14), rgba(211,211,211,.16), rgba(254,87,22,.18)); /* couleurs personnalisées */
    filter: blur(60px); opacity:.9; animation: nqh-spin 26s linear infinite;
  }
  @keyframes nqh-spin { to { transform: rotate(1turn); } }

  .nqh-wrap{ max-width:1180px; margin:0 auto; position:relative; z-index:1; }

  /* ===== header ===== */
  .nqh-header{ text-align:center; margin-bottom: clamp(20px, 4vw, 36px); }
  .nqh-title{
    margin:0 0 8px; font-weight:900; letter-spacing:.2px;
    font-size: clamp(1.45rem, 1.1rem + 1.9vw, 2.25rem);
    color:var(--line); /* Couleur primaire */
  }
  .nqh-title .nqh-q{
    display:inline-grid; place-items:center; margin-left:.45rem;
    width:28px; height:28px; border-radius:9px; font-size:1rem; font-weight:900; line-height:1;
    color:#FFFFFF; /* Texte blanc pour le contraste */
    transform: translateY(-2px);
    background: var(--accent); /* Couleur d'accent */
    box-shadow: 0 6px 18px rgba(254,87,22,.28); /* Ombre avec couleur d'accent */
  }
  .nqh-sub{ color:var(--muted); max-width: 70ch; margin: 0 auto; }

  /* ===== grid ===== */
  .nqh-grid{
    display:grid; grid-template-columns: repeat(12, 1fr);
    gap: clamp(12px, 2.4vw, 20px);
  }
  .nqh-card{
    grid-column: span 3;
    background: var(--paper); /* Couleur des cartes */
    border: 1.5px solid var(--secondary); /* Bordure avec couleur secondaire */
    border-radius: calc(var(--r) + 2px);
    padding: 18px;
    box-shadow: var(--shadow);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
    transform: perspective(900px) rotateX(0deg) rotateY(0deg);
  }
  .nqh-card:hover{
    transform: perspective(900px) translateY(-4px) rotateX(.6deg) rotateY(-.6deg);
    border-color:var(--accent); /* Bordure accentuée au survol */
    box-shadow: 0 22px 60px rgba(254,87,22,.18); /* Ombre accentuée */
    background: linear-gradient(180deg, var(--paper), #f0f8ff); /* Léger dégradé au survol */
  }
  @media (max-width: 1020px){ .nqh-card{ grid-column: span 6; } }
  @media (max-width: 680px){ .nqh-card{ grid-column: span 12; } }

  .nqh-ico{
    width:48px; height:48px; border-radius:14px; display:grid; place-items:center; margin-bottom:10px;
    background: linear-gradient(135deg, rgba(16,54,122,.12), rgba(254,87,22,.12)); /* Dégradé bleu/orange */
    border:1.5px solid var(--secondary); /* Bordure secondaire */
  }
  .nqh-ico svg{ width:24px; height:24px; color:var(--line); } /* Icône en couleur primaire */

  .nqh-card h3{ font-size:1.06rem; margin:2px 0 6px; font-weight:900; color:var(--line); } /* Titre en couleur primaire */
  .nqh-card p{ margin:0; color:var(--muted); }

  /* ===== CTA ===== */
  .nqh-cta{
    grid-column: 1 / -1;
    display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap;
    gap:10px; margin-top: clamp(12px, 3vw, 20px);
    border:1.5px dashed var(--line); /* Bordure en couleur primaire */
    border-radius: calc(var(--r) + 6px);
    background:var(--paper); /* Fond blanc */
    padding: 14px 16px;
  }
  .nqh-cta strong{ color:var(--line); } /* Texte en gras en couleur primaire */
  .nqh-btn{
    appearance:none; -webkit-appearance:none; cursor:pointer; border:none;
    display:inline-flex; align-items:center; gap:.55rem; padding:.9rem 1.1rem;
    border-radius:14px; font-weight:900; color:#FFFFFF; /* Texte blanc pour le contraste */
    background: var(--accent); /* Bouton en couleur d'accent */
    box-shadow: 0 14px 28px rgba(254,87,22,.22); /* Ombre accentuée */
    transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
    text-decoration:none;
  }
  .nqh-btn:hover{ transform: translateY(-1px); filter:saturate(1.06); box-shadow: 0 20px 48px rgba(254,87,22,.26); } /* Survol accentué */

  /* a11y */
  .nqh-complement :is(a,button){ outline:none; }
  .nqh-complement :is(a,button):focus-visible{ outline:2px solid #fbbf24; outline-offset:3px; border-radius:12px; }
  @media (prefers-reduced-motion: reduce){
    .nqh-ambient::before{ animation:none; }
    .nqh-card, .nqh-btn{ transition:none; }
  }