.elementor-85 .elementor-element.elementor-element-5ef3899{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-theme-builder-content-area{height:400px;}.elementor-location-header:before, .elementor-location-footer:before{content:"";display:table;clear:both;}/* Start custom CSS for html, class: .elementor-element-c30aa81 */footer.ha-footer,
.elementor-widget-html footer.ha-footer,
.elementor-element .ha-footer,
[class*="elementor"] .ha-footer {
  background: #F1F8FF !important;
  background-color: #F1F8FF  !important;
  background-image: none !important;
}

.ha-footer {
  background: #F1F8FF ;                          /* ← BLEU CLAIR */
  border-top: 1px solid rgba(19, 81, 168, 0.18); /* bordure un peu plus visible */
  font-family: 'Plus Jakarta Sans', sans-serif;
  color: #0d2b5e;
  overflow: hidden;
}

.ha-container {
  width: 100%;
  max-width: 1280px;
  margin: auto;
  padding-left: 2rem;
  padding-right: 2rem;
}

/* =========================
   TOP BAR
========================= */

.ha-footer-top {
  border-bottom: 1px solid rgba(19, 81, 168, 0.15);
  padding: 1.2rem 0;
}

.ha-top-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.ha-top-left {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
}

.ha-mini-item {
  display: flex;
  align-items: center;
  gap: .45rem;
}

.ha-mini-item span {
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #0d2b5e;                /* ← plus foncé pour le contraste */
  font-weight: 500;
}

.ha-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}

.blue { background: #1351a8; }
.cyan { background: #7ec8ff; }
.green { background: #0d2b5e; }
.purple { background: #1351a8; }

/* =========================
   URGENCE
========================= */

.ha-urgent {
  display: flex;
  align-items: center;
  gap: .6rem;
  flex-wrap: wrap;
}

.ha-pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #dc2626;
  animation: fpulse 1.5s infinite;
}

.ha-urgent-text {
  font-size: .62rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: #dc2626;
  font-weight: 600;
}

.ha-urgent a {
  font-size: .75rem;
  font-weight: 700;
  color: #0d2b5e;                /* ← plus foncé */
  text-decoration: none;
}

/* =========================
   MAIN GRID
========================= */

.ha-footer-grid {
  padding-top: 4rem;
  padding-bottom: 3rem;
  display: grid;
  grid-template-columns:
    minmax(240px, 1.2fr)
    minmax(170px, .9fr)
    minmax(220px, 1fr)
    minmax(170px, .9fr);
  gap: 4rem;
}

/* =========================
   BRAND — LOGO PLUS VISIBLE
========================= */

.ha-logo {
  height: 55px;
  width: 110px;
  margin-bottom: .8rem;
  filter: brightness(1) contrast(1);
  transition: filter 0.3s ease;
}

.ha-logo:hover {
  filter: brightness(1.1) contrast(1.05);
}

.ha-brand-title {
  font-size: .9rem;
  font-weight: 800;
  letter-spacing: .06em;
  margin-bottom: .25rem;
  color: #0d2b5e;
}

.ha-brand-sub {
  font-size: .6rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #1351a8;
  margin-bottom: 1rem;
}

.ha-line {
  width: 32px;
  height: 2px;
  background: linear-gradient(to right, #1351a8, transparent);
  margin-bottom: 1rem;
}

.ha-brand-text {
  font-size: .79rem;
  line-height: 1.9;
  color: #1a3a6e;                /* ← assombri pour le contraste sur bleu clair */
  max-width: 220px;
}

/* =========================
   HEADINGS
========================= */

.ha-heading {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #0d2b5e;                /* ← plus foncé */
  font-weight: 700;
  margin-bottom: 1.3rem;
}

.ha-heading-line {
  width: 12px;
  height: 1px;
  background: #1351a8;
}

/* =========================
   LINKS
========================= */

.ha-links {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}

.ha-links a {
  text-decoration: none;
  font-size: 0.79rem;
  color: #1a3a6e;                /* ← assombri */
  display: flex;
  align-items: center;
  gap: 0.4rem;
  transition: color 0.3s ease;
}

.ha-links a .diamond {
  color: rgba(19, 81, 168, 0.6); /* ← un peu plus visible */
  font-size: 0.45rem;
  flex-shrink: 0;
}

.ha-links a:hover {
  color: #0d2b5e;
}

.ha-links a:hover .diamond {
  color: #0d2b5e;
}

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

.ha-contact-list {
  display: flex;
  flex-direction: column;
  gap: .9rem;
  padding: 0;
  margin: 0;
  list-style: none;
}

.ha-contact-item {
  display: flex;
  align-items: flex-start;
  gap: .65rem;
  font-size: .79rem;
}

.ha-icon-box {
  width: 26px;
  height: 26px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

.blue-box {
  background: rgba(19, 81, 168, .12);
  border: 1px solid rgba(19, 81, 168, .25);
}

.cyan-box {
  background: rgba(126, 200, 255, .25);
  border: 1px solid rgba(126, 200, 255, .4);
}

.purple-box {
  background: rgba(19, 81, 168, .12);
  border: 1px solid rgba(19, 81, 168, .25);
}

.green-box {
  background: rgba(13, 43, 94, .1);
  border: 1px solid rgba(13, 43, 94, .2);
}

.ha-contact-item span {
  color: #1a3a6e;                /* ← assombri */
}

.ha-contact-item a {
  color: #0d2b5e;                /* ← plus foncé */
  text-decoration: none;
  transition: .3s;
  font-weight: 600;
}

.ha-contact-item a:hover {
  color: #1351a8;
}

/* =========================
   SOCIALS
========================= */

.ha-socials {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  gap: .55rem;
}

.ha-socials a {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: rgba(19, 81, 168, .15);
  border: 1px solid rgba(19, 81, 168, .3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .25s;
}

.ha-socials a:hover {
  border-color: rgba(19, 81, 168, .5);
  background: rgba(19, 81, 168, .25);
}

.ha-socials svg {
  width: 14px;
  height: 14px;
  stroke: currentColor;
  color: #0d2b5e;                /* ← plus foncé */
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: .25s;
}

.ha-socials a:hover svg {
  color: #1351a8;
}

/* =========================
   BUTTON
========================= */

.ha-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  width: 100%;
  background: linear-gradient(135deg, #1351a8, #1a63c8);
  color: #fff;
  text-decoration: none;
  border: none;
  border-radius: 8px;
  padding: .7rem 1.2rem;
  font-size: .74rem;
  font-weight: 700;
  cursor: pointer;
  font-family: 'Plus Jakarta Sans', sans-serif;
  transition: all .25s ease;
}

.ha-btn:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(19, 81, 168, .35);
}

.ha-btn svg {
  flex-shrink: 0;
}

/* =========================
   FOOTER BOTTOM
========================= */

.ha-footer-bottom {
  padding: 0 0 1.4rem;
}

/* =========================
   DIVIDER
========================= */

.ha-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2rem;
  margin-bottom: 1.2rem;
}

.ha-divider-line {
  flex: 1;
  height: 1px;
}

.ha-divider-line.left {
  background: linear-gradient(to right, transparent 0%, rgba(19, 81, 168, .4) 100%);
}

.ha-divider-line.right {
  background: linear-gradient(to left, transparent 0%, rgba(19, 81, 168, .4) 100%);
}

.ha-divider-diamond {
  font-size: .7rem;
  color: rgba(19, 81, 168, .7);  /* ← plus visible */
  padding: 0 10px;
  line-height: 1;
  flex-shrink: 0;
}

/* =========================
   BOTTOM TEXT
========================= */

.ha-bottom-inner {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
  padding: 0 2rem;
}

.ha-copy {
  font-size: .65rem;
  letter-spacing: .08em;
  color: #1a3a6e;                /* ← assombri */
}

.ha-slogan {
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #1351a8;                /* ← plus foncé */
}

.ha-dev-credit {
  font-size: .62rem;
  color: rgba(13,43,94,0.4);
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  letter-spacing: .04em;
}
.ha-dev-credit svg { width: 11px; height: 11px; opacity: 0.45; color: #1351a8; }
.ha-dev-credit a {
  color: rgba(19,81,168,0.55);
  text-decoration: none;
  font-weight: 700;
  letter-spacing: .06em;
  border-bottom: 1px solid rgba(19,81,168,0.2);
  padding-bottom: 1px;
  transition: color .2s, border-color .2s;
}
.ha-dev-credit a:hover {
  color: #1351a8;
  border-bottom-color: #1351a8;
}

/* =========================
   ANIMATION
========================= */

@keyframes fpulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .35; }
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 992px) {
  .ha-footer-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
  }
}

@media (max-width: 768px) {
  .ha-container {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }
  
  .ha-footer-grid {
    grid-template-columns: 1fr;
    gap: 2.5rem;
    padding-top: 3rem;
  }
  
  .ha-top-inner {
    align-items: flex-start;
  }
  
  .ha-top-left {
    gap: 1rem;
  }
  
  .ha-bottom-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: .4rem;
  }
  
  .ha-brand-text {
    max-width: 100%;
  }
  
  .ha-logo {
    height: 50px;
    width: 100px;
  }
}

@media (max-width: 640px) {
  .ha-divider {
    padding: 0 1rem;
  }
}

@media (max-width: 480px) {
  .ha-mini-item span {
    font-size: .58rem;
  }
  
  .ha-urgent {
    width: 100%;
  }
  
  .ha-btn {
    font-size: .72rem;
  }
  
  .ha-logo {
    height: 45px;
    width: 90px;
  }
}/* End custom CSS */