@font-face {
  font-family: Pp Pangram sans;
  src: url('../fonts/PPPangramSans-Medium.otf') format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root {
  --white: #f8f8f8;
  --black: #1c1c1c;
  --gray: #d8d8d8;
  --green: #1da851;
  --orange: #fe7505;
  --linen: #fff1e6;
  --gainsboro: #e8e8e8;
  --light-blue: #eef3ff;
  --normal-radius: .5rem;
  --transparent: #fff0;
}

.w-layout-grid {
  grid-row-gap: 16px;
  grid-column-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

body {
  background-color: var(--white);
  color: var(--black);
  text-align: center;
  font-family: Pp Pangram sans, sans-serif;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.25;
}

h1 {
  letter-spacing: -2px;
  text-transform: capitalize;
  cursor: default;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 4rem;
  line-height: 1.3;
}

h2 {
  letter-spacing: -1.5px;
  cursor: default;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3rem;
  line-height: 1.15;
}

h3 {
  letter-spacing: -1px;
  cursor: default;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2rem;
  line-height: 1.25;
}

h4 {
  letter-spacing: -.75px;
  cursor: default;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 24px;
}

h5 {
  letter-spacing: -.5px;
  cursor: default;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 20px;
}

h6 {
  letter-spacing: -.25px;
  cursor: default;
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 12px;
  line-height: 18px;
}

p {
  cursor: default;
  margin-bottom: 0;
}

a {
  text-decoration: none;
  transition: color .2s, background-color .2s;
}

.global-styles {
  display: block;
  position: fixed;
  inset: 0% auto auto 0%;
}

.padding-section-large {
  padding-top: 8rem;
  padding-bottom: 8rem;
}

.padding-section-medium {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.padding-global {
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.container-large {
  width: 100%;
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
}

.max-width-regular {
  width: 100%;
  max-width: 32rem;
}

.text-size-medium {
  font-size: 1.125rem;
}

.container-small {
  width: 100%;
  max-width: 48rem;
  margin-left: auto;
  margin-right: auto;
}

.container-medium {
  width: 100%;
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
}

.padding-section-small {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.button-group {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.button-group.is-center {
  justify-content: center;
}

.heading-style-h4 {
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1.4;
}

.heading-style-h5 {
  letter-spacing: -1px;
  font-size: 1.25rem;
  line-height: 1.5;
}

.text-weight-semibold {
  font-weight: 600;
}

.text-size-large {
  font-size: 1.5rem;
}

.text-size-small {
  font-size: .875rem;
}

.text-style-link {
  text-decoration: underline;
}

.text-style-link:hover {
  color: #195eff;
}

.text-align-center {
  text-align: center;
}

.text-align-center.position-relative {
  position: relative;
}

.max-width-large {
  width: 100%;
  max-width: 48rem;
}

.max-width-large.align-center {
  margin-left: auto;
  margin-right: auto;
}

.padding-xxlarge {
  padding: 5rem;
}

.margin-bottom {
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
}

.margin-bottom.margin-xsmall {
  margin-bottom: .5rem;
}

.margin-bottom.margin-xxlarge {
  margin-bottom: 6rem;
}

.margin-small {
  margin: 1rem;
}

.margin-medium {
  margin: 2rem;
}

.margin-xlarge {
  margin: 4rem;
}

.align-center {
  margin-left: auto;
  margin-right: auto;
}

.navbar_logo {
  height: 2rem;
}

.section_benefits {
  overflow: hidden;
}

.benefits_component {
  grid-column-gap: 6rem;
  grid-row-gap: 6rem;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr .5fr;
  grid-auto-columns: 1fr;
  align-items: center;
  display: flex;
}

.header_background-circle-1 {
  z-index: 1;
  width: 20vw;
  position: absolute;
  top: 40%;
  left: -7.5%;
}

.header_component {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.header_background-circle-2 {
  filter: saturate(150%) invert();
  width: 25vw;
  position: absolute;
  top: 10%;
  right: -7.5%;
}

.icon-embed-xsmall {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
}

.icon-embed-xxsmall {
  flex-direction: column;
  justify-content: center;
  align-self: center;
  align-items: center;
  width: 1rem;
  height: 1rem;
  display: flex;
}

.icon-embed-small {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 2rem;
  height: 2rem;
  display: flex;
}

.section_about {
  overflow: hidden;
}

.text-style-tag {
  background-color: var(--linen);
  color: var(--orange);
  text-transform: uppercase;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: .25rem .5rem;
  font-size: .875rem;
  display: inline-block;
}

.about_component {
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.about_image {
  width: 3rem;
  position: absolute;
}

.about_image.is-1 {
  top: 10%;
  left: -8vw;
}

.about_image.is-2 {
  width: 2rem;
  top: 0%;
  left: -10vw;
}

.about_image.is-3 {
  width: 2.4rem;
  bottom: 25%;
  right: -4vw;
}

.about_image.is-4 {
  width: 1.2rem;
  bottom: 20%;
  right: -6vw;
}

.about_image-wrapper {
  z-index: -1;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.about_label {
  position: absolute;
}

.about_label.is-1 {
  top: -10vh;
  left: -5vw;
  transform: rotate(-15deg);
}

.about_label.is-2 {
  top: -5vh;
  right: 0;
  transform: rotate(15deg);
}

.about_label.is-3 {
  bottom: -10vh;
  left: 0;
  transform: rotate(10deg);
}

.about_label.is-4 {
  bottom: -8vh;
  right: -4vw;
  transform: rotate(-10deg);
}

.max-width-custom-1 {
  width: 100%;
  max-width: 40vw;
}

.max-width-custom-1.align-center {
  max-width: 34ch;
}

.text-size-xlarge {
  font-size: 2.5rem;
}

.project_image-wrapper {
  border: 1px solid var(--gainsboro);
  flex-direction: column;
  flex: none;
  width: 25rem;
  display: flex;
  position: relative;
}

.project_image-wrapper.pointer-events-off {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  width: 34rem;
}

.section_testimonial {
  overflow: hidden;
}

.testimonial_component {
  flex-direction: column;
  align-items: center;
  display: flex;
}

.testimonial_rating-wrapper {
  justify-content: center;
  display: flex;
}

.testimonial_client-image-wrapper {
  margin-bottom: 1rem;
  overflow: hidden;
}

.testimonial_client-image {
  object-fit: cover;
  border-radius: 100%;
  width: 4rem;
  min-width: 4rem;
  height: 4rem;
  min-height: 4rem;
}

.footer_logo-link {
  padding-left: 0;
}

.footer_link {
  text-align: center;
  padding-top: .5rem;
  padding-bottom: .5rem;
  font-size: 1rem;
  font-weight: 400;
  text-decoration: none;
}

.footer_link:hover {
  color: var(--orange);
}

.cta_background-image-wrapper {
  z-index: -1;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.cta_background-circle-1 {
  z-index: 1;
  width: 22.5vw;
  position: absolute;
  top: 60%;
  left: -8%;
}

.cta_background-circle-2 {
  filter: saturate(150%) invert();
  width: 25vw;
  position: absolute;
  top: 20%;
  right: -10%;
}

.about_label-image {
  height: 1.75rem;
}

.benefits_item-counter {
  align-items: baseline;
  display: flex;
}

.header_background-image-wrapper {
  z-index: -1;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
  overflow: hidden;
}

.icon-embed-medium {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  display: flex;
}

.text-style-bold-stroke {
  -webkit-text-stroke-width: .75px;
}

.section_legal {
  position: relative;
}

.legal_component {
  text-align: left;
}

.legal_heading-wraper {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  text-align: center;
  grid-template-rows: auto;
  grid-template-columns: max-content 1fr;
  grid-auto-columns: 1fr;
  place-items: center;
}

.margin-top {
  margin: 0;
}

.margin-top.margin-medium {
  margin-top: 2rem;
}

.margin-top.margin-small {
  margin-top: 1rem;
}

.section_header {
  overflow: hidden;
}

.max-width-header {
  width: 100%;
  max-width: 72ch;
}

.benefits_list {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-around;
  place-items: start center;
  width: 100%;
  display: grid;
}

.icon-embed-custom {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 6rem;
  height: 6rem;
  display: flex;
}

.max-width-xsmall {
  width: 100%;
  max-width: 16rem;
}

.benefits_testimonial {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  border: 1px solid var(--gainsboro);
  background-color: var(--linen);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 5rem;
  display: flex;
  position: relative;
}

.text-size-huge {
  font-size: 1.5rem;
}

.icon-height-huge {
  height: 5rem;
}

.benefits_decoration-wrapper {
  width: 15%;
  position: absolute;
  inset: -15% -5% auto auto;
}

.benefits_decoration {
  filter: invert();
  width: 100%;
}

.benefits_item {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  flex-direction: column;
  grid-template-rows: auto;
  grid-template-columns: max-content 1fr;
  grid-auto-columns: 1fr;
  place-content: end flex-start;
  place-items: center start;
  display: flex;
}

.section_system {
  background-color: var(--light-blue);
  position: relative;
  overflow: hidden;
}

.system_component {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  flex-direction: column;
  display: flex;
}

.max-width-small {
  width: 100%;
  max-width: 28rem;
}

.system_content {
  grid-column-gap: 5rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  display: grid;
}

.system_testimonial {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  border: 1px solid var(--gainsboro);
  background-color: var(--white);
  flex-direction: column;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 2.5rem;
  display: flex;
}

.system_list {
  grid-column-gap: 2.5rem;
  grid-row-gap: 2.5rem;
  text-align: left;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  padding-top: .5rem;
  padding-bottom: .5rem;
}

.system_item {
  display: flex;
}

.system_item-icon-wrapper {
  flex: none;
  align-self: flex-start;
  margin-right: 1.5rem;
}

.system_decoration-wrapper {
  height: 30vh;
  position: absolute;
  inset: -15vh auto auto 0%;
}

.section_bonus {
  margin-top: -10vh;
  padding-top: 10vh;
  position: relative;
  overflow: hidden;
}

.bonus_component {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.bonus_heading-wrapper {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.margin-vertical {
  margin-left: 0;
  margin-right: 0;
}

.bonus_list {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  place-items: start;
  width: 100%;
  display: grid;
}

.bonus_item {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  text-align: center;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 18rem;
  display: flex;
}

.bonus_decoration-wrapper {
  height: 25vh;
  position: absolute;
  inset: 0 -5% auto auto;
}

.bonus_decoration {
  transform-style: preserve-3d;
  max-height: 100%;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.section_pain {
  background-color: var(--black);
  color: var(--white);
  position: relative;
  overflow: hidden;
}

.pain_header {
  text-align: center;
  max-width: 38rem;
  margin-inline: auto;
  margin-bottom: 3rem;
}

.pain_header .heading-style-h2 { color: var(--white); }

.pain_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .pain_grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}

.pain_card {
  background-color: rgba(248, 248, 248, 0.04);
  border: 1px solid rgba(248, 248, 248, 0.1);
  border-radius: 1.25rem;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-align: left;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
              border-color 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.pain_card:hover {
  transform: translateY(-0.25rem);
  border-color: rgba(254, 117, 5, 0.4);
}

.pain_icon {
  width: 3rem;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.75rem;
  background-color: rgba(254, 117, 5, 0.12);
  color: var(--orange);
  border: 1px solid rgba(254, 117, 5, 0.3);
  flex-shrink: 0;
}

.pain_icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.pain_quote {
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: -0.01em;
  color: var(--white);
}

.pain_amplification {
  color: rgba(248, 248, 248, 0.65);
  font-size: 1rem;
  line-height: 1.55;
}

/* ---- section_cost ---- */
.section_cost {
  background-color: var(--white);
  position: relative;
  overflow: hidden;
}

.section_cost::before {
  content: "";
  position: absolute;
  top: -20%;
  right: -10%;
  width: 45vw;
  max-width: 480px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: url('../barnils_v3/images/hero-circle.webp') center/cover no-repeat;
  filter: saturate(120%) invert(1);
  opacity: 0.35;
  pointer-events: none;
}

.cost_header {
  text-align: center;
  margin-bottom: 3rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 3rem;
  position: relative;
  z-index: 2;
}

.cost_subtitle {
  color: rgba(28, 28, 28, 0.65);
  font-size: 1.125rem;
  line-height: 1.55;
  margin-top: 1rem;
  max-width: 50ch;
}

.cost_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  position: relative;
  z-index: 2;
}

@media (min-width: 640px) {
  .cost_grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 1024px) {
  .cost_grid { grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
}

.cost_card {
  background-color: var(--linen);
  border: 1px solid var(--gainsboro);
  border-radius: 1.25rem;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: transform 0.2s cubic-bezier(0.22, 1, 0.36, 1),
              box-shadow 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.cost_card:hover {
  transform: translateY(-0.25rem);
  box-shadow: 0 8px 32px rgba(28, 28, 28, 0.08);
}

.cost_number {
  font-size: clamp(2.75rem, 5vw, 3.75rem);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--orange);
  margin-bottom: 0.5rem;
}

.cost_label {
  font-size: 1.0625rem;
  font-weight: 500;
  color: var(--black);
  line-height: 1.3;
}

.cost_description {
  font-size: .9375rem;
  color: rgba(28, 28, 28, 0.6);
  line-height: 1.55;
}

.cost_transition {
  max-width: 42rem;
  margin: 3rem auto 0;
  text-align: center;
  font-size: 1.125rem;
  line-height: 1.4;
  color: var(--black);
  font-weight: 500;
  letter-spacing: -0.015em;
  position: relative;
  z-index: 2;
}

.cost_transition strong { color: var(--orange); }

/* ---- badge ---- */
.badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .4rem .75rem;
  border-radius: 9999px;
  background-color: var(--black);
  color: var(--white);
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .03em;
  text-transform: uppercase;
  line-height: 1;
}
.badge.is-soft {
  background-color: var(--linen);
  color: var(--orange);
}
.badge.is-outline {
  background-color: transparent;
  border: 1.5px solid var(--black);
  color: var(--black);
}

/* ---- section_demo ---- */
.section_demo {
  background-color: var(--light-blue);
  position: relative;
  overflow: hidden;
}
.demo_header {
  text-align: center;
  max-width: 54rem;
  margin-inline: auto;
  margin-bottom: 3rem;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.demo_subtitle {
  color: rgba(28, 28, 28, 0.65);
  font-size: 1.125rem;
  line-height: 1.55;
  max-width: 52ch;
}
.demo_block {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: center;
  margin-bottom: 8rem;
}
@media (min-width: 992px) {
  .demo_block {
    grid-template-columns: 1fr 1fr;
    gap: 3.5rem;
  }
  .demo_block.is-reverse .demo_visual { order: -1; }
}
.demo_block:last-child { margin-bottom: 0; }
.demo_content-side .heading-style-h3 { margin-bottom: 1rem; margin-top: .75rem; }
.demo_content-side p {
  color: rgba(28, 28, 28, 0.65);
  font-size: 1.0625rem;
  line-height: 1.6;
}
.demo_steps {
  list-style: none;
  counter-reset: step;
  margin: 1.5rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.demo_steps li {
  counter-increment: step;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem;
  align-items: flex-start;
  padding: 1rem 1.25rem;
  background-color: var(--white);
  border-radius: .75rem;
  border: 1px solid var(--gainsboro);
  font-size: 1rem;
  color: var(--black);
  line-height: 1.5;
}
.demo_steps li::before {
  content: counter(step);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--orange);
  color: var(--white);
  font-weight: 700;
  font-size: .875rem;
  flex-shrink: 0;
}
.demo_conclusion {
  margin-top: 1.5rem;
  padding: 1.25rem 1.5rem;
  background-color: var(--black);
  color: var(--white);
  border-radius: .75rem;
  font-size: 1.0625rem;
  line-height: 1.4;
  letter-spacing: -.01em;
}
.demo_conclusion strong { color: var(--orange); font-weight: 500; }
.demo_visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
}
.demo_mockup {
  position: relative;
  width: 100%;
  overflow: hidden;
  transform: rotate(-3deg);
  transition: transform .25s cubic-bezier(0.22, 1, 0.36, 1);
}
.demo_mockup:hover { transform: rotate(0deg) translateY(-8px); }
.demo_mockup_img {
  display: block;
  width: 100%;
  height: auto;
}
.demo_mockup_screen {
  width: 100%;
  height: 100%;
  background-color: var(--white);
  border-radius: 28px;
  overflow: hidden;
  padding-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 10px;
  text-align: left;
}
.mockup_hero {
  padding: 16px 14px 18px;
  background: linear-gradient(135deg, #1c1c1c 0%, #2d2d2d 100%);
  color: var(--white);
}
.mockup_brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  font-size: 9px;
}
.mockup_logo { font-weight: 700; font-size: 10px; letter-spacing: -.02em; }
.mockup_menu { display: flex; gap: 3px; flex-direction: column; align-items: flex-end; }
.mockup_menu span { width: 14px; height: 1.5px; background: var(--white); display: block; }
.mockup_h1 { font-size: 14px; font-weight: 500; line-height: 1.2; letter-spacing: -.015em; margin-bottom: 8px; }
.mockup_tagline { font-size: 8px; color: rgba(255,255,255,.7); line-height: 1.4; margin-bottom: 10px; }
.mockup_cta-btn {
  background: var(--orange);
  color: var(--white);
  font-size: 8px;
  padding: 6px 10px;
  border-radius: 4px;
  font-weight: 600;
  display: inline-block;
}
.mockup_section { padding: 10px 14px; background: var(--white); }
.mockup_section_title { font-size: 9px; font-weight: 700; margin-bottom: 6px; color: var(--black); letter-spacing: -.01em; }
.mockup_form {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px;
  background: var(--linen);
  border-radius: 6px;
}
.mockup_input {
  background: var(--white);
  border: 1px solid var(--gainsboro);
  border-radius: 3px;
  height: 14px;
  font-size: 7px;
  padding: 0 5px;
  color: rgba(28,28,28,.6);
  display: flex;
  align-items: center;
}
.mockup_btn-sm {
  background: var(--black);
  color: var(--white);
  font-size: 8px;
  text-align: center;
  padding: 5px;
  border-radius: 3px;
  font-weight: 600;
  margin-top: 2px;
}
.mockup_gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3px; padding: 0 14px; }
.mockup_gallery-item { aspect-ratio: 1; background: linear-gradient(135deg, #e8e8e8, #d0d0d0); border-radius: 3px; }
.mockup_gallery-item:nth-child(2) { background: linear-gradient(135deg, #fff1e6, #fe7505); opacity: .3; }
.mockup_footer {
  margin-top: auto;
  padding: 10px 14px;
  background: var(--light-blue);
  font-size: 7px;
  color: rgba(28,28,28,.6);
  text-align: center;
  line-height: 1.4;
}
.demo_annotation {
  position: absolute;
  background: var(--white);
  border: 1.5px solid var(--black);
  border-radius: .5rem;
  padding: .5rem .75rem;
  font-size: .75rem;
  font-weight: 500;
  line-height: 1.3;
  box-shadow: 3px 3px 0 var(--black);
  z-index: 5;
  white-space: nowrap;
  display: none;
}
@media (min-width: 1200px) {
  .demo_annotation { display: block; }
  .demo_annotation.is-top    { top: 12%; left: -10%; }
  .demo_annotation.is-middle { top: 48%; right: -8%; background: var(--orange); color: var(--white); border-color: var(--orange); box-shadow: 3px 3px 0 var(--black); }
  .demo_annotation.is-bottom { bottom: 14%; left: -6%; }
}

/* ---- section_process (timeline — nouvelle LP) ---- */
.section_process.is-timeline {
  background-color: var(--white);
  position: relative;
  overflow: hidden;
}
.process_header {
  text-align: center;
  margin-inline: auto;
  margin-bottom: 3.5rem;
}
.process_subtitle {
  color: var(--orange);
  font-size: 1.0625rem;
  font-weight: 500;
  margin-top: .5rem;
}
.process_timeline {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 768px) {
  .process_timeline {
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
  }
  .process_timeline::before {
    content: "";
    position: absolute;
    top: 36px;
    left: 8%;
    right: 8%;
    height: 2px;
    background: repeating-linear-gradient(to right, var(--orange) 0, var(--orange) 6px, transparent 6px, transparent 12px);
    z-index: 0;
  }
}
.process_step {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: .75rem;
  padding: 1.5rem;
  background-color: var(--white);
  border: 1px solid var(--gainsboro);
  border-radius: 1rem;
  text-align: left;
  transition: transform .25s cubic-bezier(0.22,1,.36,1), box-shadow .25s cubic-bezier(0.22,1,.36,1);
}
.process_step:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(28,28,28,.08);
  border-color: var(--orange);
}
.process_number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: var(--black);
  color: var(--orange);
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: -.02em;
}
.process_day {
  display: inline-block;
  padding: .2rem .6rem;
  border-radius: 9999px;
  background-color: var(--linen);
  color: var(--orange);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.process_title {
  font-size: 1.0625rem;
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: -.01em;
  color: var(--black);
}
.process_desc {
  color: rgba(28,28,28,.6);
  font-size: .875rem;
  line-height: 1.55;
}
.process_summary {
  margin-top: 2.5rem;
  padding: 1.75rem 2rem;
  background-color: var(--black);
  color: var(--white);
  border-radius: 1rem;
  text-align: center;
  font-size: 1.25rem;
  line-height: 1.4;
  letter-spacing: -.015em;
}
.process_summary strong { color: var(--orange); font-weight: 500; }

/* ---- section_cases ---- */
.section_cases {
  background-color: var(--linen);
  position: relative;
  overflow: hidden;
}
.cases_header {
  text-align: center;
  margin-inline: auto;
  margin-bottom: 4rem;
}
.cases_list { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.case_card {
  background-color: var(--white);
  border: 1px solid var(--gainsboro);
  border-radius: 1.5rem;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  transition: transform .25s cubic-bezier(0.22,1,.36,1), box-shadow .25s cubic-bezier(0.22,1,.36,1);
}
.case_card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(28,28,28,.12);
}
@media (min-width: 768px) {
  .case_card { grid-template-columns: .9fr 1.1fr; align-items: stretch; }
  .case_card.is-reverse { grid-template-columns: 1.1fr .9fr; }
  .case_card.is-reverse .case_visual { order: 2; }
}
.case_visual {
  position: relative;
  background: linear-gradient(135deg, var(--linen) 0%, var(--light-blue) 100%);
  padding: 2rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 260px;
}
.case_visual::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -30%;
  width: 80%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: url('../barnils_v3/images/hero-circle.webp') center/cover no-repeat;
  filter: saturate(110%);
  opacity: .25;
}
.case_mockup-mini {
  position: relative;
  width: 100%;
  max-width: 220px;
  aspect-ratio: 9 / 16;
  background: var(--black);
  border-radius: 22px;
  padding: 8px;
  box-shadow: 0 20px 40px rgba(28,28,28,.2);
  z-index: 2;
  transform: rotate(-4deg);
}
.case_mockup-mini_screen {
  width: 100%;
  height: 100%;
  background: var(--white);
  border-radius: 16px;
  padding: 18px 10px 10px;
  text-align: left;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.case_mockup-mini_h { font-size: 11px; font-weight: 500; line-height: 1.2; letter-spacing: -.015em; }
.case_mockup-mini_badge {
  display: inline-block;
  padding: 2px 6px;
  font-size: 7px;
  background: var(--linen);
  color: var(--orange);
  border-radius: 3px;
  font-weight: 700;
  margin-top: 4px;
  width: fit-content;
}
.case_mockup-mini_lines { display: flex; flex-direction: column; gap: 3px; margin-top: 6px; }
.case_mockup-mini_lines span { display: block; height: 4px; background: var(--gainsboro); border-radius: 2px; }
.case_mockup-mini_lines span:nth-child(2) { width: 80%; }
.case_mockup-mini_lines span:nth-child(3) { width: 60%; }
.case_mockup-mini_btn {
  margin-top: auto;
  background: var(--orange);
  color: var(--white);
  font-size: 8px;
  text-align: center;
  padding: 5px;
  border-radius: 3px;
  font-weight: 600;
}
.case_mockup-mini_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; margin-top: 4px; }
.case_mockup-mini_grid > span { aspect-ratio: 1; background: var(--gainsboro); border-radius: 2px; }
.case_content {
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .85rem;
  text-align: left;
}
@media (min-width: 768px) { .case_content { padding: 2.25rem 2rem; gap: 1rem; } }
.case_tag-row { display: flex; align-items: center; justify-content: space-between; gap: .5rem; flex-wrap: wrap; }
.case_meta { font-size: .875rem; color: rgba(28,28,28,.6); font-weight: 500; }
.case_meta strong { color: var(--black); font-weight: 700; }
.case_kpi {
  display: flex;
  align-items: baseline;
  gap: .5rem;
  flex-wrap: wrap;
  padding: .75rem 0;
  border-top: 1px solid var(--gainsboro);
  border-bottom: 1px solid var(--gainsboro);
}
.case_kpi_number { font-size: clamp(2rem, 4vw, 2.75rem); font-weight: 500; line-height: 1; letter-spacing: -.03em; color: var(--orange); }
.case_kpi_label { font-size: .875rem; color: rgba(28,28,28,.6); line-height: 1.35; }
.case_narrative { font-size: 1rem; line-height: 1.6; color: var(--black); }
.case_narrative p + p { margin-top: .5rem; }
.case_narrative strong { color: var(--orange); font-weight: 500; }
.case_quote {
  padding: 1rem;
  background-color: var(--linen);
  border-left: 3px solid var(--orange);
  border-radius: 0 .375rem .375rem 0;
  font-style: italic;
  font-size: .875rem;
  line-height: 1.55;
  color: var(--black);
}
.case_quote cite { display: block; margin-top: .5rem; font-style: normal; font-size: .75rem; color: rgba(28,28,28,.6); font-weight: 600; }
.badge.is-fictif {
  background-color: rgba(28,28,28,.06);
  color: rgba(28,28,28,.5);
  border: 1px solid rgba(28,28,28,.15);
}
.cases_logos { margin-top: 4rem; text-align: center; }
.cases_logos_title { font-size: .875rem; color: rgba(28,28,28,.6); letter-spacing: .1em; text-transform: uppercase; margin-bottom: 1.25rem; font-weight: 500; }
.cases_logos_grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; max-width: 42rem; margin-inline: auto; opacity: .5; }
@media (min-width: 640px) { .cases_logos_grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 992px) { .cases_logos_grid { grid-template-columns: repeat(6, 1fr); } }
.cases_logo_placeholder { height: 42px; border: 1.5px dashed rgba(28,28,28,.3); border-radius: .375rem; display: flex; align-items: center; justify-content: center; font-size: .75rem; color: rgba(28,28,28,.5); font-weight: 500; }

/* ---- section_pricing ---- */
.section_pricing {
  background-color: var(--white);
  position: relative;
  overflow: hidden;
}
.pricing_header { text-align: center; max-width: 40rem; margin-inline: auto; margin-bottom: 3rem; }
.pricing_subtitle { color: rgba(28,28,28,.6); font-size: 1.0625rem; line-height: 1.55; margin-top: 1rem; }
.pricing_grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; align-items: stretch; }
@media (min-width: 992px) { .pricing_grid { grid-template-columns: repeat(3, 1fr); gap: 1.25rem; align-items: start; } }
.pricing_card {
  position: relative;
  background-color: var(--white);
  border: 1.5px solid var(--gainsboro);
  border-radius: 1.5rem;
  padding: 2rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  text-align: left;
  transition: transform .25s cubic-bezier(0.22,1,.36,1), box-shadow .25s cubic-bezier(0.22,1,.36,1), border-color .25s cubic-bezier(0.22,1,.36,1);
}
.pricing_card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(28,28,28,.12); border-color: rgba(28,28,28,.3); }
@media (min-width: 992px) {
  .pricing_card.is-featured { transform: scale(1.03); border-color: var(--orange); border-width: 2px; box-shadow: 0 16px 48px rgba(254,117,5,.18); z-index: 2; }
  .pricing_card.is-featured:hover { transform: scale(1.03) translateY(-4px); }
}
.pricing_card.is-featured { border-color: var(--orange); border-width: 2px; background: linear-gradient(180deg, var(--linen) 0%, var(--white) 50%); }
.pricing_badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--black);
  color: var(--orange);
  padding: .4rem .9rem;
  border-radius: 9999px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
.pricing_name { font-size: .875rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: rgba(28,28,28,.6); }
.pricing_card.is-featured .pricing_name { color: var(--orange); }
.pricing_price-row { display: flex; align-items: baseline; gap: .5rem; flex-wrap: wrap; }
.pricing_price { font-size: clamp(2.25rem, 4vw, 3rem); font-weight: 500; line-height: 1; letter-spacing: -.035em; color: var(--black); }
.pricing_price-unit { font-size: 1rem; color: rgba(28,28,28,.6); font-weight: 500; }
.pricing_delivery {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .4rem .8rem;
  background: var(--linen);
  color: var(--orange);
  border-radius: 9999px;
  font-size: .875rem;
  font-weight: 700;
  align-self: flex-start;
}
.pricing_card.is-featured .pricing_delivery { background: var(--orange); color: var(--white); }
.pricing_tagline { font-size: 1.0625rem; color: var(--black); line-height: 1.4; font-weight: 500; letter-spacing: -.01em; }
.pricing_features { list-style: none; display: flex; flex-direction: column; gap: .65rem; padding: 1rem 0; border-top: 1px solid var(--gainsboro); border-bottom: 1px solid var(--gainsboro); flex-grow: 1; }
.pricing_features li { display: grid; grid-template-columns: 20px 1fr; gap: .65rem; font-size: .875rem; line-height: 1.45; color: var(--black); }
.pricing_features li::before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  border-radius: 50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='8' fill='%23fe7505'/%3E%3Cpath d='M4.5 8l2.5 2.5L11.5 6' stroke='white' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
}
.button.is-accent { background-color: var(--orange); color: var(--white); }
.button.is-accent:hover { background-color: #d95f00; }
.button.is-block { width: 100%; justify-content: center; }
.pricing_cta { width: 100%; }
.pricing_notes { margin-top: 3rem; display: grid; grid-template-columns: 1fr; gap: 1rem; max-width: 52rem; margin-inline: auto; }
@media (min-width: 768px) { .pricing_notes { grid-template-columns: repeat(2, 1fr); } }
.pricing_note { padding: 1.25rem 1.5rem; background-color: var(--linen); border-radius: .75rem; display: flex; gap: .85rem; align-items: flex-start; font-size: .875rem; line-height: 1.5; text-align: left; }
.pricing_note_icon { flex-shrink: 0; color: var(--orange); font-size: 1.25rem; line-height: 1; margin-top: 1px; }
.pricing_note strong { display: block; color: var(--black); margin-bottom: .2rem; font-weight: 700; }



.satisfaction_component {
  max-width: 52rem;
  margin-inline: auto;
  text-align: center;
}

.satisfaction_header {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  margin-top: 4rem;
  margin-bottom: 2rem;
}

.satisfaction_stars {
  display: inline-flex;
  gap: 0.15rem;
  color: var(--orange);
  font-size: 1.1rem;
}

.satisfaction_stat strong {
  color: var(--orange);
  font-weight: 500;
}

.satisfaction_title {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.02em;
}

.satisfaction_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
}

@media (min-width: 640px) { .satisfaction_grid { grid-template-columns: repeat(2, 1fr); } }

.satisfaction_card {
  background-color: var(--linen);
  border-radius: 0.75rem;
  padding: 1.25rem 1.5rem;
  text-align: left;
  font-size: 0.875rem;
  line-height: 1.5;
}

.satisfaction_card:last-child {
  background-color: var(--light-blue);
}

.satisfaction_card p {
  font-style: italic;
  color: var(--black);
  margin-bottom: 0.5rem;
}

.satisfaction_card cite {
  display: block;
  font-style: normal;
  font-size: 0.75rem;
  color: var(--black);
  font-weight: 800;
}

/* ---- section_satisfaction ---- */
.section_satisfaction {
  background-color: var(--black);
  color: var(--white);
  position: relative;
  overflow: hidden;
}
.section_satisfaction::before {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -20%;
  width: 60vw;
  max-width: 600px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: url('../barnils_v3/images/cta-circle.webp') center/cover no-repeat;
  filter: saturate(150%);
  opacity: .5;
  pointer-events: none;
}
.guarantee_header { text-align: center; margin-inline: auto; margin-bottom: 3rem; position: relative; z-index: 2; }
.guarantee_header .heading-style-h2 { color: var(--white); }
.guarantee_header em { font-style: normal; color: var(--orange); }
.guarantee_grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; max-width: 52rem; margin-inline: auto; position: relative; z-index: 2; }
@media (min-width: 768px) { .guarantee_grid { grid-template-columns: repeat(2, 1fr); } }
.guarantee_card {
  background-color: rgba(248,248,248,.05);
  border: 1px solid rgba(248,248,248,.15);
  border-radius: 1.5rem;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-align: left;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: transform .25s cubic-bezier(0.22,1,.36,1), border-color .25s cubic-bezier(0.22,1,.36,1);
}
.guarantee_card:hover { transform: translateY(-4px); border-color: var(--orange); }
.guarantee_icon { width: 56px; height: 56px; display: flex; align-items: center; justify-content: center; border-radius: 14px; background-color: var(--orange); color: var(--white); }
.guarantee_icon svg { width: 28px; height: 28px; }
.guarantee_title { font-size: 1.35rem; font-weight: 500; line-height: 1.25; letter-spacing: -.015em; color: var(--white); }
.guarantee_title em { font-style: normal; color: var(--orange); }
.guarantee_desc { color: rgba(248,248,248,.78); font-size: 1rem; line-height: 1.6; }
.guarantee_desc strong { color: var(--orange); font-weight: 500; }
.guarantee_signature { max-width: 42rem; margin: 2.5rem auto 0; text-align: center; font-size: .875rem; color: rgba(248,248,248,.6); display: flex; align-items: center; justify-content: center; gap: .5rem; position: relative; z-index: 2; }

.section_clients {
  background-color: #1c1c1c;
  position: relative;
  overflow: hidden;
}

.clients_component {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  display: flex;
}

.clients_list {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1rem;
  white-space: nowrap;
  flex-wrap: wrap;
  grid-template-rows: auto;
  grid-template-columns: 12.5rem 12.5rem 12.5rem 12.5rem 12.5rem 12.5rem 12.5rem 12.5rem;
  grid-auto-columns: 1fr;
  justify-content: flex-end;
  place-items: center start;
  display: grid;
}

.clients_wrapper {
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.clients_logo {
  color: #f8f8f8;
  max-height: 4rem;
}

.max-width-medium {
  width: 100%;
  max-width: 36rem;
}

.max-width-medium.align-center {
  max-width: 44rem;
}

.benefits_list-wrapper {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  flex-direction: column;
  width: 100%;
  display: flex;
}

.padding-section-custom {
  padding-top: 8rem;
}

.projects_list {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  grid-template-rows: auto;
  grid-template-columns: 33vw 33vw 33vw 33vw;
  padding-left: 5rem;
  display: flex;
}

.projects_component {
  grid-column-gap: 5rem;
  grid-row-gap: 5rem;
  flex-direction: column;
  align-items: flex-start;
  padding-top: 5rem;
  padding-bottom: 5rem;
  display: flex;
}

.projects_list-wrapper {
  align-items: center;
  display: flex;
}

.projects_decoration-wrapper {
  height: 30vh;
  position: absolute;
  inset: -15vh auto auto 0%;
}

.section_work {
  background-color: var(--linen);
  position: relative;
  overflow: hidden;
}

.pricing_plan {
  background-color: #fff;
}

.button {
  grid-column-gap: .5rem;
  grid-row-gap: .5rem;
  color: #f8f8f8;
  text-align: center;
  background-color: #1c1c1c;
  border-radius: .5rem;
  justify-content: center;
  align-items: center;
  padding: .75rem 1.5rem;
  font-weight: 600;
  transition: background-color .2s, box-shadow .2s, transform .2s;
  display: flex;
  box-shadow: 4px 4px #0003;
}

.button:hover {
  background-color: var(--orange);
  transform: translate(0, -.25rem);
  box-shadow: 7px 7px 1px #0003;
}

.button.is-footer {
  box-shadow: none;
  color: #f8f8f8;
  background-color: #0000;
  border: .125rem solid #f8f8f8;
  width: 100%;
  padding: 2rem;
  font-size: 2rem;
  transition: box-shadow .2s, color .2s, background-color .2s, transform .2s;
}

.button.is-footer:hover {
  color: #1c1c1c;
  background-color: #f8f8f8;
  transform: translate(0, -.5rem);
  box-shadow: 11px 11px #fff3;
}

.button.is-secondary {
  border: .125rem solid var(--black);
  background-color: var(--white);
  color: var(--black);
}

.button.is-secondary:hover {
  background-color: var(--black);
  color: var(--white);
}

.faq_accordion {
  border: 1px solid var(--gainsboro);
  -webkit-backdrop-filter: blur(30px);
  backdrop-filter: blur(30px);
  text-align: left;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
}

.faq_icon-wrappper {
  align-self: flex-start;
  width: 2rem;
  margin-left: 1.5rem;
  display: flex;
}

.faq_answer {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  overflow: hidden;
}

.section_faq {
  margin-top: -15vh;
  padding-top: 15vh;
  position: relative;
  overflow: hidden;
}

.faq_list {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto;
  grid-template-columns: 100%;
  grid-auto-columns: 100%;
  place-items: start stretch;
  display: grid;
}

.faq_question {
  cursor: pointer;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem;
  display: flex;
}

.faq_decoration-wrapper {
  height: 30vh;
  position: absolute;
  inset: -10vh 0% auto auto;
}

.section_cta {
  color: #f8f8f8;
  background-color: #1c1c1c;
  position: relative;
}

.cta_component {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-direction: column;
  align-items: center;
  position: relative;
}

.container-xsmall {
  width: 100%;
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
}

.footer_logo {
  height: 2.5rem;
}

.footer_bottom-wrapper {
  grid-column-gap: 1.5rem;
  grid-row-gap: 0rem;
  white-space: normal;
  grid-template-rows: auto;
  grid-template-columns: .25fr .5fr .25fr;
  grid-auto-columns: max-content;
  grid-auto-flow: column;
  justify-content: center;
  justify-items: center;
  display: grid;
}

.footer_list {
  grid-column-gap: 1.5rem;
  grid-row-gap: 0px;
  white-space: normal;
  grid-template-rows: auto;
  grid-template-columns: max-content;
  grid-auto-columns: max-content;
  grid-auto-flow: column;
  display: grid;
}

.line-divider {
  background-color: #0000;
  width: 100%;
  height: 1px;
}

.padding-bottom {
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
}

.footer_component {
  color: var(--white);
  background-color: #1c1c1c;
  width: 100%;
  position: relative;
  overflow: hidden;
}

.footer_legal-link {
  font-size: .875rem;
  text-decoration: underline;
}

.footer_legal-link:hover {
  color: var(--orange);
}

.footer_credit-text {
  font-size: .875rem;
}

.footer_top-wrapper {
  grid-column-gap: 4vw;
  grid-template-rows: auto;
  grid-template-columns: .25fr .75fr;
  justify-content: space-between;
  place-items: center end;
}

.padding-section-xlarge {
  padding-top: 10rem;
  padding-bottom: 10rem;
}

.footer_image {
  width: 12rem;
  position: absolute;
  inset: auto auto -10rem -6rem;
}

.section_process {
  background-color: var(--light-blue);
}

.process_component {
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  height: 300vh;
  position: relative;
}

.process_content {
  grid-column-gap: 5rem;
  grid-row-gap: 4rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  height: 100vh;
  display: grid;
  position: sticky;
  top: 0;
}

.process_content-left {
  text-align: left;
}

.process_content-right {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 12rem;
  display: flex;
  position: relative;
}

.process_card {
  border: 1px solid var(--gainsboro);
  background-color: var(--white);
  flex-direction: column;
  justify-content: space-between;
  margin-right: 1.5rem;
  padding: 2rem;
  display: flex;
  position: absolute;
}

.process_card.card-1 {
  z-index: 3;
}

.process_card.card-2 {
  z-index: 2;
  transform: rotate(3deg);
}

.process_card.card-3 {
  z-index: 1;
  transform: rotate(6deg);
}

.process_card.card-4 {
  transform: rotate(9deg);
}

.icon-1x1-medium {
  width: 3rem;
  height: 3rem;
  display: inline-block;
}

.process_ix-trigger {
  z-index: -1;
  margin-top: 100vh;
  position: absolute;
  inset: 0%;
}

.navbar_component {
  background-color: var(--transparent);
  align-items: center;
  width: 100%;
  height: auto;
  min-height: 4.5rem;
  padding-left: 5%;
  padding-right: 5%;
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
}

.navbar_container {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.navbar_logo-link {
  padding-left: 0;
}

.navbar_button-wrapper {
  grid-column-gap: 1rem;
  margin-left: 1rem;
  display: flex;
}

.cta_image-wrapper {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.cta_image {
  width: 3rem;
  position: absolute;
}

.cta_image.is-1 {
  top: -5%;
  left: -2.5rem;
}

.cta_image.is-2 {
  width: 2rem;
  top: -10%;
  left: -5rem;
}

.cta_image.is-3 {
  width: 2.4rem;
  bottom: 35%;
  right: -5rem;
}

.cta_image.is-4 {
  width: 1.2rem;
  bottom: 25%;
  right: -2.5rem;
}

.footer_image-wrapper {
  width: 100%;
  height: 100%;
  position: relative;
}

.cta_content {
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.project_image {
  max-height: 100%;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

@media screen and (max-width: 991px) {
  h2 {
    font-size: 2.5rem;
  }

  h3 {
    font-size: 1.5rem;
  }

  .max-width-large {
    max-width: 54rem;
  }

  .padding-xxlarge {
    padding: 4rem;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .margin-medium {
    margin: 1.5rem;
  }

  .margin-xlarge {
    margin: 3rem;
  }

  .benefits_component {
    grid-template-columns: 1.25fr .5fr;
  }

  .header_background-circle-1 {
    filter: blur(20px);
  }

  .header_background-circle-2 {
    filter: blur(20px) saturate(150%) invert();
  }

  .about_image.is-1 {
    width: 2.6rem;
    top: 5%;
    left: -3vw;
  }

  .about_image.is-2 {
    width: 1.6rem;
    top: -5%;
    left: -7.5vw;
  }

  .about_image.is-3 {
    width: 2rem;
  }

  .about_label.is-1 {
    left: -2.5vw;
  }

  .about_label.is-4 {
    right: -2vw;
  }

  .project_image-wrapper.pointer-events-off {
    width: 24rem;
  }

  .benefits_list {
    grid-column-gap: 2rem;
  }

  .system_content {
    grid-column-gap: 3rem;
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    min-height: auto;
  }

  .system_testimonial {
    text-align: center;
    align-items: center;
    padding: 2rem;
  }

  .system_item {
    align-items: center;
  }

  .system_decoration-wrapper {
    height: 22vh;
    top: -11vh;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .bonus_list {
    grid-column-gap: 2rem;
  }

  .padding-section-custom {
    padding-top: 6rem;
  }

  .projects_component {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .projects_list-wrapper {
    padding-top: 0;
  }

  .projects_decoration-wrapper {
    height: 25vh;
  }

  .section_cta {
    overflow: hidden;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .footer_top-wrapper {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
    justify-content: center;
    justify-items: center;
  }

  .padding-section-xlarge {
    padding-bottom: 6rem;
  }

  .process_component {
    grid-column-gap: 3rem;
    grid-template-columns: 1fr 1fr;
    grid-auto-flow: row;
    height: 300svh;
    min-height: auto;
  }

  .process_content {
    height: 100svh;
  }

  .navbar_button-wrapper {
    z-index: 11;
    align-items: center;
    position: relative;
  }

  .cta_image.is-1 {
    width: 2.6rem;
    top: 5%;
    left: 0;
  }

  .cta_image.is-2 {
    width: 1.6rem;
    top: -5%;
    left: -2rem;
  }

  .cta_image.is-3 {
    width: 2rem;
    bottom: 45%;
    right: 0;
  }

  .cta_image.is-4 {
    bottom: 35%;
    right: -2rem;
  }
}

@media screen and (max-width: 767px) {
  .padding-global {
    padding-left: 5%;
    padding-right: 5%;
  }

  .padding-section-small {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .heading-style-h5 {
    font-size: 1.125rem;
  }

  .text-size-large {
    font-size: 1.25rem;
  }

  .padding-xxlarge {
    padding: 3rem;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .margin-medium {
    margin: 1.25rem;
  }

  .margin-xlarge {
    margin: 2rem;
  }

  .benefits_component {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    grid-template-rows: auto auto auto;
    grid-template-columns: 1fr;
  }

  .about_image.is-3 {
    bottom: 50%;
    right: -8vw;
  }

  .about_image.is-4 {
    bottom: 40%;
    right: -10vw;
  }

  .about_label.is-1 {
    left: 0;
  }

  .about_label.is-2 {
    right: 2.5vw;
  }

  .about_label.is-3 {
    left: 2.5vw;
  }

  .about_label.is-4 {
    right: 0;
  }

  .max-width-custom-1 {
    max-width: 80%;
  }

  .text-size-xlarge {
    font-size: 1.25rem;
  }

  .project_image-wrapper {
    width: 15rem;
  }

  .about_label-image {
    height: 1.5rem;
  }

  .legal_heading-wraper {
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
  }

  .benefits_list {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .text-size-huge {
    font-size: 1.25rem;
  }

  .system_content {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .system_decoration-wrapper {
    height: 35vh;
    top: -17.5vh;
  }

  .bonus_heading-wrapper {
    text-align: center;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .bonus_list {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .clients_list {
    grid-column-gap: 1rem;
    grid-template-columns: 10rem 10rem 10rem 10rem 10rem 10rem 10rem 10rem;
    padding-top: 1rem;
  }

  .clients_wrapper {
    padding: .75rem 1rem;
  }

  .clients_logo {
    max-height: 3rem;
  }

  .padding-section-custom {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .projects_list {
    grid-column-gap: 2.5rem;
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
    padding-left: 2.5rem;
  }

  .projects_decoration-wrapper {
    height: 35vh;
    top: -20vh;
  }

  .pricing_plan {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .faq_icon-wrappper {
    width: 1.75rem;
  }

  .faq_answer {
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }

  .faq_question {
    padding: 1rem 1.25rem;
  }

  .footer_bottom-wrapper {
    grid-column-gap: 0rem;
    grid-row-gap: 1rem;
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    justify-items: center;
    padding-bottom: 1rem;
  }

  .footer_list {
    grid-column-gap: 0px;
    grid-row-gap: 1.5rem;
    grid-auto-flow: row;
    justify-items: center;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .footer_credit-text {
    margin-top: 1rem;
  }

  .padding-section-xlarge {
    padding-top: 8rem;
  }

  .footer_image {
    bottom: -16rem;
  }

  .process_component {
    grid-row-gap: 3rem;
    grid-template-columns: 1fr;
  }

  .process_content {
    grid-template-columns: 1fr;
    align-content: start;
    height: 100%;
    padding-top: 4rem;
    padding-bottom: 4rem;
    position: static;
  }

  .process_content-left {
    text-align: center;
  }

  .process_content-right {
    min-height: 24.5rem;
    position: sticky;
    top: 25%;
  }

  .process_card {
    margin-left: 1.5rem;
  }

  .navbar_component {
    min-height: 4rem;
  }

  .cta_image.is-1 {
    top: -20%;
  }

  .cta_image.is-2 {
    top: -25%;
    left: -1rem;
  }

  .cta_image.is-3 {
    bottom: -20%;
    right: 2rem;
  }

  .cta_image.is-4 {
    bottom: -15%;
    right: 0;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    white-space: pre-line;
    font-size: 3rem;
  }

  h2 {
    font-size: 2rem;
  }

  .heading-style-h4 {
    -webkit-text-stroke-width: .5px;
    font-size: 1.125rem;
  }

  .margin-bottom {
    margin-top: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .icon-embed-xxsmall {
    align-self: flex-end;
  }

  .about_image.is-1 {
    width: 1.5rem;
    top: 0%;
    left: 12%;
  }

  .about_image.is-2 {
    width: 1rem;
    top: -7.5%;
    left: 5%;
  }

  .about_image.is-3 {
    width: 1.4rem;
    bottom: 45%;
    right: 5%;
  }

  .about_image.is-4 {
    width: .8rem;
    bottom: 40%;
    right: 0%;
  }

  .max-width-custom-1 {
    max-width: 100%;
  }

  .project_image-wrapper.pointer-events-off {
    width: 10rem;
  }

  .cta_background-circle-1 {
    width: 22.5vw;
    top: 70%;
    left: -12.5%;
  }

  .cta_background-circle-2 {
    width: 26vw;
    right: -12.5%;
  }

  .about_label-image {
    height: 1rem;
  }

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

  .benefits_testimonial {
    padding: 5rem 2.5rem;
  }

  .benefits_decoration-wrapper {
    width: 25%;
    top: -6%;
  }

  .system_content, .system_list {
    grid-template-columns: 1fr;
  }

  .system_decoration-wrapper {
    height: 18vh;
    top: -9vh;
  }

  .margin-vertical {
    margin-left: 0;
    margin-right: 0;
  }

  .bonus_list {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .bonus_decoration-wrapper {
    height: 15vh;
  }

  .clients_list {
    justify-content: center;
  }

  .clients_wrapper {
    justify-content: center;
    align-items: flex-start;
  }

  .padding-section-custom {
    padding-bottom: 0;
  }

  .projects_decoration-wrapper {
    height: 20vh;
    top: -10vh;
  }

  .button.is-footer {
    font-size: 1.25rem;
    text-decoration: none;
  }

  .faq_decoration-wrapper {
    height: 20vh;
    top: -8vh;
  }

  .padding-bottom {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

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

  .cta_image.is-1 {
    width: 1.5rem;
    top: -2.5rem;
    left: 1rem;
  }

  .cta_image.is-2 {
    width: 1rem;
    top: -3.5rem;
    left: 0;
  }

  .cta_image.is-3 {
    width: 1.4rem;
    bottom: 38%;
    right: 0%;
  }

  .cta_image.is-4 {
    width: .8rem;
    bottom: 34%;
    right: -2.5%;
  }
}

#w-node-_100eb1c1-1a2d-446b-8970-5c806a73c97f-58efa2ae {
  justify-self: start;
}

#w-node-_100eb1c1-1a2d-446b-8970-5c806a73c981-58efa2ae {
  justify-self: center;
}

#w-node-_100eb1c1-1a2d-446b-8970-5c806a73c98b-58efa2ae {
  justify-self: end;
}

#w-node-_2cf33636-5f1a-a78d-c770-8e26653096f4-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e26653096f6-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e26653096f8-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e26653096fa-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e26653096fc-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e26653096fe-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e2665309700-58efa2ae, #w-node-_2cf33636-5f1a-a78d-c770-8e2665309702-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b36-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b38-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b3a-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b3c-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b3e-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b40-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b42-58efa2ae, #w-node-_84ad9f77-c32d-2467-40b1-81e675cf1b44-58efa2ae {
  justify-self: center;
}

#w-node-a56d49de-b417-4b9b-4c72-5eafc0375d1e-58efa2ae, #w-node-a56d49de-b417-4b9b-4c72-5eafc0375d27-58efa2ae, #w-node-a56d49de-b417-4b9b-4c72-5eafc0375d30-58efa2ae {
  align-self: start;
}

#w-node-_035db4c5-4b57-1c2e-ce46-738ee22d424d-58efa2ae {
  justify-self: start;
}

#w-node-_035db4c5-4b57-1c2e-ce46-738ee22d425a-58efa2ae, #w-node-_035db4c5-4b57-1c2e-ce46-738ee22d425b-58efa2ae {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_035db4c5-4b57-1c2e-ce46-738ee22d425e-58efa2ae {
  justify-self: end;
}

#w-node-_235290c2-65a4-9c3e-0e1a-0b990c877b35-58efa2b6 {
  justify-self: start;
}

#w-node-_235290c2-65a4-9c3e-0e1a-0b990c877b37-58efa2b6 {
  justify-self: center;
}

#w-node-_235290c2-65a4-9c3e-0e1a-0b990c877b41-58efa2b6 {
  justify-self: end;
}

#w-node-_74c9e87b-f514-f9bf-831f-6e7f7135acd3-58efa2b6 {
  justify-self: start;
}

#w-node-_74c9e87b-f514-f9bf-831f-6e7f7135ace0-58efa2b6, #w-node-_74c9e87b-f514-f9bf-831f-6e7f7135ace1-58efa2b6 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_74c9e87b-f514-f9bf-831f-6e7f7135ace4-58efa2b6 {
  justify-self: end;
}

@media screen and (max-width: 991px) {
  #w-node-_035db4c5-4b57-1c2e-ce46-738ee22d424d-58efa2ae, #w-node-_74c9e87b-f514-f9bf-831f-6e7f7135acd3-58efa2b6 {
    justify-self: center;
  }
}

@media screen and (max-width: 767px) {
  #w-node-_035db4c5-4b57-1c2e-ce46-738ee22d425e-58efa2ae, #w-node-_74c9e87b-f514-f9bf-831f-6e7f7135ace4-58efa2b6 {
    justify-self: center;
  }
}

@media screen and (max-width: 479px) {
  #w-node-_035db4c5-4b57-1c2e-ce46-738ee22d424d-58efa2ae, #w-node-_74c9e87b-f514-f9bf-831f-6e7f7135acd3-58efa2b6 {
    grid-area: span 1 / span 1 / span 1 / span 1;
  }
}


@font-face {
  font-family: 'Pp Pangram sans';
  src: url('../fonts/PPPangramSans-Medium.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}