/* =========================================================
   IMMIX MODERN FOOTER
   Clean source of truth
   Lead-driving footer with ScrollMeta-ready structure
   File: /assets/css/footer2.css

   Footer architecture, conversion design, readability refinement,
   and page-system standardization by Ken Buis, Fervid Solutions.
========================================================= */

/* IMMIX-FOOTER2-ACTIVE */

.ixf-footer {
  --ixf-navy: #092a50;
  --ixf-navy-dark: #061b34;
  --ixf-green: #5f9938;
  --ixf-green-dark: #4f842e;
  --ixf-text: #dce8f2;
  --ixf-muted: rgba(220, 232, 242, 0.82);
  --ixf-line: rgba(255, 255, 255, 0.12);
  --ixf-white: #ffffff;

  position: relative;
  overflow: hidden;
  color: var(--ixf-text);
  background:
    radial-gradient(circle at 12% 0%, rgba(95, 153, 56, 0.18), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(255, 255, 255, 0.06), transparent 30%),
    linear-gradient(180deg, #0b2d54 0%, var(--ixf-navy-dark) 100%);
}

.ixf-scrollmeta {
  display: none !important;
}

.ixf-wrap {
  width: min(100% - clamp(28px, 4vw, 72px), 1180px);
  margin-inline: auto;
}

.ixf-footer,
.ixf-footer p,
.ixf-footer li,
.ixf-footer a,
.ixf-footer span,
.ixf-footer address,
.ixf-footer button {
  font-family: var(--ix-font-sans);
  font-size: 16px;
  line-height: 1.62;
}

.ixf-footer h2,
.ixf-footer h3 {
  font-family: var(--ix-font-sans);
  letter-spacing: -0.02em;
  text-wrap: balance;
}

/* Lead band */

.ixf-lead-band {
  padding: clamp(34px, 4vw, 54px) 0 0;
}

.ixf-lead-band__inner {
  position: relative;
  overflow: hidden;
  width: min(100% - 0px, 1180px);
  margin-inline: auto;
  padding: clamp(28px, 3vw, 38px) clamp(28px, 4vw, 54px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: clamp(24px, 4vw, 52px);
  align-items: center;
  border-radius: 24px;
  background:
    radial-gradient(circle at 92% 10%, rgba(255, 255, 255, 0.14), transparent 28%),
    linear-gradient(135deg, #5f9938 0%, #538a34 52%, #47782f 100%);
  box-shadow:
    0 22px 58px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.ixf-lead-band__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.00) 0%,
      rgba(255, 255, 255, 0.06) 58%,
      rgba(255, 255, 255, 0.12) 100%
    );
}

.ixf-lead-band__copy,
.ixf-lead-band__actions {
  position: relative;
  z-index: 1;
}

.ixf-kicker {
  margin: 0 0 10px;
  color: rgba(255, 255, 255, 0.84);
  font-size: 16px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  line-height: 1.2;
}

.ixf-lead-band h2 {
  max-width: 24ch;
  margin: 0 0 10px;
  color: #ffffff;
  font-size: clamp(28px, 2vw, 36px);
  font-weight: 800;
  line-height: 1.12;
}

.ixf-lead-band p {
  max-width: 58ch;
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}

.ixf-lead-band__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

/* Buttons */

.ixf-btn {
  min-height: 52px;
  padding: 0 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  transition:
    transform 180ms ease,
    background-color 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.ixf-btn:hover,
.ixf-btn:focus-visible {
  transform: translateY(-2px);
  outline: none;
}

.ixf-btn--primary {
  color: var(--ixf-navy) !important;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.12);
}

.ixf-btn--secondary {
  color: #ffffff !important;
  border: 1px solid rgba(255, 255, 255, 0.34);
  background: rgba(255, 255, 255, 0.08);
}

.ixf-btn--secondary:hover {
  background: rgba(255, 255, 255, 0.14);
}

/* Main footer */

.ixf-main {
  padding: clamp(44px, 5vw, 68px) 0 clamp(38px, 4vw, 56px);
}

.ixf-grid {
  display: grid;
  grid-template-columns: minmax(250px, 1.05fr) minmax(180px, 0.75fr) minmax(260px, 1fr) minmax(245px, 0.95fr);
  gap: clamp(30px, 4vw, 56px);
  align-items: start;
}

/* Brand */

.ixf-logo {
  display: inline-flex;
  align-items: center;
  max-width: 210px;
  margin-bottom: 22px;
  text-decoration: none;
}

.ixf-logo img {
  width: 100%;
  height: auto;
  display: block;
}

.ixf-brand-card h2 {
  max-width: 20ch;
  margin: 0 0 14px;
  color: #ffffff;
  font-size: clamp(24px, 1.7vw, 30px);
  font-weight: 800;
  line-height: 1.12;
}

.ixf-brand-card p {
  max-width: 40ch;
  margin: 0;
  color: var(--ixf-muted);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.66;
}

.ixf-choice-row {
  margin-top: 20px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.ixf-choice-row a {
  padding: 11px 15px;
  border-radius: 999px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--ixf-line);
  font-size: 16px;
  font-weight: 800;
  text-decoration: none;
}

.ixf-choice-row a:hover,
.ixf-choice-row a:focus-visible {
  background: rgba(95, 153, 56, 0.22);
  border-color: rgba(95, 153, 56, 0.48);
  outline: none;
}

/* Link / contact headings */

.ixf-link-card h3,
.ixf-contact-card h3,
.ixf-linkedin-card h3 {
  margin: 0 0 16px;
  color: #ffffff;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.14;
}

/* Services */

.ixf-link-card ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.ixf-link-card a,
.ixf-contact-list a,
.ixf-bottom a {
  color: var(--ixf-muted);
  text-decoration: none;
}

.ixf-link-card a {
  position: relative;
  display: inline-flex;
  padding-left: 16px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}

.ixf-link-card a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.62em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--ixf-green);
  transform: translateY(-50%);
}

.ixf-link-card a:hover,
.ixf-contact-list a:hover,
.ixf-bottom a:hover {
  color: #ffffff;
}

/* LinkedIn */

.ixf-linkedin-card {
  min-width: 0;
}

.ixf-linkedin-card__intro {
  max-width: 34ch;
  margin: 0 0 16px;
  color: rgba(220, 232, 242, 0.78);
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}

.ixf-linkedin-card .elfsight-app-59dd1e7c-1146-4ad2-8038-3b654e0cadb4 {
  overflow: hidden;
  max-width: 100%;
  min-height: 250px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* Contact */

.ixf-contact-card address {
  margin: 0 0 16px;
  color: var(--ixf-muted);
  font-style: normal;
  font-size: 16px;
  line-height: 1.65;
}

.ixf-contact-card address strong {
  color: #ffffff;
}

.ixf-contact-list {
  display: grid;
  gap: 10px;
  color: var(--ixf-muted);
  font-size: 16px;
  font-weight: 600;
  line-height: 1.58;
}

.ixf-social {
  margin-top: 22px;
  display: flex;
  gap: 10px;
}

.ixf-social a {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--ixf-line);
  text-decoration: none;
  font-size: 16px;
}

.ixf-social a:hover,
.ixf-social a:focus-visible {
  background: var(--ixf-green);
  border-color: var(--ixf-green);
  outline: none;
}

/* Proof strip */

.ixf-proof-strip {
  padding: 0 0 clamp(30px, 4vw, 48px);
}

.ixf-proof-strip__grid {
  overflow: hidden;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--ixf-line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.055);
}

.ixf-proof-strip__grid > div {
  padding: 22px 24px;
  display: grid;
  gap: 6px;
  border-right: 1px solid var(--ixf-line);
}

.ixf-proof-strip__grid > div:last-child {
  border-right: 0;
}

.ixf-proof-strip strong {
  color: #ffffff;
  font-family: var(--ix-font-sans);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.15;
}

.ixf-proof-strip span {
  color: var(--ixf-muted);
  font-size: 16px;
  line-height: 1.55;
}

/* Bottom */

.ixf-bottom {
  border-top: 1px solid var(--ixf-line);
  background: rgba(0, 0, 0, 0.18);
}

.ixf-bottom__inner {
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.ixf-bottom p {
  margin: 0;
  color: rgba(220, 232, 242, 0.74);
  font-size: 16px;
  line-height: 1.55;
}

.ixf-bottom p:last-child {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Responsive */

@media (max-width: 1120px) {
  .ixf-lead-band__inner {
    grid-template-columns: 1fr;
  }

  .ixf-lead-band__actions {
    justify-content: flex-start;
  }

  .ixf-grid {
    grid-template-columns: 1fr 1fr;
  }

  .ixf-brand-card {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .ixf-lead-band {
    padding-top: 28px;
  }

  .ixf-lead-band__inner {
    padding: 26px 22px;
    border-radius: 20px;
  }

  .ixf-lead-band h2,
  .ixf-brand-card h2 {
    max-width: 100%;
  }

  .ixf-lead-band__actions,
  .ixf-btn {
    width: 100%;
  }

  .ixf-grid,
  .ixf-proof-strip__grid {
    grid-template-columns: 1fr;
  }

  .ixf-proof-strip__grid > div {
    border-right: 0;
    border-bottom: 1px solid var(--ixf-line);
  }

  .ixf-proof-strip__grid > div:last-child {
    border-bottom: 0;
  }

  .ixf-bottom__inner {
    padding: 20px 0;
    align-items: flex-start;
    flex-direction: column;
  }
}