@charset "UTF-8";
body {
  background: #ffffff;
  font-family: "Source Sans 3", sans-serif;
  overflow-x: hidden; }

header, section, footer {
  overflow-x: hidden; }

body.inner {
  padding-top: 60px; }

header.main_page {
  padding: 18px 0;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 2; }
  header.main_page .wrapper {
    width: 100%;
    margin: 0 auto;
    max-width: 1480px;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between; }
  header.main_page .logo img {
    max-height: 50px; }
  header.main_page .eyebrow {
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #E2753B;
    margin-bottom: 24px; }
  header.main_page .header_menu ul {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    header.main_page .header_menu ul li {
      padding: 0 16px; }
      header.main_page .header_menu ul li a {
        font-size: 20px;
        color: #ffffff;
        text-decoration: none;
        position: relative;
        font-family: "Source Sans 3", sans-serif;
        font-weight: 600; }
        header.main_page .header_menu ul li a::after {
          content: '';
          position: absolute;
          bottom: -4px;
          left: 0;
          width: 100%;
          height: 1px;
          background-color: #E2753B;
          transform: scaleX(0);
          transform-origin: left center;
          transition: transform 0.4s ease; }
        header.main_page .header_menu ul li a:hover {
          color: #E2753B; }
          header.main_page .header_menu ul li a:hover::after {
            transform: scaleX(1); }
  header.main_page .menu_btn:not(.close_btn) {
    background-image: url(../images/burger-menu.svg); }

header.inner_page {
  padding: 18px 0;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 9;
  background: #ffffff;
  box-shadow: 0 4px 16px rgba(226, 117, 59, 0.18); }
  header.inner_page .wrapper {
    width: 100%;
    margin: 0 auto;
    max-width: 1480px;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between; }
  header.inner_page .logo img {
    max-height: 50px; }
  header.inner_page .header_menu ul {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    header.inner_page .header_menu ul li {
      padding: 0 16px; }
      header.inner_page .header_menu ul li a {
        font-size: 20px;
        color: #E2753B;
        text-decoration: none;
        position: relative;
        font-family: "Source Sans 3", sans-serif;
        font-weight: 600; }
        header.inner_page .header_menu ul li a::after {
          content: '';
          position: absolute;
          bottom: -4px;
          left: 0;
          width: 100%;
          height: 1px;
          background-color: #E2753B;
          transform: scaleX(0);
          transform-origin: left center;
          transition: transform 0.4s ease; }
        header.inner_page .header_menu ul li a:hover {
          color: #E2753B; }
          header.inner_page .header_menu ul li a:hover::after {
            transform: scaleX(1); }
        @media screen and (max-width: 900px) {
          header.inner_page .header_menu ul li a {
            color: #ffffff; } }
  header.inner_page .menu_btn:not(.close_btn) {
    background-image: url(../images/burger-menu-orange.svg); }

.main section, .main footer {
  padding: 120px 0;
  position: relative; }
  .main section .wrapper, .main footer .wrapper {
    width: 100%;
    max-width: 1280px;
    padding: 0 20px;
    margin: 0 auto; }

.inner section, .inner footer {
  padding: 120px 0;
  position: relative; }
  .inner section .wrapper, .inner footer .wrapper {
    width: 100%;
    max-width: 1140px;
    padding: 0 20px;
    margin: 0 auto; }

h2 {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: 52px;
  line-height: 1.08;
  letter-spacing: -0.02px;
  color: #000000;
  margin-bottom: 40px;
  max-width: 760px;
  padding: 18px 0 0 0;
  position: relative; }
  h2 span {
    color: #712A64; }
  h2::before {
    content: '';
    display: inline-block;
    width: 54px;
    height: 6px;
    background: #E2753B;
    border-radius: 4px;
    position: absolute;
    left: 0;
    top: 0; }

h2.zigzag-title,
h2.contact-cta-title {
  padding-top: 0; }
  h2.zigzag-title:before,
  h2.contact-cta-title:before {
    display: none; }

.main .main_hero .wrapper {
  max-width: 1480px; }

.main_hero {
  position: relative;
  height: 100vh;
  overflow: hidden; }
  .main_hero__bg {
    position: absolute;
    inset: 0; }
    .main_hero__bg:after {
      content: "";
      display: block;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      position: absolute; }
  .main_hero__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center; }
  .main_hero__video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center; }
    .main_hero__video.loaded {
      opacity: 1; }
  .main_hero__content {
    position: relative;
    z-index: 1;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center; }
  .main_hero h1 {
    font-family: "Source Sans 3", sans-serif;
    font-size: 64px;
    font-weight: 700;
    line-height: 1.14;
    color: #ffffff;
    max-width: 950px;
    margin-bottom: 38px;
    display: flex;
    flex-direction: column; }
    .main_hero h1:before {
      content: "";
      display: inline-block;
      width: 72px;
      height: 8px;
      background: #E2753B;
      margin-bottom: 12px;
      border-radius: 4px; }
  .main_hero p {
    font-family: "Source Sans 3", sans-serif;
    font-size: 24px;
    font-weight: 500;
    line-height: 1.24;
    color: #ffffff;
    max-width: 920px;
    margin-bottom: 32px; }
  .main_hero .cta_buttons {
    display: flex;
    align-items: center;
    gap: 12px;
    width: fit-content; }
  .main_hero .cta {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    background: #C44427;
    border-radius: 18px;
    border: 2px solid transparent;
    padding: 12px 22px;
    font-family: "Source Sans 3", sans-serif;
    font-weight: 500;
    font-size: 18px;
    color: #fff;
    transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
    overflow: hidden; }
    .main_hero .cta__icon {
      display: flex;
      align-items: center;
      flex-shrink: 0; }
    .main_hero .cta__text {
      display: flex;
      flex-direction: column;
      height: 1.2em;
      overflow: hidden; }
    .main_hero .cta__label {
      display: block;
      line-height: 1.2;
      transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
      white-space: nowrap; }
      .main_hero .cta__label:last-child {
        transform: translateY(100%); }
    .main_hero .cta:hover {
      background: #712A64;
      border-color: #712A64;
      color: #ffffff; }
      .main_hero .cta:hover .cta__label {
        transform: translateY(-100%); }
    .main_hero .cta.no_bg {
      background: rgba(0, 0, 0, 0.4);
      border-color: #C44427;
      color: #ffffff; }
      .main_hero .cta.no_bg:hover {
        background: #712A64;
        border-color: transparent;
        color: #fff; }

@media (max-width: 900px) {
  .main_hero h1 {
    font-size: 48px; }

  .main_hero p {
    font-size: 20px; } }
@media (max-width: 648px) {
  .main_hero {
    padding-bottom: 40px; }
    .main_hero h1 {
      font-size: 36px; }

  .main_hero p {
    font-size: 18px; }

  .main_hero .cta_buttons {
    flex-direction: column;
    align-items: flex-start; } }
@media (max-width: 380px) {
  .main_hero h1 {
    font-size: 32px; } }
.text_section-inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 80px;
  align-items: center; }

.text_section-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px 48px;
  max-width: 760px;
  font-family: "Source Sans 3", sans-serif; }

.text_section-body p {
  font-size: 18px;
  line-height: 1.8;
  color: #555555;
  font-family: "Source Sans 3", sans-serif; }

.text_section-body p strong {
  color: #000000;
  font-weight: 600; }

.text_section-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 220px; }

.text_section-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  background: #E2753B;
  color: #fff;
  font-family: "Source Sans 3", sans-serif;
  font-size: 18px;
  font-weight: 600;
  padding: 14px 24px;
  border-radius: 24px;
  border: 2px solid transparent;
  transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  white-space: nowrap; }

.text_section-cta:hover {
  background: transparent;
  border-color: #E2753B;
  color: #E2753B; }

.text_section-cta.secondary {
  background: transparent;
  border-color: #712A64;
  color: #712A64; }

.text_section-cta.secondary:hover {
  background: #712A64;
  color: #fff; }

.text_section-cta svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  stroke: currentColor; }

@media (max-width: 960px) {
  .text_section-inner {
    grid-template-columns: 1fr;
    gap: 40px; }

  .text_section-right {
    padding-top: 0;
    flex-direction: row;
    flex-wrap: wrap; }

  .text_section-body {
    grid-template-columns: 1fr; } }
.hti-section {
  background-image: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); }
  @media (max-width: 900px) {
    .hti-section {
      background: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.hti-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: end;
  margin-bottom: 80px; }

.hti-tagline {
  font-size: 16px;
  line-height: 1.4;
  color: #555555;
  max-width: 350px;
  align-self: center;
  padding-bottom: 6px;
  border-left: 3px solid #E2753B;
  padding-left: 20px;
  font-family: "Source Sans 3", sans-serif;
  margin-right: 30px; }

.hti-tagline strong {
  color: #000000;
  font-weight: 600; }

.main .hti-tagline {
  margin-left: auto; }

.hti-track {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  position: relative; }

/* ── FLIP CARD ── */
.flip-card {
  perspective: 1400px;
  height: 500px;
  cursor: pointer; }

.flip-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.75s cubic-bezier(0.4, 0.2, 0.2, 1); }

.flip-card:hover .flip-inner,
.flip-card.flipped .flip-inner {
  transform: rotateY(180deg); }

.flip-front,
.flip-back {
  position: absolute;
  inset: 0;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  overflow: hidden; }

/* ── FRONT (image side stays dark — it's a photo card) ── */
.flip-front {
  background: #712A64;
  border-radius: 4px;
  overflow: hidden; }

.card-img-placeholder img {
  position: absolute;
  inset: 0;
  width: 100%;
  object-fit: contain;
  object-position: center;
  opacity: 0.99; }

.card-img-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background: #ededed; }

/* placeholder bg per card */
.ph-control {
  background: #f1f1f1; }

.ph-hpca {
  background: #f1f1f1; }

.ph-anode {
  background: #ededed; }

.ph-control-svg {
  position: absolute;
  inset: 0;
  opacity: 0.28; }

.circuit-lines line {
  stroke: #E2753B;
  stroke-width: 1;
  fill: none; }

.circuit-lines circle {
  fill: #E2753B; }

.card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10, 12, 18, 0.92) 0%, rgba(10, 12, 18, 0.3) 50%, transparent 100%);
  z-index: 1; }

.card-front-content {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 28px 28px 26px;
  z-index: 2; }

.card-tag {
  font-family: "Source Sans 3", sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px; }

.card-tag::before {
  content: '';
  width: 16px;
  height: 2px;
  background: #E2753B;
  display: inline-block;
  border-radius: 1px; }

.card-title {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 600;
  font-size: 28px;
  color: #fff;
  line-height: 1.15; }

.card-subtitle {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.45);
  margin-top: 6px;
  font-weight: 400;
  font-family: "Source Sans 3", sans-serif; }

/* Hover hint */
.flip-hint {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 3;
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 0.3s, transform 0.3s;
  background: rgba(255, 255, 255, 0.08); }

.flip-card:hover .flip-hint {
  opacity: 1;
  transform: scale(1); }

.flip-hint svg {
  width: 14px;
  height: 14px;
  stroke: rgba(255, 255, 255, 0.7); }

/* ── BACK (light) ── */
.flip-back {
  transform: rotateY(180deg);
  background: #ffffff;
  border: 2px solid #712A64;
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 36px 32px; }

.back-header {
  border-bottom: 1px solid rgba(51, 51, 51, 0.1);
  padding-bottom: 20px;
  margin-bottom: 20px; }

.back-tag {
  font-family: "Source Sans 3", sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 10px; }

.back-title {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: #000000;
  line-height: 1.15; }

.back-desc {
  font-size: 17px;
  line-height: 1.45;
  color: #555555;
  flex: 1;
  font-family: "Source Sans 3", sans-serif; }

.back-metrics {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  padding-top: 24px; }

.metric {
  display: flex;
  flex-direction: column;
  gap: 4px; }

.metric-value {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: 28px;
  color: #712A64;
  line-height: 1; }

.metric-label {
  font-family: "Source Sans 3", sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #555555; }

/* ── KEY MESSAGE ── */
.hti-message {
  margin-top: 80px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 64px;
  align-items: center;
  padding: 56px 0;
  border-top: 1px solid rgba(51, 51, 51, 0.1); }

.msg-number {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: clamp(80px, 12vw, 140px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px rgba(226, 117, 59, 0.2);
  letter-spacing: -0.04em;
  text-align: center; }

.msg-headline {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 3vw, 34px);
  color: #000000;
  line-height: 1.15;
  margin-bottom: 20px;
  letter-spacing: -0.01em; }

.msg-headline em {
  font-style: normal;
  color: #712A64; }

.msg-body {
  font-size: 16px;
  line-height: 1.8;
  color: #555555;
  max-width: 520px; }

.msg-body strong {
  color: #000000;
  font-weight: 600; }

/* ── OBJECTIVE STRIP ── */
.hti-objectives {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px; }

.obj-item {
  background: #ffffff;
  border: 1px solid rgba(51, 51, 51, 0.1);
  border-radius: 4px;
  padding: 32px 36px;
  display: flex;
  align-items: flex-start;
  gap: 24px;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease; }

.obj-item.visible {
  opacity: 1;
  transform: translateY(0); }

.obj-item:hover {
  border-color: #E2753B;
  background: #ffffff;
  transition: border-color 0.3s ease, background 0.3s ease, opacity 0.5s ease, transform 0.5s ease; }

.obj-icon {
  width: 48px;
  height: 48px;
  border: 1.5px solid rgba(51, 51, 51, 0.1);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
  background: #ffffff; }

.obj-icon svg {
  width: 20px;
  height: 20px; }

.obj-label {
  font-family: "Source Sans 3", sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 6px; }

.obj-title {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #000000;
  margin-bottom: 8px; }

.obj-desc {
  font-size: 14px;
  color: #555555;
  line-height: 1.65; }

/* ── RESPONSIVE ── */
@media (max-width: 1160px) {
  .flip-back {
    padding: 16px 12px; }

  .metric-value {
    font-size: 24px; } }
@media (max-width: 980px) {
  .hti-header {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 40px; }

  .hti-track {
    grid-template-columns: 1fr; }

  .hti-message {
    grid-template-columns: 1fr;
    gap: 32px; }

  .msg-number {
    font-size: 80px;
    text-align: left; }

  .hti-objectives {
    grid-template-columns: 1fr; }

  .container {
    padding: 0 24px; }

  .metric-value {
    font-size: 28px; }

  .card-img-placeholder img {
    position: relative; } }
@media (max-width: 600px) {
  .card-img-placeholder img {
    position: absolute; } }
.loop-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none; }

.loop-header {
  display: grid;
  grid-template-columns: 0.89fr 1fr;
  gap: 32px;
  align-items: center;
  margin-bottom: 80px; }

.loop-tagline {
  font-size: 16px;
  line-height: 1.7;
  color: #555555;
  max-width: 380px;
  align-self: center;
  border-left: 3px solid #E2753B;
  padding-left: 20px;
  margin-right: 30px;
  font-family: "Source Sans 3", sans-serif; }

.loop-tagline strong {
  color: #000000;
  font-weight: 600; }

.loop-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center; }

.loop-diagram {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  max-width: 520px;
  margin: 0 auto; }

.loop-diagram svg {
  width: 100%;
  height: 100%; }

.loop-node {
  cursor: default;
  transition: all 0.35s ease; }

.node-card {
  fill: #ffffff;
  stroke: rgba(51, 51, 51, 0.1);
  stroke-width: 1.5;
  filter: drop-shadow(0 2px 8px rgba(51, 51, 51, 0.07));
  transition: all 0.35s ease; }

.loop-node.active .node-card {
  stroke: #E2753B;
  stroke-width: 2;
  filter: drop-shadow(0 4px 16px rgba(226, 117, 59, 0.18)); }

.node-num {
  font-family: "Source Sans 3", sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.15em;
  fill: #E2753B; }

.node-label {
  font-family: "Source Sans 3", sans-serif;
  font-size: 16px;
  font-weight: 700;
  fill: #000000; }

.node-sub {
  font-family: "Source Sans 3", sans-serif;
  font-size: 14px;
  font-weight: 400;
  fill: #555555; }

/* ── STEPS LIST ── */
.loop-steps {
  display: flex;
  flex-direction: column;
  gap: 0; }

.step {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  padding: 28px 0;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1);
  cursor: default;
  transition: background 0.3s ease;
  position: relative; }

.step:first-child {
  border-top: 1px solid rgba(51, 51, 51, 0.1); }

.step::before {
  content: '';
  position: absolute;
  left: -48px;
  top: 0;
  bottom: 0;
  width: 3px;
  background: #E2753B;
  transform: scaleY(0);
  transform-origin: top;
  transition: transform 0.4s ease;
  border-radius: 2px; }

.step.active::before {
  transform: scaleY(1); }

.step-num {
  font-family: "Source Sans 3", sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: #E2753B;
  flex-shrink: 0;
  width: 24px;
  padding-top: 3px; }

.step-icon {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid rgba(51, 51, 51, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: #ffffff;
  transition: background 0.3s ease, border-color 0.3s ease; }

.step.active .step-icon {
  background: #E2753B;
  border-color: #E2753B; }

.step-icon svg {
  width: 16px;
  height: 16px;
  stroke: #555555;
  transition: stroke 0.3s ease; }

.step.active .step-icon svg {
  stroke: #fff; }

.step-text {
  flex: 1; }

.step-title {
  font-family: "Source Sans 3", sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #000000;
  margin-bottom: 4px;
  line-height: 1.2;
  transition: color 0.3s ease; }

.step.active .step-title {
  color: #E2753B; }

.step-desc {
  font-family: "Source Sans 3", sans-serif;
  font-size: 16px;
  color: #555555;
  line-height: 1.6; }

/* ── ARROW connector between step-icon and text ── */
.step-inner {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  flex: 1; }

/* ── ANCHOR PHRASE ── */
.loop-anchor {
  margin-top: 80px;
  padding-top: 56px;
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 48px;
  align-items: center;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease; }

.anchor-number {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: clamp(80px, 10vw, 120px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px rgba(226, 117, 59, 0.18);
  letter-spacing: -0.04em;
  user-select: none; }

.anchor-phrase {
  font-family: "Source Sans 3", sans-serif;
  font-weight: 700;
  font-size: clamp(22px, 3vw, 36px);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #555555; }

.anchor-phrase em {
  font-style: normal;
  color: #000000; }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .loop-header {
    grid-template-columns: 1fr;
    gap: 24px; }

  .loop-body {
    grid-template-columns: 1fr; }

  .loop-diagram {
    max-width: 360px; }

  .loop-anchor {
    grid-template-columns: 1fr;
    gap: 16px; }

  .anchor-number {
    font-size: 64px; }

  .container {
    padding: 0 24px; }

  .step::before {
    display: none; } }
.zigzag-section {
  background-image: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); }
  @media (max-width: 900px) {
    .zigzag-section {
      background: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.zigzag-wrapper {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 48px;
  position: relative; }

.zigzag-image {
  width: 900px;
  max-width: 100%;
  height: 500px;
  overflow: hidden;
  position: relative;
  z-index: 0;
  transition: opacity 0.7s ease;
  left: -100px; }
  @media (max-width: 900px) {
    .zigzag-image {
      left: -10px;
      width: calc(100% + 20px) !important;
      max-width: calc(100% + 20px); } }

.zigzag-image.in {
  opacity: 1; }

.zigzag-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.7s ease; }

.zigzag-section:hover .zigzag-image img {
  transform: scale(1.03); }

.zigzag-image-placeholder {
  width: 100%;
  height: 100%;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: #555555;
  letter-spacing: 0.1em;
  text-transform: uppercase; }

/* ── CARD ── */
.zigzag-card {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 55%;
  background: #ffffff;
  padding: 52px 48px;
  box-shadow: 0 8px 48px rgba(51, 51, 51, 0.13);
  z-index: 2; }

.zigzag-card.in {
  opacity: 1; }

.zigzag-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 48px;
  background: #E2753B;
  border-radius: 0 2px 2px 0; }

/* ── REVERSE ── */
.zigzag-section.reverse .zigzag-image {
  margin-left: auto; }

.zigzag-section.reverse .zigzag-card {
  right: auto;
  left: 48px; }

.zigzag-section.reverse .zigzag-card::before {
  left: auto;
  right: 0;
  border-radius: 2px 0 0 2px; }

/* ── SURFACE variant ── */
.zigzag-section.surface .zigzag-card {
  background: #ffffff; }

/* ════════════════════════════════════════
   CARD CONTENT
   ════════════════════════════════════════ */
.zigzag-eyebrow {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: #E2753B;
  text-transform: uppercase;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: "Source Sans 3", sans-serif; }

.zigzag-eyebrow::before {
  content: '';
  display: inline-block;
  width: 40px;
  height: 5px;
  background: #E2753B;
  border-radius: 3px;
  flex-shrink: 0; }

.zigzag-title {
  font-weight: 700;
  font-size: clamp(22px, 2.5vw, 32px);
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: #000000;
  margin-bottom: 16px;
  font-family: "Source Sans 3", sans-serif; }

.zigzag-title span {
  color: #712A64; }

.zigzag-desc {
  font-size: 18px;
  line-height: 1.8;
  color: #555555;
  margin-bottom: 32px;
  font-family: "Source Sans 3", sans-serif; }

.zigzag-desc strong {
  color: #000000;
  font-weight: 600; }

.zigzag-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px; }

.zigzag-cta {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
  font-size: 15px;
  font-weight: 600;
  padding: 13px 24px;
  border-radius: 24px;
  border: 2px solid transparent;
  transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  white-space: nowrap;
  cursor: pointer;
  font-family: "Source Sans 3", sans-serif; }

.zigzag-cta svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  flex-shrink: 0; }

.zigzag-cta.primary {
  background: #E2753B;
  color: #fff; }

.zigzag-cta.primary:hover {
  background: transparent;
  border-color: #E2753B;
  color: #E2753B; }

.zigzag-cta.secondary {
  background: transparent;
  border-color: #712A64;
  color: #712A64; }

.zigzag-cta.secondary:hover {
  background: #712A64;
  color: #fff; }

/* ════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════ */
@media (max-width: 960px) {
  .zigzag-section {
    padding: 0 0 56px; }

  .zigzag-wrapper {
    padding: 0 24px; }

  .zigzag-image {
    width: 100%;
    height: 260px;
    margin-left: 0 !important; }

  .zigzag-card {
    position: relative;
    right: auto;
    left: auto;
    top: auto;
    transform: none;
    width: 100%;
    margin-top: -40px;
    padding: 36px 28px; } }
/* ── HEADER ── */
.news-header {
  margin-bottom: 48px; }

/* ── GRID ── */
.news-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  margin-bottom: 56px; }

/* ── CARD ── */
.news-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: opacity 0.6s ease, transform 0.6s ease;
  font-family: "Source Sans 3", sans-serif; }

/* image */
.news-card-image {
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #ffffff;
  margin-bottom: 20px;
  position: relative; }

.news-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform 0.5s ease; }

.news-card:hover .news-card-image img {
  transform: scale(1.05); }

/* placeholder */
.news-card-image-placeholder {
  width: 100%;
  height: 100%;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: #555555;
  letter-spacing: 0.08em;
  text-transform: uppercase; }

/* tag */
.news-card-tag {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #555555;
  text-transform: uppercase;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px; }

.news-card-tag::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #E2753B;
  flex-shrink: 0; }

/* headline */
.news-card-title {
  font-weight: 700;
  font-size: 19px;
  line-height: 1.35;
  color: #000000;
  transition: color 0.25s ease; }

.news-card:hover .news-card-title {
  color: #712A64; }

/* ── BOTTOM ROW ── */
.news-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 40px;
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  transition: opacity 0.6s ease 0.3s, transform 0.6s ease 0.3s;
  font-family: "Source Sans 3", sans-serif; }

.news-count {
  font-size: 16px;
  color: #555555; }

.news-count strong {
  color: #000000;
  font-weight: 600; }

/* CTA */
.news-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-size: 16px;
  font-weight: 600;
  padding: 13px 28px;
  border-radius: 24px;
  border: 2px solid #712A64;
  color: #712A64;
  background: transparent;
  transition: background 0.3s ease, color 0.3s ease; }

.news-cta:hover {
  background: #712A64;
  color: #fff; }

.news-cta svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  flex-shrink: 0;
  transition: transform 0.3s ease; }

.news-cta:hover svg {
  transform: translateX(3px); }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
  .news-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 28px; } }
@media (max-width: 600px) {
  .news-grid {
    grid-template-columns: 1fr; }

  .news-footer {
    flex-direction: column;
    gap: 20px;
    align-items: flex-start; }

  .container {
    padding: 0 24px; }

  .news-count {
    display: none; }

  .news-cta {
    margin: 0 auto; } }
.contact-cta {
  background: #f5f4f1;
  text-align: center;
  font-family: "Source Sans 3", sans-serif; }

.contact-cta-inner {
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px; }

.contact-cta-desc {
  font-size: 18px;
  line-height: 1.7;
  color: #555555;
  margin-bottom: 8px; }

/* CTA button */
.contact-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-family: "Source Sans 3", sans-serif;
  font-size: 16px;
  font-weight: 600;
  padding: 15px 36px;
  border-radius: 32px;
  border: 2px solid transparent;
  background: #E2753B;
  color: #fff;
  transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  cursor: pointer;
  margin-top: 8px; }

.contact-cta-btn:hover {
  background: transparent;
  border-color: #E2753B;
  color: #E2753B; }

.contact-cta-btn svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  flex-shrink: 0; }

@media (max-width: 600px) {
  .contact-cta {
    padding: 72px 24px; } }
.main footer.site-footer,
.inner footer.site-footer {
  background: #333333;
  color: #ffffff;
  padding: 80px 0 0;
  font-family: "Source Sans 3", sans-serif; }

/* ── TOP ROW: logo + nav + contacts ── */
.footer-top {
  display: grid;
  grid-template-columns: 200px 1fr auto;
  gap: 64px;
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08); }

/* ── LOGO ── */
.footer-logo {
  display: flex;
  flex-direction: column;
  gap: 16px; }

.footer-logo-mark {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none; }

/* placeholder logo */
.footer-logo-icon img {
  height: 46px; }

.footer-logo-name {
  font-weight: 700;
  font-size: 18px;
  color: #ffffff;
  letter-spacing: -0.01em; }

.footer-logo-name span {
  color: #E2753B; }

.footer-tagline {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.38);
  line-height: 1.6; }

/* ── NAV ── */
.footer-nav ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  columns: 2;
  column-gap: 48px; }

/* two-column nav using columns */
.footer-nav {
  columns: unset;
  /* reset, using ul columns */ }

.footer-nav ul {
  display: block;
  columns: 2;
  column-gap: 48px; }

.footer-nav li {
  break-inside: avoid;
  margin-bottom: 4px; }

.footer-nav a {
  text-decoration: none;
  font-size: 16px;
  color: rgba(255, 255, 255, 0.65);
  transition: color 0.25s ease;
  display: inline-block;
  padding: 6px 0;
  position: relative; }

.footer-nav a::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #E2753B;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s ease; }

.footer-nav a:hover {
  color: #ffffff; }

.footer-nav a:hover::after {
  transform: scaleX(1); }

/* ── CONTACT INFO ── */
.footer-contact {
  display: flex;
  flex-direction: column;
  gap: 24px;
  min-width: 220px; }

.footer-contact-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 8px; }

.footer-contact-value {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.65);
  line-height: 1.6; }

.footer-contact-link {
  display: inline-block;
  text-decoration: none;
  font-size: 16px;
  font-weight: 600;
  color: #fff;
  transition: color 0.25s ease; }

.footer-contact-link:hover {
  color: #E2753B; }

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 0;
  gap: 24px; }

.footer-copyright {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.35); }

.footer-legal {
  display: flex;
  gap: 24px;
  list-style: none; }

.footer-legal a {
  text-decoration: none;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.35);
  transition: color 0.25s ease; }

.footer-legal a:hover {
  color: rgba(255, 255, 255, 0.7); }

@media (max-width: 900px) {
  .footer-top {
    grid-template-columns: 1fr;
    gap: 40px; }

  .footer-nav ul {
    columns: 1; }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px; }

  .footer-container {
    padding: 0 24px; } }
.inner_hero .wrapper {
  z-index: 2;
  position: relative; }

.inner_hero {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  color: #ffffff;
  padding: 100px 0 100px;
  position: relative;
  overflow: hidden; }
  @media screen and (max-width: 600px) {
    .inner_hero {
      background-position: 70% 50%; } }

.inner_hero::before {
  position: absolute;
  right: 0;
  bottom: 0;
  font-size: 128px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.03);
  line-height: 1;
  pointer-events: none;
  user-select: none; }

.inner .inner_hero_with_stat.inner_hero {
  padding-bottom: 0; }

.inner_hero::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1; }

.inner_hero-eyebrow {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 24px; }

.inner_hero-eyebrow_2 {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #ffffff;
  margin-bottom: 1.5rem;
  background: #E2753B;
  width: fit-content;
  padding: 4px 8px;
  line-height: 1; }

.inner_hero h1 {
  font-size: 58px;
  font-weight: 700;
  line-height: 1.05;
  max-width: 750px;
  margin-bottom: 32px; }

.inner_hero-lead {
  font-size: 18px;
  font-weight: 400;
  color: white;
  max-width: 560px;
  line-height: 1.75; }

/* stats bar */
.hero-stats {
  display: flex;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  margin-top: 36px; }

.hero-stat {
  flex: 1;
  padding: 20px 24px;
  border-right: 1px solid rgba(255, 255, 255, 0.08); }

.hero-stat:last-child {
  border-right: none; }

.hero-stat-value {
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  margin-bottom: 6px; }

.hero-stat-label {
  font-size: 14px;
  color: #E2753B;
  font-weight: 400; }

/* diagram strip */
.hero-diagram {
  background: #000000;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  padding: 28px 0 0;
  overflow: hidden; }

.hero-diagram img {
  display: block;
  max-width: 860px;
  margin: 0 auto;
  width: 100%;
  -webkit-mask-image: linear-gradient(to bottom, black 55%, transparent 100%);
  mask-image: linear-gradient(to bottom, black 55%, transparent 100%); }

@media (max-width: 620px) {
  .hero-stats {
    flex-wrap: wrap; }

  .hero-stat {
    flex: 1 1 45%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06); }

  .hero-stat-value {
    font-size: 16px; } }
@media (max-width: 900px) {
  .main_hero h1 {
    font-size: 48px; }

  .main_hero p {
    font-size: 20px; } }
@media (max-width: 648px) {
  .inner_hero h1 {
    font-size: 36px; }

  .main_hero p {
    font-size: 18px; } }
@media (max-width: 380px) {
  .inner_hero h1 {
    font-size: 32px; } }
/* ── OVERVIEW GRID ── */
.overview {
  background: #f5f4f1;
  padding: 100px 0;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

.overview-label {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 2rem; }

.product-nav {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  border: 1px solid rgba(51, 51, 51, 0.1); }

.product-nav-card {
  padding: 1.5rem 1.25rem;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: background 0.15s;
  border-right: 1px solid rgba(51, 51, 51, 0.1);
  background: #ffffff; }

.product-nav-card:last-child {
  border: none; }

.product-nav-card:hover {
  background: #712A64; }

.product-nav-name {
  font-size: 1.3rem;
  font-weight: 700;
  color: #712A64;
  line-height: 1; }

.product-nav-title {
  font-size: 14px;
  font-weight: 600;
  text-transform: uppercase;
  color: #555555;
  line-height: 1.4;
  min-height: 60px; }

.product-nav-saving {
  margin-top: auto;
  padding-top: 0.75rem;
  font-size: 14px;
  font-weight: 500;
  color: #E2753B;
  border-top: 1px solid rgba(51, 51, 51, 0.1); }

.product-nav-card:hover .product-nav-name {
  color: #ffffff; }

.product-nav-card:hover .product-nav-title {
  color: #ffffff; }

.product-nav-card:hover .product-nav-saving {
  color: #ffffff; }

.product-section {
  padding: 60px 0;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

.product-section:nth-child(odd) {
  background: #ffffff; }

.product-section:nth-child(even) {
  background-image: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); }
  @media screen and (max-width: 960px) {
    .product-section:nth-child(even) {
      background-image: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.product-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start; }

.product-body--reversed .product-images {
  order: -1; }

.product-images {
  display: flex;
  flex-direction: column;
  gap: 1.5px; }

.img-wrap {
  background: #f5f4f1;
  overflow: hidden;
  aspect-ratio: 4/3;
  border-radius: 8px; }

.img-wrap.square {
  aspect-ratio: 1/1; }

.img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: contrast(1.03); }

/* text side */
.product-intro:first-of-type {
  margin-top: 28px; }

.product-intro {
  font-size: 18px;
  color: #555555;
  line-height: 1.25;
  margin-bottom: 32px; }

.product-text table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px; }
.product-text th, .product-text td {
  padding: 6px 8px;
  text-align: left;
  border: 1px solid rgba(51, 51, 51, 0.1); }
.product-text thead th, .product-text thead td {
  border: 1px solid #ffffff;
  text-align: center; }
  @media screen and (max-width: 420px) {
    .product-text thead th th, .product-text thead th td, .product-text thead td th, .product-text thead td td {
      padding: 4px 6px; } }
.product-text thead tr:first-child th {
  background: #712A64;
  color: #ffffff;
  font-weight: 600; }
.product-text thead tr:last-child th {
  background: rgba(113, 42, 100, 0.8);
  color: #ffffff;
  font-weight: 500;
  font-size: 12px;
  text-align: center; }
.product-text tbody td {
  text-align: center;
  font-size: 14px; }
.product-text .bold {
  font-weight: 600; }

.product-intro strong {
  color: #000000;
  font-weight: 500; }

.product-saving {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: #E2753B;
  color: #fff;
  padding: 10px 16px; }

.product-saving:first-of-type {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: #712A64;
  color: #fff;
  padding: 10px 16px;
  margin-bottom: 12px; }

.product-saving-value {
  font-size: 16px;
  font-weight: 700;
  color: #ffffff; }

.product-saving-label {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.9); }

.feature-group {
  margin-bottom: 32px; }

.feature-group-title {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #555555;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

.feature-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 12px; }

.feature-list li {
  font-size: 18px;
  color: #555555;
  padding-left: 16px;
  position: relative;
  line-height: 1.55; }

.feature-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #E2753B; }

.feature-list.green li::before {
  background: #698F3F; }

.product-cta {
  margin-top: 32px;
  padding: 12px 16px;
  background: rgba(196, 92, 26, 0.2);
  border-left: 3px solid #E2753B;
  font-size: 16px;
  color: #555555;
  line-height: 1.6; }

.product-cta strong {
  color: #E2753B;
  font-weight: 600; }

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .product-nav {
    grid-template-columns: repeat(3, 1fr); }

  .product-body, .product-body--reversed {
    grid-template-columns: 1fr; }

  .product-body--reversed .product-images {
    order: 0; }

  .product-images.two-up {
    grid-template-columns: 1fr 1fr; }

  .savings-table {
    grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) {
  .product-nav {
    grid-template-columns: repeat(2, 1fr); }

  .savings-table {
    grid-template-columns: 1fr; }

  .inner_hero {
    padding: 40px 0; }

  .product-nav-card {
    border-right: none;
    border-bottom: 1px solid rgba(51, 51, 51, 0.1); }
    .product-nav-card:nth-child(odd) {
      border-right: 1px solid rgba(51, 51, 51, 0.1); } }
.eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 24px; }

.closing p:not(.eyebrow) {
  font-size: 16px;
  font-weight: 400;
  color: #333333;
  line-height: 1.75;
  margin-bottom: 14px; }

.savings-table {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  border: 1px solid rgba(255, 255, 255, 0.08); }

.savings-cell {
  border: 1px #E2753B solid;
  padding: 24px 16px;
  background: rgba(226, 117, 59, 0.14); }

.savings-product {
  font-size: 22px;
  font-weight: 700;
  color: #712A64;
  margin-bottom: 12px; }

.savings-number {
  font-size: 20px;
  font-weight: 700;
  color: #E2753B;
  margin-bottom: 12px; }

.savings-unit {
  font-size: 16px;
  color: #333333; }

.closing-p {
  font-size: 12px;
  font-weight: 300;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.75; }

.closing-pillars {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.06); }

.pillar {
  background: rgba(255, 255, 255, 0.03);
  padding: 1.2rem 1.5rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start; }

.pillar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #E2753B;
  flex-shrink: 0;
  margin-top: 0.5rem; }

.pillar-text {
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.55; }

.pillar-text strong {
  color: #fff;
  font-weight: 500; }

.climate-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-top: 3rem; }

.climate_section .hti-tagline {
  max-width: unset; }

.mechanism-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1); }

.mechanism {
  background: #f5f4f1;
  padding: 16px 18px;
  display: flex;
  gap: 12px;
  align-items: flex-start; }

.mech-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #698F3F;
  flex-shrink: 0;
  margin-top: 8px; }

.mech-text {
  font-size: 16px;
  color: #555555;
  line-height: 1.55; }

.mech-text strong {
  color: #000000;
  font-weight: 500; }

.cbam-box {
  background: #698F3F;
  color: #fff;
  padding: 26px 24px; }

.cbam-label {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.38);
  margin-bottom: 16px; }

.cbam-items {
  display: flex;
  flex-direction: column;
  gap: 12px; }

.cbam-item {
  display: flex;
  gap: 10px;
  align-items: flex-start; }

.cbam-bullet {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.38);
  flex-shrink: 0;
  margin-top: 8px; }

.cbam-item-text {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.55; }

.cbam-item-text strong {
  color: #fff;
  font-weight: 500; }

.cbam-footer {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.45);
  font-size: 14px;
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
  font-style: italic; }

.green_aluminium {
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  background: #f5f4f1; }

.green_aluminium h2 {
  margin-bottom: 24px; }

.esg-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1);
  margin-top: 32px; }

.esg-card {
  background: #ffffff;
  padding: 2.25rem 2rem; }

.esg-bar {
  width: 32px;
  height: 3px;
  margin-bottom: 16px; }

.esg-card--ga .esg-bar {
  background: #698F3F; }

.esg-card--esg .esg-bar {
  background: #E2753B; }

.esg-card-title {
  color: #712A64;
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 10px; }

p.esg-card-body {
  font-size: 17px !important;
  color: #555555;
  line-height: 1.64; }

.section-lead {
  font-size: 16px;
  color: #555555;
  line-height: 1.75;
  max-width: 600px; }

.trial_block .wrapper {
  z-index: 2;
  position: relative; }

.trials-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-top: 36px; }

.trials-strip {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1); }

.trial-cell {
  background: #fff !important;
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px; }

.trial-bar {
  width: 24px;
  height: 3px;
  background: #698F3F;
  border-radius: 2px; }

.trial-text {
  font-size: 18px;
  color: #000000;
  line-height: 1.5;
  font-weight: 400; }

.trial-cell.full {
  grid-column: 1 / -1; }

.trials-statement {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.25;
  color: #000000;
  margin-bottom: 16px; }

.trials-p {
  font-size: 16px;
  color: #555555;
  line-height: 1.75; }

.esg-translate {
  margin-top: 1.25rem;
  padding: 1.1rem 1.25rem;
  background: #e4ede5;
  border-left: 3px solid #698F3F;
  font-size: 16px;
  color: #333333;
  line-height: 1.65; }

.esg-translate strong {
  color: #698F3F;
  font-weight: 600; }

.trial_block {
  position: relative; }

.trial_block:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-image: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%);
  position: absolute;
  z-index: 1;
  pointer-events: none; }
  @media screen and (max-width: 900px) {
    .trial_block:before {
      background-image: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.products-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 2.5rem; }

.prod-card {
  background: #f5f4f1;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px; }

.prod-name {
  font-size: 18px;
  font-weight: 700;
  color: #698F3F;
  line-height: 1; }

.prod-subtitle {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #555555; }

.prod-desc {
  font-size: 17px !important;
  color: #555555;
  line-height: 1.42 !important;
  margin-top: 8px; }

.prod-media {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  border: 1px solid rgba(51, 51, 51, 0.1);
  border-top: none;
  height: 200px; }

.prod-media-img {
  overflow: hidden; }

.prod-media-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.88) contrast(1.05) saturate(0.8); }

.drivers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1);
  margin-top: 3rem; }

.driver-card {
  background: #ffffff;
  padding: 28px 24px;
  display: flex;
  flex-direction: column; }

.driver-num {
  font-size: 40px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 12px; }

.driver-card--e .driver-num {
  color: #712A64; }

.driver-card--p .driver-num {
  color: #E2753B; }

.driver-card--v .driver-num {
  color: #698F3F; }

.driver-bar {
  width: 32px;
  height: 3px;
  margin-bottom: 16px; }

.driver-card--e .driver-bar {
  background: #712A64; }

.driver-card--p .driver-bar {
  background: #E2753B; }

.driver-card--v .driver-bar {
  background: #698F3F; }

.driver-title {
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 0.65rem;
  color: #000000; }

.driver-intro {
  font-size: 16px;
  color: #555555;
  line-height: 1.6;
  margin-bottom: 20px; }

.driver-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: auto; }

.driver-list li {
  font-size: 16px;
  color: #555555;
  padding-left: 12px;
  position: relative;
  line-height: 1.5; }

.driver-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 5px;
  height: 5px;
  border-radius: 50%; }

.driver-card--e .driver-list li::before {
  background: #712A64; }

.driver-card--p .driver-list li::before {
  background: #E2753B; }

.driver-card--v .driver-list li::before {
  background: #698F3F; }

.driver-badge {
  display: inline-block;
  margin-top: 18px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  border-radius: 2px;
  background: rgba(105, 143, 63, 0.1);
  color: #698F3F; }

.apc-strip {
  margin-top: 24px;
  background: rgba(226, 117, 59, 0.1);
  border-left: 3px solid #E2753B;
  padding: 1.1rem 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap; }

.apc-strip p {
  font-size: 16px;
  color: #000000;
  margin-bottom: 0;
  line-height: 1.55; }

.apc-link {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #E2753B;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  white-space: nowrap; }

.strategy-steps {
  background: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); }
  @media screen and (max-width: 900px) {
    .strategy-steps {
      background: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.energy-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-top: 36px; }

.energy-chain {
  background: #333333;
  color: #fff;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px; }

.echain-step {
  display: flex;
  gap: 12px;
  align-items: flex-start; }

.echain-n {
  font-size: 12px;
  font-weight: 700;
  color: #E2753B;
  flex-shrink: 0;
  padding-top: 2px;
  width: 20px; }

.echain-body {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.55; }

.echain-body strong {
  color: #fff;
  font-weight: 500;
  font-size: 16px; }

.echain-arrow {
  text-align: center;
  color: rgba(255, 255, 255, 0.12);
  padding-left: 30px;
  font-size: 16px; }

.echain-result {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  padding-top: 16px;
  font-size: 16px;
  font-weight: 600;
  color: #E2753B;
  line-height: 1.3; }

.energy-text p {
  font-size: 16px;
  color: #555555;
  line-height: 1.75; }

.energy-text p + p {
  margin-top: 12px; }

.compat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 30px; }

.compat-group {
  background: #f5f4f1;
  padding: 18px 16px;
  border: 1px solid rgba(51, 51, 51, 0.1); }

.compat-gname {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #712A64;
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

.compat-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem; }

.compat-tag {
  font-size: 14px;
  font-weight: 600;
  background: #E2753B;
  color: #fff;
  padding: 0.25rem 0.6rem;
  border-radius: 2px; }

.compat-note {
  margin-top: 1.25rem;
  font-size: 16px;
  color: #333333;
  font-style: italic; }

/* media grid under compat */
.compat-media {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1);
  margin-top: 2rem;
  height: 240px; }

.cmedia-img {
  overflow: hidden; }

.cmedia-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: brightness(0.95) contrast(1.04); }

.cmedia-placeholder {
  background: #333333;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.4rem; }

.cmedia-placeholder span {
  font-size: 14px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.18); }

.results_section {
  background: radial-gradient(circle at 20% 50%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 80% 50%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); }
  @media screen and (max-width: 900px) {
    .results_section {
      background: radial-gradient(circle at 50% 20%, rgba(226, 117, 59, 0.24) 0%, transparent 64%), radial-gradient(circle at 50% 80%, rgba(113, 42, 100, 0.24) 0%, transparent 60%); } }

.results-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  margin-top: 36px; }

.result-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: rgba(51, 51, 51, 0.1);
  border: 1px solid rgba(51, 51, 51, 0.1); }

.result-row {
  background: #fff;
  padding: 16px 18px;
  display: flex;
  align-items: center;
  gap: 12px; }

.rbar {
  width: 4px;
  height: 2.25rem;
  border-radius: 2px;
  flex-shrink: 0;
  background: #E2753B; }

.rbar.g {
  background: #712A64; }

.rtext {
  font-size: 16px;
  color: #000000;
  font-weight: 400;
  line-height: 1.45; }

.results-text .statement {
  font-size: 18px;
  font-weight: 600;
  line-height: 1.25;
  color: #000000;
  margin-bottom: 1.25rem; }

.results-text p {
  font-size: 16px;
  color: #333;
  line-height: 1.75; }

.results-text p + p {
  margin-top: 0.75rem; }

.why-metsol-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start; }

.why-metsol-pillars {
  display: flex;
  flex-direction: column;
  gap: 1.5px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.06); }

.pillar {
  background: #E2753B;
  padding: 1.2rem 1.5rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start; }

.pillar-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ffffff;
  flex-shrink: 0;
  margin-top: 0.5rem; }

.pillar-text {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.8);
  line-height: 1.55; }

.pillar-text strong {
  color: #fff;
  font-weight: 500; }

.team-section {
  padding: 80px 0;
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

.team-section__heading {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px; }

/* ─── Member ─── */
.team-member {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 64px;
  align-items: center;
  padding: 56px 0;
  border-top: 1px solid rgba(51, 51, 51, 0.1);
  opacity: 0;
  transform: translateY(28px);
  animation: fadeUp 0.6s ease forwards; }

.team-member:first-of-type {
  border-top: none; }

.team-member:nth-child(1) {
  animation-delay: 0.1s; }

.team-member:nth-child(2) {
  animation-delay: 0.25s; }

.team-member:nth-child(3) {
  animation-delay: 0.4s; }

.team-member:nth-child(even) {
  grid-template-columns: 1fr 260px; }

.team-member:nth-child(even) .team-member__photo {
  order: 2; }

.team-member:nth-child(even) .team-member__content {
  order: 1; }

/* ─── Photo ─── */
.team-member__photo {
  position: relative; }

.team-member__photo-wrap {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto;
  position: relative;
  background: #f5f4f1; }

.team-member__photo-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  box-shadow: inset 0 0 0 3px rgba(226, 117, 59, 0.15);
  transition: box-shadow 0.3s ease; }

.team-member:hover .team-member__photo-wrap::after {
  box-shadow: inset 0 0 0 3px #E2753B; }

.team-member__photo-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  transition: transform 0.5s ease; }

.team-member:hover .team-member__photo-wrap img {
  transform: scale(1.04); }

/* ─── Content ─── */
.team-member__content {
  display: flex;
  flex-direction: column;
  gap: 20px; }

.team-member__quote {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.45;
  color: #333333;
  position: relative;
  padding-left: 24px; }

.team-member__quote::before {
  content: '';
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 6px;
  width: 3px;
  background: #E2753B;
  border-radius: 2px; }

.team-member__bio {
  font-size: 17px;
  font-weight: 400;
  line-height: 1.7;
  color: #333333; }

.team-member__name {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: #000000;
  text-transform: uppercase; }

.team-member__role {
  font-size: 13px;
  font-weight: 400;
  color: #888;
  margin-top: 2px; }

/* ─── Animation ─── */
@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0); } }
/* ─── Responsive ─── */
@media (max-width: 700px) {
  .team-member,
  .team-member:nth-child(even) {
    grid-template-columns: 1fr;
    gap: 32px; }

  .team-member:last-of-type {
    padding-bottom: 0; }

  .team-member:first-of-type {
    padding-top: 0; }

  .team-member:nth-child(even) .team-member__photo,
  .team-member:nth-child(even) .team-member__content {
    order: unset; }

  .team-member__photo-wrap {
    width: 160px;
    height: 160px; }

  .team-member__quote {
    padding-left: 18px; } }
/* ─── Grid ─── */
.mvb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0; }

/* ─── Card ─── */
.mvb-card {
  padding: 48px 40px 48px 0;
  border-right: 1px solid rgba(51, 51, 51, 0.1);
  opacity: 0;
  transform: translateY(24px);
  animation: fadeUp 0.55s ease forwards;
  position: relative; }

.mvb-card:last-child {
  border-right: none;
  padding-right: 0; }

.mvb-card:not(:first-child) {
  padding-left: 40px; }

.mvb-card:nth-child(1) {
  animation-delay: 0.05s; }

.mvb-card:nth-child(2) {
  animation-delay: 0.18s; }

.mvb-card:nth-child(3) {
  animation-delay: 0.31s; }

/* ─── Red top bar ─── */
.mvb-card::before {
  content: '';
  display: block;
  width: 36px;
  height: 3px;
  background: #E2753B;
  margin-bottom: 28px;
  transition: width 0.35s ease; }

.mvb-card:hover::before {
  width: 64px; }

/* ─── Label ─── */
.mvb-card__label {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #712A64;
  margin-bottom: 14px; }

/* ─── Title ─── */
.mvb-card__title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
  color: #333333;
  margin-bottom: 18px; }

/* ─── Body ─── */
.mvb-card__text {
  font-size: 17px;
  font-weight: 400;
  line-height: 1.75;
  color: #555; }

/* ─── Animation ─── */
@keyframes fadeUp {
  to {
    opacity: 1;
    transform: translateY(0); } }
/* ─── Responsive ─── */
@media (max-width: 768px) {
  .mvb-grid {
    grid-template-columns: 1fr; }

  .mvb-card {
    padding: 40px 0;
    border-right: none;
    border-bottom: 1px solid rgba(51, 51, 51, 0.1); }

  .mvb-card:first-of-type {
    padding-top: 0; }

  .mvb-card:last-of-type {
    padding-bottom: 0; }

  .mvb-card:not(:first-child) {
    padding-left: 0; }

  .mvb-card:last-child {
    border-bottom: none; } }
.contact-layout {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 5rem;
  align-items: start; }

.info-block {
  margin-bottom: 2.5rem; }

.info-label {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #E2753B;
  margin-bottom: 0.75rem; }

.info-value {
  font-size: 18px;
  color: #000000;
  line-height: 1.65; }

.info-value a {
  color: #000000;
  text-decoration: none;
  border-bottom: 1px solid rgba(51, 51, 51, 0.1);
  transition: border-color 0.15s; }

.info-value a:hover {
  border-color: #E2753B;
  color: #E2753B; }

.info-divider {
  height: 1px;
  background: rgba(51, 51, 51, 0.1);
  margin: 2rem 0; }

.info-note {
  font-size: 16px;
  color: #555555;
  line-height: 1.65;
  padding: 1.25rem;
  background: #f5f4f1;
  border: 1px solid rgba(51, 51, 51, 0.1);
  border-left: 3px solid #E2753B; }

.form-heading {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 2rem; }

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

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.4rem; }

.form-group.full {
  grid-column: 1 / -1; }

label {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #555555; }

label .req {
  color: #E2753B;
  margin-left: 2px; }

input, select, textarea {
  font-size: 14px;
  color: #000000;
  background: #ffffff;
  border: 1px solid rgba(51, 51, 51, 0.1);
  padding: 0.7rem 0.9rem;
  border-radius: 0;
  outline: none;
  transition: border-color 0.15s;
  width: 100%;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box; }

input:focus, select:focus, textarea:focus {
  border-color: rgba(51, 51, 51, 0.1); }

textarea {
  resize: vertical;
  min-height: 130px;
  line-height: 1.6; }

/* select arrow */
.select-wrap {
  position: relative; }

.select-wrap::after {
  content: '↓';
  position: absolute;
  right: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  color: #555555;
  pointer-events: none; }

.select-wrap select {
  padding-right: 2rem;
  cursor: pointer; }

/* validation states */
.form-group.has-error input,
.form-group.has-error select,
.form-group.has-error textarea {
  border-color: #C44427;
  background: #f5f4f1; }

.form-group.has-ok input,
.form-group.has-ok select,
.form-group.has-ok textarea {
  border-color: rgba(51, 51, 51, 0.1); }

.field-error {
  font-size: 14px;
  color: #E2753B;
  display: none; }

.form-group.has-error .field-error {
  display: block; }

/* submit */
.form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-top: 1.75rem;
  padding-top: 1.75rem;
  border-top: 1px solid rgba(51, 51, 51, 0.1); }

.form-privacy {
  font-size: 16px;
  color: #555555;
  line-height: 1.5;
  max-width: 280px; }

.btn-submit {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #fff;
  background: #E2753B;
  border: none;
  padding: 0.85rem 2.25rem;
  cursor: pointer;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap; }

.btn-submit:hover {
  background: #E2753B; }

.btn-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed; }

/* success message */
.form-success {
  display: none;
  background: #698F3F;
  color: #fff;
  padding: 2rem;
  margin-top: 1.5rem; }

.form-success.visible {
  display: block; }

.form-success-title {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 0.5rem; }

.form-success p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.75);
  line-height: 1.6; }

@media screen and (max-width: 760px) {
  .contact-layout {
    grid-template-columns: 1fr; } }
.h2-eyebrow {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #E2753B; }

.h2-eyebrow + h2:before {
  display: none; }

.menu_btn {
  width: 42px;
  height: 42px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  cursor: pointer;
  outline: none;
  border: none;
  background-color: unset;
  display: none; }

.about_us p:not(.h2-eyebrow) {
  font-size: 18px;
  font-weight: 400;
  color: #333333;
  line-height: 1.75;
  margin-bottom: 0.75rem; }

@media (max-width: 900px) {
  .main section, .main footer {
    padding: 80px 0; }

  .inner section, .inner footer {
    padding: 80px 0; }

  header.main_page {
    position: fixed;
    background: #712A64;
    padding: 12px 0;
    z-index: 4; }
    header.main_page .logo {
      position: relative;
      z-index: 5; }

  .header_menu {
    position: fixed;
    right: -400px;
    top: 0;
    width: 100%;
    max-width: 300px;
    background-color: rgba(113, 42, 100, 0.95);
    height: 100%;
    flex-direction: column;
    transition: ease-in-out 0.3s;
    padding-top: 80px;
    pointer-events: unset;
    opacity: 0;
    backdrop-filter: blur(2px); }
    .header_menu ul {
      flex-direction: column;
      width: calc(100% - 40px);
      margin-left: 20px;
      gap: 0; }
      .header_menu ul li {
        border-bottom: 1px rgba(255, 255, 255, 0.3) solid;
        width: 100%; }
        .header_menu ul li a {
          text-align: right;
          text-decoration: none;
          display: block;
          padding: 16px 0; }
          .header_menu ul li a:hover:after {
            display: none; }
    .header_menu.open {
      right: 0;
      pointer-events: unset;
      opacity: 1; }

  .menu_btn {
    display: block; }
    .menu_btn.close_btn {
      background-image: url("../images/cross.svg");
      z-index: 5; }

  h2 {
    font-size: 38px; }
    h2 br {
      display: none; } }
.product-section-hidden {
  display: none; }

.show-all-wrap {
  display: flex;
  width: 100%;
  justify-content: center; }

.show-all-products {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-family: "Source Sans 3", sans-serif;
  font-size: 16px;
  font-weight: 600;
  padding: 15px 36px;
  border-radius: 32px;
  border: 2px solid transparent;
  background: #E2753B;
  color: #fff;
  transition: background 0.3s ease, border-color 0.3s ease, color 0.3s ease;
  cursor: pointer;
  margin: 24px auto 0 auto; }
  .show-all-products:hover {
    background: transparent;
    border-color: #E2753B;
    color: #E2753B; }

@media (max-width: 960px) {
  .climate-layout, .trials-layout, .closing-layout, .why-metsol-layout {
    grid-template-columns: 1fr;
    gap: 2.5rem; }

  .energy-layout, .results-layout {
    grid-template-columns: 1fr;
    gap: 2.5rem; }

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

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

  .prod-media {
    grid-template-columns: 1fr;
    height: auto; }

  .prod-media-img {
    height: 200px; }

  .esg-layout {
    grid-template-columns: 1fr; }

  .trials-strip {
    grid-template-columns: 1fr; }

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

  .compat-media {
    height: 180px; } }
@media (max-width: 620px) {
  .compat-grid {
    grid-template-columns: 1fr; }

  .compat-media {
    height: auto;
    grid-template-columns: 1fr; }

  .cmedia-img, .cmedia-placeholder {
    height: 160px; } }

/*# sourceMappingURL=styles.css.map */
