/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/

:root {
  --4d-purple: #211733;
  --4d-purple-2: #2e1f47;
  --4d-red: #ff6663;
  --4d-red-dark: #e64f4c;
  --4d-blue: #8491a3;
  --4d-pink: #f7bab8;
  --4d-offwhite: #fdfefe;
  --4d-ink: #211733;
  --4d-muted: #6f6a7d;
  --4d-line: rgba(132, 145, 163, 0.25);
  --4d-line-strong: #8491a3;
  --4d-gradient: linear-gradient(120deg, #211733 0%, #2c1c44 38%, #7d3a5b 72%, #ff6663 115%);
  --font-head: proxima-nova, "Proxima Nova", "Source Sans 3", system-ui, sans-serif;
  --font-body: 16px proxima-nova, "Proxima Nova", "Source Sans 3", system-ui, sans-serif;
  --container: 1200px;
  --pad: clamp(20px, 5vw, 40px);
  --section-y: clamp(56px, 9vw, 110px);
  --radius: 16px;
  --radius-lg: 24px;
  --shadow: 0 18px 50px -24px rgba(33, 23, 51, 0.35);
  --icon-arrow-right: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14'/%3E%3Cpath d='m13 6 6 6-6 6'/%3E%3C/svg%3E");
  --icon-arrow-up-right: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7'/%3E%3Cpath d='M8 7h9v9'/%3E%3C/svg%3E");
  --icon-chevron-down: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m4 6 4 4 4-4'/%3E%3C/svg%3E");
  --icon-spark: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M12 2.5 14.35 9.65 21.5 12 14.35 14.35 12 21.5 9.65 14.35 2.5 12 9.65 9.65 12 2.5Z'/%3E%3C/svg%3E");
  --icon-check: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m5 12 4 4 10-10'/%3E%3C/svg%3E");
  --icon-search: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='7'/%3E%3Cpath d='m16.5 16.5 4 4'/%3E%3C/svg%3E");
  --icon-grid: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='4' width='6' height='6' rx='1'/%3E%3Crect x='14' y='4' width='6' height='6' rx='1'/%3E%3Crect x='4' y='14' width='6' height='6' rx='1'/%3E%3Crect x='14' y='14' width='6' height='6' rx='1'/%3E%3C/svg%3E");
  --icon-code: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m8 9-4 3 4 3'/%3E%3Cpath d='m16 9 4 3-4 3'/%3E%3Cpath d='m14 5-4 14'/%3E%3C/svg%3E");
  --icon-pin: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 5-8 11-8 11S4 15 4 10a8 8 0 1 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
  --icon-phone: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.2 2 19.8 19.8 0 0 1-8.6-3.1 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.1 4.2 2 2 0 0 1 4.1 2h3a2 2 0 0 1 2 1.7c.1 1 .4 2 .7 2.9a2 2 0 0 1-.5 2.1L8 10a16 16 0 0 0 6 6l1.3-1.3a2 2 0 0 1 2.1-.5c.9.3 1.9.6 2.9.7A2 2 0 0 1 22 16.9Z'/%3E%3C/svg%3E");
  --icon-mail: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='14' rx='2'/%3E%3Cpath d='m3 7 9 6 9-6'/%3E%3C/svg%3E");
}

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  color: var(--4d-ink);
  background: var(--4d-offwhite);
  font-family: var(--font-body) !important;
  line-height: 1.6;
  padding-top: 87px;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

h1,
h2,
h3,
h4,
h5,
h6,
.brxe-heading,
.brxe-button {
  font-family: var(--font-head);
  font-family: var(--font-head) !important;
  letter-spacing: 0;
}

p,
.brxe-text,
.brxe-text-basic {
  font-family: var(--font-body);
  font-family: var(--font-body) !important;
}

.site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 999 !important;
  width: 100% !important;
  min-height: 87px;
  background: rgba(253, 254, 254, 0.96) !important;
  border-bottom: 1px solid var(--4d-line);
  backdrop-filter: blur(12px);
  transition: background-color 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, backdrop-filter 0.2s ease;
}

.site-header.is-scrolled {
  background: rgba(253, 254, 254, 0.92) !important;
  border-bottom-color: rgba(132, 145, 163, 0.42);
  box-shadow: 0 14px 34px -26px rgba(33, 23, 51, 0.55);
}

.site-header.section,
.site-header.brxe-section {
  padding-block: 0 !important;
}

.site-header .nav-inner {
  position: relative;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  min-height: 87px;
  max-width: var(--container);
  margin-inline: auto;
  padding: 16px var(--pad) !important;
}

#brxe-hdrlogolink {
  display: inline-flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: max-content !important;
}

#brxe-navcontact {
  flex: 0 0 auto !important;
  width: auto !important;
  max-width: max-content !important;
}

.logo-img,
.logo-img.brxe-image {
  width: auto !important;
  min-width: 120px;
}

.logo-img img,
img.logo-img {
  display: block;
  width: auto !important;
  height: 38px !important;
  object-fit: contain;
}

.nav-links {
  gap: 28px !important;
}

.site-header .nav-links.brxe-block {
  flex: 0 1 auto !important;
}

.nav-item-drop,
#brxe-navservicesitem {
  position: relative !important;
  display: inline-flex !important;
  align-items: center;
  width: auto !important;
}

.nav-drop,
#brxe-navdrop {
  position: absolute !important;
  top: 140% !important;
  left: 50% !important;
  z-index: 60 !important;
  display: block !important;
  width: 240px !important;
  min-width: 240px !important;
  padding: 10px !important;
  border: 1px solid var(--4d-line);
  border-radius: var(--radius) !important;
  background: var(--4d-offwhite) !important;
  box-shadow: var(--shadow);
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateX(-50%) translateY(8px) !important;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
  pointer-events: none;
}

.nav-item-drop:hover .nav-drop,
.nav-item-drop:focus-within .nav-drop,
#brxe-navservicesitem:hover #brxe-navdrop,
#brxe-navservicesitem:focus-within #brxe-navdrop {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateX(-50%) translateY(0) !important;
  transition-delay: 0s;
  pointer-events: auto;
}

.nav-drop .nav-link.brxe-button,
#brxe-navdrop .nav-link.brxe-button {
  display: flex !important;
  justify-content: flex-start;
  width: 100% !important;
  padding: 10px 14px !important;
  border-radius: 10px !important;
  font-size: 14px;
}

.nav-drop .nav-link.brxe-button:hover,
#brxe-navdrop .nav-link.brxe-button:hover {
  background: rgba(247, 186, 184, 0.3) !important;
}

.site-nav.brxe-nav-menu {
  flex: 1 1 auto !important;
  display: flex !important;
  justify-content: center !important;
  width: auto !important;
}

.site-nav .bricks-nav-menu-wrapper {
  display: flex !important;
  justify-content: center !important;
  width: auto !important;
}

.site-nav .bricks-nav-menu {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.site-nav .bricks-nav-menu > li {
  position: relative;
  width: auto !important;
  margin: 0 !important;
  white-space: nowrap;
}

.site-nav .bricks-nav-menu > li > .brx-submenu-toggle {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  width: auto !important;
  white-space: nowrap;
}

.site-nav .bricks-nav-menu > li > a,
.site-nav .bricks-nav-menu > li > .brx-submenu-toggle > a,
.site-nav .bricks-nav-menu > li > .brx-submenu-toggle > button {
  padding: 8px 0 !important;
  color: var(--4d-purple) !important;
  font-family: var(--font-head) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.site-nav .bricks-nav-menu > li.menu-item-has-children > .brx-submenu-toggle > a::after {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  margin-left: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  opacity: 0.6;
  vertical-align: 0.18em;
  transform: rotate(45deg);
  transform-origin: center;
}

.site-nav .bricks-nav-menu > li > .brx-submenu-toggle > button {
  display: none !important;
}

.site-nav .bricks-nav-menu > li:hover > a,
.site-nav .bricks-nav-menu > li:hover > .brx-submenu-toggle > a,
.site-nav .bricks-nav-menu > li:hover > .brx-submenu-toggle > button {
  color: var(--4d-red) !important;
}

.site-nav .bricks-nav-menu .sub-menu {
  top: 140% !important;
  left: 50% !important;
  min-width: 240px !important;
  padding: 8px !important;
  border: 1px solid var(--4d-line) !important;
  border-radius: var(--radius) !important;
  background: var(--4d-offwhite) !important;
  box-shadow: var(--shadow) !important;
  transform: translateX(-50%) translateY(8px) !important;
}

.site-nav .bricks-nav-menu > li:hover > .sub-menu,
.site-nav .bricks-nav-menu > li:hover > .brx-submenu-toggle + .sub-menu,
.site-nav .bricks-nav-menu > li:focus-within > .sub-menu,
.site-nav .bricks-nav-menu > li:focus-within > .brx-submenu-toggle + .sub-menu {
  transform: translateX(-50%) translateY(0) !important;
}

.site-nav .bricks-nav-menu .sub-menu li a {
  display: block !important;
  padding: 8px 12px !important;
  border-radius: 10px !important;
  color: var(--4d-purple) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.5 !important;
}

.site-nav .bricks-nav-menu .sub-menu li a:hover {
  background: rgba(247, 186, 184, 0.3) !important;
  color: var(--4d-red) !important;
}

.site-nav .bricks-mobile-menu-toggle {
  position: relative !important;
  width: 40px !important;
  height: 42px !important;
  padding: 8px !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--4d-purple) !important;
}

.site-nav .bricks-mobile-menu-toggle span {
  position: absolute !important;
  left: 8px !important;
  display: block !important;
  width: 24px !important;
  height: 2px !important;
  margin: 0 !important;
  border-radius: 2px;
  background: currentColor !important;
  opacity: 1 !important;
  transform-origin: center;
  transition: transform 0.25s ease, opacity 0.2s ease;
}

.site-nav .bricks-mobile-menu-toggle .bar-top {
  top: 12px !important;
  transform: none;
}

.site-nav .bricks-mobile-menu-toggle .bar-center {
  top: 20px !important;
}

.site-nav .bricks-mobile-menu-toggle .bar-bottom {
  top: 28px !important;
  transform: none;
}

.site-nav.show-mobile-menu .bricks-mobile-menu-toggle .bar-top {
  top: 20px !important;
  transform: rotate(45deg);
}

.site-nav.show-mobile-menu .bricks-mobile-menu-toggle .bar-center {
  opacity: 0 !important;
}

.site-nav.show-mobile-menu .bricks-mobile-menu-toggle .bar-bottom {
  top: 20px !important;
  transform: rotate(-45deg);
}

.nav-link.brxe-button {
  display: inline-flex !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 8px 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: var(--4d-purple) !important;
  font-family: var(--font-head);
  font-family: var(--font-head) !important;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
}

.nav-link.brxe-button:hover {
  color: var(--4d-red) !important;
}

#brxe-navservices::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-left: 5px;
  background: var(--4d-muted);
  -webkit-mask: var(--icon-chevron-down) center / contain no-repeat;
  mask: var(--icon-chevron-down) center / contain no-repeat;
  transform: translateY(-1px);
}

.btn.brxe-button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: auto !important;
  min-width: 0 !important;
  min-height: 54px;
  gap: 10px;
  padding: 14px 28px !important;
  border-radius: 999px !important;
  font-family: var(--font-head);
  font-family: var(--font-head) !important;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.2s ease;
}

.btn-primary.brxe-button {
  min-width: 162px !important;
  background: var(--4d-purple) !important;
  color: var(--4d-offwhite) !important;
}

.btn-primary.brxe-button:hover {
  background: var(--4d-red) !important;
  color: #fff !important;
}

.btn.brxe-button:not(.nav-link):not(.nav-burger)::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-left: 0;
  background: currentColor;
  -webkit-mask: var(--icon-arrow-right) center / contain no-repeat;
  mask: var(--icon-arrow-right) center / contain no-repeat;
  transform: translateY(-2px);
  transition: transform 0.2s ease;
}

.btn.brxe-button:not(.nav-link):not(.nav-burger):hover::after {
  transform: translate(3px, -2px);
}

.nav-burger.brxe-button {
  position: relative;
  display: none !important;
  width: 24px !important;
  min-width: 24px !important;
  min-height: 20px !important;
  padding: 0 !important;
  overflow: hidden;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: transparent !important;
}

.nav-burger::before,
.nav-burger::after,
.nav-burger span {
  content: "";
  position: absolute;
  left: 0;
  width: 24px;
  height: 2px;
  border-radius: 2px;
  background: var(--4d-purple);
  transition: transform 0.2s ease, opacity 0.2s ease;
}

.nav-burger::before {
  top: 2px;
}

.nav-burger span {
  top: 9px;
}

.nav-burger::after {
  top: 16px;
}

.site-header.nav-open .nav-burger::before {
  transform: translateY(7px) rotate(45deg);
}

.site-header.nav-open .nav-burger span {
  opacity: 0;
}

.site-header.nav-open .nav-burger::after {
  transform: translateY(-7px) rotate(-45deg);
}

.btn-light.brxe-button {
  min-width: 252px !important;
  background: var(--4d-offwhite) !important;
  color: var(--4d-purple) !important;
}

.btn-light.brxe-button:hover {
  background: var(--4d-pink) !important;
}

.hero {
  padding: 0 !important;
  overflow: hidden;
  background: var(--4d-gradient) !important;
}

.hero.section,
.hero.brxe-section {
  padding-block: 0 !important;
}

.hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 120% at 80% 10%, rgba(255, 102, 99, 0.25), transparent 55%);
  pointer-events: none;
}

.hero-grid {
  position: relative;
  z-index: 2;
  min-height: 0 !important;
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(70px, 10vw, 130px) var(--pad) !important;
}

.hero-title {
  max-width: 760px;
  margin: 0 0 22px;
  color: var(--4d-offwhite) !important;
  font-family: var(--font-head);
  font-family: var(--font-head) !important;
  font-size: clamp(38px, 6vw, 72px) !important;
  font-weight: 700 !important;
  line-height: 1.04 !important;
}

.hero-title .hl {
  color: var(--4d-red);
}

.hero-text {
  max-width: 560px;
  margin: 0 0 34px;
  color: rgba(253, 254, 254, 0.85) !important;
  font-size: clamp(17px, 1.6vw, 20px) !important;
}

.hero-copy {
  row-gap: 0 !important;
}

.hero-wire img {
  width: 100% !important;
  max-width: 100% !important;
  opacity: 0.1 !important;
  transform: scale(2) !important;
  filter: drop-shadow(0 8px 30px rgba(0, 0, 0, 0.25));
}

.section {
  padding-block: var(--section-y) !important;
}

.brxe-section.section:not(.hero):not(.footer),
.brxe-section:not(.hero):not(.site-header):not(.footer) {
  border-top: 1px solid var(--4d-line);
}

.container {
  max-width: var(--container) !important;
  width: 100% !important;
  margin-inline: auto !important;
  padding-inline: var(--pad) !important;
  min-width: 0;
}

.logossec .container {
  display: flex !important;
  flex-direction: column;
  align-items: center;
}

.logo-row {
  display: flex !important;
  flex-flow: row wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 24px 30px !important;
  padding-top: 18px;
  width: 100%;
}

.logo-row > * {
  flex: 0 0 auto !important;
  width: auto !important;
}

.logo-row img {
  width: auto !important;
  height: 45px !important;
  opacity: 0.55;
  filter: grayscale(1);
}

.section-intro {
  color: #4a4458 !important;
  font-size: clamp(16px, 1.4vw, 18px) !important;
}

.logossec .section-intro,
#brxe-logostxt {
  width: 100%;
  align-self: stretch;
  margin-bottom: 26px;
  color: var(--4d-blue) !important;
  font-size: 14px !important;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-align: center;
}

.logossec.section,
.logossec.brxe-section {
  padding-block: 42px !important;
  border-top: 0;
  border-bottom: 1px solid var(--4d-line);
}

.eyebrow {
  display: inline-flex !important;
  align-items: center;
  gap: 9px;
  width: auto !important;
  margin-bottom: 20px;
  padding: 7px 14px !important;
  border-radius: 999px !important;
  background: rgba(247, 186, 184, 0.35) !important;
  color: var(--4d-purple) !important;
  font-size: 12px !important;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  text-transform: uppercase;
}

.eyebrow::before {
  content: "";
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--4d-red);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 2.5 14.35 9.65 21.5 12 14.35 14.35 12 21.5 9.65 14.35 2.5 12 9.65 9.65 12 2.5Z'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 11px 11px;
}

.section-dark .eyebrow {
  background: rgba(255, 102, 99, 0.16) !important;
  color: var(--4d-pink) !important;
}

.section-title {
  margin: 0 0 14px;
  color: var(--4d-purple) !important;
  font-size: clamp(28px, 4vw, 44px) !important;
  font-weight: 700 !important;
  line-height: 1.12 !important;
}

.section-dark .section-title,
.section-dark h2,
.section-dark h3 {
  color: var(--4d-offwhite) !important;
}

.section-dark .section-intro,
#brxe-servicesintro {
  max-width: 720px !important;
  color: rgba(253, 254, 254, 0.78) !important;
}

.section-head,
.section-head-center {
  max-width: 720px !important;
  margin-bottom: 40px !important;
}

.section-head-center {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  margin-inline: auto !important;
  text-align: center !important;
}

.section-head-center > * {
  margin-inline: auto !important;
}

.section-head-center .section-intro,
.section-head-center p,
.section-head-center .brxe-text-basic {
  text-align: center !important;
}

#brxe-abouthead,
#brxe-testhead {
  display: flex !important;
  flex-direction: column;
  align-items: center !important;
  text-align: center !important;
}

#brxe-aboutcopy {
  text-align: center;
}

.founder-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  max-width: 680px !important;
  margin-right: auto !important;
  margin-bottom: 34px !important;
  margin-left: auto !important;
  text-align: center !important;
}

.founder-copy p,
.founder-copy .brxe-text-basic,
.founder-copy .brxe-text {
  text-align: center !important;
}

.founder-person {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  margin-inline: auto !important;
  text-align: center !important;
}

.founder-person img {
  width: 84px !important;
  height: 84px !important;
  border: 3px solid var(--4d-pink);
  border-radius: 50%;
  object-fit: cover;
}

#brxe-workhead {
  display: flex !important;
  flex-direction: column;
  align-items: center;
}

#brxe-statssec {
  display: none !important;
}

.card {
  overflow: hidden;
  border: 1px solid var(--4d-line) !important;
  border-radius: var(--radius-lg) !important;
  background: #fff !important;
  color: var(--4d-purple) !important;
  text-decoration: none !important;
  transition: all 0.25s ease;
}

.card h3,
.card p,
.card .brxe-text-basic {
  color: inherit;
}

.card:hover {
  border-color: var(--4d-line-strong) !important;
  box-shadow: var(--shadow);
  transform: translateY(-4px);
  text-decoration: none !important;
}

.services-list {
  border-top: 1px solid rgba(253, 254, 254, 0.14);
}

.service-row {
  display: grid !important;
  grid-template-columns: 64px minmax(0, 1fr) auto !important;
  align-items: center;
  gap: 28px;
  padding: 30px 8px !important;
  border-bottom: 1px solid rgba(253, 254, 254, 0.14);
  color: inherit !important;
  text-decoration: none !important;
  transition: padding 0.25s ease, background-color 0.25s ease;
}

.service-row:hover,
.service-row:focus-visible {
  padding-inline: 24px !important;
  background: rgba(255, 102, 99, 0.06);
  text-decoration: none !important;
}

.service-row > .brxe-heading:first-child {
  color: var(--4d-blue) !important;
  font-size: 20px !important;
  line-height: 1;
  transition: color 0.25s ease;
}

.service-row:hover > .brxe-heading:first-child,
.service-row:focus-visible > .brxe-heading:first-child {
  color: var(--4d-red) !important;
}

.service-row h3:not(:first-child),
.service-row .brxe-block h3 {
  margin: 0 0 6px !important;
  font-size: clamp(22px, 2.6vw, 30px) !important;
}

.service-row p,
.service-row .brxe-text-basic {
  max-width: 640px;
  color: rgba(253, 254, 254, 0.78) !important;
}

.service-row::after {
  content: "";
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border: 1.5px solid rgba(253, 254, 254, 0.3);
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fdfefe' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7'/%3E%3Cpath d='M8 7h9v9'/%3E%3C/svg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 19px 19px;
  color: var(--4d-offwhite);
  transition: background-color 0.25s ease, border-color 0.25s ease, transform 0.2s ease;
}

.service-row:hover::after,
.service-row:focus-visible::after {
  border-color: var(--4d-red);
  background-color: var(--4d-red);
  transform: translate(2px, -2px);
}

.process-aside .section-intro {
  margin-bottom: 0 !important;
}

.process-aside .btn {
  margin-top: 24px !important;
}

#brxe-processbtn {
  margin-top: 24px !important;
}

.step-card {
  position: relative;
  padding: 28px 26px !important;
  border-radius: var(--radius) !important;
}

.icon-circle {
  position: relative;
  display: grid !important;
  place-items: center;
  width: 54px !important;
  height: 54px !important;
  margin-bottom: 18px !important;
  border: 1.5px solid var(--4d-line);
  border-radius: 50%;
  background: rgba(247, 186, 184, 0.25);
  transition: background-color 0.25s ease, border-color 0.25s ease;
}

.icon-circle::before {
  content: "";
  display: block;
  width: 25px;
  height: 25px;
  background: var(--4d-purple);
  -webkit-mask: var(--icon-search) center / contain no-repeat;
  mask: var(--icon-search) center / contain no-repeat;
}

.step-card:nth-child(2) .icon-circle::before {
  -webkit-mask-image: var(--icon-grid);
  mask-image: var(--icon-grid);
}

.step-card:nth-child(3) .icon-circle::before {
  -webkit-mask-image: var(--icon-code);
  mask-image: var(--icon-code);
}

.step-card:nth-child(4) .icon-circle::before {
  -webkit-mask-image: var(--icon-arrow-up-right);
  mask-image: var(--icon-arrow-up-right);
}

.step-card:hover .icon-circle {
  border-color: var(--4d-red);
  background: var(--4d-red);
}

.step-card:hover .icon-circle::before {
  background: #fff;
}

.step-num {
  position: absolute;
  top: 22px;
  right: 24px;
  color: rgba(132, 145, 163, 0.35) !important;
  font-family: var(--font-head) !important;
  font-size: 30px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
}

.testimonial-card {
  padding: 34px 34px 30px !important;
}

/* Space after the quote, before the author name */
.testimonial-card h3 {
  margin-top: 22px !important;
}

.testimonial-card::before {
  content: "";
  display: block;
  width: 34px;
  height: 26px;
  margin-bottom: 4px;
  background: var(--4d-red);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 36' fill='black'%3E%3Cpath d='M18 0C8.8 4.7 4 11.3 4 19.8 4 29.1 9.1 36 16.2 36c5.1 0 8.8-3.7 8.8-8.7 0-4.8-3.4-8.2-8-8.2-1.2 0-2.3.2-3.2.7.7-4.5 3.8-8.4 9.3-11.8L18 0Zm24 0C32.8 4.7 28 11.3 28 19.8 28 29.1 33.1 36 40.2 36c5.1 0 8.8-3.7 8.8-8.7 0-4.8-3.4-8.2-8-8.2-1.2 0-2.3.2-3.2.7.7-4.5 3.8-8.4 9.3-11.8L42 0Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 36' fill='black'%3E%3Cpath d='M18 0C8.8 4.7 4 11.3 4 19.8 4 29.1 9.1 36 16.2 36c5.1 0 8.8-3.7 8.8-8.7 0-4.8-3.4-8.2-8-8.2-1.2 0-2.3.2-3.2.7.7-4.5 3.8-8.4 9.3-11.8L18 0Zm24 0C32.8 4.7 28 11.3 28 19.8 28 29.1 33.1 36 40.2 36c5.1 0 8.8-3.7 8.8-8.7 0-4.8-3.4-8.2-8-8.2-1.2 0-2.3.2-3.2.7.7-4.5 3.8-8.4 9.3-11.8L42 0Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.blog-grid {
  margin-top: 14px !important;
}

#brxe-bloghead {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 24px !important;
  margin-bottom: 40px !important;
}

#brxe-blogheadcopy {
  width: auto !important;
}

#brxe-blogall {
  align-self: flex-end;
  margin-bottom: 0 !important;
}

#brxe-bloggrid {
  margin-top: 0 !important;
}

.blog-thumb {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--4d-gradient-soft);
}

.blog-thumb.brxe-image {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover;
}

.blog-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.card:hover .blog-thumb img {
  transform: scale(1.04);
}

#brxe-blogcat0,
#brxe-blogcat1,
#brxe-blogcat2 {
  display: flex !important;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

.pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: rgba(247, 186, 184, 0.4);
  color: var(--4d-purple);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
  padding: 5px 11px;
  text-transform: uppercase;
}

.blog-date {
  color: var(--4d-blue);
  font-size: 13px;
  font-weight: 600;
}

#brxe-blogdesc0,
#brxe-blogdesc1,
#brxe-blogdesc2 {
  margin-bottom: 22px;
  font-size: 14.5px;
}

#brxe-workdesc0,
#brxe-workdesc1,
#brxe-workdesc2,
#brxe-workdesc3 {
  margin-bottom: 24px;
}

#brxe-workbtn0,
#brxe-workbtn1,
#brxe-workbtn2,
#brxe-workbtn3,
#brxe-blogbtn0,
#brxe-blogbtn1,
#brxe-blogbtn2 {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  min-height: 0;
  padding: 10px 16px !important;
  border: 1.5px solid var(--4d-purple);
  border-radius: 999px;
  color: var(--4d-purple) !important;
  font-family: var(--font-head) !important;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
}

#brxe-workbtn0::after,
#brxe-workbtn1::after,
#brxe-workbtn2::after,
#brxe-workbtn3::after,
#brxe-blogbtn0::after,
#brxe-blogbtn1::after,
#brxe-blogbtn2::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: currentColor;
  -webkit-mask: var(--icon-arrow-right) center / contain no-repeat;
  mask: var(--icon-arrow-right) center / contain no-repeat;
  transform: translateY(-2px);
  transition: transform 0.2s ease;
}

.card:hover #brxe-workbtn0::after,
.card:hover #brxe-workbtn1::after,
.card:hover #brxe-workbtn2::after,
.card:hover #brxe-workbtn3::after,
.card:hover #brxe-blogbtn0::after,
.card:hover #brxe-blogbtn1::after,
.card:hover #brxe-blogbtn2::after {
  transform: translate(3px, -2px);
}

.image-cover {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--4d-purple);
}

.image-cover img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}

.cta {
  position: relative;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  overflow: hidden;
  padding: clamp(40px, 6vw, 72px) !important;
  border-radius: var(--radius-lg) !important;
  background: var(--4d-gradient) !important;
  color: var(--4d-offwhite) !important;
  text-align: center !important;
}

.cta > * {
  position: relative;
  z-index: 2;
  margin-inline: auto !important;
}

.cta .section-title,
.cta h2 {
  color: var(--4d-offwhite) !important;
}

#brxe-ctablock {
  display: flex !important;
  flex-direction: column;
  align-items: center !important;
  text-align: center;
}

.cta p,
.cta .brxe-text-basic,
.cta .brxe-text,
#brxe-ctap {
  max-width: 620px;
  margin: 0 auto 30px !important;
  color: rgba(253, 254, 254, 0.85) !important;
  font-size: 17px;
  text-align: center !important;
}

.page-hero {
  position: relative;
  overflow: hidden;
  padding-block: 0 !important;
  background: var(--4d-gradient) !important;
  color: var(--4d-offwhite);
}

.page-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(120% 130% at 85% 0%, rgba(255, 102, 99, 0.28), transparent 55%);
  pointer-events: none;
}

.page-hero-inner {
  position: relative;
  z-index: 2;
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(28px, 5vw, 56px);
  max-width: var(--container);
  margin-inline: auto;
  padding: clamp(56px, 9vw, 96px) var(--pad) !important;
}

.page-hero-copy {
  display: flex !important;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
}

.page-hero-copy h1 {
  margin: 0 !important;
  color: var(--4d-offwhite) !important;
  font-size: clamp(34px, 5.5vw, 60px) !important;
  line-height: 1.06 !important;
}

.page-hero-copy .hl {
  color: var(--4d-red);
}

.page-hero-copy p {
  max-width: 600px;
  margin: 0 !important;
  color: rgba(253, 254, 254, 0.85) !important;
  font-size: clamp(16px, 1.5vw, 19px) !important;
}

.page-hero .eyebrow {
  background: rgba(255, 102, 99, 0.16) !important;
  color: var(--4d-pink) !important;
}

.hero-wire-right {
  position: relative;
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-height: 240px;
}

.hero-wire-right img {
  width: 110% !important;
  max-width: 580px !important;
  opacity: 0.32 !important;
  transform: translateX(8%);
  filter: drop-shadow(0 8px 30px rgba(0, 0, 0, 0.25));
}

.hero-mockup img {
  display: block;
  width: 110% !important;
  max-width: 660px !important;
  border-radius: 12px;
  box-shadow: 0 32px 70px -18px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.06);
  transform: rotate(-1.5deg);
}

.network {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(28px, 5vw, 56px);
}

.network-card {
  padding: clamp(30px, 4vw, 46px) !important;
  border-radius: var(--radius-lg) !important;
  background: var(--4d-purple) !important;
  color: var(--4d-offwhite);
}

.network-card h3 {
  color: var(--4d-offwhite) !important;
  font-size: clamp(22px, 2.6vw, 30px) !important;
}

.network-card p,
.network-card .brxe-text-basic {
  color: rgba(253, 254, 254, 0.82) !important;
}

.network-card > .brxe-text-basic:not(:first-child) {
  position: relative;
  padding-left: 28px;
}

.network-card > .brxe-text-basic:not(:first-child)::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 15px;
  height: 15px;
  background: var(--4d-red);
  -webkit-mask: var(--icon-check) center / contain no-repeat;
  mask: var(--icon-check) center / contain no-repeat;
}

.value-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch !important;
  gap: 24px;
  margin-top: 16px;
}

/* 'What sets us apart' cards: equal height */
.value-grid > .value-card {
  height: 100% !important;
}

/* Sub-service 'The full lifecycle' rows: no hover arrow (keep the hover transition) */
.page-id-30 .service-row::after,
.page-id-31 .service-row::after,
.page-id-32 .service-row::after,
.page-id-33 .service-row::after {
  display: none !important;
}

/* CTA inner: centre content (Projects 'Get started today' was left-aligned) */
.cta-inner {
  align-items: center !important;
  text-align: center !important;
}

/* 'Tools we use' chips: real tool logos */
.chip .tool-logo {
  flex: 0 0 auto !important;
  width: auto !important;
  height: 22px !important;
  object-fit: contain;
}

/* Contact CRO: visible form labels */
.contact-form label {
  display: block;
  margin-bottom: 7px;
  color: var(--4d-purple);
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 600;
}

/* Contact CRO: reassurance microcopy under the form */
.contact-reassure {
  margin-top: 14px !important;
  color: #6b7280 !important;
  font-size: 13.5px;
}

/* Contact CRO: trust / testimonial card */
.trust-card {
  display: block !important;
  padding: 22px 24px !important;
  border: 1px solid var(--4d-line);
  border-radius: var(--radius);
  background: rgba(255, 102, 99, 0.06);
}

.trust-stars {
  margin-bottom: 8px;
  color: #f5b301;
  font-size: 16px;
  letter-spacing: 3px;
}

.trust-quote {
  margin-bottom: 8px;
  color: var(--4d-purple) !important;
  font-size: 15px;
  font-style: italic;
  line-height: 1.5;
}

.trust-attr {
  color: #4a4458 !important;
  font-size: 13px;
  font-weight: 700;
}

/* Case study single — facts card: align columns, tighten padding, larger text */
.case-facts__row--work {
  grid-template-columns: 1fr 1fr !important;
}

.case-visit-link {
  grid-column: 1 / -1 !important;
  min-height: 0 !important;
  border-left: 0 !important;
  border-top: 1px solid rgba(132, 145, 163, 0.16) !important;
}

/* Hide the Visit website link when no URL is entered (Bricks omits href) */
.case-visit-link:not([href]),
.case-visit-link[href=""],
.case-visit-link[href="#"] {
  display: none !important;
}

/* Hide an "At a glance" fact (e.g. Launched) when its value is empty */
.case-fact:has(.case-fact__value:empty) {
  display: none !important;
}

/* Case study content: inline links read as links (were plain dark text) */
.case-content a:not(.purple-btn) {
  color: var(--4d-red);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s ease;
}

.case-content a:not(.purple-btn):hover {
  color: var(--4d-purple);
}

/* Case study content: .purple-btn CTA (e.g. "Visit website") styled as a button */
.case-content a.purple-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  padding: 12px 22px !important;
  border-radius: 999px;
  background: var(--4d-purple) !important;
  color: var(--4d-offwhite) !important;
  font-family: var(--font-head);
  font-size: 15px;
  font-weight: 700;
  text-decoration: none !important;
  transition: background-color 0.2s ease, transform 0.2s ease;
}

.case-content a.purple-btn:hover {
  background: var(--4d-red) !important;
  color: #fff !important;
  transform: translateY(-2px);
}

.case-fact,
.case-facts__item,
.case-visit-link {
  padding: 18px 24px !important;
}

.case-fact__label,
.case-facts__label {
  font-size: 11.5px !important;
}

.case-fact__value,
.case-facts__value {
  font-size: 16px !important;
}

.case-visit-link {
  font-size: 16px !important;
}

/* Case study single — bottom CTA: white background (distinct from the purple footer).
   Flip text + button to dark/solid so they read on white. */
.case-bottom-cta {
  background: #f2f3f6 !important; /* soft light grey (brand has no dedicated grey) */
  border-top: 1px solid var(--4d-line) !important;
}

.case-bottom-cta::before {
  content: none !important;
  display: none !important;
}

.case-template .case-bottom-cta h2,
.case-template .case-bottom-cta__title {
  color: var(--4d-purple) !important;
}

.case-template .case-bottom-cta p,
.case-template .case-bottom-cta__text {
  color: #4a4458 !important;
}

.case-template .case-bottom-cta .btn {
  background: var(--4d-purple) !important;
  color: var(--4d-offwhite) !important;
}

.case-template .case-bottom-cta .btn:hover {
  background: var(--4d-red) !important;
  color: #fff !important;
}

/* Hero 4D wire: cursor-follow tilt (driven by motion.js) */
.hero-wire,
[id$="herowire"] {
  will-change: transform;
  transform-style: preserve-3d;
}

.value-card,
.detail-card,
.faq-item {
  border: 1px solid var(--4d-line) !important;
  border-radius: var(--radius) !important;
  background: #fff !important;
}

.value-card {
  padding: 28px 24px !important;
  transition: all 0.25s ease;
}

.value-card:hover {
  border-color: var(--4d-line-strong) !important;
  box-shadow: var(--shadow);
  transform: translateY(-4px);
}

.chip-row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-top: 16px;
}

.chip {
  display: inline-flex !important;
  align-items: center;
  flex: 0 0 auto !important;
  gap: 10px;
  width: auto !important;
  max-width: max-content !important;
  padding: 12px 22px;
  border: 1px solid var(--4d-line);
  border-radius: 999px;
  background: #fff;
  color: var(--4d-purple) !important;
  font-family: var(--font-head) !important;
  font-size: 16px;
  font-weight: 700;
}

.chip .icon-circle {
  flex: 0 0 34px;
  width: 34px !important;
  height: 34px !important;
  margin: 0 !important;
  border-color: transparent;
  background: rgba(255, 102, 99, 0.12);
}

.chip .icon-circle::before {
  background: var(--4d-red);
  font-size: 16px;
  font-weight: 800;
}

.chip:nth-child(1) .icon-circle::before {
  content: "W";
  width: auto;
  height: auto;
  background: transparent;
  color: var(--4d-red);
  -webkit-mask: none;
  mask: none;
}

.chip:nth-child(2) .icon-circle::before {
  content: "F";
  width: auto;
  height: auto;
  background: transparent;
  color: var(--4d-red);
  -webkit-mask: none;
  mask: none;
}

.chip:nth-child(3) .icon-circle::before {
  -webkit-mask-image: var(--icon-arrow-up-right);
  mask-image: var(--icon-arrow-up-right);
}

.chip:nth-child(4) .icon-circle::before {
  -webkit-mask-image: var(--icon-search);
  mask-image: var(--icon-search);
}

.why-grid,
.detail-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
  margin-top: 16px;
}

.benefit {
  display: flex !important;
  align-items: flex-start;
  gap: 16px;
  padding: 24px 26px !important;
  border: 1px solid var(--4d-line);
  border-radius: var(--radius);
  background: #fff;
}

.benefit > .icon-circle {
  flex: 0 0 40px;
  width: 40px !important;
  height: 40px !important;
  margin: 0 !important;
  border-color: transparent;
  background: rgba(255, 102, 99, 0.12);
}

.benefit > .icon-circle::before {
  -webkit-mask-image: var(--icon-check);
  mask-image: var(--icon-check);
  background: var(--4d-red);
}

.faq-list {
  display: grid !important;
  gap: 14px;
  max-width: 820px;
  margin: 16px auto 0 !important;
}

.faq-item {
  padding: 22px 26px !important;
}

.faq-item h3 {
  position: relative;
  margin: 0 0 10px !important;
  font-size: 17px !important;
}

.detail-grid {
  gap: 24px;
}

.detail-card {
  padding: 28px 26px !important;
}

.content-stack {
  display: flex !important;
  flex-direction: column;
  gap: 24px;
}

.section-head-row {
  display: flex !important;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 40px !important;
}

.section-head-row .section-head {
  margin-bottom: 0 !important;
}

.page-hero-wire {
  position: absolute;
  top: 50%;
  right: 0;
  width: min(420px, 42%);
  opacity: 0.1;
  pointer-events: none;
  transform: translateY(-50%);
}

.page-hero--full-stats .page-hero-inner {
  display: block !important;
  max-width: 1080px;
  text-align: left !important;
}

.page-hero--full-stats .page-hero-inner > * {
  margin-inline: 0 !important;
}

.page-hero--full-stats h1 {
  margin: 0 !important;
  color: var(--4d-offwhite) !important;
  font-size: clamp(38px, 6vw, 68px) !important;
  line-height: 1.04 !important;
}

.page-hero--full-stats p {
  max-width: 680px;
  margin: 0 !important;
  color: rgba(253, 254, 254, 0.85) !important;
  font-size: clamp(16px, 1.5vw, 19px) !important;
}

.hero-stats {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 12px 20px;
  margin: 30px auto 32px !important;
  padding-block: 18px;
  border-top: 1px solid rgba(253, 254, 254, 0.18);
  border-bottom: 1px solid rgba(253, 254, 254, 0.18);
}

.page-hero--full-stats .hero-stats {
  justify-content: flex-start;
  margin-inline: 0 !important;
}

.hero-stats .stat-pt {
  display: inline-flex !important;
  flex: 0 0 auto !important;
  width: auto !important;
  align-items: center;
  gap: 8px;
  color: rgba(253, 254, 254, 0.78) !important;
  font-size: 14.5px;
}

.hero-stats .stat-pt strong {
  color: var(--4d-offwhite);
  font-family: var(--font-head);
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
}

.hero-stats .dot-sep {
  display: block;
  flex: 0 0 4px !important;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(253, 254, 254, 0.4);
}

.work-grid,
.blog-grid {
  display: grid !important;
  gap: 26px;
}

.work-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.blog-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.work-card,
.blog-card,
.loop-card {
  display: flex !important;
  flex-direction: column;
  height: 100%;
}

.work-card,
.blog-card {
  color: var(--4d-purple) !important;
  text-decoration: none !important;
}

.work-card:hover,
.blog-card:hover {
  text-decoration: none !important;
}

.work-thumb,
.blog-thumb {
  display: block !important;
  width: 100% !important;
  overflow: hidden;
}

.work-thumb {
  aspect-ratio: 16 / 10;
  background: var(--4d-purple);
}

.blog-thumb {
  aspect-ratio: 16 / 9;
  background: var(--4d-gradient-soft);
}

.work-thumb img,
.blog-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.work-card:hover .work-thumb img,
.blog-card:hover .blog-thumb img {
  transform: scale(1.04);
}

.work-body,
.blog-body,
.loop-card-body {
  display: flex !important;
  flex: 1 1 auto;
  flex-direction: column;
}

.work-body {
  padding: 24px 26px 26px !important;
}

.blog-body {
  padding: 22px 24px 26px !important;
}

.work-meta,
.blog-tags {
  display: flex !important;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 12px;
}

.work-meta {
  color: var(--4d-blue) !important;
  font-size: 13px;
  font-weight: 600;
}

.work-meta .cat,
.work-meta a {
  color: var(--4d-red) !important;
}

.work-body h3,
.blog-body h3,
.loop-card-body h3 {
  margin-bottom: 8px !important;
}

.work-body h3 {
  font-size: 22px !important;
}

.blog-body h3 {
  font-size: 19px !important;
}

.work-body p,
.work-body .brxe-post-excerpt,
.blog-body p,
.blog-body .brxe-post-excerpt {
  margin-bottom: 18px !important;
  color: #4a4458 !important;
}

.work-link,
.blog-link,
.card-read-link {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  margin-top: auto !important;
  color: var(--4d-purple) !important;
  font-family: var(--font-head) !important;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
}

.work-link::after,
.blog-link::after,
.card-read-link::after {
  content: "";
  display: inline-block;
  width: 15px;
  height: 15px;
  background: currentColor;
  -webkit-mask: var(--icon-arrow-up-right) center / contain no-repeat;
  mask: var(--icon-arrow-up-right) center / contain no-repeat;
  transition: transform 0.2s ease;
}

.work-card:hover .work-link,
.work-card:hover .card-read-link,
.blog-card:hover .blog-link,
.blog-card:hover .card-read-link {
  color: var(--4d-red) !important;
}

.work-card:hover .work-link::after,
.work-card:hover .card-read-link::after,
.blog-card:hover .blog-link::after,
.blog-card:hover .card-read-link::after {
  transform: translate(3px, -3px);
}

.contact-grid {
  display: grid !important;
  grid-template-columns: 1.3fr 0.9fr;
  align-items: start;
  gap: clamp(28px, 4vw, 48px);
}

.contact-form {
  padding: clamp(28px, 3.5vw, 40px) !important;
  border: 1px solid var(--4d-line);
  border-radius: var(--radius-lg);
  background: #fff;
}

.contact-form .form-group {
  margin-bottom: 18px;
}

.contact-form .form-group:nth-of-type(1),
.contact-form .form-group:nth-of-type(2),
.contact-form .form-group:nth-of-type(3),
.contact-form .form-group:nth-of-type(4) {
  width: calc(50% - 9px);
}

.contact-form .form-group:nth-of-type(1),
.contact-form .form-group:nth-of-type(3) {
  float: left;
  clear: left;
}

.contact-form .form-group:nth-of-type(2),
.contact-form .form-group:nth-of-type(4) {
  float: right;
}

.contact-form .submit-button-wrapper {
  clear: both;
}

.form-row {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.form-field {
  margin-bottom: 18px;
}

.form-field label {
  display: block;
  margin-bottom: 7px;
  color: var(--4d-purple);
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 600;
}

.form-field input,
.form-field select,
.form-field textarea {
  width: 100%;
  padding: 13px 16px;
  border: 1px solid var(--4d-line);
  border-radius: 10px;
  background: var(--4d-offwhite);
  color: var(--4d-ink);
  font-family: var(--font-body);
  font-size: 15px;
  transition: border-color 0.2s ease;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--4d-red);
}

.form-field textarea {
  min-height: 130px;
  resize: vertical;
}

.contact-side {
  display: grid !important;
  gap: 18px;
}

.contact-detail {
  display: flex !important;
  align-items: flex-start;
  gap: 16px;
  padding: 22px 24px !important;
  border: 1px solid var(--4d-line);
  border-radius: var(--radius);
  background: #fff;
}

.contact-detail .icon-circle {
  flex: 0 0 54px;
  margin: 0 !important;
  border-color: transparent;
  background: rgba(255, 102, 99, 0.12);
}

.contact-detail .icon-circle::before {
  background: var(--4d-red);
}

.contact-detail:nth-child(1) .icon-circle::before {
  -webkit-mask-image: var(--icon-pin);
  mask-image: var(--icon-pin);
}

.contact-detail:nth-child(2) .icon-circle::before {
  -webkit-mask-image: var(--icon-phone);
  mask-image: var(--icon-phone);
}

.contact-detail:nth-child(3) .icon-circle::before {
  -webkit-mask-image: var(--icon-mail);
  mask-image: var(--icon-mail);
}

.contact-detail h3 {
  margin-bottom: 4px !important;
  font-size: 15px !important;
}

.contact-detail p,
.contact-detail a {
  color: #4a4458 !important;
  font-size: 15px;
}

.contact-detail a:hover {
  color: var(--4d-red) !important;
}

.footer {
  background: var(--4d-purple) !important;
  padding-block: clamp(50px, 7vw, 80px) 30px !important;
}

.footer,
.footer h4 {
  color: var(--4d-offwhite) !important;
}

.footer p,
.footer a,
.footer .brxe-text-basic {
  color: rgba(253, 254, 254, 0.72) !important;
}

.footer a:hover {
  color: var(--4d-red) !important;
  text-decoration: none !important;
}

.footer .container {
  padding-inline: var(--pad) !important;
}

.footer .logo-img img,
.footer img.logo-img {
  filter: brightness(0) invert(1);
}

.footer .logo-img,
.footer .logo-img.brxe-image {
  order: 0 !important;
  margin-bottom: 18px;
}

#brxe-ftrcopy {
  order: 1;
}

.footer h4 {
  margin-bottom: 18px !important;
  font-size: 14px !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.footer .nav-link.brxe-button {
  justify-content: flex-start;
  padding: 0 !important;
  color: rgba(253, 254, 254, 0.72) !important;
  font-size: 14.5px;
  line-height: 1.65;
  min-height: 0 !important;
}

.footer .nav-link.brxe-button:hover,
.footer .nav-link.brxe-button:focus-visible {
  color: var(--4d-red) !important;
  text-decoration: none !important;
}

.footer .brxe-block {
  align-items: flex-start;
}

.footer-grid {
  display: grid !important;
  grid-template-columns: 1.4fr 1fr 1fr 1fr !important;
  gap: 40px !important;
}

#brxe-ftrcompany,
#brxe-ftrservices,
#brxe-ftrcontact {
  gap: 11px !important;
}

#brxe-ftrsocial {
  order: 2;
  display: flex !important;
  flex-direction: row !important;
  gap: 12px !important;
  margin-top: 22px;
}

#brxe-ftrfacebook,
#brxe-ftrlinkedin,
#brxe-ftrinstagram {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  min-width: 36px !important;
  min-height: 36px !important;
  padding: 0 !important;
  overflow: hidden;
  border: 1px solid rgba(253, 254, 254, 0.2) !important;
  border-radius: 50% !important;
  color: var(--4d-offwhite) !important;
  font-size: 0 !important;
  line-height: 1 !important;
  text-align: center !important;
  text-indent: -9999px;
}

#brxe-ftrfacebook:hover,
#brxe-ftrlinkedin:hover,
#brxe-ftrinstagram:hover {
  border-color: var(--4d-red) !important;
  background: var(--4d-red) !important;
}

#brxe-ftrfacebook::before,
#brxe-ftrlinkedin::before,
#brxe-ftrinstagram::before {
  display: none !important;
  content: none !important;
}

#brxe-ftrfacebook::after,
#brxe-ftrlinkedin::after,
#brxe-ftrinstagram::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 16px;
  height: 16px;
  background: currentColor;
  content: "";
  text-indent: 0;
  transform: translate(-50%, -50%);
}

#brxe-ftrfacebook::after {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M14 8.2V6.6c0-.8.2-1.3 1.3-1.3H17V2.2c-.8-.1-1.7-.2-2.5-.2-2.5 0-4.2 1.5-4.2 4.3v1.9H7.5v3.5h2.8V22H14V11.7h3l.5-3.5H14Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M14 8.2V6.6c0-.8.2-1.3 1.3-1.3H17V2.2c-.8-.1-1.7-.2-2.5-.2-2.5 0-4.2 1.5-4.2 4.3v1.9H7.5v3.5h2.8V22H14V11.7h3l.5-3.5H14Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

#brxe-ftrlinkedin::after {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M5.1 8.8H2.2V22h2.9V8.8ZM3.7 2C2.7 2 2 2.7 2 3.6s.7 1.7 1.7 1.7 1.7-.7 1.7-1.7S4.7 2 3.7 2ZM22 14.4c0-4-2.1-5.8-4.9-5.8-2.2 0-3.2 1.2-3.8 2.1V8.8h-2.9V22h2.9v-6.5c0-1.7.3-3.4 2.5-3.4s2.2 2 2.2 3.5V22h3v-7.6Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M5.1 8.8H2.2V22h2.9V8.8ZM3.7 2C2.7 2 2 2.7 2 3.6s.7 1.7 1.7 1.7 1.7-.7 1.7-1.7S4.7 2 3.7 2ZM22 14.4c0-4-2.1-5.8-4.9-5.8-2.2 0-3.2 1.2-3.8 2.1V8.8h-2.9V22h2.9v-6.5c0-1.7.3-3.4 2.5-3.4s2.2 2 2.2 3.5V22h3v-7.6Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

#brxe-ftrinstagram::after {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M7.3 2h9.4C19.6 2 22 4.4 22 7.3v9.4c0 2.9-2.4 5.3-5.3 5.3H7.3C4.4 22 2 19.6 2 16.7V7.3C2 4.4 4.4 2 7.3 2Zm0 2C5.5 4 4 5.5 4 7.3v9.4C4 18.5 5.5 20 7.3 20h9.4c1.8 0 3.3-1.5 3.3-3.3V7.3C20 5.5 18.5 4 16.7 4H7.3ZM12 7.3a4.7 4.7 0 1 1 0 9.4 4.7 4.7 0 0 1 0-9.4Zm0 2a2.7 2.7 0 1 0 0 5.4 2.7 2.7 0 0 0 0-5.4Zm5-1.1a1.1 1.1 0 1 1 0-2.2 1.1 1.1 0 0 1 0 2.2Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'%3E%3Cpath d='M7.3 2h9.4C19.6 2 22 4.4 22 7.3v9.4c0 2.9-2.4 5.3-5.3 5.3H7.3C4.4 22 2 19.6 2 16.7V7.3C2 4.4 4.4 2 7.3 2Zm0 2C5.5 4 4 5.5 4 7.3v9.4C4 18.5 5.5 20 7.3 20h9.4c1.8 0 3.3-1.5 3.3-3.3V7.3C20 5.5 18.5 4 16.7 4H7.3ZM12 7.3a4.7 4.7 0 1 1 0 9.4 4.7 4.7 0 0 1 0-9.4Zm0 2a2.7 2.7 0 1 0 0 5.4 2.7 2.7 0 0 0 0-5.4Zm5-1.1a1.1 1.1 0 1 1 0-2.2 1.1 1.1 0 0 1 0 2.2Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

#brxe-ftrsocial svg {
  display: block !important;
  grid-area: 1 / 1 !important;
  width: 16px !important;
  height: 16px !important;
  margin: 0 !important;
  fill: currentColor !important;
  flex: 0 0 16px;
}

#brxe-ftrbottom {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between;
  align-items: center;
  width: 100% !important;
  gap: 16px;
  margin-top: 50px;
  padding-top: 24px;
  border-top: 1px solid rgba(253, 254, 254, 0.14);
  color: rgba(253, 254, 254, 0.5);
  font-size: 13px;
}

#brxe-ftrcredit {
  color: rgba(253, 254, 254, 0.5) !important;
  flex: 0 0 auto;
  font-size: 13px;
  white-space: nowrap;
}

#brxe-ftrbottomlinks {
  display: flex !important;
  flex-direction: row !important;
  flex: 0 0 auto !important;
  justify-content: flex-end;
  width: auto !important;
  gap: 18px !important;
  margin-left: auto;
}

#brxe-ftrprivacy,
#brxe-ftrbottomcontact {
  color: rgba(253, 254, 254, 0.7) !important;
  font-size: 13px !important;
  line-height: 1.4;
}

#brxe-ftraddr,
#brxe-ftrphone,
#brxe-ftremail {
  position: relative;
  padding-left: 26px !important;
}

#brxe-ftrphone,
#brxe-ftremail {
  display: inline-flex !important;
}

#brxe-ftraddr::before,
#brxe-ftrphone::before,
#brxe-ftremail::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.1em;
  width: 16px;
  height: 16px;
  background: #ff6663 !important;
  opacity: 1 !important;
  -webkit-mask: var(--icon-pin) center / contain no-repeat;
  mask: var(--icon-pin) center / contain no-repeat;
}

#brxe-ftraddr::before {
  -webkit-mask-image: var(--icon-pin);
  mask-image: var(--icon-pin);
}

#brxe-ftrphone::before {
  -webkit-mask-image: var(--icon-phone);
  mask-image: var(--icon-phone);
}

#brxe-ftremail::before {
  -webkit-mask-image: var(--icon-mail);
  mask-image: var(--icon-mail);
}

.single-post-page {
  background: var(--4d-offwhite);
  color: var(--4d-purple);
  overflow-x: clip;
}

.single-hero {
  position: relative;
  isolation: isolate;
  padding: clamp(150px, 18vw, 220px) 0 clamp(70px, 9vw, 120px);
  overflow: hidden;
  background:
    radial-gradient(circle at 78% 22%, rgba(255, 75, 70, 0.24), transparent 24rem),
    linear-gradient(135deg, var(--4d-purple) 0%, #201327 55%, #120c16 100%);
  color: var(--4d-offwhite);
}

.single-hero::after {
  position: absolute;
  inset: auto -10% -44% auto;
  z-index: -1;
  width: min(620px, 58vw);
  aspect-ratio: 1;
  border: 1px solid rgba(253, 254, 254, 0.12);
  border-radius: 50%;
  content: "";
}

.single-hero__inner {
  max-width: 940px !important;
}

.single-hero .pill {
  margin-bottom: 22px;
}

.single-hero h1 {
  max-width: 900px;
  margin: 0;
  color: var(--4d-offwhite) !important;
  font-size: clamp(42px, 7vw, 84px);
  line-height: 0.98;
  overflow-wrap: anywhere;
}

.single-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 24px;
  color: rgba(253, 254, 254, 0.72);
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.single-hero__meta span + span {
  position: relative;
}

.single-hero__meta span + span::before {
  position: absolute;
  left: -11px;
  color: rgba(253, 254, 254, 0.35);
  content: "/";
}

.single-hero p {
  max-width: 720px;
  margin: 28px 0 0;
  color: rgba(253, 254, 254, 0.82);
  font-size: clamp(18px, 2vw, 22px);
  line-height: 1.55;
  overflow-wrap: break-word;
}

.single-featured {
  margin-top: clamp(-54px, -5vw, -34px);
}

.single-featured img {
  display: block;
  width: 100%;
  max-height: 620px;
  object-fit: cover;
  border-radius: 8px;
  box-shadow: 0 24px 80px rgba(38, 23, 47, 0.18);
}

.single-article-section {
  padding: clamp(58px, 8vw, 98px) 0 clamp(76px, 10vw, 130px);
}

.single-article-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: clamp(34px, 6vw, 78px);
  align-items: start;
}

.single-content {
  max-width: 760px;
  color: #3e3548;
  font-size: 18px;
  line-height: 1.72;
  overflow-wrap: break-word;
}

.single-content > *:first-child {
  margin-top: 0;
}

.single-content h2,
.single-content h3,
.single-content h4 {
  margin: 1.7em 0 0.55em;
  color: var(--4d-purple);
  line-height: 1.12;
}

.single-content h2 {
  font-size: clamp(30px, 4vw, 46px);
}

.single-content h3 {
  font-size: clamp(24px, 3vw, 32px);
}

.single-content p,
.single-content li {
  color: #4a4458;
}

.single-content a {
  color: var(--4d-red);
  font-weight: 700;
  text-decoration: none;
}

.single-content a:hover {
  color: var(--4d-purple);
}

.single-content img {
  max-width: 100%;
  height: auto;
  border-radius: 8px;
}

.single-content blockquote {
  margin: 34px 0;
  padding: 28px 30px;
  border-left: 4px solid var(--4d-red);
  border-radius: 0 8px 8px 0;
  background: #fff;
  color: var(--4d-purple);
  font-size: clamp(22px, 3vw, 30px);
  line-height: 1.3;
  box-shadow: 0 18px 55px rgba(38, 23, 47, 0.08);
}

.single-aside {
  position: sticky;
  top: 112px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.single-aside-card,
.case-testimonial {
  border: 1px solid rgba(38, 23, 47, 0.1);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 18px 48px rgba(38, 23, 47, 0.08);
}

.single-aside-card {
  padding: 28px;
}

.single-aside-card h2 {
  margin: 0 0 22px;
  color: var(--4d-purple);
  font-size: 22px;
  line-height: 1.18;
}

.single-aside-card p {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin: 0;
  padding: 14px 0;
  border-top: 1px solid rgba(38, 23, 47, 0.09);
  color: #5b5365;
  font-size: 14px;
  line-height: 1.45;
}

.single-aside-card strong {
  color: var(--4d-purple);
}

.single-aside-card .btn {
  width: 100%;
  margin-top: 22px;
}

.single-aside-card .btn-icon-arrow {
  display: inline-block;
  width: 18px;
  height: 18px;
  background: currentColor;
  -webkit-mask: var(--icon-arrow-right) center / contain no-repeat;
  mask: var(--icon-arrow-right) center / contain no-repeat;
  transform: translateY(-2px);
  transition: transform 0.2s ease;
}

.single-aside-card .btn:hover .btn-icon-arrow {
  transform: translate(3px, -2px);
}

.case-testimonial {
  padding: 30px;
  background: var(--4d-purple);
  color: var(--4d-offwhite);
}

.case-testimonial span {
  display: block;
  margin-bottom: 16px;
  color: var(--4d-red);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.case-testimonial blockquote {
  margin: 0;
  color: var(--4d-offwhite);
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 1.28;
}

.legal-content {
  max-width: 860px;
  margin-inline: auto;
  color: #4a4458;
  font-size: 18px;
  line-height: 1.72;
  overflow-wrap: break-word;
}

.legal-content h2,
.legal-content h3 {
  color: var(--4d-purple);
  line-height: 1.14;
  overflow-wrap: anywhere;
}

.legal-content h2 {
  margin: 0 0 18px;
  font-size: clamp(30px, 4vw, 44px);
}

.legal-content h3 {
  margin: 34px 0 12px;
  font-size: clamp(22px, 3vw, 30px);
}

.legal-content p {
  margin: 0 0 18px;
}

.js .reveal,
.js .reveal-stagger > * {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}

.js .reveal.is-visible,
.js .reveal-stagger.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

.js .reveal-stagger.is-visible > *:nth-child(2) {
  transition-delay: 0.08s;
}

.js .reveal-stagger.is-visible > *:nth-child(3) {
  transition-delay: 0.16s;
}

.js .reveal-stagger.is-visible > *:nth-child(4) {
  transition-delay: 0.24s;
}

@media (min-width: 961px) {
  .site-nav.brxe-nav-menu {
    position: absolute !important;
    left: 50%;
    flex: 0 0 auto !important;
    transform: translateX(-50%);
  }

  .site-header .btn-primary.brxe-button {
    margin-left: auto;
  }

  .hero-grid {
    min-height: 794px !important;
  }
}

@media (max-width: 960px) {
  .container {
    max-width: 100% !important;
  }

  .section {
    overflow-x: clip;
  }

  .work-grid,
  .blog-grid,
  .contact-grid,
  .testimonials-grid,
  .process-steps {
    grid-template-columns: 1fr !important;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  #brxe-bloghead {
    align-items: flex-start !important;
  }

  .process-grid {
    grid-template-columns: 1fr !important;
  }

  .service-row {
    grid-template-columns: 48px minmax(0, 1fr) 44px !important;
    gap: 18px;
  }

  .service-row::after {
    width: 44px;
    height: 44px;
  }

  .nav-links {
    display: flex !important;
    position: absolute;
    top: calc(100% + 1px);
    right: 0;
    left: 0;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    max-height: calc(100vh - 80px);
    padding: 6px 0 14px !important;
    overflow-y: auto;
    border-bottom: 1px solid var(--4d-line);
    background: var(--4d-offwhite);
    box-shadow: 0 22px 40px -22px rgba(33, 23, 51, 0.25);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-10px);
    transition: opacity 0.42s cubic-bezier(0.25, 0.1, 0.25, 1), transform 0.42s cubic-bezier(0.25, 0.1, 0.25, 1), visibility 0s linear 0.42s;
  }

  .site-header .btn-primary {
    display: none !important;
  }

  .nav-burger.brxe-button {
    display: block !important;
  }

  .site-header.nav-open .nav-links {
    display: flex !important;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    transition-delay: 0s;
  }

  .site-header.nav-open .nav-link {
    justify-content: flex-start;
    padding: 15px 24px !important;
    border-bottom: 1px solid rgba(132, 145, 163, 0.12) !important;
    font-size: 16px;
  }

  .site-header.nav-open .nav-links > .nav-link:last-child {
    border-bottom: 0 !important;
  }

  .nav-item-drop,
  #brxe-navservicesitem {
    display: block !important;
    width: 100% !important;
  }

  #brxe-navservices::after {
    display: none;
  }

  .nav-drop,
  #brxe-navdrop {
    position: static !important;
    display: block !important;
    width: 100% !important;
    min-width: 0;
    padding: 0 !important;
    border: 0;
    border-radius: 0 !important;
    background: rgba(247, 186, 184, 0.1) !important;
    box-shadow: none;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    transition: none;
    pointer-events: auto;
  }

  .nav-drop .nav-link.brxe-button,
  #brxe-navdrop .nav-link.brxe-button {
    padding: 12px 24px 12px 42px !important;
    border-radius: 0 !important;
    border-bottom: 1px solid rgba(132, 145, 163, 0.08) !important;
    font-size: 14.5px;
  }

  .site-header .nav-inner {
    position: relative;
    min-height: 74px;
    gap: 14px !important;
  }

  .logo-img,
  .logo-img.brxe-image {
    order: 1;
  }

  .site-header .btn-primary.brxe-button {
    order: 2;
    margin-left: auto;
  }

  .site-nav.brxe-nav-menu {
    order: 3;
    flex: 0 0 auto !important;
    width: 40px !important;
    min-width: 40px !important;
    margin-left: 0 !important;
  }

  .site-nav .bricks-nav-menu-wrapper {
    display: none !important;
  }

  .site-nav .bricks-mobile-menu-toggle {
    display: block !important;
    flex: 0 0 40px !important;
  }

  .site-nav .bricks-mobile-menu-wrapper::before {
    display: none !important;
    content: none !important;
  }

  .site-nav .bricks-mobile-menu-overlay {
    display: none !important;
  }

  /* iOS: the nav is transform-centred on desktop; a position:fixed child
     inside a transformed ancestor mis-paints on iOS. The desktop menu is
     hidden at mobile, so drop the transform here. */
  .site-nav.brxe-nav-menu {
    transform: none !important;
  }

  /* iOS: backdrop-filter on the header ALSO creates a containing block for the
     position:fixed mobile-menu panel (same trap as transform), so the panel is
     clipped inside the ~74px header and appears then vanishes - the real cause
     of the "menu disappears before I can tap it" bug. The header background is
     near-opaque anyway, so dropping the blur on mobile is visually negligible. */
  .site-header,
  .site-header.brxe-section,
  .site-header.is-scrolled {
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
    background: rgba(253, 254, 254, 0.98) !important;
  }

  /* Full-width dropdown panel under the header (overrides Bricks' default left
     drawer). Bricks' own JS drives open/close + the opacity fade and z-index. */
  .site-nav .bricks-mobile-menu-wrapper {
    position: fixed !important;
    top: 87px !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    /* Bricks positions the menu so the panel won't size to it; an explicit
       height is required or the fixed panel collapses to 0 (the tablet bug). */
    height: min(560px, calc(100dvh - 87px)) !important;
    max-height: calc(100dvh - 87px) !important;
    padding: 6px 0 14px !important;
    overflow-y: auto;
    overscroll-behavior: contain;
    border-bottom: 1px solid var(--4d-line);
    background: var(--4d-offwhite) !important;
    box-shadow: 0 22px 40px -22px rgba(33, 23, 51, 0.25);
    transform: translateY(-8px) !important;
  }

  .site-nav.show-mobile-menu .bricks-mobile-menu-wrapper {
    transform: translateY(0) !important;
  }

  .site-nav .bricks-mobile-menu {
    display: flex !important;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  .site-nav .bricks-mobile-menu li {
    display: block !important;
    width: 100%;
  }

  .site-nav .bricks-mobile-menu a,
  .site-nav .bricks-mobile-menu .brx-submenu-toggle > a,
  .site-nav .bricks-mobile-menu .brx-submenu-toggle > button {
    display: block !important;
    width: 100% !important;
    padding: 15px 24px !important;
    border-bottom: 1px solid rgba(132, 145, 163, 0.12) !important;
    color: var(--4d-purple) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 1.6 !important;
    text-align: left;
  }

  .site-nav .bricks-mobile-menu .brx-submenu-toggle {
    display: block !important;
  }

  .site-nav .bricks-mobile-menu .brx-submenu-toggle > a::after {
    display: none;
  }

  .site-nav .bricks-mobile-menu .brx-submenu-toggle > button {
    display: none !important;
  }

  .site-nav .bricks-mobile-menu .sub-menu {
    position: static !important;
    display: block !important;
    min-width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: rgba(247, 186, 184, 0.1) !important;
    box-shadow: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .site-nav .bricks-mobile-menu .sub-menu li,
  .site-nav .bricks-mobile-menu .sub-menu a {
    pointer-events: auto !important;
  }

  .site-nav .bricks-mobile-menu .sub-menu a {
    padding: 10px 24px 10px 42px !important;
    border-bottom: 1px solid rgba(132, 145, 163, 0.08) !important;
    font-size: 14.5px !important;
    line-height: 1.6 !important;
  }

  .site-nav .bricks-mobile-menu a:hover,
  .site-nav .bricks-mobile-menu a:focus,
  .site-nav .bricks-mobile-menu .brx-submenu-toggle > a:hover,
  .site-nav .bricks-mobile-menu .brx-submenu-toggle > a:focus,
  .site-nav .bricks-mobile-menu .sub-menu a:hover,
  .site-nav .bricks-mobile-menu .sub-menu a:focus {
    background: rgba(247, 186, 184, 0.22) !important;
    color: var(--4d-purple) !important;
    text-decoration: none !important;
  }

  .hero,
  .hero-grid {
    min-height: 441px;
  }

  .hero-grid {
    grid-template-columns: 1fr !important;
    padding-block: 75px !important;
  }

  .hero-wire {
    display: none !important;
  }

  .page-hero-inner,
  .network,
  .why-grid,
  .detail-grid {
    grid-template-columns: 1fr !important;
  }

  .hero-mockup img {
    width: 100% !important;
    transform: none;
  }

  .hero-wire-right {
    display: none !important;
  }

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

@media (min-width: 601px) and (max-width: 960px) {
  .site-header .btn-primary.brxe-button {
    display: inline-flex !important;
  }

  .hero,
  .hero-grid {
    min-height: 441px;
  }

  .single-article-grid {
    grid-template-columns: 1fr;
  }

  .single-aside {
    position: static;
  }
}

@media (max-width: 600px) {
  .site-header {
    min-height: 74px;
  }

  body {
    padding-top: 74px;
  }

  .site-header .nav-inner {
    padding-inline: 20px !important;
  }

  .site-nav .bricks-mobile-menu-wrapper {
    top: 75px !important;
    height: min(560px, calc(100dvh - 75px)) !important;
    max-height: calc(100dvh - 75px);
  }

  .site-nav.brxe-nav-menu {
    margin-left: auto !important;
  }

  .logo-img img,
  img.logo-img {
    height: 36px !important;
  }

  .btn-primary.brxe-button {
    min-width: 139px !important;
    min-height: 56px;
    padding-inline: 24px !important;
  }

  .hero-title {
    font-size: 36px !important;
    line-height: 1.1 !important;
  }

  .hero,
  .hero-grid {
    min-height: 477px;
  }

  .hero-grid {
    padding-block: 69px !important;
  }

  .hero-text {
    display: block !important;
    font-size: 17px !important;
    line-height: 1.6 !important;
  }

  .hero .btn-light.brxe-button {
    display: inline-flex !important;
    min-width: 251px !important;
  }

  .logo-row {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-items: center;
    justify-content: center !important;
    gap: 24px 26px !important;
  }

  #brxe-logosrow {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    justify-items: center;
    justify-content: center !important;
  }

  .footer-grid {
    grid-template-columns: 1fr !important;
  }

  #brxe-ftrgrid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 30px !important;
  }

  #brxe-ftrbottom {
    flex-direction: column !important;
    align-items: flex-start;
  }

  #brxe-ftrcredit {
    white-space: normal;
  }

  #brxe-ftrbottomlinks {
    justify-content: flex-start;
    margin-left: 0;
  }

  #brxe-bloghead {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .section-head-row {
    flex-direction: column;
    align-items: flex-start;
  }

  #brxe-blogall {
    align-self: flex-start;
  }

  .service-row {
    grid-template-columns: 1fr !important;
    gap: 12px;
    padding: 24px 0 !important;
  }

  .service-row:hover,
  .service-row:focus-visible {
    padding-inline: 16px !important;
  }

  .service-row::after {
    width: 42px;
    height: 42px;
  }

  .step-card,
  .testimonial-card,
  .card-body {
    padding-inline: 22px !important;
  }

  .cta {
    padding: 36px 24px !important;
  }

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

  .form-row {
    grid-template-columns: 1fr !important;
    gap: 0;
  }

  .contact-form .form-group:nth-of-type(1),
  .contact-form .form-group:nth-of-type(2),
  .contact-form .form-group:nth-of-type(3),
  .contact-form .form-group:nth-of-type(4) {
    float: none;
    width: 100%;
  }

  .hero-stats .dot-sep {
    display: none;
  }

  .single-hero {
    padding: 118px 0 64px;
  }

  .single-hero h1 {
    font-size: 38px;
  }

  .single-hero__meta span + span::before {
    display: none;
  }

  .single-featured {
    margin-top: -28px;
  }

  .single-article-grid {
    grid-template-columns: 1fr;
  }

  .single-content {
    font-size: 16px;
    line-height: 1.68;
  }

  .single-aside {
    position: static;
  }

  .single-aside-card,
  .case-testimonial {
    padding: 24px;
  }
}

/* Source-aligned single blog post template. */
.single-post-page {
  background: var(--4d-offwhite) !important;
  overflow-x: clip;
}

.single-post-page .single-hero {
  position: relative;
  isolation: isolate;
  min-height: 470px;
  padding: clamp(72px, 5vw, 94px) 0 clamp(142px, 12vw, 190px);
  overflow: visible;
  background: var(--4d-gradient);
  color: var(--4d-offwhite);
}

.single-post-page .brxe-section {
  border-top: 0 !important;
}

.single-post-page .single-hero::after {
  display: none;
}

.single-post-page .single-hero__inner {
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin-inline: auto !important;
  padding-inline: var(--pad) !important;
}

.single-post-pill {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  margin-bottom: 24px;
  padding: 8px 18px;
  border-radius: 999px;
  background: rgba(253, 254, 254, 0.16);
  color: rgba(253, 254, 254, 0.84);
  font-family: var(--font-head);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.single-post-page .single-hero h1 {
  max-width: 760px;
  margin: 0;
  color: var(--4d-offwhite) !important;
  font-size: clamp(46px, 5.2vw, 68px);
  line-height: 1.02;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.single-post-page .single-hero__meta {
  display: flex;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-top: 20px;
  color: rgba(253, 254, 254, 0.7);
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.3;
  text-transform: uppercase;
}

.single-post-page .single-hero__meta > * {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 12px;
  width: auto !important;
}

.single-post-page .single-hero__meta > * + *::before {
  position: static;
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(253, 254, 254, 0.5);
  content: "";
}

.single-post-page .single-hero p {
  max-width: 640px;
  margin: 24px 0 0;
  color: rgba(253, 254, 254, 0.84);
  font-size: 17px;
  line-height: 1.62;
  overflow-wrap: break-word;
}

.single-post-page .single-featured {
  position: relative;
  z-index: 3;
  width: min(calc(100% - (var(--pad) * 2)), 1200px) !important;
  max-width: 1200px !important;
  margin-top: -98px;
  padding-inline: 0 !important;
}

.single-featured__frame {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  border-radius: 18px;
  background:
    radial-gradient(circle at 49% 42%, rgba(255, 102, 99, 0.16), transparent 245px),
    linear-gradient(125deg, #150d22 0%, #211733 38%, #7d3a5b 100%);
  box-shadow: 0 28px 68px rgba(33, 23, 51, 0.18);
}

.single-featured__frame img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: none;
  object-fit: cover;
  border-radius: 0;
  box-shadow: none;
}

.single-featured__image,
.single-featured__image.brxe-image {
  display: block;
  width: 100% !important;
  height: 100% !important;
}

.single-featured__image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}

.single-featured__placeholder {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: rgba(253, 254, 254, 0.42);
  font-size: 11px;
  line-height: 1;
}

.single-featured__icon {
  width: 24px;
  height: 24px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='16' rx='2'/%3E%3Ccircle cx='8.5' cy='9.5' r='1.5'/%3E%3Cpath d='m21 15-5-5L5 20'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='16' rx='2'/%3E%3Ccircle cx='8.5' cy='9.5' r='1.5'/%3E%3Cpath d='m21 15-5-5L5 20'/%3E%3C/svg%3E") center / contain no-repeat;
}

.single-post-page .single-article-section {
  padding: 64px 0 96px;
}

.single-article-container {
  max-width: 760px !important;
  padding-inline: var(--pad) !important;
}

.single-post-page .single-content {
  width: 100%;
  max-width: 720px;
  margin-inline: auto;
  color: #4a4458;
  font-size: 16px;
  line-height: 1.72;
  overflow-wrap: break-word;
}

.single-post-page .single-content > *:first-child {
  margin-top: 0;
}

.single-post-page .single-content p {
  margin: 0 0 24px;
  color: #4a4458;
}

.single-post-page .single-content h2 {
  margin: 76px 0 18px;
  color: var(--4d-purple);
  font-size: clamp(34px, 4vw, 46px);
  line-height: 1.1;
}

.single-post-page .single-content h3 {
  margin: 42px 0 14px;
  color: var(--4d-purple);
  font-size: 24px;
  line-height: 1.18;
}

.single-post-page .single-content strong {
  color: var(--4d-purple);
  font-weight: 700;
}

.single-post-page .single-content a {
  color: var(--4d-red);
  font-weight: 700;
  text-decoration: none;
}

.single-post-page .single-content a:hover {
  text-decoration: underline;
}

.single-post-page .single-content ul,
.single-post-page .single-content ol {
  display: grid;
  gap: 18px;
  margin: 24px 0 28px;
  padding-left: 0;
  list-style: none;
}

.single-post-page .single-content li {
  position: relative;
  padding-left: 26px;
  color: #4a4458;
}

.single-post-page .single-content li::before {
  position: absolute;
  top: 0.72em;
  left: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--4d-red);
  content: "";
}

.single-post-page .single-content blockquote {
  margin: 46px 0;
  padding: 0 0 0 28px;
  border-left: 4px solid var(--4d-red);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--4d-purple);
  font-size: 24px;
  line-height: 1.35;
}

.single-post-page .single-content figure {
  margin: 42px 0;
}

.single-post-page--insight .single-content .wp-block-image {
  display: none;
}

.single-post-page .single-content img {
  width: 100%;
  height: auto;
  border-radius: 16px;
}

.single-post-cta {
  margin-top: 72px;
  padding: clamp(32px, 5vw, 46px);
  border-radius: 18px;
  background: var(--4d-gradient);
  color: var(--4d-offwhite);
}

.single-post-cta h2 {
  margin: 0 0 16px !important;
  color: var(--4d-offwhite) !important;
  font-size: clamp(26px, 3vw, 34px) !important;
  line-height: 1.12 !important;
}

.single-post-cta p {
  max-width: 610px;
  margin: 0 0 26px !important;
  color: rgba(253, 254, 254, 0.86) !important;
  font-size: 15px;
  line-height: 1.58;
}

.single-post-cta .btn {
  min-width: 0 !important;
  min-height: 48px;
  padding: 13px 24px !important;
  font-size: 14px;
}

.single-post-page .case-testimonial {
  margin: 56px 0 0;
}

@media (max-width: 960px) {
  .single-post-page .single-hero {
    min-height: 420px;
    padding-top: 78px;
    padding-bottom: 132px;
  }

  .single-post-page .single-featured {
    margin-top: -78px;
  }

  .single-featured__frame {
    aspect-ratio: 16 / 8.5;
  }
}

@media (max-width: 600px) {
  .single-post-page .single-hero {
    min-height: auto;
    padding: 64px 0 108px;
  }

  .single-post-page .single-hero__inner {
    padding-inline: 24px !important;
  }

  .single-post-page .single-hero h1 {
    font-size: clamp(36px, 10vw, 46px);
    line-height: 1.06;
  }

  .single-post-page .single-hero p {
    font-size: 16px;
  }

  .single-post-page .single-hero__meta {
    gap: 7px 10px;
  }

  .single-post-page .single-featured {
    width: calc(100% - 48px) !important;
    margin-top: -58px;
  }

  .single-featured__frame {
    aspect-ratio: 1.35 / 1;
    border-radius: 14px;
  }

  .single-post-page .single-article-section {
    padding-top: 52px;
  }

  .single-article-container {
    padding-inline: 24px !important;
  }

  .single-post-page .single-content {
    font-size: 16px;
    line-height: 1.68;
  }

  .single-post-page .single-content h2 {
    margin-top: 54px;
    font-size: 31px;
  }

  .single-post-cta {
    margin-top: 56px;
    padding: 30px 26px;
  }
}

/* Source-aligned single case study template. */
.case-template {
  background: var(--4d-offwhite) !important;
  color: var(--4d-ink);
  overflow-x: clip;
}

.case-template .bricks-lazy-hidden {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.case-template .brxe-section {
  border-top: 0 !important;
}

.case-template .case-hero {
  position: relative;
  isolation: isolate;
  min-height: 500px;
  padding: clamp(74px, 5vw, 96px) 0 clamp(136px, 11vw, 176px);
  overflow: visible;
  background: var(--4d-gradient);
  color: var(--4d-offwhite);
}

.case-template .case-hero::after {
  display: none;
}

.case-template .case-hero__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin-inline: auto !important;
  padding-inline: var(--pad) !important;
}

.case-template .case-hero h1 {
  max-width: 760px;
  margin: 0;
  color: var(--4d-offwhite) !important;
  font-size: clamp(46px, 5vw, 68px);
  line-height: 1.02;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.case-template .case-hero p {
  max-width: 650px;
  margin: 24px 0 0;
  color: rgba(253, 254, 254, 0.84) !important;
  font-size: 17px;
  line-height: 1.62;
}

.case-template .case-meta,
.case-template .case-hero__meta {
  display: flex;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 8px 12px;
  margin-top: 20px;
  color: rgba(253, 254, 254, 0.7);
  font-family: var(--font-head);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.3;
  text-transform: uppercase;
}

.case-template .case-meta > *,
.case-template .case-hero__meta > * {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 12px;
  width: auto !important;
}

.case-template .case-meta > * + *::before,
.case-template .case-hero__meta > * + *::before {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: rgba(253, 254, 254, 0.5);
  content: "";
}

.case-template .case-preview {
  position: relative;
  z-index: 4;
  width: min(calc(100% - (var(--pad) * 2)), 1200px) !important;
  max-width: 1200px !important;
  margin-top: -96px;
  padding-inline: 0 !important;
}

.case-preview__frame {
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 43%, rgba(255, 102, 99, 0.18), transparent 260px),
    linear-gradient(125deg, #150d22 0%, #211733 38%, #7d3a5b 100%);
  box-shadow: 0 28px 68px rgba(33, 23, 51, 0.18);
}

.case-preview__placeholder {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 9px;
  color: rgba(253, 254, 254, 0.4);
  font-size: 11px;
  line-height: 1;
}

.case-preview__image,
.case-preview__image.brxe-image {
  display: block;
  width: 100% !important;
  height: 100% !important;
}

.case-preview__image img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  max-height: none;
  object-fit: cover;
  border-radius: 0;
  box-shadow: none;
}

.case-preview__icon {
  width: 25px;
  height: 25px;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='13' rx='2'/%3E%3Cpath d='M8 21h8'/%3E%3Cpath d='M12 17v4'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='13' rx='2'/%3E%3Cpath d='M8 21h8'/%3E%3Cpath d='M12 17v4'/%3E%3C/svg%3E") center / contain no-repeat;
}

.case-facts-section {
  padding: 34px 0 10px;
}

.case-facts-section > .case-facts,
.case-facts-wrap {
  width: min(calc(100% - (var(--pad) * 2)), 1200px) !important;
  max-width: 1200px !important;
  padding-inline: 0 !important;
}

.case-facts {
  overflow: hidden;
  border: 1px solid rgba(132, 145, 163, 0.18);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 20px 54px rgba(33, 23, 51, 0.08);
}

.case-facts__row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  border-top: 1px solid rgba(132, 145, 163, 0.16);
}

.case-facts > .case-facts__row:first-child,
.case-facts > .case-fact:first-child {
  border-top: 0;
}

.case-facts__row--wide,
.case-fact--sectors {
  grid-template-columns: 1fr;
}

.case-facts__row--three,
.case-facts__row--work {
  grid-template-columns: 1fr 0.72fr 0.72fr;
}

.case-fact,
.case-facts__item {
  min-width: 0;
  padding: 24px 28px 23px;
  border-left: 1px solid rgba(132, 145, 163, 0.16);
}

.case-facts > .case-fact {
  border-top: 1px solid rgba(132, 145, 163, 0.16);
  border-left: 0;
}

.case-facts__row > .case-fact:first-child,
.case-facts__item:first-child {
  border-left: 0;
}

.case-fact__label,
.case-facts__label {
  margin-bottom: 8px;
  color: var(--4d-blue);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.case-fact__value,
.case-facts__value {
  margin: 0;
  color: var(--4d-purple);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

.case-visit-link,
.case-facts__link {
  display: inline-flex;
  align-items: center;
  align-self: stretch;
  justify-content: flex-start;
  min-height: 100%;
  padding: 24px 28px 23px !important;
  border-left: 1px solid rgba(132, 145, 163, 0.16) !important;
  background: transparent !important;
  color: var(--4d-red) !important;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  text-decoration: none;
}

.case-visit-link:hover,
.case-facts__link:hover {
  background: rgba(247, 186, 184, 0.16) !important;
  color: var(--4d-red) !important;
  text-decoration: underline;
}

.case-visit-wrap {
  display: flex;
  min-height: 100%;
  margin: 0;
}

.case-visit-wrap:empty {
  display: none;
}

.case-chip-row {
  display: flex;
  flex-direction: row !important;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
}

.case-chip {
  display: inline-flex;
  align-items: center;
  width: auto !important;
  min-height: 28px;
  padding: 7px 12px;
  border: 1px solid rgba(255, 102, 99, 0.18);
  border-radius: 999px;
  background: rgba(247, 186, 184, 0.24);
  color: var(--4d-purple);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

.case-section {
  padding: clamp(78px, 7vw, 104px) 0;
}

.case-content-section {
  padding: clamp(52px, 6vw, 80px) 0;
}

.case-content {
  width: 100%;
  max-width: 720px;
  margin-inline: auto;
  color: #4a4458;
  font-size: 16px;
  line-height: 1.72;
}

.case-content > *:first-child {
  margin-top: 0;
}

.case-content p {
  margin: 0 0 22px;
  color: #4a4458 !important;
}

.case-content h2 {
  margin: 44px 0 20px;
  color: var(--4d-purple) !important;
  font-size: clamp(34px, 3.8vw, 46px);
  line-height: 1.1;
}

.case-content h3 {
  margin: 32px 0 14px;
  color: var(--4d-purple) !important;
  font-size: clamp(24px, 2.4vw, 31px);
  line-height: 1.18;
}

.case-content ul,
.case-content ol {
  display: grid;
  gap: 16px;
  margin: 28px 0 34px;
  padding-left: 0;
  list-style: none;
}

.case-content li {
  position: relative;
  padding-left: 26px;
  color: #4a4458;
}

.case-content li::before {
  position: absolute;
  top: 0.72em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--4d-red);
  content: "";
}

.case-content blockquote {
  margin: 46px 0;
  padding: 0 0 0 28px;
  border-left: 4px solid var(--4d-red);
  background: transparent;
  color: var(--4d-purple);
  font-size: 22px;
  font-weight: 700;
  line-height: 1.38;
}

.case-content figure,
.case-content .wp-block-image {
  margin: 42px 0;
}

.case-content img {
  width: 100%;
  height: auto;
  border-radius: 16px;
}

.case-section--challenge {
  padding-top: 84px;
}

.case-section--approach {
  background: #f4f5f6;
}

.case-measure {
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin-inline: auto !important;
  padding-inline: var(--pad) !important;
}

.case-section__kicker,
.case-section-kicker {
  margin: 0 0 26px;
  color: var(--4d-blue);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-transform: uppercase;
}

.case-section h2 {
  margin: 0 0 24px;
  color: var(--4d-purple) !important;
  font-size: clamp(34px, 3.8vw, 46px);
  line-height: 1.1;
  letter-spacing: 0;
}

.case-section h3 {
  margin: 46px 0 16px;
  color: var(--4d-purple) !important;
  font-size: clamp(24px, 2.4vw, 31px);
  line-height: 1.18;
}

.case-section p {
  margin: 0 0 22px;
  color: #4a4458 !important;
  font-size: 16px;
  line-height: 1.72;
}

.case-section p:last-child {
  margin-bottom: 0;
}

.case-feature-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 26px;
  margin: 34px 0 8px;
}

.case-feature {
  position: relative;
  padding-left: 26px;
  color: var(--4d-purple);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.45;
}

.case-feature::before {
  position: absolute;
  top: 0.45em;
  left: 0;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--4d-red);
  content: "";
}

.case-clients-section {
  padding: 42px 0 96px;
}

.case-clients,
.case-clients-wrap {
  width: min(calc(100% - (var(--pad) * 2)), 1200px) !important;
  max-width: 1200px !important;
  padding-inline: 0 !important;
}

.case-clients__title,
.case-clients-title {
  margin: 0 0 26px;
  color: var(--4d-blue);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.2;
  text-align: center;
  text-transform: uppercase;
}

.case-client-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.case-client-chip,
.case-client {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 58px;
  padding: 17px 18px;
  border: 1px solid rgba(132, 145, 163, 0.2);
  border-radius: 999px;
  background: #fff;
  color: var(--4d-purple);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
}

.case-testimonial-section {
  padding: 0 0 96px;
}

.case-testimonial-section:has(.case-testimonial-panel__quote:empty) {
  display: none;
}

.case-testimonial-wrap {
  width: min(calc(100% - (var(--pad) * 2)), 1200px) !important;
  max-width: 1200px !important;
  padding-inline: 0 !important;
}

.case-testimonial-panel {
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 102, 99, 0.2), transparent 250px),
    var(--4d-gradient);
  color: var(--4d-offwhite);
  padding: clamp(44px, 5vw, 66px);
}

body #brxe-cstestsec,
body #brxe-cstestctn,
body #brxe-cstestpanel,
body #brxe-cstestpanel * {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

body #brxe-cstestpanel {
  display: flex !important;
  flex-direction: column !important;
  background-color: var(--4d-purple) !important;
}

.case-testimonial-panel::before {
  position: absolute;
  top: 34px;
  right: 48px;
  z-index: 1;
  color: rgba(253, 254, 254, 0.1);
  font-size: 142px;
  font-weight: 700;
  line-height: 1;
  content: "\"";
}

.case-testimonial-panel::after {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 102, 99, 0.2), transparent 250px),
    var(--4d-gradient);
  content: "";
}

.case-testimonial-panel p {
  position: relative;
  z-index: 1;
  max-width: 930px;
  margin: 0 0 24px;
  color: rgba(253, 254, 254, 0.88) !important;
  font-size: 17px;
  line-height: 1.62;
}

.case-testimonial-panel p:first-child {
  color: var(--4d-offwhite) !important;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 700;
  line-height: 1.36;
}

.case-testimonial-panel p:last-of-type {
  margin-bottom: 30px;
}

.case-testimonial-author {
  position: relative;
  z-index: 1;
  color: var(--4d-offwhite);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
}

.case-bottom-cta {
  padding: clamp(82px, 8vw, 112px) 0 clamp(78px, 7vw, 104px);
  background: var(--4d-purple);
  color: var(--4d-offwhite);
  text-align: center;
}

.case-bottom-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(100%, 720px) !important;
  max-width: 720px !important;
  margin-inline: auto !important;
  padding-inline: var(--pad) !important;
}

.case-bottom-cta h2 {
  margin: 0 0 18px;
  color: var(--4d-offwhite) !important;
  font-size: clamp(36px, 4vw, 52px);
  line-height: 1.08;
}

.case-bottom-cta p {
  max-width: 580px;
  margin: 0 0 28px;
  color: rgba(253, 254, 254, 0.78) !important;
  font-size: 16px;
  line-height: 1.62;
}

.case-bottom-cta .btn {
  min-width: 0 !important;
  min-height: 48px;
  padding: 14px 27px !important;
  background: var(--4d-offwhite) !important;
  color: var(--4d-purple) !important;
  font-size: 15px;
}

.case-bottom-cta .btn:hover {
  background: var(--4d-pink) !important;
}

@media (max-width: 960px) {
  .case-template .case-hero {
    min-height: 430px;
    padding-top: 78px;
    padding-bottom: 130px;
  }

  .case-template .case-preview {
    margin-top: -78px;
  }

  .case-preview__frame {
    aspect-ratio: 16 / 8.5;
  }

  .case-facts__row,
  .case-facts__row--three,
  .case-facts__row--work {
    grid-template-columns: 1fr 1fr;
  }

  .case-facts__row--wide,
  .case-fact--sectors {
    grid-template-columns: 1fr;
  }

  .case-client-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 600px) {
  .case-template .case-hero {
    min-height: auto;
    padding: 64px 0 106px;
  }

  .case-template .case-hero__inner,
  .case-measure,
  .case-bottom-cta__inner {
    padding-inline: 24px !important;
  }

  .case-template .case-hero h1 {
    font-size: clamp(36px, 10vw, 46px);
    line-height: 1.06;
  }

  .case-template .case-hero p,
  .case-section p {
    font-size: 16px;
  }

  .case-template .case-preview,
  .case-facts-section > .case-facts,
  .case-facts-wrap,
  .case-clients,
  .case-clients-wrap,
  .case-testimonial-wrap {
    width: calc(100% - 48px) !important;
  }

  .case-template .case-preview {
    margin-top: -58px;
  }

  .case-preview__frame {
    aspect-ratio: 1.35 / 1;
    border-radius: 14px;
  }

  .case-facts-section {
    padding-top: 28px;
  }

  .case-facts__row,
  .case-facts__row--three,
  .case-facts__row--work {
    grid-template-columns: 1fr;
  }

  .case-fact,
  .case-facts__item,
  .case-facts__item:first-child {
    padding: 22px 22px 21px;
    border-top: 1px solid rgba(132, 145, 163, 0.16);
    border-left: 0;
  }

  .case-visit-link {
    padding: 22px !important;
    border-top: 1px solid rgba(132, 145, 163, 0.16) !important;
    border-left: 0 !important;
  }

  .case-facts__row:first-child .case-fact:first-child,
  .case-facts__row:first-child .case-facts__item:first-child {
    border-top: 0;
  }

  .case-section {
    padding: 64px 0;
  }

  .case-content-section {
    padding: 64px 0;
  }

  .case-section--challenge {
    padding-top: 58px;
  }

  .case-section h2,
  .case-content h2 {
    font-size: 31px;
  }

  .case-feature-grid {
    grid-template-columns: 1fr;
    gap: 15px;
  }

  .case-clients-section {
    padding: 20px 0 70px;
  }

  .case-client-grid {
    grid-template-columns: 1fr;
  }

  .case-testimonial-section {
    padding-bottom: 72px;
  }

  .case-testimonial-panel {
    padding: 36px 26px;
    border-radius: 14px;
  }

  .case-testimonial-panel::before {
    top: 20px;
    right: 24px;
    font-size: 96px;
  }

  .case-testimonial-panel p:first-child {
    font-size: 21px;
  }
}

/* ============================================================
   Homepage refinements — 9 Jun 2026
   ============================================================ */

/* About: add spacing between the founder paragraphs (were flush) */
.founder-copy {
  gap: 1em !important;
}

/* Services: reveal the row arrow on hover only (it was always visible) */
.service-row::after {
  opacity: 0;
  transform: translateX(-8px);
  transition: background-color 0.25s ease, border-color 0.25s ease,
    transform 0.25s ease, opacity 0.25s ease;
}

.service-row:hover::after,
.service-row:focus-visible::after {
  opacity: 1;
}

/* Cards: consistent hover lift site-wide (process step cards had none) */
.step-card {
  transition: transform 0.25s ease, box-shadow 0.25s ease,
    background-color 0.25s ease, border-color 0.25s ease;
}

.step-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}

/* Blog cards: left-align the tag pill + date (were centred).
   Homepage loop = bloglooptags; Blog page loop = bllooptags. */
.brxe-bloglooptags,
.brxe-bllooptags {
  align-items: flex-start !important;
  text-align: left !important;
}

/* Case-study cards: service-category pill (replaces the old 'Case study' label)
   Covers homepage, Projects and service-page work loops. */
.work-card .pill {
  align-self: flex-start;
  margin-bottom: 12px;
}

/* Hide the pill on case studies with no service term assigned */
.work-card .pill:empty {
  display: none !important;
}

/* Work-card images: crop to fit (were object-fit:fill = stretched/squashed) */
.work-card img,
.work-card .work-thumb {
  object-fit: cover !important;
}

/* Work-card service pills: one pill per service (split by motion.js) */
.work-card .pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-self: flex-start;
  margin-bottom: 12px;
}

.work-card .pill-row .pill {
  align-self: auto !important;
  margin-bottom: 0 !important;
}

/* Logo carousel — native Bricks carousel element (#brxe-logoscar.logo-carousel).
   Bricks renders each logo as a background-image on a .image div, so size that. */
.logo-carousel {
  width: 100%;
  margin-top: 6px;
}

.logo-carousel .swiper-slide {
  display: flex !important;
  align-items: center;
  justify-content: center;
}

.logo-carousel .image {
  width: 100% !important;
  height: 45px !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  opacity: 0.55;
  filter: grayscale(1);
}

/* In case a build renders an <img> instead of a background */
.logo-carousel img {
  width: auto !important;
  height: 45px !important;
  max-width: 100%;
  object-fit: contain;
  opacity: 0.55;
  filter: grayscale(1);
}

/* ── Mobile-menu Contact + CTA items (added to WP menu, mobile-only) ───────── */
/* Hide them in the desktop nav bar so the desktop menu is unchanged. */
.site-nav .bricks-nav-menu .menu-mobile-only {
  display: none !important;
}

/* In the mobile dropdown, style the CTA item as a brand button. */
@media (max-width: 960px) {
  .site-nav .bricks-mobile-menu li.menu-cta {
    padding: 8px 24px 16px !important;
    border-bottom: 0 !important;
  }
  .site-nav .bricks-mobile-menu li.menu-cta > a {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: auto !important;
    padding: 13px 28px !important;
    border-bottom: 0 !important;
    border-radius: 999px !important;
    background: var(--4d-purple) !important;
    color: var(--4d-offwhite) !important;
    font-family: var(--font-head) !important;
    font-weight: 700 !important;
    line-height: 1 !important;
  }
  .site-nav .bricks-mobile-menu li.menu-cta > a:hover {
    background: var(--4d-red) !important;
    color: var(--4d-offwhite) !important;
  }
}

/* ── Body copy: one consistent base size site-wide ────────────────────────────
   The base text inherits from <body> (was 15px). Setting it here makes ALL
   body/reading copy consistent — 16px on desktop, 18px on phones — while
   elements with their own explicit size (pills/labels, section intros, hero
   lead, footer legal) keep theirs. */
body {
  font-size: 16px !important;
}

@media (max-width: 600px) {
  body {
    font-size: 18px !important;
    line-height: 1.65;
  }
  /* keep the leads above body copy at phone size */
  .section-intro {
    font-size: 19px !important;
  }
  .hero-text {
    font-size: 20px !important;
  }
}

/* ── Contact form submit button → match the brand CTA buttons ─────────────── */
.brxe-form button[type="submit"],
.brxe-form .bricks-button,
.bricks-form button[type="submit"] {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: auto !important;
  min-height: 54px;
  padding: 14px 28px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: var(--4d-purple) !important;
  color: var(--4d-offwhite) !important;
  font-family: var(--font-head) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  cursor: pointer;
  transition: all 0.2s ease;
}
.brxe-form button[type="submit"]:hover,
.brxe-form .bricks-button:hover,
.bricks-form button[type="submit"]:hover {
  background: var(--4d-red) !important;
  color: #fff !important;
}
.brxe-form button[type="submit"]::after,
.brxe-form .bricks-button::after,
.bricks-form button[type="submit"]::after {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background: currentColor;
  -webkit-mask: var(--icon-arrow-right) center / contain no-repeat;
  mask: var(--icon-arrow-right) center / contain no-repeat;
  transform: translateY(-1px);
  transition: transform 0.2s ease;
}
.brxe-form button[type="submit"]:hover::after,
.brxe-form .bricks-button:hover::after,
.bricks-form button[type="submit"]:hover::after {
  transform: translate(3px, -1px);
}

/* ── "At a glance" facts: stack every fact on its own line on phones ───────── */
@media (max-width: 600px) {
  .case-facts__row,
  .case-facts__row--three,
  .case-facts__row--work {
    grid-template-columns: 1fr !important;
  }
  .case-facts__row > .case-fact,
  .case-facts__row > .case-visit-link {
    border-left: 0 !important;
  }
  .case-facts__row > .case-fact:not(:first-child),
  .case-facts__row > .case-visit-link {
    border-top: 1px solid rgba(132, 145, 163, 0.16) !important;
  }
}

/* ── Case-study cards: cap service pills at 2 on mobile (they stack vertically,
   and more than two gets unwieldy). ──────────────────────────────────────── */
@media (max-width: 600px) {
  .work-card .pill-row .pill:nth-child(n+3) {
    display: none !important;
  }
}

@media (max-width: 960px) {
  /* Closed mobile menu panel must be fully inert */
  .site-nav .bricks-mobile-menu-wrapper {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
  .site-nav.show-mobile-menu .bricks-mobile-menu-wrapper {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
  /* Sub-menu links set their own visibility/pointer-events for the open
     accordion - keep them inert while the menu is closed */
  .site-nav:not(.show-mobile-menu) .bricks-mobile-menu,
  .site-nav:not(.show-mobile-menu) .bricks-mobile-menu a,
  .site-nav:not(.show-mobile-menu) .bricks-mobile-menu .sub-menu,
  .site-nav:not(.show-mobile-menu) .bricks-mobile-menu .sub-menu li,
  .site-nav:not(.show-mobile-menu) .bricks-mobile-menu .sub-menu a {
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
