@import url('https://fonts.googleapis.com/css2?family=Pathway+Extreme:ital,opsz,wght@0,8..144,100..900;1,8..144,100..900&display=swap');

:root {
    --green: #00FF99;
    --darkgrey: #282D2B;
    --midgrey: #404049;
    --lightgrey: #7C7C7C;
    --grey: #B2BAB7;
    --lightblue: #D4C2FC;
    --black: #040F0A;
    --white: #F5F5F5;
    --navgrey: #1B1D1C;
    --cl-overlap: clamp(420px, 60vh, 980px);
}
html {
  box-sizing: border-box;
  font-size: 100%;
  scroll-behavior: smooth;
  font-size: 18px;
  overflow-wrap: break-word;
  word-break: normal;
}
*, *::before, *::after {
  box-sizing: inherit;
}
body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  font-family: "Pathway Extreme", sans-serif;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--grey);
  background-color: var(--midgrey);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.home {
  display: flex;
  flex-direction: column;
  align-items: center;
}
a {
  color: inherit;
  text-decoration: none;
  font-weight: 200;
}
a:hover {
  text-decoration: underline;
}
.anchor-target {
    scroll-margin-top: 160px;
}
.header {
  position: fixed;
  display: flex;
  justify-content: space-between;
  width: 95vw;
  align-items: center;
  gap: 1rem;
  padding: 1rem 2rem;
  background: var(--navgrey);
  border-radius: 32px;
  -webkit-border-radius: 32px;
  -moz-border-radius: 32px;
  -ms-border-radius: 32px;
  -o-border-radius: 32px;
  top: 1rem;
  z-index: 9999;
}
.logo img {
  width: 8.9vw;
  min-width: 60px;
  max-width: 171px;
  height: auto;
}
.navlink a {
  color: var(--grey);
  text-decoration: none;
  font-weight: 500;
}
.burger {
  display: flex;
  position: relative;
  width: 46px;
  height: 28px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  z-index: 20;
}
.bar {
  position: absolute;
  top: 50%;
  height: 1px;
  background: var(--green);
  border-radius: 2px;
  transition: transform .3s ease, opacity .2s ease, width .3s ease, left .3s ease;
}
.bar:nth-child(1),
.bar:nth-child(2) {
  left: 50%;
  width: 46px;
}
.bar:nth-child(1) { transform: translate(-50%, calc(-50% - 8px)); }
.bar:nth-child(2) { transform: translate(-50%, -50%); }
.bar:nth-child(3) {
  left: 0;
  width: 23px;
  transform: translate(0, calc(-50% + 8px));
}
.burger.active .bar:nth-child(1) {
  transform: translate(-50%, -50%) rotate(45deg);
}
.burger.active .bar:nth-child(2) { opacity: 0; }
.burger.active .bar:nth-child(3) {
  left: 50%;
  width: 46px;
  transform: translate(-50%, -50%) rotate(-45deg);
}
.nav {
  position: relative;
  height: 40px;
  margin-left: auto;
  text-align: right;
  font-weight: 500;
  }
.navlink {
  position: relative;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transform: translateX(24px) translateY(-50%);
  -webkit-transform: translateX(24px) translateY(-50%);
  -moz-transform: translateX(24px) translateY(-50%);
  -ms-transform: translateX(24px) translateY(-50%);
  -o-transform: translateX(24px) translateY(-50%);
  list-style: none;
  display: flex;
  gap: 4rem;
  transition: transform 0.22s ease, opacity 0.22s ease;
  -webkit-transition: transform 0.22s ease, opacity 0.22s ease;
  -moz-transition: transform 0.22s ease, opacity 0.22s ease;
  -ms-transition: transform 0.22s ease, opacity 0.22s ease;
  -o-transition: transform 0.22s ease, opacity 0.22s ease;
}
.navlink.active {
  transform: translateX(0) translateY(-50%);
  opacity: 1;
  pointer-events: auto;
}
@media (max-width: 1024px) {
    .navlink {
        position: absolute;
        top: 100%;
        right: 0;
        flex-direction: column;
        align-items: center;
        padding: 1rem;
        background-color: var(--darkgrey);
        transform:none;
        -webkit-transform:none;
        -moz-transform:none;
        -ms-transform:none;
        -o-transform:none;
}
    .navlink.active {
  transform: translateX(0) translateY(5%);
  -webkit-transform: translateX(0) translateY(5%);
  -moz-transform: translateX(0) translateY(5%);
  -ms-transform: translateX(0) translateY(5%);
  -o-transform: translateX(0) translateY(5%);
}
}
#contact, #aboutus, #services, #references {
    scroll-margin-top: 17vh;
}
/* Main content */
main {
  isolation: isolate;
  overflow-x: hidden;
  overflow-y: visible;
}
.hero {
  position: relative;
  overflow: visible;
  z-index: 2;
  background-image: url("Assets/Header-bg.jpg");
  background-size: cover;
  background-position: top 50% center;
  background-repeat: no-repeat;
  width: 100vw;
  height: 90vh;
}
@media (max-width: 768px) {
   .hero {
    background-position: top 100% center;
    background-size: revert;
   }
}
.heroline {
   grid-column: 1;
   grid-row: 2;
   position: relative;
   z-index: 100;
   transform: translateY(20%);
  -webkit-transform: translateY(20%);
  -moz-transform: translateY(20%);
  -ms-transform: translateY(20%);
  -o-transform: translateY(20%);
}
.demo-bg {
    display: grid; 
    gap: 24px;
    place-items: center;
    min-height: 100vh;
    background: conic-gradient(from 180deg at 50% 50%, #fafafa, #f0f0f0);
}
.provide {
  position: relative;
  overflow: visible;
  z-index: 1;
  background: url("Assets/Hero bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100vw;
  min-height: 120vh;
  text-align: center;
  color: white;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 4rem 1rem;
   margin-top: calc(-1 * var(--cl-overlap));
  padding-top: calc(4rem + var(--cl-overlap) + 2rem);
}

.provide::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 0; bottom: -2px;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(64,64,72,0) 80%, rgba(64,64,72,1) 100%);
  z-index: 0;
}

.providecontent{ 
    position: relative;
    z-index: 1;
    padding: 20rem 0;
}
.providecontent h2 {
  color: var(--black);
  font-size: 3.2rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin: 0;
}
.providecontent p{
  color: white;
  font-size: 1rem;
  font-weight: 400;
  margin: 2rem auto 0 auto;
}
.btn {
  display: inline-block;
  padding: 0.6rem 2rem;
  margin-top: 2rem;
  border-radius: 20px;
  color: white;
  font-weight: 400;
  border: 2px solid var(--green);
  transition: background-color 0.3s ease, color 0.3s ease;
  -webkit-transition: background-color 0.3s ease, color 0.3s ease;
  -moz-transition: background-color 0.3s ease, color 0.3s ease;
  -ms-transition: background-color 0.3s ease, color 0.3s ease;
  -o-transition: background-color 0.3s ease, color 0.3s ease;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  -ms-border-radius: 20px;
  -o-border-radius: 20px;
}
.btn:hover {
  background-color: var(--green);
  color: var(--darkgrey);
  text-decoration: none;
}
@media (min-width: 1200px) {
    .providecontent{ 
        padding: 8rem 0;
    }
    .providecontent p{
      width: 35vw;
    }
}

.contentline {
  justify-self: center;
  align-self: end;
  width: min(95vw, 1920px);
  display: flex;
  gap: 5rem;
  background-color: var(--darkgrey);
  border-radius: 32px;
  padding: 1rem 2rem;
  align-items: center;
  z-index: 100; 
}
.contentline--overlap {
  position: absolute;
  left: 50%;
  top: 100%;
  transform: translate(-50%, -50%);
      -webkit-transform:translateY(-50%, -50%);
      -moz-transform:translateY(-50%, -50%);
      -ms-transform:translateY(-50%, -50%);
      -o-transform:translateY(-50%, -50%);
  z-index: 1000;
}
.secondcontentline {
    position: relative;
    top: 0;
    transform:translateY(-70%);
      -webkit-transform:translateY(-70%);
      -moz-transform:translateY(-70%);
      -ms-transform:translateY(-70%);
      -o-transform:translateY(-70%);
}
.down-arrow-circle {
  position: absolute;
  left: 50%;
  transform:translateX(-50%);
    -webkit-transform:translateX(-50%);
    -moz-transform:translateX(-50%);
    -ms-transform:translateX(-50%);
    -o-transform:translateX(-50%);
  z-index: 1000;
  width: 62px;
  height: 62px;
  display: grid;
  place-items: center;
  border: 1px solid var(--lightblue);
  border-radius: 50%;
  background: var(--lightblue);
  color: black;
  user-select: none;
}
.down-arrow-circle svg .arrow {
  animation: nudge 3.5s ease-in-out infinite;
  transform-origin: center;
  -webkit-animation: nudge 3.5s ease-in-out infinite;
}
.hero .down-arrow-circle{
  bottom: -2rem;
}
.gallery .down-arrow-circle.arrow2 {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  top: 0 !important;
  bottom: auto !important;
  transform: none !important;
  margin: 1rem auto 0 auto;
}
@keyframes nudge {
    0%, 82%, 100% { transform: translateY(0); }
    90% { transform: translateY(2px); -webkit-transform: translateY(2px); -moz-transform: translateY(2px); -ms-transform: translateY(2px); -o-transform: translateY(2px); }
    96% { transform: translateY(0); }
}

@media (max-width: 768px) {
  .contentline {
    flex-direction: column;
    gap: 1.5rem;
    text-align: left;
  }
}
.numero {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: var(--lightgrey);
  border-right: 1px solid var(--lightgrey);
  width: 35vw;
}
.numero h2 {
  font-size: 4.8rem;
  font-weight: 400;
  margin: 0;
  color: var(--lightgrey);
}
.divider {
  width: 49px;
  height: 1px;
  background: var(--lightgrey);
}
.numero h3 {
  font-size: 1rem;
  font-weight: 400;
}
.contentlinetitle h2{
  font-size: 3.2rem;
  font-weight: 400;
  color: var(--green);
  line-height: 3.2rem;
  margin: 0;
  word-break: auto-phrase;
  width: 25vw;
}
.contentlinetext {
  font-size: 1rem;
  font-weight: 400;
  line-height: 30px;
  width: 100%;
}

@media (max-width: 1200px) {
  .contentline {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: 1fr 1fr;
    gap: 1rem
  }
  .numero {
    grid-column: 1 / span 1;
    grid-row: 1 / span 1;
  }
  .contentlinetitle {
    grid-column: 2 / span 2;
    grid-row: 1 / span 1;
  }
  .contentlinetitle h2 {
    width: 100%
  }
  .contentlinetext {
    grid-column: 1 / span 3;
    grid-row: 2 / span 1;
  }
}
@media (max-width: 576px) {
    .contentline {
      grid-template-columns: 1fr;
      grid-template-rows: auto;
    }
    .contentlinetitle h2 {
      font-size: 2rem;
      line-height: 2.8rem;
    }
    .numero, .contentlinetitle, .contentlinetext {
      grid-column: 1 / span 1;
      grid-row: auto;
    }
    .numero {
      border-right: none;
      border-bottom: 1px solid var(--lightgrey);
      padding-bottom: 1rem;
    }
    .contentlinetitle h2 {
      width: 100%
    }
    .contentlinetext {
      font-size: 0.7rem;
      font-weight: 400;
      line-height: 20px;
    }
}
/* LOGO GRID SZEKCIÓ */
.partners {
    position: relative;
    width: 100vw;
    overflow: visible;
    padding-bottom: calc(var(--cl-overlap) / 2);
}
.partner-grid{
    display: grid;
    gap: clamp(16px, 3vw, 40px);
    width: min(1200px, 94vw);
    margin: 3rem auto;
    align-items: center;
    justify-items: center;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.partner-grid img{
  width: 100%;
  max-width: 220px;
  height: auto;
  object-fit: contain;
}

/* DESKTOP: 3 "oszlop" úgy, hogy a 2. sor 2 eleme középre kerüljön */
@media (min-width: 1200px){
  .partner-grid{
    grid-template-columns: repeat(6, 1fr); /* 6 oszlop */
  }

  .partner-grid img{
    grid-column: span 2; /* minden logo 2 oszlop = 3 logo / sor */
  }

  /* 2. sor: 2 logo középre (a 4. és 5. elem) */
  .partner-grid img:nth-child(4){
    grid-column: 2 / span 2; /* középre húzás */
  }
  .partner-grid img:nth-child(5){
    grid-column: 4 / span 2; /* középre húzás */
  }
}

@media (max-width: 1200px) {
    .thirdcontentline {
  transform: translateY(0);
  -webkit-transform: translateY(0);
  -moz-transform: translateY(0);
  -ms-transform: translateY(0);
  -o-transform: translateY(0);
    }
}
/* Portfolio */
.portfolio {
  display: flex;
  flex-direction: column;
  align-items: center;
  grid-row: 6;
}
.portfolioprohead, .portfoliohomehead {
  position: relative;
  z-index: 10;
  background-image: 
    url('Assets/portfolio\ bg.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  width: 100vw;
  height: 80vh;
}
.portfoliohomehead {
  overflow: visible;
  background-image: 
      url('Assets/portfolio\ home\ bg.jpg') !important;
}
.portfoliohomehead::after, .portfolioprohead::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: -2px; bottom: -2px;
  pointer-events: none;
  background-image: 
      linear-gradient(to bottom, rgba(64, 64, 72, 1) 0%, rgba(64, 64, 72, 0) 40%),
      linear-gradient(to bottom, rgba(64, 64, 72, 0) 50%, rgba(64, 64, 72, 1) 100%);
}
.section-title {
  display: flex;
  align-items: center;   
  justify-content: center;
  gap: 20px;
  width: 100%;
  margin: 40px 0;
  position: relative;
  z-index: 11;
  color: var(--white);
}

.section-title::before,
.section-title::after {
  content: "";
  flex: 1;
  height: 1px;
  background-color: var(--white);
  opacity: 0.6;
}
.section-title span {
  font-size: 1.5rem;
  font-weight: 600;
}
@media (min-width: 1200px){
  .section-title span {
    white-space: nowrap;
}
}
.portfcards {
   position: relative;
  z-index: 15;
  width: min(90vw, 1824px);
  margin: 0 auto 4rem;
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 768px) {
  .portfcards {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1200px) {
  .portfcards {
    grid-template-columns: repeat(3, 1fr);
  }
}
#pcard {
  position: relative;
  width: 100%;
  min-width: 0;
  background: var(--darkgrey);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 2rem;
  text-align: center;
  justify-content: space-between;
  border-radius: 32px;
}
@media (min-width: 1200px) {
  #pcard {
    width: 24vw;
  }
}
#pcard h2 {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.4rem;
}
#pcard p {
  font-size: 0.7rem;
  line-height: 20px;
  font-weight: 400;
}
@media (min-width: 1200px) {
  #pcard h2 {
    font-size: 2rem;
    line-height: 2.2rem;
  }
  #pcard p {
    font-size: 1rem;
    line-height: 1.6rem;
  }
}
/* Gallery */
.gallery {
  position: relative;
  top: 0;
  z-index: 11;
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
  background: url('Assets/reference-bg.jpg');
  background-size: cover;
  overflow: visible;
  padding: 0 3%;
}
.gallery::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: -2px; bottom: -2px;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(64, 64, 72, 1) 0.5%, rgba(64, 64, 72, 0) 40%),
    linear-gradient(to bottom, rgba(64, 64, 72, 0) 70%, rgba(64, 64, 72, 1) 100%);
}
.galleryhead h2{
  position: relative;
  z-index: 11;
  color: var(--green);
  font-size: 3.2rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin: 0;
}
@media (max-width: 768px) {
  .galleryhead h2 {
    font-size: 2rem;
    line-height: 2.8rem;
    hyphens: none;
    -webkit-hyphens: none;
    -ms-hyphens: none;
  }
}
.arrow2 {
  position: relative !important;
  top: 0 !important;
  bottom: auto !important;
}
.gallerygrid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  position: relative;
  z-index: 11;
}
#galleryitem {
  border-radius: 36px;
  -webkit-border-radius: 36px;
  -moz-border-radius: 36px;
  -ms-border-radius: 36px;
  -o-border-radius: 36px;
  overflow: hidden;
  transition: transform 0.5s ease;
  -webkit-transition: transform 0.5s ease;
  -moz-transition: transform 0.5s ease;
  -ms-transition: transform 0.5s ease;
  -o-transition: transform 0.5s ease;
  height: clamp(160px, 32vw, 600px);
}

#galleryitem img {
  width: 100%;
  height: 100%;
  object-fit: cover;                              /* vágás, hogy minden azonos magasságú legyen */
  display: block;
}

.wide { grid-column: span 2; }                    /* alap: két oszlop */
.start  { grid-column: 1 / span 2; }              /* 1. sor: balra */
.center { grid-column: 2 / span 2; }              /* 2. sor: középen */
.end    { grid-column: 3 / span 2; }              /* 3. sor: jobbra */

@media (min-width: 1200px) {
      #galleryitem:hover {
        transform: scale(1.03);
        -webkit-transform: scale(1.03);
        -moz-transform: scale(1.03);
        -ms-transform: scale(1.03);
        -o-transform: scale(1.03);
      }
}
@media (max-width: 900px) {
      .gallery { grid-auto-rows: clamp(130px, 28vw, 220px); }
    }
@media (max-width: 640px) {
      .gallerygrid { grid-template-columns: repeat(2, 1fr); }
      .start, .center, .end { grid-column: 1 / -1; }      /* fekvő képek teljes szélességben */
      .gallery { grid-auto-rows: clamp(140px, 35vw, 200px); }
    }
.ctaline {
  position: relative;
  margin-bottom: 5%;
}
.ctaline h3 {
  color: var(--midgrey);
  font-size: 2.4rem;
  line-height: 2.4rem;
  font-weight: 400;
}
.btn-secondary {
  border-radius: 20px;
  border: 0px solid var(--darkgrey);
  background-color: var(--darkgrey);
  color: var(--green);
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;
  -ms-border-radius: 20px;
  -o-border-radius: 20px;
  margin-bottom: 3rem;
}
/* Testimonial carousel */
 :root{
      --gap: 3rem;
      --peek: 40px;
      --card-bg: #fff;
      --card-fg: #0b0b0b;
      --muted: #6b7280;
      --ring: #e5e7eb;
    }
    .section {
      max-width: 1920px;
      margin-inline: auto;
      padding: 24px clamp(12px, 4vw, 48px);
    }
    .carousel {
      position: relative;
    }
    .viewport {
      overflow: hidden;
    }
    .testimonials {
    margin-top: 5%;
    position: relative;
    z-index: 11;
    width: 100vw;
}
    .track {
      display: flex;
      gap: var(--gap);
      will-change: transform;
      margin-inline: calc(var(--peek) * -1);
      padding-block: 8px;
      scroll-behavior: smooth;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
      scroll-snap-type: x mandatory;
    }
    .track::-webkit-scrollbar { 
      height: 0;
    }
    .track {
      scrollbar-width: none;
    }
    .card {
      flex: 0 0 auto;
      display: flex;
      flex-direction: column;
      scroll-snap-align: start;
      width: 95vw;
      max-width: 600px;
      background: var(--card-bg);
      border: 1px solid var(--ring);
      border-radius: 2rem;
      padding: 1.2rem;
      margin-top: 5rem;
      box-shadow: 0 4px 20px rgba(0, 0, 0, .05);
      align-items: center;
      text-align: left;
      -webkit-border-radius: 2rem;
      -moz-border-radius: 2rem;
      -ms-border-radius: 2rem;
      -o-border-radius: 2rem;
    }
    .name {
      color:var(--black);
      font-weight: 700;
      font-size: 1.2rem;
      margin: 0;
    }
    .meta {
      color: var(--grey);
      margin: 0;
      padding-bottom: 1.5rem;
}
    .green-arrow-down {
      width: 12px;
      height: 12px;
      border-bottom: 3px solid var(--green);
      border-right: 3px solid var(--green);
      transform: rotate(45deg);
      border-radius: 2px;
      -webkit-border-radius: 2px;
      -moz-border-radius: 2px;
      -ms-border-radius: 2px;
      -o-border-radius: 2px;
      margin: 0 auto;
}
    .avatar {
      width: 136px;
      height: 136px;
      border-radius: 999px;
      object-fit: cover;
      border: 0;
    }
    .quote {
      position: relative;
      margin: 0;
      line-height: 20px;
      color: var(--black);
      padding-top: 1rem;
      font-size: 0.7rem;
    }

    @media (min-width: 640px) {
      .card { width: calc((100% - var(--gap)) / 2.2); }
    }
    @media (min-width: 1024px) {
      .card { width: calc((100% - 2*var(--gap)) / 3.2); 
      .quote { font-size: 1rem; line-height: 1.6;}}
    }
    @media (min-width: 1280px) {
      .card { width: calc((100% - 3*var(--gap)) / 4.1); }
    }
    @media (min-width: 1536px) {
      .card { width: calc((100% - 3*var(--gap)) / 4.1); }
    }
    @media (max-width: 420px) {
      .track {
        justify-content: center;
        scroll-snap-type: none;
        overflow-x: hidden;
        margin-inline: 0;
      }

      .card {
        width: 90%;
        max-width: 380px;
        flex: 0 0 auto;
  }
}
    .dots {
      display: flex;
      justify-content: center;
      gap: 8px;
      margin-top: 14px;
      user-select: none;
    }
    .dot {
      width: 14px;
      height: 14px;
      border-radius: 50%;
      background: var(--lightgrey);
      border: 0;
      outline: 1px solid var(--lightgrey);
      outline-offset: 1px;
      padding: 0;
      margin: 2rem 0.5rem;
      cursor: pointer;
      transition: transform .2s ease, background .2s ease;
      -webkit-transition: transform .2s ease, background .2s ease;
      -moz-transition: transform .2s ease, background .2s ease;
      -ms-transition: transform .2s ease, background .2s ease;
      -o-transition: transform .2s ease, background .2s ease;
}
    .dot[aria-current="true"] {
      background: none;
      transform: scale(1.1);
    }
/*form*/
.contactform {

    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 3rem;
}
.nf-form-fields-required, .nf-field-label {
    display: none;
}
input, textarea {
    padding: 0.6rem 1rem;
    border: 0;
    border-radius: 15px;
    background-color: #d9d9d9;
    font-size: 1rem;
    font-family:"Pathway Extreme", sans-serif;
    font-weight: 100;
}
label#nf-label-field-6 {
    font-size: 0.8rem;
    font-family:"Pathway Extreme", sans-serif;
    font-weight: 100;
}
.nf-form-content {
    width: 85vw;
    max-width: 660px;
}
input#nf-field-4 {
    background: var(--mediumgrey);
    border: 1px solid var(--green);
    color: white;
    padding: 0.5rem 2rem;
}
input#nf-field-4:hover {
    cursor: pointer;
    background: var(--green);
    color: var(--darkgrey);
    text-decoration: none;
}
.nf-field-element {
    display: flex;
    justify-content: flex-end;
}
/* Footer */
footer {
  position: relative;
  bottom: 0;
  width: 90vw;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  align-items: center;
  border-top: 1px solid var(--grey);
  margin-top: 1rem;
}
footer ul {
  padding: 0;
}
footer ul li {
  list-style: none;
  padding: 0.8rem 0;
}
.foottop p {
  color: var(--green);
}
.foottop p::after {
  content: " ›"; 
}
.foottop {
  display: grid;
  grid-template-columns: repeat(3, 1fr) 1fr 1fr;
  gap: 2rem;
}
.footerlogo {
  grid-column: 1 / 1 span;
  width: 134px;
  height: auto;
}
.footmenu {
   grid-column: 2 / 1 span;
}
.footsolutions {
  grid-column: 3 / 1 span;
}
.foothome {
  grid-column: 4 / 1 span;
}
.footerbottom {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 4rem;
  color: var(--lightgrey);
  font-size: 0.8rem;
}
@media (max-width: 1200px) {
  .foottop {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: auto auto auto;
    gap: 1rem;
  }
  .footlogo {
    grid-column: 2 / span 1;
    justify-self: center;
  }
  .footmenu {
    grid-column: 1 / span 2;
  }
  footer ul li {
    padding: 0.2rem 0;
  }
  .footsolutions {
    grid-column: 1 / span 2;
  }
  .foothome {
    grid-column: 1 / span 2;
    justify-self: center;
  }
  .footerbottom {
    flex-direction: column;
    gap: 1rem;
    text-align: center;
  }
}

/*Product pages design */
#productpage {
  width: 100vw; 
}
.prodheader {
  background-size: cover;
  background-position: center;
  height: 95vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.prodcontent {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  width: 85vw;
  color: white;
}
@media (min-width: 1200px){
  .prodcontent {
    width: 45vw;
  }
}
.prodicon img {
  width: 132px;
  height: auto;
}
.prodcontent h2 {
  font-size: 3.2rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin: 1rem 0 0 0;
}
.down-arrow-product {
  transform: translateY(-50%) !important;
  -webkit-transform: translateY(-50%) !important;
  -moz-transform: translateY(-50%) !important;
  -ms-transform: translateY(-50%) !important;
  -o-transform: translateY(-50%) !important;
}
.spcontent {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: #ffffff;
  position: relative;
  z-index: 10;
}
.spcontent h2 {
  width: 50vw;
  font-weight: 400;
  font-size: 3.2rem;
  line-height: 3.2rem;
}
.spcontent p {
  width: 50vw
}
.spimage {
  height: 100vh;
  width: 100vw;
  background-size: cover;
  background-position: center;
  position: relative;
  transform:translateY(-10%);
  -webkit-transform:translateY(-10%);
  -moz-transform:translateY(-10%);
  -ms-transform:translateY(-10%);
  -o-transform:translateY(-10%);
  z-index: 1;
}
.spimage::after {
  content: "";
  position: absolute;
  left: 0; right: 0; top: -2px; bottom: -2px;
  pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(64, 64, 72, 1) 0.5%, rgba(64, 64, 72, 0) 40%),
    linear-gradient(to bottom, rgba(64, 64, 72, 0) 70%, rgba(64, 64, 72, 1) 100%);
}
#ctaform {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.ctaformtitle h2 {
  font-size: 3.2rem;
  line-height: 3.2rem;
  font-weight: 400;
  margin: 0;
  width: 35vw;
  text-align: center;
  color: var(--green);
  transform: translateY(-85%);
  -webkit-transform: translateY(-85%);
  -moz-transform: translateY(-85%);
  -ms-transform: translateY(-85%);
  -o-transform: translateY(-85%);
  position: relative;
  z-index: 10;
}
@media (max-width: 768px) {
  .prodheader {
    height: 150vh;
  }
  .prodcontent h2 {
    width: 80vw;
    font-size: 2.4rem;
    line-height: 2.8rem;
  }
  .spcontent h2 {
    width: 80vw;
    font-size: 2.4rem;
    line-height: 2.8rem;
  }
  .spcontent p{
    width: 90vw;
  }
  .ctaformtitle h2 {
    width: 80vw;
    font-size: 2rem;
    line-height: 2.8rem;
}
}
/*Content Page*/

#primary {
    margin: 12rem 5rem 0 3rem;
}
.entry-content figure.wp-block-table {
  display: block;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}
.entry-content figure.wp-block-table > table {
  border-collapse: collapse;
  table-layout: auto;        
  width: auto !important;
  min-width: 900px;
}
.entry-content figure.wp-block-table td,
.entry-content figure.wp-block-table th {
  white-space: normal;
  word-break: break-word;
}

