/* =========================================
   Planiso – Theme Tokens (Bootstrap aware)
   ========================================= */

:root {
  /* Layout */
  --logo-height: 40px;
  --toggler-bar-gap: 5px;

  /* ISO marquee fade */
  --planisoIsoFadeWidth: 0px;

  /* Brand – Primary */
  --planiso-primary: #f47c20;
  --planiso-primary-hover: #e86f12;
  --planiso-primary-rgb: 244, 124, 32;

  /* Surfaces (light default) */
  --planiso-surface: #ffffff;
  --planiso-surface-2: #f7f8fa;
  --planiso-border: rgba(0, 0, 0, 0.08);

  /* Text (light default) */
  --planiso-text: #1f2a37;
  --planiso-muted: #6b7280;

  /* Divider tuning */
  --planiso-divider-height: 140px;
  --planiso-divider-attach: -34px;

  --planisoClientFadeWidth: 80px;
  --planisoClientSpeedSeconds: 28;

  --planisoClientCardBg: #ffffff;
  --planisoClientCardBorder: rgba(0, 0, 0, .08);
  --planisoClientCardShadow: 0 12px 30px rgba(0, 0, 0, .08);

  --planisoClientFadeRgb: 255, 255, 255;

  --planisoCurveHeight: var(--planiso-divider-height);
  --planisoCurveContentPadRatio: 0.85;
  /* how much space to reserve for content */
  --planisoCurveMask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 140' preserveAspectRatio='none'%3E%3Cpath fill='black' d='M0,70 C240,140 520,10 760,70 C1000,130 1200,30 1440,85 L1440,140 L0,140 Z'/%3E%3C/svg%3E");
}

/* =========================================
   Bootstrap theme overrides
   ========================================= */

html[data-bs-theme="dark"] {
  --bs-body-color: #cccccc;
  --bs-body-color-rgb: 204, 204, 204;
  --bs-body-bg: #141414;
  --bs-body-bg-rgb: 20, 20, 20;

  --bs-secondary-color: #cccccc;
  --bs-secondary-color-rgb: 204, 204, 204;
  --bs-secondary-bg: #333333;
  --bs-secondary-bg-rgb: 32, 32, 32;

  --bs-tertiary-color: #cccccc;
  --bs-tertiary-color-rgb: 204, 204, 204;
  --bs-tertiary-bg: #060606;
  --bs-tertiary-bg-rgb: 6, 6, 6;

  --bs-dark: #111111;
  --bs-dark-rgb: 17, 17, 17;
  --bs-dark-bg-subtle: #020202;
  --bs-dark-border-subtle: #000000;

  --bs-primary-accent: #4da6ff;
  --bs-secondary-accent: #3399ff;

  --bs-emphasis-color: #cccccc;
  --bs-emphasis-color-rgb: 204, 204, 204;

  /* BLEU*/
  /* --bs-border-color: #1a3f66; */
  --bs-border-color: rgba(var(--planiso-primary-rgb), 0.3); 

  --planiso-surface: #050814;
  /* ton “dark surface” */
  --planiso-surface-2: #070a12;
  /* ton “dark surface alt” */
  --planiso-border: rgba(255, 255, 255, 0.10);

  --planiso-text: rgba(255, 255, 255, 0.92);
  --planiso-muted: rgba(255, 255, 255, 0.68);






  a:not([type="button"]):not(.dropdown-item):not(.nav-link){
    color: rgba(var(--planiso-primary-rgb), var(--bs-link-opacity, 1));
  }

  .accordion {
    .accordion-button:not(.collapsed) 
    {
      color: white;
      background: rgba(var(--planiso-primary-rgb), 0.5);
    }

    .accordion-button:focus {
      box-shadow: 0 0 0 .25rem rgba(var(--planiso-primary-rgb), 0.7);
    }
  }

  .card {
    figcaption {
      --bs-border-color: rgba(var(--planiso-primary-rgb), 0.5)
    }
     
  }

  .form-control:focus,
  .form-select:focus
    {
        border-color: var(--planiso-primary);
        box-shadow: 0 0 0 .25rem var(--bs-border-color);
    }

  .rounded-circle {
    --bs-border-color: rgba(var(--planiso-primary-rgb), 0.3);
    background: rgba(var(--planiso-primary-rgb), 0.12);
  }

  .form-check-input:checked {
      background-color: var(--planiso-primary);
      border-color: var(--planiso-primary-hover);
  }

  .form-check-input:focus {
    border-color: var(--bs-border-color);
    outline: 0;
    box-shadow: 0 0 0 .25rem rgba(var(--planiso-primary-hover), .25);
  }

  .dropdown-menu {
    --bs-dropdown-link-active-bg: var(--planiso-primary);
    &:hover {
      --bs-dropdown-link-hover-bg: rgb(var(--planiso-primary-rgb),0.3);
    }
  }
}


[data-bs-theme="dark"] {
  --planisoClientCardBg: rgba(255, 255, 255, .035);
  --planisoClientCardBorder: rgba(255, 255, 255, .10);
  --planisoClientCardShadow: 0 26px 70px rgba(0, 0, 0, .70);

  --planisoClientFadeRgb: 20, 20, 20;
  /* proche de ton body bg */
}

/* =========================================
   Utilities
   ========================================= */

.pointer {
  cursor: pointer;
}

.logo {
  height: var(--logo-height);
}

/* Fixes */
label {
  user-select: none;
}

.navbar-toggler:focus,
.navbar-toggler:active,
.navbar-toggler:focus-visible {
  outline: none;
  box-shadow: none;
}

/* Custom Padding */
.py-6 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.py-7 {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.py-8 {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.py-9 {
  padding-top: 7rem;
  padding-bottom: 7rem;
}

.py-10 {
  padding-top: 8rem;
  padding-bottom: 8rem;
}

/* Text helpers */
.text-facebook {
  color: #4267b2!important;
}

.text-linkedin {
  color: #0e76a8!important;
}

/* =========================================
   Typography
   ========================================= */


.planiso-text {
  color: var(--planiso-primary);
  text-shadow: var(--planiso-text) 1px 1px 1px;
}

.section-title {
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-bottom: 0.75rem !important;
}

.section-title::after {
  content: "";
  display: block;
  width: 56px;
  height: 3px;
  margin: 14px auto 0;
  border-radius: 2px;
  background: linear-gradient(90deg,
      rgba(var(--planiso-primary-rgb), 0.85),
      rgba(var(--planiso-primary-rgb), 0.25));
}

/* Dark mode title underline */
[data-bs-theme="dark"] .planiso-sectionTitle::after {
  background: linear-gradient(90deg,
      rgba(var(--planiso-primary-rgb), 0.80),
      rgba(var(--planiso-primary-rgb), 0.18));
}

.section-title+p.lead,
.section-title+.text-body-secondary {
  margin-top: 0.35rem !important;
}

/* =========================================
   Border radius normalization
   ========================================= */

.card,
.list-group,
.accordion-item,
.accordion-button,
.dropdown-menu,
.dropdown-item,
.progress,
.btn:not(.btn-group .btn):not(.input-group .btn),
.navbar .nav-item a {
  border-radius: var(--bs-border-radius-xl) !important;
}

/* =========================================
   Dropdown (DO NOT CHANGE)
   ========================================= */

.dropdown {
  .dropdown-menu {
    --bs-dropdown-bg: var(--bs-body-bg);
    --bs-dropdown-border-color: var(--bs-secondary-bg);
    --bs-dropdown-divider-bg: var(--bs-secondary-bg);
    padding: 6px !important;
    border: 0;
  }

  .dropdown-item {
    --bs-dropdown-bg: var(--bs-body-bg);
    --bs-dropdown-border-color: var(--bs-secondary-bg);
    --bs-dropdown-divider-bg: var(--bs-secondary-bg);
    margin-bottom: 3px;
  }
}

/* =========================================
   Navbar (DO NOT CHANGE)
   ========================================= */

.navbar {

  /*.nav-item a:hover,
  .nav-item a.active,
  .dropdown-item:hover {
      background-color: var(--bs-primary);
      color: var(--bs-white);
  }*/

  .navbar-nav .nav-link {
    position: relative;
    display: inline-block;
    color: var(--bs-body-color);
    transition: color 0.3s ease;
  }

  .navbar-nav .nav-link::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: -2px;
    width: 0;
    height: 3px;
    background-color: currentColor;
    border-radius: 2px;
    transform: translateX(-50%);
    transition: width 0.3s ease;
  }

  .navbar-nav .nav-link:hover::after,
  .navbar-nav .nav-link.active::after {
    width: 80%;
  }

  .dropdown-menu {
    top: 52px;
    min-width: 180px;
  }

  .nav-item a {
    padding: 4px 15px !important;
    margin-right: 6px;
  }

  .navbar-toggler {
    border: none;
    background: transparent;
    padding: 0.25rem;
    position: relative;
    width: 28px;
    height: 24px;
    cursor: pointer;
  }

  .toggler-bar {
    display: block;
    position: absolute;
    width: 100%;
    height: 3px;
    background-color: var(--bs-emphasis-color);
    border-radius: 2px;
    left: 0;
    top: 50%;
    transition: all 0.3s ease;
    border-radius: 2px;
  }

  .toggler-bar:nth-child(1) {
    transform: translateY(calc(-1 * var(--toggler-bar-gap)));
  }

  .toggler-bar:nth-child(2) {
    transform: translateY(var(--toggler-bar-gap));
  }

  .navbar-toggler.open .toggler-bar:nth-child(1) {
    transform: rotate(45deg);
    top: 50%;
  }

  .navbar-toggler.open .toggler-bar:nth-child(2) {
    transform: rotate(-45deg);
    top: 50%;
  }

  .themeSwitcherIcon {
    display: inline-block;
    transition: transform 0.4s ease;
  }

  .themeSwitcherIcon:hover {
    transform: rotateY(180deg);
  }

  @media (max-width: 992px) {
    .navbar-collapse ul {
      height: calc(100vh - 82px);
      transition: transform 0.3s ease;
    }

    .navbar-nav .nav-item {
      margin: 3px 0px;
    }

    .navbar-right {
      flex-direction: row !important;
      flex-wrap: nowrap;
      overflow-x: auto;
      margin-left: 10px !important;
    }

    .navbar-right .nav-item {
      margin: 0 0px;
    }

    .themeSwitcherIcon {
      margin-top: 12px;
    }
  }

  @media (min-width: 992px) {
    .dropdown:hover .dropdown-menu {
      display: block;
      margin-top: 0;
    }
  }
}

/* =========================================
   Bootstrap primary -> Planiso orange
   ========================================= */

.btn-primary {
  --bs-btn-bg: var(--planiso-primary);
  --bs-btn-border-color: var(--planiso-primary);
  --bs-btn-hover-bg: var(--planiso-primary-hover);
  --bs-btn-hover-border-color: var(--planiso-primary-hover);
  --bs-btn-active-bg: var(--planiso-primary-hover);
  --bs-btn-active-border-color: var(--planiso-primary-hover);
  --bs-btn-focus-shadow-rgb: var(--planiso-primary-rgb);
}




/* =========================================
   Clients grid
   ========================================= */
.planiso-clientMarquee {
  position: relative;
  border-radius: var(--bs-border-radius-xl);
  overflow: hidden;
  padding: 14px 0;
}

.planiso-clientViewport {
  overflow: hidden;
  padding-left: var(--planisoClientFadeWidth);
  padding-right: var(--planisoClientFadeWidth);
}

.planiso-clientTrack {
  display: flex;
  align-items: center;
  gap: 18px;
  width: max-content;
  will-change: transform;
  animation: planisoClientScroll calc(var(--planisoClientSpeedSeconds) * 1s) linear infinite;
}

.planiso-clientMarquee:hover .planiso-clientTrack {
  animation-play-state: paused;
}

@keyframes planisoClientScroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.planiso-clientFade {
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--planisoClientFadeWidth);
  z-index: 2;
  pointer-events: none;
}

.planiso-clientFadeLeft {
  left: 0;
  background: linear-gradient(90deg,
      rgba(var(--planisoClientFadeRgb), .96) 0%,
      rgba(var(--planisoClientFadeRgb), 0) 100%);
}

.planiso-clientFadeRight {
  right: 0;
  background: linear-gradient(270deg,
      rgba(var(--planisoClientFadeRgb), .96) 0%,
      rgba(var(--planisoClientFadeRgb), 0) 100%);
}

.planiso-clientItem {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 150px;
  height: 82px;

  border-radius: var(--bs-border-radius-xl);
  background: var(--planisoClientCardBg);
  border: 1px solid var(--planisoClientCardBorder);
  box-shadow: var(--planisoClientCardShadow);

  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.planiso-clientItem:hover {
  transform: translateY(-2px);
  border-color: rgba(var(--planiso-primary-rgb), .28);
  box-shadow:
    0 18px 44px rgba(0, 0, 0, .14),
    0 6px 14px rgba(var(--planiso-primary-rgb), .16);
}

.planiso-clientLogo {
  max-width: 78%;
  max-height: 60%;
  width: auto;
  height: auto;
  object-fit: contain;
  filter: none;
}

/* Optional: if some logos are too dark in dark mode */
[data-bs-theme="dark"] .planiso-clientLogo.planiso-logoInvert {
  filter: invert(1) grayscale(1);
  opacity: .92;
}

@media (max-width: 576px) {
  :root {
    --planisoClientFadeWidth: 0px;
  }

  .planiso-clientItem {
    background-color: #ffffff;
    width: 132px;
    height: 74px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .planiso-clientTrack {
    animation: none;
  }
}

/* =========================================
   Cookie banner – bottom bar
   ========================================= */

#onetrust-banner-sdk {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0 !important;
  z-index: 2000;
  display: none;
  background: #1f1f1f;
  color: #fff;
  padding: 12px 16px;
  box-shadow: 0 -10px 25px rgba(0, 0, 0, 0.25);
}

#onetrust-banner-sdk .ot-sdk-container {
  max-width: 1200px;
  margin: 0 auto;
}

#onetrust-banner-sdk .ot-sdk-row {
  display: flex;
  align-items: center;
  gap: 16px;
}

#onetrust-group-container {
  flex: 1 1 auto;
  min-width: 260px;
}

#onetrust-policy-text {
  font-size: 14px;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.85);
}

#onetrust-policy-text a {
  color: #f7a84a;
  text-decoration: underline;
}

#onetrust-button-group-parent {
  flex: 0 0 auto;
}

#onetrust-close-btn-container {
  display: none;
}

#onetrust-button-group {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center;
  gap: 12px;
}

#onetrust-button-group .btn {
  min-width: 180px;
  height: 38px;
  padding: 0 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  font-size: 14px;
  white-space: nowrap;
}

@media (max-width: 768px) {
  #onetrust-banner-sdk .ot-sdk-row {
    flex-direction: column;
    align-items: stretch;
  }

  #onetrust-button-group {
    justify-content: center !important;
  }
}

/* =========================================
   Sections – Auth/home backgrounds
   ========================================= */

.planiso-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(900px circle at 20% 10%, rgba(var(--planiso-primary-rgb), 0.14), transparent 60%),
    linear-gradient(180deg, var(--planiso-surface-2), var(--planiso-surface));
}

[data-bs-theme="dark"] .planiso-section {
  background:
    /* accents Planiso */
    radial-gradient(1000px circle at 20% 15%,
      rgba(var(--planiso-primary-rgb), 0.18),
      rgba(var(--planiso-primary-rgb), 0.06) 35%,
      transparent 65%),
    radial-gradient(900px circle at 80% 30%,
      rgba(90, 120, 255, 0.06),
      transparent 55%),

    /* SURFACE BOOTSTRAP → transition douce avec la navbar */
    linear-gradient(180deg,
      var(--bs-tertiary-bg) 0%,
      var(--bs-body-bg) 100%);
}


[data-bs-theme="dark"] .planiso-section .text-body-secondary {
  color: rgba(255, 255, 255, 0.68) !important;
}

[data-bs-theme="dark"] .planiso-section .text-body {
  color: rgba(255, 255, 255, 0.92) !important;
}

[data-bs-theme="dark"] .planiso-section hr {
  opacity: 0.20;
}

[data-bs-theme="dark"] .planiso-section .form-control {
  background-color: rgba(255, 255, 255, 0.03);
  border-color: rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.92);
}

[data-bs-theme="dark"] .planiso-section .form-control::placeholder {
  color: rgba(255, 255, 255, 0.45);
}

[data-bs-theme="dark"] .planiso-section .input-group-text {
  background-color: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.70);
}

html[data-bs-theme="dark"] .planiso-section .form-control:focus {
  border-color: rgba(var(--planiso-primary-rgb), 0.60);
  box-shadow: 0 0 0 0.25rem rgba(var(--planiso-primary-rgb), 0.18);
}

[data-bs-theme="dark"] .planiso-section .btn-outline-secondary {
  border-color: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.86);
  background: rgba(255, 255, 255, 0.02);
}

[data-bs-theme="dark"] .planiso-section .btn-outline-secondary:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.22);
}

.planiso-section .btn-primary {
  --bs-btn-bg: rgb(var(--planiso-primary-rgb));
  --bs-btn-border-color: rgb(var(--planiso-primary-rgb));
  --bs-btn-hover-bg: rgba(var(--planiso-primary-rgb), 0.92);
  --bs-btn-hover-border-color: rgba(var(--planiso-primary-rgb), 0.92);
  --bs-btn-focus-shadow-rgb: var(--planiso-primary-rgb);
}

[data-bs-theme="dark"] .planiso-section .badge {
  background: rgba(var(--planiso-primary-rgb), 0.12) !important;
  border-color: rgba(var(--planiso-primary-rgb), 0.22) !important;
  color: rgba(255, 255, 255, 0.88) !important;
}

[data-bs-theme="dark"] .planiso-section .alert-success {
  background: rgba(25, 135, 84, 0.18);
  border-color: rgba(25, 135, 84, 0.25);
  color: rgba(255, 255, 255, 0.86);
}

/* Inverse section */
.planiso-section-inverse {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(900px circle at 80% 90%, rgba(var(--planiso-primary-rgb), 0.16), transparent 60%),
    linear-gradient(180deg, var(--planiso-surface), var(--planiso-surface-2));
}

[data-bs-theme="dark"] .planiso-section-inverse {
  background:
    radial-gradient(1000px circle at 80% 85%,
      rgba(var(--planiso-primary-rgb), 0.18),
      rgba(var(--planiso-primary-rgb), 0.08) 35%,
      transparent 65%),
    radial-gradient(900px circle at 20% 20%,
      rgba(90, 120, 255, 0.07),
      transparent 55%),
    linear-gradient(180deg,
      var(--bs-body-bg) 0%,
      var(--bs-tertiary-bg) 100%);
}

/* Fullscreen section (safe) */
.planiso-fullscreen {
  min-height: 100svh !important;
  display: flex;
  align-items: center;
  padding-top: clamp(4rem, 8vh, 7rem);
  padding-bottom: clamp(4rem, 8vh, 7rem);
}

.planiso-fullscreen>.container,
.planiso-fullscreen>.container-fluid {
  width: 100%;
}

/* Default curve fill (must be overridden by utility class) */
.planiso-section,
.planiso-section-inverse {
  --planisoCurveFill: transparent;
}

/* When a section has a bottom curve, fill = START color of NEXT section */
.planisoCurveDown:has(+ .planiso-section) {
  --planisoCurveFill: var(--planiso-surface-2);
}

.planisoCurveDown:has(+ .planiso-section-inverse) {
  --planisoCurveFill: var(--planiso-surface);
}

/* When a section has a top curve, fill = END color of PREVIOUS section
   (We infer it by looking at what this section IS, because it transitions from previous.) */
.planiso-section.planisoCurveUp {
  --planisoCurveFill: var(--planiso-surface-2);
}

.planiso-section-inverse.planisoCurveUp {
  --planisoCurveFill: var(--planiso-surface);
}

/* Pseudo-elements base */
.planiso-section::before,
.planiso-section::after,
.planiso-section-inverse::before,
.planiso-section-inverse::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: var(--planisoCurveHeight);
  pointer-events: none;
  z-index: 2;
  opacity: 0;

  background: var(--planisoCurveFill);

  -webkit-mask-image: var(--planisoCurveMask);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-image: var(--planisoCurveMask);
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}

/* -----------------------------------------
   Curve direction (transition only)
   ----------------------------------------- */

/* Curve at bottom (goes down) */
.planisoCurveDown::after {
  bottom: -1px;
  opacity: 1;
}

/* Curve at top (goes up) */
.planisoCurveUp::before {
  top: -1px;
  transform: rotate(180deg);
  transform-origin: center;
  opacity: 1;
}

/* -----------------------------------------
   Content safe padding (no content loss)
   ----------------------------------------- */

.planisoCurveDown {
  padding-bottom: calc(var(--planisoCurveHeight) * var(--planisoCurveContentPadRatio));
}

.planisoCurveUp {
  padding-top: calc(var(--planisoCurveHeight) * var(--planisoCurveContentPadRatio));
}

/* -----------------------------------------
   Utility fills
   IMPORTANT: fill must match the NEXT section start color
   ----------------------------------------- */

/* Next section is .planiso-section => its TOP start color
   Light: var(--planiso-surface-2)
   Dark: #070a12 (matches your planiso-section dark gradient 0%)
*/
.planisoCurveToSectionStart {
  --planisoCurveFill: var(--planiso-surface-2);
}

html[data-bs-theme="dark"] .planisoCurveToSectionStart {
  --planisoCurveFill: var(--bs-tertiary-bg);
}

/* Next section is .planiso-section-inverse => its TOP start color
   Light: var(--planiso-surface)
   Dark: #050814 (matches your planiso-section-inverse dark gradient 0%)
*/
.planisoCurveToInverseStart {
  --planisoCurveFill: var(--planiso-surface);
}

html[data-bs-theme="dark"] .planisoCurveToInverseStart {
  --planisoCurveFill: var(--bs-body-bg);
}

/* Responsive tuning */
@media (max-width: 768px) {
  :root {
    --planisoCurveHeight: 110px;
    --planisoCurveContentPadRatio: 0.62;
  }
}


/* =========================================
   Cards / Pills / Icons
   ========================================= */

.planiso-card {
  background: var(--planiso-surface);
  border: 1px solid var(--planiso-border);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
  border-radius: 16px;
  margin-bottom: 15px;
}

html[data-bs-theme="light"] .planiso-card {
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.07);
}

[data-bs-theme="dark"] .planiso-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.015));
  border: 1px solid rgba(255, 255, 255, 0.09);
  box-shadow:
    0 26px 70px rgba(0, 0, 0, 0.78),
    0 2px 0 rgba(255, 255, 255, 0.02) inset;
  backdrop-filter: blur(6px);
}

.planiso-pill {
  background: rgba(var(--planiso-primary-rgb), 0.10) !important;
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.22) !important;
}

html[data-bs-theme="light"] .planiso-pill {
  background: rgba(var(--planiso-primary-rgb), .14) !important;
  border-color: rgba(var(--planiso-primary-rgb), .28) !important;
  color: var(--bs-body-color) !important;
}

html[data-bs-theme="light"] .planiso-pill i {
  color: var(--bs-body-color);
}

/* Planiso pill badge — dark fix (keeps light mode intact) */
[data-bs-theme="dark"] .planiso-pill {
  background: rgba(var(--planiso-primary-rgb), 0.16) !important;
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.26) !important;
  color: rgba(255, 255, 255, 0.90) !important;
}

[data-bs-theme="dark"] .planiso-pill i {
  color: rgba(255, 255, 255, 0.92);
}

.planiso-featureIcon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  background: rgba(var(--planiso-primary-rgb), 0.12);
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.22);
}

/* =========================================
   Auth helpers
   ========================================= */

.authTitle {
  color: var(--planiso-text);
}

.authMuted {
  color: var(--planiso-muted);
}

.authPill {
  background: rgba(var(--planiso-primary-rgb), 0.12);
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.25);
  color: var(--planiso-text);
}

[data-bs-theme="dark"] .authPill {
  background: rgba(var(--planiso-primary-rgb), 0.12);
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.25);
  color: rgba(255, 255, 255, 0.68) !important;
}

.authDot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--planiso-primary);
  box-shadow: 0 0 0 4px rgba(var(--planiso-primary-rgb), 0.18);
}

.authIconBox {
  width: 44px;
  height: 44px;
}

.authProviderIcon {
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.planiso-card .btn-outline-secondary {
  min-height: 108px;
  padding-top: 0;
  padding-bottom: 0;
  display: flex;
  align-items: center;
}

/* FIX LIGHT: provider buttons hover text should stay readable */
[data-bs-theme="light"] .planiso-section .btn-outline-secondary {
  color: var(--bs-body-color);
  border-color: rgba(0, 0, 0, 0.18);
  background: rgba(0, 0, 0, 0.01);
}

[data-bs-theme="light"] .planiso-section .btn-outline-secondary:hover,
[data-bs-theme="light"] .planiso-section .btn-outline-secondary:focus {
  color: var(--bs-body-color) !important;
  background: rgba(0, 0, 0, 0.04) !important;
  border-color: rgba(0, 0, 0, 0.28) !important;
}

[data-bs-theme="light"] .planiso-section .btn-outline-secondary:hover .text-body-secondary,
[data-bs-theme="light"] .planiso-section .btn-outline-secondary:focus .text-body-secondary {
  color: rgba(0, 0, 0, 0.60) !important;
}

[data-bs-theme="light"] .planiso-section .btn-outline-secondary:hover .fa-chevron-right,
[data-bs-theme="light"] .planiso-section .btn-outline-secondary:focus .fa-chevron-right {
  color: rgba(0, 0, 0, 0.45) !important;
}

/* =========================================
   Video divider
   ========================================= */

.planiso-dividerVideo {
  position: relative;
  width: 100%;
  aspect-ratio: 16/6;
  overflow: hidden;
  isolation: isolate;
  background: var(--bs-body-bg);
  display: block;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0;
}

.planiso-dividerVideo .planiso-dividerVideoMedia {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.planiso-dividerVideo .planiso-dividerVideoOverlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
      rgba(255, 255, 255, 0.92) 0%,
      rgba(255, 255, 255, 0.60) 40%,
      rgba(255, 255, 255, 0.15) 70%,
      rgba(255, 255, 255, 0) 100%);
  z-index: 1;
}

html[data-bs-theme="dark"] .planiso-dividerVideo .planiso-dividerVideoOverlay {
  background: linear-gradient(90deg,
      rgba(7, 10, 18, 0.82) 0%,
      rgba(7, 10, 18, 0.55) 45%,
      rgba(7, 10, 18, 0.18) 75%,
      rgba(7, 10, 18, 0) 100%);
}

@media (prefers-reduced-motion: reduce) {
  .planiso-dividerVideo .planiso-dividerVideoMedia {
    display: none;
  }

  .planiso-dividerVideo {
    background: url('../../../assets/video/planiso-divider.png') center/cover no-repeat;
  }
}

/* =========================================
   Carousel – big Planiso arrows (BS 5.3)
   ========================================= */

#testimonyCarousel {
  position: relative;
}

#testimonyCarousel .carousel-inner {
  padding-left: 56px;
  padding-right: 56px;
}

@media (max-width: 768px) {
  #testimonyCarousel .carousel-inner {
    padding-left: 46px;
    padding-right: 46px;
  }
}

#testimonyCarousel .carousel-control-prev,
#testimonyCarousel .carousel-control-next {
  width: 56px;
  opacity: 1;
}

#testimonyCarousel .carousel-control-prev-icon,
#testimonyCarousel .carousel-control-next-icon {
  background-image: none;
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--planiso-primary-rgb), 0.16);
  border: 1px solid rgba(var(--planiso-primary-rgb), 0.40);
  box-shadow:
    0 14px 30px rgba(0, 0, 0, 0.18),
    0 2px 0 rgba(255, 255, 255, 0.15) inset;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

#testimonyCarousel .carousel-control-prev-icon::after,
#testimonyCarousel .carousel-control-next-icon::after {
  content: '';
  width: 13px;
  height: 13px;
  border-right: 4px solid rgba(var(--planiso-primary-rgb), 0.98);
  border-bottom: 4px solid rgba(var(--planiso-primary-rgb), 0.98);
}

#testimonyCarousel .carousel-control-prev-icon::after {
  transform: rotate(135deg);
  margin-left: 3px;
}

#testimonyCarousel .carousel-control-next-icon::after {
  transform: rotate(-45deg);
  margin-right: 3px;
}

#testimonyCarousel .carousel-control-prev:hover .carousel-control-prev-icon,
#testimonyCarousel .carousel-control-next:hover .carousel-control-next-icon,
#testimonyCarousel .carousel-control-prev:focus-visible .carousel-control-prev-icon,
#testimonyCarousel .carousel-control-next:focus-visible .carousel-control-next-icon {
  transform: scale(1.08);
  background: rgba(var(--planiso-primary-rgb), 0.24);
  border-color: rgba(var(--planiso-primary-rgb), 0.55);
  box-shadow:
    0 18px 44px rgba(0, 0, 0, 0.22),
    0 2px 0 rgba(255, 255, 255, 0.18) inset;
}

#testimonyCarousel .carousel-control-prev:active .carousel-control-prev-icon,
#testimonyCarousel .carousel-control-next:active .carousel-control-next-icon {
  transform: scale(0.98);
}

[data-bs-theme="dark"] #testimonyCarousel .carousel-control-prev-icon,
[data-bs-theme="dark"] #testimonyCarousel .carousel-control-next-icon {
  background: rgba(var(--planiso-primary-rgb), 0.12);
  border-color: rgba(var(--planiso-primary-rgb), 0.34);
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.55),
    0 2px 0 rgba(255, 255, 255, 0.06) inset;
}

[data-bs-theme="dark"] #testimonyCarousel .carousel-control-prev:hover .carousel-control-prev-icon,
[data-bs-theme="dark"] #testimonyCarousel .carousel-control-next:hover .carousel-control-next-icon {
  background: rgba(var(--planiso-primary-rgb), 0.18);
  border-color: rgba(var(--planiso-primary-rgb), 0.50);
}

@media (max-width: 576px) {
  #testimonyCarousel .carousel-inner {
    padding-left: 40px;
    padding-right: 40px;
  }

  #testimonyCarousel .carousel-control-prev,
  #testimonyCarousel .carousel-control-next {
    width: 44px;
  }

  #testimonyCarousel .carousel-control-prev-icon,
  #testimonyCarousel .carousel-control-next-icon {
    width: 42px;
    height: 42px;
  }

  #testimonyCarousel .carousel-control-prev-icon::after,
  #testimonyCarousel .carousel-control-next-icon::after {
    width: 11px;
    height: 11px;
    border-right-width: 4px;
    border-bottom-width: 4px;
  }
}

/* Testimony typography */
.testimonyText {
  color: var(--bs-body-color);
  line-height: 1.6;
}

.testimonyAuthor {
  margin-bottom: 0;
}

.testimonyLogo {
  max-width: 140px;
  max-height: 48px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.testimonyHeader {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 1rem;
}

.testimonyBadge {
  flex-shrink: 0;
  white-space: nowrap;
}

/* =========================================
   Video cover
   ========================================= */
/* =========================================
   Video cover
   ========================================= */
.planiso-videoCover {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  min-height: 320px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.planiso-videoCoverSm {
  min-height: 360px;
}

.planiso-videoCover::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.55));
}

.planiso-videoBtn {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
}

.planiso-videoIcon {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--planiso-primary-rgb), 0.92);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.planiso-videoBtn:hover .planiso-videoIcon {
  transform: scale(1.06);
  transition: transform 0.18s ease;
}

@media (max-width: 992px) {
  .planiso-videoCover {
    min-height: 240px;
  }

  .planiso-videoCoverSm {
    min-height: 260px;
  }
}

.planiso-videoCover {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  min-height: 320px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.planiso-videoCoverSm {
  min-height: 360px;
}

.planiso-videoCover::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.25), rgba(0, 0, 0, 0.55));
}

.planiso-videoBtn {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 18px;
}

.planiso-videoIcon {
  width: 54px;
  height: 54px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(var(--planiso-primary-rgb), 0.92);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.35);
}

.planiso-videoBtn:hover .planiso-videoIcon {
  transform: scale(1.06);
  transition: transform 0.18s ease;
}

@media (max-width: 992px) {
  .planiso-videoCover {
    min-height: 240px;
  }

  .planiso-videoCoverSm {
    min-height: 260px;
  }
}

/* =========================================
   ISO marquee
   ========================================= */

.planiso-isoMarquee {
  position: relative;
  border-radius: 1.25rem;
  overflow: hidden;
  padding: 1rem 0;
}

.planiso-isoViewport {
  overflow: hidden;
  padding-left: var(--planisoIsoFadeWidth);
  padding-right: var(--planisoIsoFadeWidth);
}

.planiso-isoTrack {
  padding-bottom: 10px;
  padding-left: 0;
  margin-left: 0;
  display: flex;
  align-items: center;
  gap: 2.5rem;
  width: max-content;
  will-change: transform;
  animation: planisoIsoScroll 28s linear infinite;
}

.logo-slider-img{
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 100px;
  height: 100px; /* ← clé pour l’effet rond */
  padding: 18px;

  background: #ffffff;
  border-radius: 50px;

  box-shadow:
    0 10px 26px rgba(0,0,0,.08),
    0 2px 0 rgba(255,255,255,.6) inset;

  object-fit: contain;
  transition:
    transform .18s ease,
    box-shadow .18s ease;
}

.logo-slider-img:hover{
  transform: translateY(-2px);
  box-shadow:
    0 16px 40px rgba(0,0,0,.14),
    0 2px 0 rgba(255,255,255,.8) inset;
}

.planiso-isoFade {
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--planisoIsoFadeWidth);
  z-index: 2;
  pointer-events: none;
}

/* Light fade */
.planiso-isoFadeLeft {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.90), rgba(255, 255, 255, 0));
}

.planiso-isoFadeRight {
  background: linear-gradient(270deg, rgba(255, 255, 255, 0.90), rgba(255, 255, 255, 0));
}

/* Dark fade (fix: no white fade in dark theme) */
[data-bs-theme="dark"] .planiso-isoFadeLeft {
  background: linear-gradient(90deg, rgba(7, 10, 18, 0.92), rgba(7, 10, 18, 0));
}

[data-bs-theme="dark"] .planiso-isoFadeRight {
  background: linear-gradient(270deg, rgba(7, 10, 18, 0.92), rgba(7, 10, 18, 0));
}

.planiso-isoMarquee:hover .planiso-isoTrack {
  animation-play-state: paused;
}

@keyframes planisoIsoScroll {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (max-width: 576px) {
  .planiso-isoTrack {
    gap: 1.25rem;
  }

  .planiso-isoFade {
    width: 0px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .planiso-isoTrack {
    animation: none;
  }
}

/* =========================
   Politique qualité
   ========================= */
/* Politique qualité - section */
.planiso-sectionQualityBg {
  position: absolute;
  inset: -1px;
  /* kill seams */
  z-index: 0;

  background-color: var(--bs-body-bg);

  background-image:
    linear-gradient(180deg,
      rgba(var(--planiso-primary-rgb), 0.18) 0%,
      rgba(var(--planiso-primary-rgb), 0.10) 40%,
      rgba(var(--planiso-primary-rgb), 0.06) 100%),
    url("../../../assets/images/public/politique.png");

  /* ✅ 1er layer (gradient) = cover plein écran, 2e layer (image) = contain */
  background-size: cover, clamp(520px, 52vw, 860px) auto;

  /* ✅ gradient centré, image poussée à droite */
  background-position: center, right -40px bottom;

  background-repeat: no-repeat, no-repeat;

  transform: translateZ(0);
}

html[data-bs-theme="dark"] .planiso-sectionQualityBg {
  background-color: #ffffff;

  background-image:
    linear-gradient(180deg,
      rgba(7, 10, 18, 0.88) 25%,
      rgba(7, 10, 18, 0.92) 75%,
      rgba(7, 10, 18, 0.94) 100%),
    url("../../../assets/images/public/politique.png");

  background-size: cover, clamp(520px, 52vw, 860px) auto;
  background-position: center, right -40px bottom;
  background-repeat: no-repeat, no-repeat;
}

@media (max-width: 768px) {
  .planiso-sectionQualityBg {
    background-size: cover, 520px auto;
    background-position: center, right -120px bottom;
  }
}

.planiso-fab {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 1055;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 12px 18px 12px 14px;
  border-radius: 999px;

  font-weight: 600;
  font-size: 15px;

  border: 1px solid rgba(var(--planiso-primary-rgb), 0.35);
  background:
    linear-gradient(180deg,
      rgba(var(--planiso-primary-rgb), 0.95),
      rgba(var(--planiso-primary-rgb), 0.88));

  color: #fff;

  box-shadow:
    0 18px 44px rgba(0, 0, 0, .28),
    0 0 0 0 rgba(var(--planiso-primary-rgb), 0.35);

  transition:
    transform .18s ease,
    box-shadow .18s ease,
    background .18s ease;
}

.planiso-fabIcon {
  width: 38px;
  height: 38px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255, 255, 255, .16);
  box-shadow: 0 2px 0 rgba(255, 255, 255, .25) inset;

  font-size: 16px;
}

.planiso-fab:hover,
.planiso-fab:focus-visible {
  transform: translateY(-2px);
  box-shadow:
    0 22px 54px rgba(0, 0, 0, .32),
    0 0 0 6px rgba(var(--planiso-primary-rgb), 0.18);
}

.planiso-fab:active {
  transform: translateY(0);
}

[data-bs-theme="dark"] .planiso-fab {
  box-shadow:
    0 26px 70px rgba(0, 0, 0, .65),
    0 0 0 0 rgba(var(--planiso-primary-rgb), 0.35);
}

@keyframes planisoFabPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(var(--planiso-primary-rgb), 0.35);
  }

  70% {
    box-shadow: 0 0 0 10px rgba(var(--planiso-primary-rgb), 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(var(--planiso-primary-rgb), 0);
  }
}

.planiso-fabContact {
  animation: planisoFabPulse 3.8s ease-out infinite;
}

@keyframes planisoFabPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(var(--planiso-primary-rgb), 0.35);
  }

  70% {
    box-shadow: 0 0 0 10px rgba(var(--planiso-primary-rgb), 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(var(--planiso-primary-rgb), 0);
  }
}

.planiso-fabContact {
  animation: planisoFabPulse 3.8s ease-out infinite;
}

.planisoDepthBottom {
  position: relative;
}

.planisoDepthBottom::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 120px;
  pointer-events: none;
  z-index: 1;

  background: linear-gradient(180deg,
      rgba(0, 0, 0, 0.00) 0%,
      rgba(0, 0, 0, 0.09) 55%,
      rgba(0, 0, 0, 0.18) 100%);

  mix-blend-mode: multiply;
}