img:is([sizes=auto i],[sizes^="auto," i]){contain-intrinsic-size:3000px 1500px}
/*# sourceURL=wp-img-auto-sizes-contain-inline-css */

img.wp-smiley, img.emoji {
		display: inline !important;
		border: none !important;
		box-shadow: none !important;
		height: 1em !important;
		width: 1em !important;
		margin: 0 0.07em !important;
		vertical-align: -0.1em !important;
		background: none !important;
		padding: 0 !important;
	}
/* Home page typography (scoped) */
body.home {
  font-family: "Poppins", Tahoma, Geneva, sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 25px;
  color: #6e6e6e;
}
body.home h1 { font-size: 40px; line-height: 45px; font-weight: 600; color: #1e2637; }
body.home h2 { font-size: 36px; line-height: 44px; font-weight: 600; color: #1e2637; }
body.home h3 { font-size: 30px; line-height: 35px; font-weight: 600; color: #1e2637; }
body.home h4 { font-size: 25px; line-height: 30px; font-weight: 600; color: #1e2637; }
body.home h5 { font-size: 20px; line-height: 30px; font-weight: 600; color: #1e2637; }
body.home h6 { font-size: 15px; line-height: 20px; font-weight: 600; color: #1e2637; }

body.home .tm-custom-heading,
body.home .entry-title,
body.home .tm-vc_cta3-content,
body.home .tm-vc_cta3-content-header {
  font-family: "Poppins", Tahoma, Geneva, sans-serif;
}

/* Manx-spec pages typography (scoped to our new lightweight pages) */
body.manx-site {
  font-family: "Poppins", Tahoma, Geneva, sans-serif;
  color: #1c2842;
  background: #f7f9fb;
  line-height: 1.6;
}
body.manx-site main h1 { font-size: 36px; line-height: 1.2; font-weight: 700; color: #1c2842; margin: 0 0 12px; }
body.manx-site main h2 { font-size: 28px; line-height: 1.25; font-weight: 700; color: #1c2842; margin: 0 0 12px; }
body.manx-site main h3 { font-size: 22px; line-height: 1.3; font-weight: 700; color: #1c2842; margin: 0 0 8px; }
body.manx-site main p  { font-size: 16px; line-height: 1.6; margin: 0 0 12px; color: #4a5568; }
body.manx-site main .card h3 { font-size: 22px; line-height: 1.3; font-weight: 700; }
body.manx-site main .card p  { font-size: 15.5px; line-height: 1.6; color: #4a5568; }
body.manx-site main .eyebrow { font-size: 11px; letter-spacing: 0.12em; font-weight: 600; }

/* Shared layout helpers for all Manx pages */
body.manx-site main.container,
body.manx-site main .container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }
body.manx-site main.container.narrow,
body.manx-site main .container.narrow { max-width: 960px; }
body.manx-site main.site-main,
body.manx-site main.page { padding: 48px 0 64px; }
body.manx-site main.page header { margin-bottom: 24px; }
body.manx-site main.page section { padding: 32px 0; border-top: 1px solid #e6edf5; }
body.manx-site main.page section:first-of-type { border-top: 0; padding-top: 0; }
body.manx-site .hero { display:flex; flex-wrap:wrap; align-items:center; gap:32px; padding:48px 0; }
body.manx-site .hero-copy { flex:1 1 100%; max-width:720px; color:#fff; }
body.manx-site .cta-row { display:flex; flex-wrap:wrap; gap:12px; margin:16px 0 12px; }
body.manx-site .btn { display:inline-block; padding:12px 20px; border-radius:6px; font-weight:600; border:2px solid transparent; text-decoration:none; }
body.manx-site .btn-primary { background:#21b6c7; color:#fff; border-color:#21b6c7; }
body.manx-site .btn-secondary { background:#fff; color:#1c2842; border-color:#1c2842; }
body.manx-site .trust-bar { display:flex; flex-wrap:wrap; gap:12px; margin-top:18px; color:#1c2842; font-weight:600; }
body.manx-site .trust-bar span { background:#e8f6f9; border:1px solid #cdebf1; padding:8px 12px; border-radius:4px; }
body.manx-site .section { padding:48px 0; }
body.manx-site .section + .section { border-top:1px solid #e6edf5; }
body.manx-site .grid { display:grid; gap:16px; }
body.manx-site .grid.two { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
body.manx-site .grid.three { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
body.manx-site .grid.five { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
body.manx-site .grid.auto-280 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
body.manx-site .card { background:#fff; border:1px solid #e6edf5; border-radius:8px; padding:16px; box-shadow:0 6px 20px rgba(28,40,66,0.06); transition: transform 0.2s ease, box-shadow 0.2s ease; }
body.manx-site .card:hover { transform: translateY(-4px); box-shadow:0 10px 24px rgba(28,40,66,0.08); }
body.manx-site .final-cta { text-align:center; }
body.manx-site .final-cta .cta-row { justify-content:center; }
body.manx-site form { background:#fff; border:1px solid #e6edf5; border-radius:8px; padding:16px; box-shadow:0 6px 20px rgba(28,40,66,0.06); }
body.manx-site label { display:block; font-weight:600; margin:12px 0 6px; }
body.manx-site input,
body.manx-site textarea { width:100%; padding:10px 12px; border:1px solid #d4dce6; border-radius:6px; font-family:inherit; }
body.manx-site textarea { min-height:120px; }
body.manx-site .btn { transition: transform 0.15s ease, box-shadow 0.15s ease, background-color 0.2s ease, color 0.2s ease; }
body.manx-site .btn:hover { transform: translateY(-2px); box-shadow:0 6px 16px rgba(28,40,66,0.12); }
body.manx-site .trust-bar span { transition: transform 0.15s ease, box-shadow 0.15s ease; }
body.manx-site .trust-bar span:hover { transform: translateY(-2px); box-shadow:0 4px 12px rgba(28,40,66,0.1); }
/* Hero slider */
/* Hero with background image */
body.manx-site .hero {
  position: relative;
  margin: 0 auto 32px;
  padding: 72px 0;
  border-radius: 16px;
  overflow: hidden;
  background: #0f1626;
  color: #0d1b2a;
  box-shadow: 0 12px 36px rgba(28,40,66,0.12);
}
body.manx-site .hero::before {
  content:"";
  position:absolute;
  inset:0;
  background: url("/homepage_files/uploads/2022/10/new3-manx.svg") center/cover no-repeat;
  transform: scale(1.02);
  z-index:0;
}
body.manx-site .hero::after {
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(12,24,46,0.68) 0%, rgba(12,24,46,0.35) 55%, rgba(12,24,46,0.05) 100%);
  z-index:1;
}
body.manx-site .hero .container { position:relative; z-index:2; }
body.manx-site .hero-content { display:flex; flex-wrap:wrap; align-items:center; gap:32px; }
body.manx-site .hero-copy { flex:1 1 100%; max-width:720px; color:#fff; }
body.manx-site .hero-copy h1 { color:#fff; }
body.manx-site .hero-copy p { color:#e8f1ff; }
body.manx-site .hero-copy .trust-bar span { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.18); color:#fff; }
@media (max-width: 992px) {
  body.manx-site .hero { border-radius:12px; padding:56px 0; }
  body.manx-site .hero-content { gap:24px; }
}
@media (max-width: 768px) {
  body.manx-site .hero { padding:48px 0; }
  body.manx-site .hero-copy { max-width:100%; }
  body.manx-site .hero-art { order:-1; }
  body.manx-site .hero::after { background: linear-gradient(180deg, rgba(12,24,46,0.75) 0%, rgba(12,24,46,0.25) 100%); }
}

@media (max-width: 768px) {
  body.manx-site main h1 { font-size: 30px; line-height: 1.25; }
  body.manx-site main h2 { font-size: 24px; line-height: 1.3; }
  body.manx-site main h3 { font-size: 20px; line-height: 1.35; }
  body.manx-site main p  { font-size: 15px; line-height: 1.55; }
  body.manx-site main .card h3 { font-size: 20px; }
}
/* WordPress generated global block styles removed (static site) */

/* Match header logo sizing from original */
.headerlogo img {
  max-height: 96px !important; /* allow taller wordmark */
}
.is_stuck .headerlogo img {
  max-height: 64px !important;
}
.site-title .home-link,
.headerlogo .home-link {
  font-family: "Poppins", Tahoma, Geneva, sans-serif;
  font-weight: 400;
  font-size: 26px;
  line-height: 27px;
  color: #202020;
}

/* Ensure tm-anomica icon glyphs use the correct font */
.tm-header-icons i[class^="tm-anomica-icon"],
.tm-header-icons i[class*=" tm-anomica-icon"],
.tm-site-searchform button span.tm-anomica-icon-search,
.tm-site-searchform i.tm-anomica-icon-search {
  font-family: "tm-anomica-icons" !important;
  font-style: normal;
  font-weight: normal;
}

/* Scroll reveal for Manx sections */
body.manx-site .manx-reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 650ms ease, transform 650ms ease;
  will-change: transform, opacity;
}
body.manx-site .manx-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  body.manx-site .manx-reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Header/menu fixes for Manx pages (keep About Us untouched) */
body.manx-site #site-header-menu #site-navigation { position: relative; }

/* IMPORTANT: both the wrapper <div> and the <ul> use "nav-menu" in the injected header,
   so we target the actual list by id to avoid accidentally absolutely-positioning the <ul>. */
body.manx-site #menu-manx-main {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  justify-content: flex-end;
  list-style: none;
  margin: 0;
  padding: 0;
}
body.manx-site #menu-manx-main > li { display: block; }
body.manx-site #menu-manx-main > li > a {
  display: inline-block;
  padding: 8px 0;
  font-weight: 600;
  color: #1e2637;
}
body.manx-site #menu-manx-main > li > a:hover { color: #21b6c7; }

@media (min-width: 992px) {
  body.manx-site #menu-toggle { display: none; }
  body.manx-site #site-header-menu #site-navigation > .nav-menu {
    display: block !important;
    position: static;
    background: transparent;
    padding: 0;
    box-shadow: none;
  }
}

@media (max-width: 991px) {
  body.manx-site #menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 1px solid #d4dce6;
    border-radius: 6px;
    background: #ffffff;
    color: #1c2842;
  }
  body.manx-site #site-header-menu #site-navigation > .nav-menu {
    display: none;
    position: absolute;
    top: 100%;
    right: 0;
    left: 0;
    background: #ffffff;
    padding: 12px 16px;
    box-shadow: 0 16px 40px rgba(28,40,66,0.12);
    z-index: 10;
  }
  body.manx-site #site-header-menu #site-navigation.toggled-on > .nav-menu { display: block; }
  body.manx-site #menu-manx-main {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
  body.manx-site #menu-manx-main > li > a {
    width: 100%;
    padding: 10px 0;
  }
}

/* =========================================================
   Shared components + page-specific layout (Manx site)
   (Restored after accidental truncation)
   ========================================================= */

/* Slightly smaller homepage headings (improves density/UX) */
body.home h2 { font-size: 30px; line-height: 38px; font-weight: 600; color: #1e2637; }
body.home h3 { font-size: 20px; line-height: 26px; font-weight: 600; color: #1e2637; }
body.home h4 { font-size: 18px; line-height: 24px; font-weight: 600; color: #1e2637; }
body.home h5 { font-size: 16px; line-height: 22px; font-weight: 600; color: #1e2637; }
@media (max-width: 768px) {
  body.home h1 { font-size: 32px; line-height: 38px; }
  body.home h2 { font-size: 26px; line-height: 32px; }
  body.home h3 { font-size: 18px; line-height: 24px; }
}

/* Homepage: remove the white gap above the hero */
body.home main.site-main { padding-top: 0 !important; }

/* Homepage: card sections (Delivery Model / How We Work / Trust) */
/* Force spacing on homepage card sections (beats theme .section padding) */
body.home section.section.container.home-card-section { padding: 28px 0 56px !important; }
body.home .home-card-section .lede { margin-bottom: 14px; }
body.home .home-card-section .cta-row { margin: 14px 0 0; }

/* Homepage: remove dividers between these sections (shadows + divider look messy) */
body.home section.section.container.home-card-section + section.section.container.home-card-section { border-top: 0 !important; }
body.home section.section.container.home-card-section + section.section.container.final-cta { border-top: 0 !important; }

/* Prevent card shadows bleeding into the next section */
body.home section.section.container.home-card-section,
body.home section.section.container.final-cta { overflow: hidden; }

/* Homepage: final CTA spacing (match rhythm + keep stronger bottom) */
body.home section.section.container.final-cta { padding: 28px 0 72px !important; }
body.home .final-cta .lede { margin-bottom: 14px; }
body.home .final-cta .cta-row { margin: 18px 0 0; }

/* Icon cards (homepage style) — shared across Manx pages */
body.manx-site main .icon-card-grid { gap: 18px; }
body.manx-site main .icon-card {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  align-items: start;
  padding: 22px 20px;
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 16px;
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  color: #1e2637;
}
body.manx-site main .icon-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 22px 56px rgba(0,0,0,0.16);
}
body.manx-site main .icon-card .card-icon {
  width: 72px;
  height: 72px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(33,182,199,0.10);
  border: 2px solid rgba(33,182,199,0.18);
  color: #21b6c7;
  font-size: 26px;
}
body.manx-site main .icon-card .card-body { min-width: 0; }
body.manx-site main .icon-card h3 {
  margin: 2px 0 8px;
  font-size: 14px;
  line-height: 20px;
  font-weight: 700;
  color: #1e2637;
}
body.manx-site main .icon-card p {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: #686e73;
}
@media (max-width: 768px) {
  body.manx-site main .icon-card { grid-template-columns: 56px 1fr; padding: 18px 16px; border-radius: 14px; }
  body.manx-site main .icon-card .card-icon { width: 56px; height: 56px; border-radius: 16px; font-size: 22px; }
}

/* Homepage What We Do (2-column) */
body.home .what-we-do-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 32px;
  align-items: center;
}
body.home .what-we-do-copy .lede { max-width: 62ch; margin-bottom: 18px; }
body.home .what-we-do-cards { margin-top: 18px; }
body.home .what-we-do-cards.icon-card-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
body.home .what-we-do-media {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}
body.home .what-we-do-media img {
  width: 100%;
  height: 100%;
  max-height: 520px;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}
@media (max-width: 992px) {
  body.home .what-we-do-grid { grid-template-columns: 1fr; }
  body.home .what-we-do-media img { max-height: 420px; }
}

/* Homepage band sections (Why + Services) */
body.home .section-band--light {
  position: relative;
  padding: 72px 0;
  margin: 0;
  border-top: 0;
  background-color: #e6fbf6; /* light green tint */
  background-image:
    linear-gradient(180deg, rgba(46,176,184,0.16) 0%, rgba(46,176,184,0.08) 100%),
    linear-gradient(180deg, rgba(255,255,255,0.86) 0%, rgba(255,255,255,0.82) 100%),
    url("/homepage_files/uploads/2019/12/post-img-two.jpg");
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
  background-attachment: scroll;
  color: #1e2637;
  font-size: 14px;
}
@media (min-width: 1024px) {
  body.home .section-band--light { background-attachment: fixed; }
}
body.home .section-band--light h2 {
  font-size: 22px;
  line-height: 28px;
  margin-bottom: 24px;
  color: #1e2637;
}
body.home .section-band--light .band-divider {
  height: 1px;
  background: rgba(0,0,0,0.08);
  margin: 48px auto;
  max-width: 800px;
}
body.home .section-band--light .icon-card-grid {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 22px;
}
body.home .section-band--light .cta-row { margin-top: 20px; }
@media (max-width: 991px) {
  body.home .section-band--light { padding: 56px 0; background-attachment: scroll; }
  body.home .section-band--light h2 { font-size: 20px; line-height: 26px; }
}

/* Services page intro (2-column) */
body.services main.page header.services-intro { margin: 0 0 34px; }
body.services .services-intro-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 32px;
  align-items: center;
}
body.services .services-intro-copy p { max-width: 70ch; }
body.services .services-intro-media {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}
body.services .services-intro-media img {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}
@media (max-width: 992px) {
  body.services .services-intro-grid { grid-template-columns: 1fr; }
  body.services .services-intro-media img { max-height: 360px; }
}

/* Services page: categories + tech stack (2-column) */
body.services .services-split {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 32px;
  align-items: start;
}
body.services .services-split-col > h2 { margin: 0 0 18px; }
body.services .services-categories-grid { gap: 18px; }
body.services main.page .services-tech-stack { font-size: 14px; }
body.services main.page .services-tech-stack p { margin: 0 0 10px; font-size: 14px; line-height: 1.6; color: #686e73; }
body.services main.page .services-tech-stack strong { color: #1e2637; }
body.services main.page .services-tech-stack p:last-child { margin-bottom: 0; }
@media (max-width: 992px) {
  body.services .services-split { grid-template-columns: 1fr; gap: 26px; }
}

/* How We Work page intro (2-column) */
body.how-we-work main.page header.how-work-intro { margin: 0 0 34px; }
body.how-we-work .how-work-intro-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 32px;
  align-items: center;
}
body.how-we-work .how-work-intro-copy p { max-width: 70ch; }
body.how-we-work .how-work-intro-media {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}
body.how-we-work .how-work-intro-media img {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}
@media (max-width: 992px) {
  body.how-we-work .how-work-intro-grid { grid-template-columns: 1fr; }
  body.how-we-work .how-work-intro-media img { max-height: 360px; }
}

/* Our Teams page intro (2-column) */
body.our-teams main.page header.teams-intro { margin: 0 0 34px; }
body.our-teams .teams-intro-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 32px;
  align-items: center;
}
body.our-teams .teams-intro-copy p { max-width: 70ch; }
body.our-teams .teams-intro-media {
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}
body.our-teams .teams-intro-media img {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}
@media (max-width: 992px) {
  body.our-teams .teams-intro-grid { grid-template-columns: 1fr; }
  body.our-teams .teams-intro-media img { max-height: 360px; }
}

/* Our Teams: Regional Pods (screenshot-style image cards) */
body.our-teams .pod-card-grid { gap: 24px; }
body.our-teams .pod-card {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
body.our-teams .pod-card:hover { transform: none; box-shadow: none; }
body.our-teams .pod-card-media {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 18px 50px rgba(0,0,0,0.12);
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}
body.our-teams .pod-card-media img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}
body.our-teams .pod-card-body {
  margin: -44px 20px 0;
  padding: 20px 18px 18px;
  background: #fff;
  border-radius: 10px;
  border-bottom: 4px solid rgba(33,182,199,0.95);
  box-shadow: 0 14px 40px rgba(0,0,0,0.12);
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, color 180ms ease;
}
body.our-teams .pod-card-body h3 { margin: 0 0 8px; font-size: 18px; line-height: 24px; }
body.our-teams .pod-card-body p { margin: 0; font-size: 14px; line-height: 1.6; color: #686e73; }
body.our-teams .pod-card:hover .pod-card-body {
  transform: translateY(-2px);
  background: #21b6c7;
  border-color: #21b6c7;
  box-shadow: 0 22px 56px rgba(0,0,0,0.16);
}
body.our-teams .pod-card:hover .pod-card-body h3,
body.our-teams .pod-card:hover .pod-card-body p { color: #fff; }
body.our-teams .pod-card:hover .pod-card-body p { opacity: 0.92; }
@media (max-width: 768px) {
  body.our-teams .pod-card-media img { height: 200px; }
  body.our-teams .pod-card-body { margin: -36px 14px 0; padding: 18px 16px 16px; }
  body.our-teams .pod-card-body h3 { font-size: 16px; line-height: 22px; }
}

/* Homepage hero text animation */
@keyframes manxFadeUp {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
body.home .hero-anim {
  opacity: 0;
  animation: manxFadeUp 850ms ease forwards;
  will-change: transform, opacity;
}
body.home .hero-anim-1 { animation-delay: 90ms; }
body.home .hero-anim-2 { animation-delay: 180ms; }
body.home .hero-anim-3 { animation-delay: 290ms; }
body.home .hero-anim-4 { animation-delay: 380ms; }
body.home .hero-anim-5 { animation-delay: 470ms; }

body.home .hero-rotator {
  display: block;
  margin-top: 6px;
  transition: opacity 280ms ease, transform 280ms ease;
}
body.home .hero-rotator.is-fading {
  opacity: 0;
  transform: translateY(10px);
}

@media (prefers-reduced-motion: reduce) {
  body.home .hero-anim { opacity: 1; animation: none !important; }
  body.home .hero-rotator { transition: none !important; }
}
