/* ==========================================================================
   IJN+ - Cartes services en verre depoli (styles de bloc core/group)
   Charge via wp_enqueue_block_style sur core/group (front + editeur).
   ========================================================================== */

/* Rangee de cartes qui chevauche le bas du hero, alignee sur la colonne */
.wp-block-group.is-style-ijn-cards-overlap{
  position:relative;
  z-index:3;
  margin-top:-84px;
  width:100%;
  max-width:var(--ijn-shell,1480px);
  margin-inline:auto;
  padding-inline:var(--ijn-edge,40px);
}
.is-style-ijn-cards-overlap .wp-block-columns{
  max-width:none;
  width:100%;
  margin-inline:0;
  align-items:stretch;
}
@media (max-width:781px){
  .wp-block-group.is-style-ijn-cards-overlap{ margin-top:24px; padding-inline:var(--ijn-edge,18px); }
  .is-style-ijn-cards-overlap .wp-block-columns{ flex-direction:column; gap:16px; }
  .is-style-ijn-cards-overlap .wp-block-column{ width:100% !important; flex-basis:100% !important; }
  .wp-block-group.is-style-ijn-card-glass,
  .wp-block-group.is-style-ijn-card-glass-dark{ padding:30px; }
  .is-style-ijn-card-glass h3,
  .is-style-ijn-card-glass-dark h3{ font-size:22px; }
  .is-style-ijn-card-glass p,
  .is-style-ijn-card-glass-dark p{ font-size:15px; }
}
/* Dans l'editeur de blocs : largeur pleine + pas de chevauchement negatif (apercu fidele) */
.editor-styles-wrapper .wp-block-group.is-style-ijn-cards-overlap{ margin-top:24px; max-width:none; }
.editor-styles-wrapper .is-style-ijn-cards-overlap .wp-block-columns{ width:100%; max-width:none; }

/* Base commune des deux cartes */
.wp-block-group.is-style-ijn-card-glass,
.wp-block-group.is-style-ijn-card-glass-dark{
  height:100%;
  border-radius:16px;
  padding:26px;
  box-shadow:0 18px 40px -20px rgba(11,60,143,.40);
  transition:transform .45s cubic-bezier(.22,.61,.36,1), box-shadow .45s ease;
}
.wp-block-group.is-style-ijn-card-glass:hover,
.wp-block-group.is-style-ijn-card-glass-dark:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 44px -18px rgba(11,60,143,.32);
}

/* Carte verre clair */
.wp-block-group.is-style-ijn-card-glass{
  background:rgba(255,255,255,.10);
  -webkit-backdrop-filter:blur(24px) saturate(190%);
  backdrop-filter:blur(24px) saturate(190%);
  border:1px solid rgba(255,255,255,.38);
}

/* Pastille d'icone en haut de carte (facon Apex) */
.wp-block-image.ijn-card-ic{
  width:46px; height:46px;
  margin:0 auto 16px 0 !important;
  border-radius:12px;
  display:flex; align-items:center; justify-content:center;
}
.wp-block-image.ijn-card-ic img{ width:26px; height:26px; }
.is-style-ijn-card-glass .wp-block-image.ijn-card-ic{ background:#F1F8E6; }
.is-style-ijn-card-glass-dark .wp-block-image.ijn-card-ic{ background:rgba(255,255,255,.14); }

/* ==========================================================================
   Ruban de preuves qui defile (style de bloc core/group : Ruban defilant)
   ========================================================================== */
.is-style-ijn-marquee{
  width:100%;
  margin-top:20px;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
}
.ijn-marquee-track{
  display:flex;
  width:max-content;
  gap:14px;
  align-items:center;
  animation:ijn-marquee-scroll 32s linear infinite;
}
/* Annule la marge de bloc WP (is-layout-flow) qui decalait le 1er item vers le haut */
.ijn-marquee-track > *{ margin-block:0 !important; align-self:center; }
.is-style-ijn-marquee:hover .ijn-marquee-track{ animation-play-state:paused; }
@keyframes ijn-marquee-scroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
.ijn-chip{
  display:inline-flex; align-items:center; gap:8px; white-space:nowrap;
  margin:0; padding:8px 16px;
  font-family:Inter,sans-serif; font-weight:500; font-size:14px; color:#16243A;
  background:rgba(255,255,255,.62);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:999px;
}
.ijn-chip::before{ content:""; width:7px; height:7px; border-radius:50%; background:#81C12F; flex:0 0 auto; }
/* Editeur : pas d'animation, retour a la ligne pour voir tous les items */
.editor-styles-wrapper .ijn-marquee-track{ animation:none; flex-wrap:wrap; }
@media (prefers-reduced-motion: reduce){ .ijn-marquee-track{ animation:none; flex-wrap:wrap; } }

/* ==========================================================================
   Section Avis clients (carrousel d'avis Google qui defile)
   ========================================================================== */
.ijn-reviews{ background:#ffffff; padding:78px 0 86px; }
.ijn-reviews .ijn-reviews-head{
  width:100%; max-width:var(--ijn-shell,1480px) !important;
  margin-inline:auto !important; padding-inline:var(--ijn-edge,40px);
}
.ijn-reviews-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-reviews h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 12px; }
.ijn-reviews .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0 0 22px; max-width:780px; }
.ijn-reviews-btn .wp-block-button__link,
.ijn-reviews-btn a{ display:inline-flex; align-items:center; gap:8px; font-family:Poppins,sans-serif; font-weight:600; font-size:14px; color:#0B3C8F; text-decoration:none; background:transparent; border:1.5px solid #0B3C8F; border-radius:999px; padding:10px 20px; transition:background .3s ease,color .3s ease; }
.ijn-reviews-btn .wp-block-button__link:hover,
.ijn-reviews-btn a:hover{ background:#0B3C8F; color:#ffffff; }
.ijn-reviews .ijn-reviews-marquee{
  width:100%; max-width:calc(var(--ijn-shell,1480px) - 80px) !important; margin:38px auto 0 !important;
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 3%,#000 97%,transparent);
}
.ijn-reviews-track{
  display:flex; align-items:stretch; width:max-content; gap:22px;
  animation:ijn-marquee-scroll 90s linear infinite;
}
.ijn-reviews-marquee:hover .ijn-reviews-track{ animation-play-state:paused; }
.ijn-review-card{
  flex:0 0 360px; width:360px;
  display:flex; flex-direction:column;
  background:#ffffff; border:1px solid #E3E9F0; border-radius:16px; padding:26px;
}
.ijn-review-stars{ color:#F5A623; font-size:16px; letter-spacing:3px; margin:0 0 12px; }
.ijn-review-text{ color:#16243A; font-size:14.5px; line-height:1.6; margin:0 0 16px; flex:1; }
.ijn-review-name{ font-family:Poppins,sans-serif; font-weight:600; color:#0B3C8F; font-size:14px; margin:0; }
.ijn-review-meta{ color:#5C6B7E; font-size:12.5px; margin:2px 0 0; }
@media (max-width:600px){ .ijn-review-card{ flex-basis:290px; width:290px; padding:24px; } }

/* ==========================================================================
   Section Zone d'intervention (grille de departements, plate)
   ========================================================================== */
.ijn-zones{ background:#F3F7FB; padding:78px 0 84px; }
.ijn-zones .ijn-zones-head,
.ijn-zones .ijn-zones-grid,
.ijn-zones .ijn-zones-foot{
  width:100%; max-width:var(--ijn-shell,1480px) !important;
  margin-inline:auto !important; padding-inline:var(--ijn-edge,40px);
}
.ijn-zones-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-zones h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 12px; }
.ijn-zones .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0; max-width:880px; }
.ijn-zones-grid{ display:grid !important; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:40px; }
.ijn-zones-grid > .ijn-zone-card{ margin:0 !important; }
.ijn-zone-card{ background:#ffffff; border:1px solid #E3E9F0; border-radius:14px; padding:22px 24px; }
.ijn-zone-card h3{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:17px; margin:0 0 6px; }
.ijn-zone-card p{ color:#5C6B7E; font-size:13.5px; line-height:1.5; margin:0; }
.ijn-zones-foot{ margin-top:26px; }
.ijn-zones-foot p{ color:#5C6B7E; font-size:14.5px; margin:0; }
.ijn-zones-foot a{ color:#0B3C8F; font-weight:600; text-decoration:none; border-bottom:2px solid #81C12F; }
@media (max-width:980px){ .ijn-zones-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .ijn-zones-grid{ grid-template-columns:1fr; } }

/* ==========================================================================
   Galerie interventions (fond marine + photos avec legende en verre depoli)
   ========================================================================== */
.ijn-gallery{ position:relative; overflow:hidden; background:linear-gradient(130deg,#0B3C8F 0%,#0B3C8F 40%,#037CC9 100%); padding:80px 0 86px; }
.ijn-gallery::before{ content:""; position:absolute; width:600px; height:600px; border-radius:50%; background:#2AA8EC; filter:blur(120px); opacity:.55; top:-170px; right:10%; pointer-events:none; }
.ijn-gallery .ijn-gallery-head,
.ijn-gallery .ijn-gallery-grid{ position:relative; z-index:2; width:100%; max-width:var(--ijn-shell,1480px) !important; margin-inline:auto !important; padding-inline:var(--ijn-edge,40px); }
.ijn-gallery-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-gallery .ijn-eyebrow{ color:#A9E06A; }
.ijn-gallery h2{ font-family:Poppins,sans-serif; color:#ffffff; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 12px; }
.ijn-gallery .ijn-lead{ color:#DCE9F8; font-size:16px; line-height:1.6; margin:0; max-width:820px; }
.ijn-gallery-grid{ display:grid !important; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:38px; }
.ijn-gallery-grid > .ijn-gallery-item{ margin:0 !important; }
.ijn-gallery-item{ position:relative; border-radius:16px; overflow:hidden; aspect-ratio:4/5; box-shadow:0 22px 50px -28px rgba(0,0,0,.6); }
.ijn-gallery-item .wp-block-image,
.ijn-gallery-item figure{ margin:0; height:100%; }
.ijn-gallery-item img{ width:100%; height:100%; object-fit:cover; display:block; }
.ijn-gallery-cap{ position:absolute; left:12px; right:12px; bottom:12px; margin:0; color:#ffffff; font-family:Poppins,sans-serif; font-weight:600; font-size:13px; padding:9px 14px; border-radius:12px; background:rgba(255,255,255,.14); -webkit-backdrop-filter:blur(12px) saturate(150%); backdrop-filter:blur(12px) saturate(150%); border:1px solid rgba(255,255,255,.24); }
@media (max-width:900px){ .ijn-gallery-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .ijn-gallery-grid{ grid-template-columns:1fr; } }

/* ==========================================================================
   Section L'equipe (portraits Lucas & Guillaume)
   ========================================================================== */
.ijn-team{ background:#ffffff; padding:78px 0 84px; }
.ijn-team .ijn-team-head,
.ijn-team .ijn-team-grid{ width:100%; max-width:var(--ijn-shell,1480px) !important; margin-inline:auto !important; padding-inline:var(--ijn-edge,40px); }
.ijn-team-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-team h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 12px; }
.ijn-team .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0; max-width:840px; }
.ijn-team-grid{ display:grid !important; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:40px; align-items:stretch; }
.ijn-team-grid > .ijn-team-card{ margin:0 !important; }
.ijn-team-card{ display:flex; gap:22px; align-items:center; background:#F3F7FB; border:1px solid #E3E9F0; border-radius:18px; padding:24px; }
.ijn-team-card .wp-block-image{ margin:0; flex:0 0 130px; }
.ijn-team-card .wp-block-image img{ width:130px; height:165px; object-fit:cover; border-radius:12px; display:block; }
.ijn-team-card h3{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:20px; margin:0 0 3px; }
.ijn-team-role{ color:#3F6B17; font-family:Poppins,sans-serif; font-weight:600; font-size:13px; margin:0 0 8px; }
.ijn-team-bio{ color:#5C6B7E; font-size:14px; line-height:1.55; margin:0; }
@media (max-width:560px){ .ijn-team-grid{ grid-template-columns:1fr; } .ijn-team-card{ flex-direction:column; align-items:flex-start; } }

/* ==========================================================================
   FAQ (reponses visibles dans le HTML pour les LLM, aligne sur la colonne)
   ========================================================================== */
.ijn-faq{ background:#ffffff; padding:80px 0 86px; }
.ijn-faq .ijn-faq-head,
.ijn-faq .ijn-faq-grid{ width:100%; max-width:var(--ijn-shell,1480px) !important; margin-inline:auto !important; padding-inline:var(--ijn-edge,40px); }
.ijn-faq-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-faq h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 12px; }
.ijn-faq .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0; max-width:820px; }
.ijn-faq-grid{ display:grid !important; grid-template-columns:repeat(2,1fr); gap:6px 48px; margin-top:38px; }
.ijn-faq-grid > .ijn-faq-item{ margin:0 !important; padding:22px 0; border-top:1px solid #E9EEF4; }
.ijn-faq-item h3{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:17px; line-height:1.3; margin:0 0 8px; }
.ijn-faq-item p{ color:#5C6B7E; font-size:14.5px; line-height:1.6; margin:0; }
@media (max-width:781px){ .ijn-faq-grid{ grid-template-columns:1fr; } }

/* ==========================================================================
   CTA final : fond degrade marine + cadre verre depoli pleine largeur
   ========================================================================== */
.ijn-cta-final{ position:relative; overflow:hidden; background:linear-gradient(130deg,#0B3C8F 0%,#0B3C8F 38%,#037CC9 100%); padding:86px 0 92px; }
.ijn-cta-final::before{ content:""; position:absolute; width:640px; height:640px; border-radius:50%; background:#2AA8EC; filter:blur(110px); opacity:.8; top:-150px; left:10%; pointer-events:none; }
.ijn-cta-final::after{ content:""; position:absolute; width:560px; height:560px; border-radius:50%; background:#81C12F; filter:blur(130px); opacity:.5; bottom:-190px; right:8%; pointer-events:none; }
.ijn-cta-final .ijn-cta-panel{
  position:relative; z-index:2;
  width:100%; max-width:calc(var(--ijn-shell,1480px) - 80px) !important; margin-inline:auto !important;
  background:rgba(255,255,255,.04);
  -webkit-backdrop-filter:blur(26px) saturate(165%);
  backdrop-filter:blur(26px) saturate(165%);
  border:1px solid rgba(255,255,255,.28);
  border-radius:26px;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.20);
  padding:64px 56px;
  text-align:center;
}
.ijn-cta-panel h2{ font-family:Poppins,sans-serif; color:#ffffff; font-size:clamp(28px,4.5vw,40px); line-height:1.12; margin:0 0 16px; }
.ijn-cta-panel .ijn-lead{ color:#DCE9F8; font-size:17px; line-height:1.6; margin:0 auto 28px; max-width:680px; }
.ijn-cta-panel .wp-block-buttons{ justify-content:center; gap:14px; }
.ijn-cta-panel .ijn-cta-green .wp-block-button__link{ background:#81C12F; color:#0B3C8F; font-family:Poppins,sans-serif; font-weight:600; border-radius:999px; padding:14px 26px; border:0; transition:transform .35s ease, box-shadow .35s ease; }
.ijn-cta-panel .ijn-cta-green .wp-block-button__link:hover{ transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(0,0,0,.5); }
.ijn-cta-panel .ijn-cta-outline .wp-block-button__link{ background:transparent; color:#ffffff; font-family:Poppins,sans-serif; font-weight:600; border-radius:999px; padding:12px 24px; border:2px solid rgba(255,255,255,.7); transition:background .35s ease, color .35s ease; }
.ijn-cta-panel .ijn-cta-outline .wp-block-button__link:hover{ background:#ffffff; color:#0B3C8F; }
@media (max-width:600px){
  .ijn-cta-final .ijn-cta-panel{ padding:44px 24px; border-radius:20px; }
  .ijn-cta-panel .wp-block-buttons{ flex-direction:column; align-items:stretch; }
}

/* ==========================================================================
   Section plate "Deux poles" (zero relief, met en valeur les cartes du hero)
   ========================================================================== */
.ijn-poles-flat{ background:#ffffff; padding:78px 0 84px; }
/* Contenu aligne sur la meme colonne pleine largeur que le hero et les cartes */
.ijn-poles-flat .ijn-poles-head,
.ijn-poles-flat .ijn-poles-cols{
  width:100%;
  max-width:var(--ijn-shell,1480px) !important;
  margin-inline:auto !important;
  padding-inline:var(--ijn-edge,40px);
}
/* En-tete aligne a gauche (et non centre par le layout du groupe) */
.ijn-poles-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-eyebrow{ font-family:Poppins,sans-serif; font-weight:600; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:#3F6B17; margin:0 0 10px; }
.ijn-poles-flat h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 14px; }
.ijn-poles-flat .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0; max-width:840px; }
.ijn-poles-cols{ margin-top:40px; gap:28px; }
/* Deux cadres plats uniformes (zero relief) */
.ijn-poles-cols > .wp-block-column{
  background:#ffffff;
  border:1px solid #E3E9F0;
  border-radius:16px;
  padding:30px 32px;
}
.ijn-poles-cols h3{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:20px; margin:0 0 8px; }
.ijn-poles-cols > .wp-block-column > p{ color:#5C6B7E; font-size:14.5px; line-height:1.55; margin:0 0 18px; }
.ijn-pole-links{ list-style:none; margin:0; padding:0; }
.ijn-pole-links li{ margin:0; border-top:1px solid #E9EEF4; }
.ijn-pole-links li:last-child{ border-bottom:1px solid #E9EEF4; }
.ijn-pole-links a{ display:flex; align-items:center; justify-content:space-between; padding:13px 2px; color:#16243A; text-decoration:none; font-family:Inter,sans-serif; font-weight:500; font-size:15px; transition:color .3s ease, padding-left .3s ease; }
.ijn-pole-links a::after{ content:"\203a"; color:#81C12F; font-weight:700; font-size:18px; }
.ijn-pole-links a:hover{ color:#0B3C8F; padding-left:8px; }
@media (max-width:781px){ .ijn-poles-cols{ gap:8px; } }

/* ==========================================================================
   Section Certifications & confiance (grille de cartes badges plates)
   ========================================================================== */
.ijn-trust{ background:#F3F7FB; padding:78px 0 84px; }
.ijn-trust .ijn-trust-head,
.ijn-trust .ijn-trust-grid,
.ijn-trust .ijn-trust-grid-2{
  width:100%;
  max-width:var(--ijn-shell,1480px) !important;
  margin-inline:auto !important;
  padding-inline:var(--ijn-edge,40px);
}
.ijn-trust-head > *{ margin-left:0 !important; margin-right:auto !important; }
.ijn-trust h2{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:clamp(26px,4vw,34px); line-height:1.15; margin:0 0 14px; }
.ijn-trust .ijn-lead{ color:#5C6B7E; font-size:16px; line-height:1.6; margin:0; max-width:860px; }
.ijn-trust-grid{
  display:grid !important;
  grid-template-columns:repeat(3,1fr);
  align-items:stretch;
  gap:20px;
  margin-top:42px;
}
.ijn-trust-card{
  background:#ffffff;
  border:1px solid #E3E9F0;
  border-radius:16px;
  padding:28px;
}
/* Pas de marge block-gap sur les cartes (sinon elles se decalent dans la grille) */
.ijn-trust-grid > .ijn-trust-card,
.ijn-trust-grid-2 > .ijn-trust-card{ margin:0 !important; }
.ijn-trust-card .wp-block-image{ margin:0 0 18px; height:50px; display:flex; align-items:center; justify-content:flex-start; }
.ijn-trust-card .wp-block-image img{ max-height:50px; width:auto; object-fit:contain; }
.ijn-trust-card h3{ font-family:Poppins,sans-serif; color:#0B3C8F; font-size:18px; line-height:1.25; margin:0 0 10px; }
.ijn-trust-card p{ color:#5C6B7E; font-size:14px; line-height:1.55; margin:0; }

/* Rangee du bas : 2 cartes uniformes plus grandes, logos plus grands */
.ijn-trust-grid-2{
  display:grid !important;
  grid-template-columns:repeat(2,1fr);
  align-items:stretch;
  gap:20px;
  margin-top:20px;
}
.ijn-trust-grid-2 .ijn-trust-card{ padding:36px; }
.ijn-trust-grid-2 .ijn-trust-card .wp-block-image{ height:78px; margin-bottom:24px; }
.ijn-trust-grid-2 .ijn-trust-card .wp-block-image img{ max-height:78px; }

@media (max-width:980px){ .ijn-trust-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:600px){ .ijn-trust-grid, .ijn-trust-grid-2{ grid-template-columns:1fr; } }
.is-style-ijn-card-glass h3{ color:#0B3C8F; font-family:Poppins,sans-serif; font-size:20px; margin:0 0 8px; }
.is-style-ijn-card-glass p{ color:#5C6B7E; font-size:14px; line-height:1.55; margin:0 0 12px; }

/* Carte verre fonce (marine) */
.wp-block-group.is-style-ijn-card-glass-dark{
  background:#0B3C8F;
  border:1px solid #0B3C8F;
}
.is-style-ijn-card-glass-dark h3{ color:#ffffff; font-family:Poppins,sans-serif; font-size:20px; margin:0 0 8px; }
.is-style-ijn-card-glass-dark p{ color:#CDD8EA; font-size:14px; line-height:1.55; margin:0 0 12px; }

/* Lien d'action de la carte */
.ijn-card-link a{ font-family:Poppins,sans-serif; font-weight:600; font-size:14px; color:#3F6B17; text-decoration:none; }
.is-style-ijn-card-glass-dark .ijn-card-link a{ color:#A9E06A; }
.ijn-card-link a::after{ content:" \203a"; }

/* === Hero trust strip : logos clients (blanc) === */
.ijn-trust-strip{display:flex;flex-direction:row;align-items:center;gap:24px;max-width:calc(var(--ijn-shell,1480px) - 2*var(--ijn-edge,40px));margin:18px auto 0;padding:9px 24px;background:rgba(255,255,255,.12);-webkit-backdrop-filter:blur(16px) saturate(160%);backdrop-filter:blur(16px) saturate(160%);border:1px solid rgba(255,255,255,.4);border-radius:16px;overflow:hidden;}
.ijn-trust-strip__label{flex:0 0 auto;margin:0;font-size:.75rem;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:#0B3C8F;opacity:.85;white-space:nowrap;line-height:1;}
.ijn-logos-marquee{flex:1 1 auto;min-width:0;}
.ijn-logos-marquee .ijn-marquee-track{display:flex;align-items:center;gap:44px;}
.ijn-logo{margin:0!important;flex:0 0 auto;}
.ijn-logos-marquee .ijn-logo img{height:21px!important;width:auto!important;max-width:none!important;display:block;filter:brightness(0);opacity:.78;}
.ijn-logos-marquee .ijn-logo.is-tall img{height:31px!important;}
@media(max-width:781px){.ijn-trust-strip{flex-direction:column;align-items:flex-start;gap:6px;margin-top:12px;padding:9px 16px;}.ijn-logos-marquee{width:100%;}.ijn-logos-marquee .ijn-marquee-track{gap:30px;}.ijn-logos-marquee .ijn-logo img{height:17px!important;}.ijn-logos-marquee .ijn-logo.is-tall img{height:25px!important;}}

.ijn-trust-strip>*{margin:0!important;}
.ijn-logos-marquee .ijn-marquee-track>*{margin:0!important;}

/* ==========================================================================
   PAGE ÉQUIPE
   ========================================================================== */

/* Fond marine pour les heros des pages internes non-service */
.ijn-team-hero.ijn-hero-flat,
.ijn-contact-hero.ijn-hero-flat {
    background: #0B3C8F !important;
    background-image: radial-gradient(760px 620px at 90% 70px, rgba(42,168,23,.08) 0%, transparent 65%), radial-gradient(500px 460px at 5% 80%, rgba(20,80,200,.22) 0%, transparent 70%) !important;
}

.ijn-team-hero.ijn-hero-flat .ijn-hero-card {
    max-width: var(--ijn-shell, 1480px) !important;
    margin-inline: auto !important;
    padding-inline: var(--ijn-edge, 40px);
}

.ijn-team-section {
    padding-block: 80px;
    background: #fff;
}
.ijn-team-section > * {
    max-width: var(--ijn-shell, 1480px) !important;
    margin-inline: auto !important;
    padding-inline: var(--ijn-edge, 40px);
}
.ijn-team-cols {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: start;
}
.ijn-team-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    background: #f8faff;
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(11,60,143,.1);
    padding: 0 0 32px 0;
}
.ijn-team-photo figure,
.ijn-team-photo {
    margin: 0 !important;
}
.ijn-team-photo img {
    width: 100% !important;
    height: 320px !important;
    object-fit: cover !important;
    object-position: top center !important;
    display: block;
    margin: 0 !important;
}
.ijn-team-name {
    font-size: 1.5rem !important;
    font-weight: 700 !important;
    color: #0B3C8F !important;
    margin: 24px 32px 0 !important;
}
.ijn-team-role {
    font-size: .9rem !important;
    font-weight: 600 !important;
    color: #1B8C5A !important;
    text-transform: uppercase;
    letter-spacing: .05em;
    margin: 0 32px !important;
}
.ijn-team-bio {
    font-size: 1rem !important;
    color: #374151 !important;
    line-height: 1.7 !important;
    margin: 8px 32px 0 !important;
}

/* Certifs */
.ijn-certifs-section {
    padding-block: 80px;
    background: #0B3C8F;
}
.ijn-certifs-section > * {
    max-width: var(--ijn-shell, 1480px) !important;
    margin-inline: auto !important;
    padding-inline: var(--ijn-edge, 40px);
}
.ijn-certifs-head {
    margin-bottom: 48px;
}
.ijn-certifs-head .ijn-eyebrow { color: #7DB3FF !important; }
.ijn-certifs-head h2 { color: #fff !important; margin: 0 !important; }
.ijn-certifs-head .ijn-answer { color: rgba(255,255,255,.8) !important; }
.ijn-certifs-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.ijn-certif-card {
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.2);
    border-radius: 12px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    text-align: center;
}
.ijn-certif-logo img {
    height: 72px !important;
    width: auto !important;
    object-fit: contain !important;
    margin: 0 auto !important;
}
.ijn-certif-label {
    font-size: .95rem !important;
    font-weight: 600 !important;
    color: #fff !important;
    margin: 0 !important;
}

@media (max-width: 768px) {
    .ijn-team-cols { grid-template-columns: 1fr; }
    .ijn-certifs-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   PAGE CONTACT
   ========================================================================== */

.ijn-contact-section {
    padding-block: 88px;
    background: #ffffff;
}
.ijn-contact-section > * {
    max-width: var(--ijn-shell, 1480px) !important;
    margin-inline: auto !important;
    padding-inline: var(--ijn-edge, 40px);
}
.ijn-contact-cols {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: start;
    margin-top: 0 !important;
}
.ijn-contact-phones {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-bottom: 18px;
}

/* --- Section blanche : cartes premium, rupture avec la marine du hero --- */
.ijn-phone-card,
.ijn-contact-nap {
    background: #ffffff;
    border: 1px solid rgba(11,60,143,.10);
    border-radius: 18px;
    box-shadow: 0 20px 50px -32px rgba(11,60,143,.28);
}
.ijn-phone-card {
    padding: 26px 30px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.ijn-phone-card.is-standard {
    border-color: rgba(11,60,143,.18);
}
.ijn-phone-card.is-urgence {
    background: #0B3C8F;
    border-color: #0B3C8F;
    box-shadow: 0 22px 50px -28px rgba(11,60,143,.5);
}
.ijn-phone-label {
    font-size: .78rem !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: .08em;
    margin: 0 !important;
}
.ijn-phone-card.is-standard .ijn-phone-label { color: #3F6BBF !important; }
.ijn-phone-card.is-urgence .ijn-phone-label { color: rgba(255,255,255,.72) !important; }
.ijn-phone-number {
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    letter-spacing: .02em;
    margin: 0 !important;
    text-decoration: none !important;
    display: block;
}
.ijn-phone-card.is-standard .ijn-phone-number { color: #0B3C8F !important; }
.ijn-phone-card.is-urgence .ijn-phone-number { color: #A9E06A !important; }
.ijn-phone-hours {
    font-size: .9rem !important;
    margin: 0 !important;
}
.ijn-phone-card.is-standard .ijn-phone-hours { color: #5C6B7E !important; }
.ijn-phone-card.is-urgence .ijn-phone-hours { color: rgba(255,255,255,.8) !important; }

.ijn-contact-nap {
    padding: 24px 30px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.ijn-contact-nap p {
    font-size: .95rem !important;
    color: #374151 !important;
    margin: 0 !important;
    line-height: 1.6;
}
.ijn-contact-nap strong { color: #0B3C8F !important; }
.ijn-contact-nap a { color: #0B3C8F !important; }

/* --- Panneau formulaire (blanc casse premium) --- */
.ijn-contact-col-right > .wp-block-group {
    background: #f8faff;
    border: 1px solid rgba(11,60,143,.10);
    border-radius: 22px;
    padding: 40px;
    box-shadow: 0 20px 50px -32px rgba(11,60,143,.28);
}
.ijn-contact-col-right > .wp-block-group h2 {
    font-size: 1.5rem !important;
    color: #0B3C8F !important;
    margin-bottom: 26px !important;
}

/* --- SureForms sur blanc : libelles encre, champs bordes --- */
.ijn-contact-section .srfm-form-container,
.ijn-contact-section .srfm-form {
    padding: 0 !important;
    background: transparent !important;
}
.ijn-contact-section .srfm-block-label,
.ijn-contact-section .srfm-block-label * {
    color: #16243A !important;
}
.ijn-contact-section .srfm-input-common,
.ijn-contact-section .ts-control,
.ijn-contact-section .iti input.srfm-input-common,
.ijn-contact-section input.srfm-input-common,
.ijn-contact-section textarea.srfm-input-common {
    background: #ffffff !important;
    color: #16243A !important;
    border: 1px solid rgba(11,60,143,.18) !important;
    border-radius: 12px !important;
    box-shadow: none !important;
}
.ijn-contact-section .srfm-input-common::placeholder,
.ijn-contact-section .ts-control input::placeholder { color: #8A98AC !important; }
.ijn-contact-section .srfm-input-common:focus,
.ijn-contact-section .ts-control.focus,
.ijn-contact-section .ts-wrapper.focus .ts-control {
    border-color: #81C12F !important;
    box-shadow: 0 0 0 3px rgba(129,193,47,.22) !important;
}

/* --- Bouton submit : pastille verte facon hero --- */
.ijn-contact-section .srfm-submit-button,
.ijn-contact-section .srfm-button.srfm-submit-button {
    background: #81C12F !important;
    color: #0B3C8F !important;
    font-family: Poppins, sans-serif !important;
    font-weight: 600 !important;
    border: 0 !important;
    border-radius: 999px !important;
    padding: 15px 34px !important;
    box-shadow: 0 16px 34px -16px rgba(129,193,47,.6) !important;
    transition: transform .35s ease, box-shadow .35s ease !important;
}
.ijn-contact-section .srfm-submit-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 20px 40px -16px rgba(129,193,47,.7) !important;
}

@media (max-width: 768px) {
    .ijn-contact-cols { grid-template-columns: 1fr; }
    .ijn-phone-number { font-size: 1.5rem !important; }
    .ijn-contact-col-right > .wp-block-group { padding: 28px; }
}
