:root {
  --cinza-base: #2C443F;
  --cinza-bg: #F3FFF0;
  --verde-folha-claro: #2C443F;
  --verde-folha-bg: #F3FFF0;
  --verde-folha-pastel: #A9B79E;
  --cinza-soft: #A9B79E;
  --fonte: 'Montserrat', Helvetica, Arial, sans-serif;
  --fonte-titulos: 'Familjen Grotesk', 'Montserrat', Arial, sans-serif;
  --nav-glass: rgba(255,255,255,0.85);
  --nav-accent: #D4E3CF;
  --nav-gradient: linear-gradient(92deg,#F3FFF000 5%,#F3FFF0CC 90%);
  --menu-line: #A9B79E;
  --menu-bg-shadow: 0 16px 44px 0 #bacebd28;
  --menu-glow: 0 0 0 0 #A9B79E00;
}

/* --- Paleta Aplicada --- */
html, body {
  margin: 0;
  padding: 0;
  font-family: var(--fonte);
  background-color: var(--cinza-bg);
  color: var(--cinza-base);
  font-size: 18px;
  scroll-behavior: smooth;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 18px;
}

.header-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.main-header {
  background: transparent;
  border-bottom: 0px solid var(--cinza-soft);
  position: sticky;
  top: 0;
  z-index: 101;
  transition: background 0.36s cubic-bezier(.42,.97,.53,1.33), box-shadow 0.29s cubic-bezier(.41,1.38,.46,1.1), border-bottom 0.25s;
  box-shadow: 0 0 0 0 #0000;
  min-height: 64px;
  filter: none;
}
.main-header:before {
  /* Accent gradient behind menu bar, animates in/out */
  content: '';
  position: absolute;
  left:0; top:0; width:100%; height:100%;
  background: var(--nav-gradient);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.47s cubic-bezier(.61,1.69,.42,.91);
  z-index: 1;
}
.main-header.scrolled {
  background: var(--nav-glass);
  border-bottom: 1.7px solid var(--nav-accent);
  box-shadow: var(--menu-bg-shadow);
}
.main-header.scrolled:before {
  opacity: 1;
}

.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 1.3em;
  letter-spacing: 1px;
  color: var(--cinza-base);
}

.logo span { 
  display: none;
}

nav ul {
  display: flex;
  gap: 25px;
  list-style: none;
  padding: 0;
  margin: 0;
  align-items: center;
}

nav ul li {
  position: relative;
}

nav ul li a {
  color: var(--cinza-base);
  text-decoration: none;
  font-weight: 700;
  font-family: var(--fonte-titulos);
  position: relative;
  font-size: 1.05em;
  letter-spacing: .2px;
  transition: color 0.19s;
  padding: 0.27em .9em 0.22em .8em;
  border-radius: 12px;
  line-height: 1.22;
  z-index: 1;
  background: none;
  overflow: hidden;
}
nav ul li a:after {
  content: '';
  display: block;
  position: absolute;
  left: 17%;
  bottom: 7px;
  width: 0;
  height: 2.5px;
  background: linear-gradient(90deg, var(--verde-folha-pastel), var(--verde-folha-claro));
  transition: width 0.29s cubic-bezier(.17,1.21,.61,.98), background 0.2s;
  border-radius: 2.7px;
  opacity: .65;
  z-index: 0;
}
nav ul li a:hover:after,
nav ul li a:focus:after {
  width: 66%;
  opacity: 0.89;
}
nav ul li a:hover,
nav ul li a:focus {
  color: #1e2b26;
  background: linear-gradient(98deg,#F3FFF0e6 50%,#e5f2e3 120%);
  box-shadow: 0 3px 16px #A9B79E1f;
  text-shadow: 0 2px 7px #bacebd14;
  transition: color 0.19s, box-shadow .16s;
}

/* Effect: glowing underline on nav links (only desktop) */
@media (min-width: 801px) {
  nav ul li a:before {
    content:'';
    position: absolute;
    left:50%; bottom:2.5px;
    width:0; height:2px;
    background: linear-gradient(93deg,#A9B79E 0%,#2C443F 90%);
    box-shadow: 0 2px 12px #A9B79E66;
    border-radius: 2px;
    transition: width 0.24s cubic-bezier(.22,1.25,.47,.95);
    z-index:2;
    opacity:.21;
    pointer-events:none;
  }
  nav ul li a:hover:before,
  nav ul li a:focus:before {
    width:90%;
    left:5%;
    opacity:.49;
  }
  nav ul li a:hover:after,
  nav ul li a:focus:after {
    width: 56%;
  }
}

/* --- Conceitual Hamburger/Burger button --- */
.menu-toggle.concept-burger {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  padding: 4px 16px 4px 12px;
  font-size: 2.2em;
  position: relative;
  z-index: 130;
  outline: none;
  cursor: pointer;
  margin-left: 16px;
  transition: box-shadow .18s;
  color: var(--verde-folha-claro);
  box-shadow: 0 2px 20px #99b5a82a, 0 0px 0 #A9B79E00;
  border-radius: 13px;
}
.menu-toggle.concept-burger:hover,
.menu-toggle.concept-burger:focus-visible {
  box-shadow: 0 4px 26px #A9B79E33;
  background: linear-gradient(91deg,#F3FFF0cc 56%,#e1efe6 130%);
}

.menu-toggle.concept-burger .burger-box {
  display: inline-block;
  position: relative;
  width: 32px;
  height: 24px;
}
.menu-toggle.concept-burger .burger-inner {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 32px;
  height: 4px;
  background: linear-gradient(90deg,#A9B79E 10%,#2C443F 90%);
  border-radius: 5px;
  transition: all .29s cubic-bezier(0.4, 0.06, 0.52, 1.45);
  box-shadow: 0 1.5px 8px #A9B79E33;
}
.menu-toggle.concept-burger .burger-inner:before,
.menu-toggle.concept-burger .burger-inner:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  width: 32px;
  height: 4px;
  background: linear-gradient(90deg,#A9B79E 0%,#799471 90%);
  border-radius: 5.2px;
  transition: all .29s cubic-bezier(0.4, 0.06, 0.52, 1.45);
}
.menu-toggle.concept-burger .burger-inner:before {
  top: -10px;
}
.menu-toggle.concept-burger .burger-inner:after {
  top: 10px;
}
.menu-toggle.concept-burger.burger-active .burger-inner {
  background: transparent;
  box-shadow: none;
}
.menu-toggle.concept-burger.burger-active .burger-inner:before {
  top: 0;
  transform: rotate(43deg);
  background: linear-gradient(98deg,#A9B79E 30%,#244f44 90%);
}
.menu-toggle.concept-burger.burger-active .burger-inner:after {
  top: 0;
  transform: rotate(-43deg);
  background: linear-gradient(96deg,#A9B79E 15%,#244f44 90%);
}
.menu-toggle:focus-visible {
  outline: 2.5px solid var(--verde-folha-claro);
  outline-offset: 2px;
  box-shadow: 0 0 0 3.3px #A9B79E35;
}

/* Mobile menu style — glassy effect */
@media (max-width: 800px) {
  nav {
    position: fixed;
    top: 0;
    right: 0;
    background: var(--nav-glass);
    backdrop-filter: blur(18px) saturate(1) contrast(1.05);
    -webkit-backdrop-filter: blur(18px) saturate(1) contrast(1.07);
    height: 100vh;
    max-width: 270px;
    width: 82vw;
    box-shadow: -2px 0 50px #bacebd24, 1.5px 0 13px #A9B79E18;
    z-index: 121;
    padding-top: 78px;
    padding-left: 19px;
    transform: translateX(102%);
    transition: transform 0.33s cubic-bezier(.61,1.24,.46,1.12);
    border-top-left-radius: 32px;
    border-bottom-left-radius: 32px;
    opacity: 1;
    display: block;
    filter: blur(0) brightness(1.07);
  }
  nav.open {
    transform: translateX(0%);
    box-shadow: -2px 0 67px #bacebd33, 0 1.5px 0 #79947122;
    border-left: 1.5px solid #A9B79E33;
    background: linear-gradient(96deg,rgba(255,255,255,0.92) 75%,rgba(169,183,158,0.13) 98%);
    filter: blur(0) brightness(1.11);
  }
  nav ul {
    flex-direction: column;
    gap: 32px;
    margin-top: 43px;
  }
  nav ul li a {
    font-size: 1.15em;
    font-family: var(--fonte-titulos);
    padding: 13px 2px;
    display: block;
    text-align: left;
    letter-spacing: .07em;
    border-radius: 16px;
  }
  nav ul li a:before,
  nav ul li a:after {display:none;}
  .menu-toggle.concept-burger {
    display: flex;
    position: relative;
    z-index: 133;
    margin-left: 2px;
  }
  .header-flex {
    flex-direction: row;
    gap: 0;
    align-items: center;
    justify-content: space-between;
    padding: 13px 0 7px 0;
  }
}

/* Hide nav by default before JS enabled */
nav[hidden] { display: none !important; }

/* Responsive header container on mobile */
@media (max-width: 800px) {
  .header-flex { gap:0; }
}

/* --- TÍTULOS --- */
h1,h2 {
  font-family: var(--fonte-titulos);
  font-weight: 900;
  letter-spacing: 0.6px;
}
h2 {
  font-size: 2em;
  font-weight: 900;
  color: var(--verde-folha-claro);
  margin-top: 0;
  margin-bottom: 32px;
  letter-spacing: 1px;
  text-align:center;
  position:relative;
}
h2:after {
  content:'';
  display:block;
  width:60px;height:3px;background:var(--verde-folha-claro);margin:12px auto 0;
  border-radius:2px;
  opacity:.3;
}

/* Hero slider */
.hero-slider {
  position: relative;
  height: 62vh;
  min-height: 340px;
  background: var(--cinza-soft);
  overflow: hidden;
}

.swiper, .swiper-container {
  width: 100%;
  height: 100%;
}

.hero-slider.fullpage-slider,
.hero-slider.fullpage-slider .swiper,
.hero-slider.fullpage-slider .swiper-wrapper,
.hero-slider.fullpage-slider .swiper-slide {
  min-height: 96vh;
  height: 96vh;
  width: 100vw;
  margin: 0;
  padding: 0;
  max-width: 100vw;
}

.hero-slider.fullpage-slider {
  position: relative;
  height: 96vh;
  min-height: 400px;
  background: #E4FFF2;
  border-radius: 0 0 70px 0;
  overflow: hidden;
  box-shadow: 0 5px 45px #A9B79E1f;
}

/* Each full slide fills the viewport with overlay */
.full-slide {
  width: 100vw;
  height: 96vh;
  min-height: 400px;
  background-position: center center;
  background-size: cover;
  display: flex;
  align-items: stretch;
  justify-content: center;
  position: relative;
  margin: 0;
  padding: 0;
  box-shadow: 0 3px 18px #0001;
}

/* Overlayed content in center with fade bg */
.slide-overlay-content {
  position: absolute;
  left: 0; top: 0; right: 0; bottom: 0;
  width: 100vw;
  height: 100%;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.slide-overlay-content > * {
  pointer-events: auto;
}

.slide-overlay-content {
  background: linear-gradient(90deg,rgba(243,255,240,0.75) 0%,rgba(255,255,255,0.10) 95%);
  flex-direction: column;
  text-align: center;
  color: var(--cinza-base);
}
.slide-overlay-content h1 {
  font-size: clamp(2.2em,7vw,3.6em);
  font-weight: 700;
  color: var(--verde-folha-claro);
  background: rgba(243,255,240,0.85);
  display: inline-block;
  padding: 0.27em 1.8em 0.16em 1.8em;
  margin: 0 0 0.5em;
  border-radius: 16px;
  box-shadow: 0 2px 22px #a9b79e2e;
  animation: slideFadeIn 1.1s;
}
@keyframes slideFadeIn {
  from { opacity: 0; transform: translateY(22px);}
  to   { opacity: 1; transform: translateY(0);}
}

.slide-overlay-content p {
  font-size: clamp(1.10em,2vw,1.49em);
  margin-bottom: 2em;
  background: #f3fff0da;
  color: var(--cinza-base);
  display: inline-block;
  padding: 0.45em .85em;
  border-radius: 14px;
}

.slide-overlay-content .cta-btn {
  margin-top: 18px;
  font-size: 1.03em;
  padding: 0.65em 2em;
}

.fullpage-slider .swiper-pagination {
  position: absolute;
  bottom: 32px;
  left: 0;
  width: 100vw;
  z-index: 12;
  text-align: center;
  pointer-events: auto;
}

.fullpage-slider .swiper-pagination-bullet {
  background: var(--verde-folha-claro);
  opacity: 0.28;
  width: 13px;
  height: 13px;
  margin: 0 7px !important;
  border-radius: 50%;
  transition: opacity .24s, transform .16s;
  border:2.5px solid #fff0;
  box-shadow: 0 2px 8px #9ebba03f;
}
.fullpage-slider .swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--verde-folha-claro);
  border:2.5px solid #fff;
  transform: scale(1.19);
}

/* Section base */
.section {
  padding: 60px 0;
  background: #fff;
}

.bg-light {
  background: var(--verde-folha-bg);
}

h3, h4 {
  color: var(--cinza-base);
  margin: 0.6em 0 0.3em 0;
  font-weight: 700;
}

/* PROJETOS - ORGANIC CARDS */
.new-mosaic-style {
  display: flex;
  gap: 44px 32px;
  justify-content: center;
  align-items: stretch;
  flex-wrap: wrap;
  margin-top: 34px;
}

.new-project-card.project-flip-card {
  background: transparent;
  box-shadow: 0 4px 22px #A9B79E18;
  width: 220px;
  height: 220px;
  aspect-ratio: 1/1;
  min-width: 160px;
  min-height: 160px;
  max-width: 260px;
  max-height: 260px;
  border-radius: 50%;
  position: relative;
  overflow: visible;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 900px;
  margin: 14px;
  padding: 0;
  transition: box-shadow .18s, transform 0.17s;
}

.new-project-card .project-flip-inner {
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  position: relative;
  border-radius: 50%;
  transform-style: preserve-3d;
  transition: transform 0.68s cubic-bezier(.13,.61,.59,1.24);
}

.new-project-card .project-flip-front,
.new-project-card .project-flip-back {
  position: absolute;
  width: 100%;
  height: 100%;
  top:0; left:0;
  border-radius: 50%;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  backface-visibility: hidden;
  z-index: 2;
  padding: 0;
  background: transparent;
  transition: none;
}

.project-card-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  box-shadow: 0 2px 12px #a9b79e1a;
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 1;
}

.project-card-title {
  z-index: 3;
  color: #fff;
  background: rgba(44,68,63,0.75);
  font-size: 1.06em;
  font-weight: 700;
  width: 94%;
  text-align: center;
  padding: 11px 0 8px 0;
  border-radius: 0 0 40px 40px / 0 0 38px 38px;
  margin: 0 auto 12px auto;
  letter-spacing: .4px;
  position: relative;
  box-shadow: 0 2px 10px #0005;
  line-height: 1.13;
}

.new-project-card .project-flip-back {
  background: rgba(255,255,255,0.98);
  color: var(--cinza-base);
  z-index: 4;
  transform: rotateY(180deg);
  border-radius: 50%;
  box-shadow: 0 2px 13px #a9b79e2f;
  padding: 0;
  justify-content: center;
  align-items: center;
}

.project-back-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 84%;
  height: 84%;
  margin: 0 auto;
  padding: 0;
  font-size: 1.07em;
  text-align: center;
  color: var(--cinza-base);
  background: none;
  border-radius: 50%;
  pointer-events: auto;
}

.new-project-card.flipped .project-flip-inner {
  transform: rotateY(180deg);
}
.new-project-card .project-flip-inner {
  transition: transform 0.68s cubic-bezier(.13,.61,.59,1.24);
}
.new-project-card:not(.flipped) .project-flip-inner {
  transform: none;
}

.new-project-card:focus-within {
  outline: 2.5px solid var(--verde-folha-claro);
  outline-offset: 3px;
}

.new-project-card:hover,
.new-project-card:focus-within,
.new-project-card.flipped {
  box-shadow: 0 9px 32px #A9B79E5c;
  z-index: 3;
  transform: translateY(-7px) scale(1.049);
}

/* Mobile tweaks for new project cards */
@media (max-width: 950px) {
  .new-mosaic-style {
    gap: 22px 1vw;
  }
  .new-project-card.project-flip-card {
    max-width: 170px;
    max-height: 170px;
    width: 33vw;
    height: 33vw;
    min-width: 120px;
    min-height: 120px;
  }
}
@media (max-width: 700px) {
  .new-mosaic-style {
    flex-wrap: wrap;
    gap: 19px 1vw;
    justify-content: center;
  }
  .new-project-card.project-flip-card {
    min-width: 35vw !important;
    max-width: 39vw !important;
    width: 39vw;
    height: 39vw;
    min-height: 82px;
    max-height: 120px;
    margin: 10px 4vw !important;
  }
}

/* --- MÍDIAS CÍRCULOS --- */
.midias-circles-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 36px 40px;
  justify-content: center;
  margin-top: 42px;
  align-items: flex-start;
}

.midia-circle-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  outline: none;
  background: transparent;
  transition: transform .18s, box-shadow .18s;
  width: 110px;
  min-width: 90px;
  max-width: 150px;
  height: auto;
  border: none;
  cursor: pointer;
}

.midia-circle-img {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 85px;
  height: 85px;
  min-width: 74px;
  min-height: 74px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 16px #A9B79E32;
  margin-bottom: 17px;
  transition: box-shadow .19s, transform .17s;
  font-size: 2.5em;
  border: 2.4px solid var(--cinza-soft);
}

.midia-circle-card:hover .midia-circle-img,
.midia-circle-card:focus .midia-circle-img {
  transform: scale(1.09);
  border-color: var(--verde-folha-claro);
  box-shadow: 0 7px 42px #A9B79E33;
}

.midia-circle-label {
  text-align: center;
  font-size: 1.06em;
  color: var(--cinza-base);
  font-weight: 700;
  letter-spacing: .25px;
  margin-top:2px;
  margin-bottom:0;
  background: none;
  border-radius: 0;
  padding: 0;
  width: 100%;
  user-select: none;
}

.midia-instagram svg circle { stroke: none; }
.midia-facebook svg circle { stroke: none; }
.midia-youtube svg circle { stroke: none; }
.midia-linkedin svg circle { stroke: none; }

/* Responsividade midias */
@media (max-width: 700px) {
  .midias-circles-grid {
    gap: 17px 17vw;
    margin-top: 19px;
  }
  .midia-circle-card {
    min-width: 70px;
    max-width: 39vw;
    width: 97px;
  }
  .midia-circle-img {
    width: 56px; height: 56px; min-width: 54px; min-height: 54px;
    margin-bottom: 7px;
  }
  .midia-circle-label {
    font-size: .93em;
  }
}

/* Soluções */
.solucoes-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(220px,1fr));
  gap: 32px 24px;
  margin-top:32px;
}
.solucao-item {
  background: #F3FFF0;
  border-radius: 13px;
  padding: 26px 18px 16px 18px;
  text-align: center;
  box-shadow: 0 2px 9px #c1ccc314;
  border: 2px solid var(--cinza-bg);
  transition: border .25s;
}
.solucao-item:hover {
  border: 2px solid var(--verde-folha-claro);
}

/* Portfolio Slider */
#portifolio .container {
  max-width: 100vw;
  padding-left: 0;
  padding-right: 0;
}
.portfolio-swiper {
  min-width: 0;
  width: 100vw;
  max-width: 100vw;
  margin-left: 0;
  margin-right: 0;
  margin-top: 0;
  border-radius: 0;
  box-shadow: 0 2px 18px #A9B79E17;
  background: #fff;
  min-height: 56vw;
  max-height: 560px;
  display: flex;
  align-items: center;
  padding-bottom: 43px;
}
@media (max-width: 800px) {
  .portfolio-swiper {
    min-height: 340px;
    height: 80vw;
    max-height: 99vw;
    padding-bottom: 38px;
  }
}
@media (max-width: 600px) {
  .portfolio-swiper {
    min-width: 0;
    max-width: 100vw;
    border-radius: 0;
    padding-bottom: 28px;
    min-height: 210px;
    height: auto;
  }
}

.portfolio-slide {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 380px;
  height: 51vw;
  max-height: 485px;
}
@media (max-width: 700px) {
  .portfolio-slide {
    min-height: 180px;
    height: 36vw;
    max-height: 99vw;
  }
}
.portfolio-slide figure {
  width: 99%;
  min-width: 220px;
  max-width: 590px;
  margin-left: auto;
  margin-right: auto;
}

.portfolio-slide img {
  display: block;
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 16px 16px 0 0;
}
.portfolio-slide figcaption {
  padding: 23px 18px 16px 18px;
  background: transparent;
  text-align: center;
}
.portfolio-slide h4 {
  color: var(--verde-folha-claro);
  font-size: 1.23em;
  margin-bottom: 0.5em;
  margin-top: 0;
  font-weight: 700;
  letter-spacing: 0.5px;
}
.portfolio-slide p {
  color: var(--cinza-base);
  margin-bottom: 0;
  font-size: 1.05em;
  line-height: 1.6;
}

.swiper-fade .swiper-slide {
  transition-property: opacity !important;
}

/* Swiper navigation buttons styling for portfolio */
.swiper-button-prev.portfolio-btn,
.swiper-button-next.portfolio-btn {
  color: var(--cinza-base);
  background: #F3FFF0;
  box-shadow: 0 1px 7px #a9b79e25;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  top: 48%;
  transform: translateY(-48%);
  opacity: 1;
  transition: background .15s;
}
.swiper-button-prev.portfolio-btn:hover,
.swiper-button-next.portfolio-btn:hover {
  background: var(--verde-folha-claro);
  color: #fff;
}
.swiper-button-prev.portfolio-btn:after,
.swiper-button-next.portfolio-btn:after {
  font-size: 20px;
}
.swiper-button-prev.portfolio-btn {
  left: 6px;
}
.swiper-button-next.portfolio-btn {
  right: 6px;
}

.portfolio-pagination.swiper-pagination {
  position: absolute;
  bottom: 17px;
  left: 0;
  width: 100%;
  z-index: 14;
  text-align: center;
  pointer-events: auto;
}
.portfolio-pagination .swiper-pagination-bullet {
  background: var(--verde-folha-claro);
  opacity: 0.28;
  width: 13px;
  height: 13px;
  margin: 0 7px !important;
  border-radius: 50%;
  border:2.5px solid #fff0;
  box-shadow: 0 2px 8px #9ebba03f;
  transition: opacity .24s, transform .16s;
}
.portfolio-pagination .swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--verde-folha-claro);
  border:2.5px solid #fff;
  transform: scale(1.19);
}

/* About */
.about-flex {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
  justify-content: space-between;
  margin-top:20px;
}
.about-flex > div {
  flex: 1 1 350px;
}
.about-illustration {
  flex: 1 1 210px;
  display:flex;
  align-items:flex-end;
  justify-content:flex-end;
  margin-left: 16px;
  min-width: 180px;
  max-width: 280px;
}

.section ul {
  list-style: none;
  padding: 0;
  margin: 16px 0 0 0;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  background: transparent;
}
.tag {
  background: var(--cinza-soft);
  color: var(--cinza-base);
  font-size: 0.97em;
  padding: 0.48em 1.3em;
  border-radius: 14px;
  margin-right:4px;
  display:inline-block;
}

/* Melhorias Sobre Nós */
.better-about {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 32px;
  justify-content: space-between;
  margin-top: 36px;
}

.about-main-text {
  flex: 1 1 340px;
  max-width: 550px;
  padding: 12px 18px 12px 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-main-text p {
  font-size: 1.13em;
  font-weight: 500;
  margin: 0 0 18px 0;
  color: var(--cinza-base);
  line-height: 1.62;
  background: transparent;
}

.about-main-text ul {
  margin: 10px 0 0 0;
  gap: 10px;
}

.about-metrics-column {
  flex: 0 1 330px;
  max-width: 370px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: center;
}

.metrics-animated.better-metrics {
  background: transparent;
  box-shadow: none;
  width: 100%;
  max-width: 330px;
  min-width: 210px;
  margin: 0;
  padding: 24px 7px 18px 12px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 30px;
}

.metric-block {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 10px !important;
  border-bottom: 1.5px solid var(--verde-folha-pastel);
  align-items: flex-end;
  min-width: 130px;
  max-width: 320px;
  padding: 9px 0 10px 0;
  margin-bottom: 0;
  display: flex;
  gap: 18px;
  flex-direction: row;
  justify-content: flex-end;
}

.metric-icon {
  background: transparent;
  box-shadow: none;
  min-width: 46px;
  width: 46px;
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.metric-value {
  font-size: 2.1em;
  color: var(--cinza-base);
  font-weight: 700;
  margin-bottom: 0;
  margin-top: 0;
  margin-right: 0;
  margin-left: 5px;
  text-align: right;
  min-width: 44px;
  line-height: 1.04;
}

.metric-label {
  margin-left: 13px;
  margin-bottom: 0;
  color: var(--cinza-base);
  font-size: 1em;
  white-space: nowrap;
  min-width: 82px;
  opacity: .92;
  text-align: left;
  background: transparent;
  font-weight: 500;
  display: block;
  letter-spacing: .15px;
}

.metric-block .metric-label {
  padding-left: 0;
  border: none;
}

/* Remove floating and rearrange grid for 'sobre nós' on desktop */
@media (min-width: 900px) {
  .about-flex.better-about {
    flex-direction: row;
    align-items: stretch;
    gap: 40px;
  }
  .about-metrics-column {
    align-items: flex-end;
    max-width: 350px;
    padding-right: 12px;
  }
  .metrics-animated.better-metrics {
    align-items: flex-end;
    max-width: 330px;
  }
}
@media (max-width: 1000px) {
  .about-flex.better-about {
    flex-direction: column;
    gap: 24px;
    align-items: stretch;
  }
  .about-metrics-column,
  .metrics-animated.better-metrics {
    align-items: flex-start !important;
    max-width: 100vw !important;
    width: 100%;
  }
  .metric-label { min-width: 62px; }
}
@media (max-width: 700px) {
  .about-flex.better-about { flex-direction: column; gap: 10px; }
  .about-main-text { max-width: 99vw; padding: 0; }
  .about-metrics-column { max-width: 99vw; padding: 0; }
  .metrics-animated.better-metrics {
    padding: 8px 0 8px 0;
    gap: 13px;
    max-width: 400px;
  }
  .metric-block {
    min-width: 82px;
    padding: 5px 0 5px 0;
    gap: 10px;
  }
  .metric-icon { min-width: 36px; width: 36px; height: 36px;}
  .metric-label { font-size: 0.80em; min-width: 48px;}
  .metric-value { font-size: 1.1em;}
}

/* Equipe */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit,minmax(220px,1fr));
  gap:33px;
  margin-top:37px;
}
.team-card {
  background: #fff;
  border-radius: 17px;
  text-align: center;
  box-shadow: 0 1px 10px #a9b79e13;
  padding: 32px 18px 18px 18px;
  transition: box-shadow .14s, transform .14s;
}
.team-card:hover {
  box-shadow: 0 7px 28px #abbaa215;
  transform: translateY(-5px) scale(1.04);
}
.team-photo {
  width: 75px;
  height: 75px;
  border-radius: 50%;
  margin: 0 auto 18px auto;
  background: var(--verde-folha-bg) center/cover no-repeat;
  border: 2px solid var(--verde-folha-claro);
}

#contato .contact-flex {
  display:flex;
  gap:35px;
  flex-wrap:wrap;
  margin-top:30px;
}
.form-fale {
  flex:1 1 330px;
  background: #fff;
  padding: 27px 26px 18px 26px;
  border-radius: 16px;
  box-shadow: 0 2px 14px #a9b79e16;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.form-fale label {
  font-weight:600;
  margin-top:11px;
}
.form-fale input,
.form-fale textarea {
  font-family: var(--fonte);
  border:1.4px solid var(--cinza-soft);
  border-radius:6px;
  transition:border .19s;
  padding:7px 9px;
  font-size:1em;
  background: #f3fff0;
}
.form-fale input:focus,
.form-fale textarea:focus {
  border:1.3px solid var(--verde-folha-claro);
  outline:none;
}
.form-fale button {
  margin-top:14px;
  background: var(--verde-folha-claro);
  border:0;
  color: #fff;
  font-weight:700;
  font-size: 1em;
  border-radius:19px;
  padding: 0.7em 2em;
  transition: background .2s;
  cursor:pointer;
  letter-spacing:1px;
}
.form-fale button:hover, 
.form-fale button:focus {
  background: #326254;
}
.contact-info {
  flex:1 1 240px;
  margin-top:19px;
  font-size:1.03em;
  color:var(--cinza-base);
  display:flex;
  flex-direction:column;
  align-items:center;
  background: #fff;
  border-radius: 12px;
  padding: 22px 18px 18px 18px;
  box-shadow: 0 2px 10px #a9b79e16;
}

.main-footer {
  background: #2C443F;
  color: #F3FFF0;
  padding: 32px 0 16px 0;
  margin-top:38px;
}
.footer-flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap:wrap;
  gap:30px;
}
.footer-logo {
  display:flex;
  align-items:center;
  gap:12px;
  font-size:1.14em;
  font-weight:700;
  color:#F3FFF0;
}
.main-footer nav ul {
  gap:18px;
}
.main-footer nav ul li a {
  color: #F3FFF0;
  font-weight:500;
  text-decoration:none;
  font-size:1em;
}
.copy {
  font-size:0.98em;
  color: #b7cebe;
  margin-top:8px;
  line-height: 1.6;
}
.footer-created-by {
  font-size: 0.98em;
  color: #d1e2cc;
  opacity: 0.65;
  display: block;
  margin-top: 4px;
  letter-spacing: 0.15px;
}

/* Tablets & Mobiles */
@media (max-width: 1100px) {
  .container { padding: 0 8px; }
}
@media (max-width: 900px) {
  .hero-slider.fullpage-slider, .hero-slider.fullpage-slider .swiper, .hero-slider.fullpage-slider .swiper-wrapper, .hero-loader.fullpage-slider .swiper-slide {
    min-height: 65vh;
    height: 65vh;
  }
  .full-slide {
    min-height: 65vh;
    height: 65vh;
  }
  .slide-overlay-content h1 {
    font-size: clamp(1.3em,7vw,2em);
    padding-left: 0.8em;
    padding-right: 0.8em;
  }
}

@media (max-width: 700px) {
  html, body { font-size: 15.7px;}
  .main-header {padding-bottom:10px;}
  .logo svg {height:29px;width:29px;}
  .hero-slider-content h1 {font-size: 1.35em;}
  .project-mosaic {flex-direction:column;align-items:center;}
  .portfolio-swiper {
    min-height: 330px;
    height: 80vw;
    max-height: 99vw;
    padding-bottom: 38px;
  }
  .portfolio-slide img { height: 180px; }
  .portfolio-grid {grid-template-columns: 1fr;}
  .team-grid {grid-template-columns: 1fr;}
  /* Adjust container padding for smaller screens */
  .container { padding: 0 4vw; }
}

@media (max-width: 600px) {
  .hero-slider.fullpage-slider, .hero-slider.fullpage-slider .swiper, .hero-slider.fullpage-slider .swiper-wrapper, .hero-loader.fullpage-slider .swiper-slide,
  .full-slide {
    height: 52vw;
    min-height: 50vw;
    max-height: 96vw;
    border-radius: 0 0 26px 0;
  }
  .slide-overlay-content p {
    font-size: 1em;
    margin-bottom: 1.2em;
  }
  .slide-overlay-content .cta-btn { font-size:.97em; padding:.57em 1.3em;}
  .fullpage-slider .swiper-pagination { bottom: 12px;}
  .section { padding: 30px 0; }
  .about-flex,
  #contato .contact-flex,
  .footer-flex { flex-direction: column; gap:18px;}
  .footer-logo { justify-content: center;}
  h2 { font-size: 1.18em;}
  .about-illustration svg { width:120px; height:80px; }
  .portfolio-swiper {
    min-height: 220px;
    max-width: 99vw;
    border-radius: 11px;
    padding-bottom: 28px;
  }
  .portfolio-slide figure {
    border-radius: 11px;
  }
  .portfolio-slide img {
    height: 32vw;
    min-height: 110px;
    max-height: 165px;
    border-radius: 11px 11px 0 0;
  }
  .portfolio-slide figcaption {
    padding: 14px 6vw 10px 6vw;
  }
  .swiper-button-prev.portfolio-btn,
  .swiper-button-next.portfolio-btn {
    width: 31px;
    height: 31px;
    top: 44%;
  }
}

/* --- Portfolio Alt Layout --- */
.alt-layout-swiper {
  display: flex;
  align-items: stretch;
  min-height: 375px;
  height: 48vw;
  max-height: 540px;
  background: var(--cinza-bg);
  box-sizing: border-box;
  border-radius: 0;
  padding: 0;
}

@media (max-width: 950px) {
  .alt-layout-swiper {
    min-height: 270px;
    height: 69vw;
    max-height: 420px;
  }
}
@media (max-width: 700px) {
  .alt-layout-swiper { height: auto; min-height: 210px; }
}

/* Alt layout slide fills swiper */
.portfolio-slide.alt-layout {
  height: 100%;
  min-height: 375px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  box-shadow: none;
  padding: 0;
}
@media (max-width: 800px) {
  .portfolio-slide.alt-layout { min-height: 220px; }
}
@media (max-width: 600px) {
  .portfolio-slide.alt-layout { min-height:140px; }
}

/* Flex container for alternated image/text layout */
.portfolio-card-flex {
  display: flex;
  align-items: stretch;
  justify-content: center;
  width: 100%;
  height: 97%;
  min-height: 320px;
  box-sizing: border-box;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 2px 18px #b2c7be24;
  overflow: hidden;
  margin: 0 auto;
  max-width: 930px;
  position: relative;
  transition: box-shadow 0.18s;
}
.portfolio-slide.alt-layout.left-img .portfolio-card-flex {
  flex-direction: row;
}
.portfolio-slide.alt-layout.right-img .portfolio-card-flex {
  flex-direction: row-reverse;
}

@media (max-width: 950px) {
  .portfolio-card-flex {
    min-height:170px;
    max-width:99vw;
    border-radius: 14px;
  }
}
@media (max-width: 700px) {
  .portfolio-card-flex {
    flex-direction: column !important;
    min-height: 250px;
    max-width: 96vw;
    border-radius: 10px;
    height: auto;
  }
  .portfolio-slide.alt-layout.right-img .portfolio-card-flex {
    flex-direction: column-reverse !important;
  }
  .portfolio-slide.alt-layout.left-img .portfolio-card-flex {
    flex-direction: column !important;
  }
}

/* Image block at left/right, fills half width */
.portfolio-img-block {
  flex: 1 1 50%;
  display: flex;
  align-items: stretch;
  justify-content: stretch;
  min-width: 0;
  min-height: 0;
  background: var(--verde-folha-bg);
  overflow: hidden;
  border-radius: 0;
}
.portfolio-img-block img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 220px;
  min-width: 160px;
  max-height: 540px;
  transition: transform 0.36s cubic-bezier(.14,.6,.44,1.04),box-shadow 0.18s;
  border-radius: 0;
  box-shadow: none;
}

@media (max-width: 900px) {
  .portfolio-img-block img {
    min-height: 140px;
    max-height: 340px;
  }
}
/* On mobile, image takes full width/height on top/bottom */
@media (max-width: 700px) {
  .portfolio-img-block {
    min-height: 110px;
    max-height: 42vw;
    width: 100%;
  }
  .portfolio-img-block img {
    min-height: 82px;
    max-height: 39vw;
    height: 32vw;
    border-radius: 0;
  }
}

/* Text block at right/left, fills half width */
.portfolio-text-block {
  flex: 1 1 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 44px 36px 44px 36px;
  min-width: 0;
  min-height: 0;
  background: transparent;
  height: 100%;
  box-sizing: border-box;
  text-align: left;
}
.portfolio-slide.alt-layout.right-img .portfolio-text-block {
  align-items: flex-end;
  text-align: right;
  padding-left: 28px;
  padding-right: 48px;
}
.portfolio-slide.alt-layout.left-img .portfolio-text-block {
  align-items: flex-start;
  text-align: left;
  padding-right: 28px;
  padding-left: 48px;
}

.portfolio-text-block h4 {
  color: var(--verde-folha-claro);
  font-size: 2em;
  margin: 0 0 0.44em 0;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 0;
}

.portfolio-text-block p {
  color: var(--cinza-base);
  margin-bottom: 0;
  font-size: 1.15em;
  line-height: 1.6;
  padding-right: 0;
  font-weight: 500;
}

@media (max-width: 900px) {
  .portfolio-text-block {
    padding: 24px 12px 24px 18px;
    font-size: 0.94em;
  }
  .portfolio-text-block h4 {
    font-size: 1.24em;
  }
}
@media (max-width: 700px) {
  .portfolio-text-block {
    padding: 13px 5vw 19px 5vw;
    width: 100%;
    min-height: 54px;
    align-items: flex-start !important;
    text-align: left !important;
  }
  .portfolio-text-block h4 { font-size: 1em;}
}

/* MÉTRICAS SOBRE NÓS */
.metrics-animated {
  display: grid;
  grid-template-columns: 1fr;
  gap: 28px;
  margin-top: 2.5em;
  margin-right: 0;
  margin-bottom: 0;
  align-items: flex-end;
  justify-items: flex-end;
  justify-content: flex-end;
  width: 100%;
  max-width: 450px;
  float: right;
  padding: 0;
  background: transparent;
  box-shadow: none;
}
.metric-block {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0;
  border-bottom: 2.2px solid var(--verde-folha-pastel);
  align-items: flex-end;
  min-width: 128px;
  padding: 18px 0 8px 0;
  max-width: 260px;
  margin-bottom: 0;
}
.metric-block:last-child { margin-bottom: 0; }
.metric-icon {
  width: 44px; height: 44px;
  margin-bottom: 0;
  margin-right: 0;
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  align-items: flex-end;
  justify-content: flex-end;
}
.metric-value {
  font-size: 2.2em;
  color: var(--cinza-base);
  margin-bottom: 2px;
  margin-top: 2px;
  text-align: right;
}
.metric-label {
  color: var(--cinza-base);
  font-size: 1em;
  text-align: right;
  margin: 0;
  opacity: .90;
}

/* Reorganizar grid à direita em sobre nós */
@media (min-width: 860px) {
  .about-flex {
    flex-direction: row;
  }
  .about-flex > div {
    max-width: 530px;
  }
  .metrics-animated {
    justify-content: flex-end;
    align-items: flex-end;
    margin-top: 0;
    float: right;
    margin-right: 0;
  }
}

/* Alinha os blocos de métricas verticalmente lado a lado à direita */
@media (min-width: 800px) {
  .about-flex {
    align-items: flex-start;
  }
  .metrics-animated {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 16px;
    max-width: 300px;
    float: right;
    margin-right: 0;
  }
  .metric-block {
    align-items: flex-end;
    max-width: 290px;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    min-width: 134px;
  }
}

/* Remove bg nos ícones SVG de métricas */
.metric-icon svg rect,
.metric-icon svg ellipse,
.metric-icon svg circle {
  fill: none !important;
  stroke: var(--verde-folha-pastel);
}

.metric-icon svg rect[fill="#e5f2e3"],
.metric-icon svg rect[fill="#d2e5db"],
.metric-icon svg ellipse[fill="#e5f2e3"],
.metric-icon svg rect[fill="#c2ccc7"],
.metric-icon svg circle[fill="#e5f2e3"] {
  fill: none !important;
}

.metric-icon svg rect[fill="#c2ccc7"],
.metric-icon svg rect[fill="#d2e5db"] {
  fill: none !important;
}

.metric-icon svg rect[stroke],
.metric-icon svg ellipse[stroke],
.metric-icon svg circle[stroke] {
  stroke: var(--verde-folha-pastel) !important;
}

/* Se manter algum preenchimento, só para destaque suave */
.metric-icon svg .metric-accent {
  fill: var(--verde-folha-pastel) !important;
  stroke: none !important;
}

/* Ul tags */
.section ul {
  background: transparent;
}

/* --- EQUIPE --- */
.team-card {
  background: #fff;
  box-shadow: 0 1px 10px #a9b79e13;
}

/* --- CONTATO --- */
.contact-info, .form-fale {
  background: #fff;
  box-shadow: 0 2px 10px #a9b79e16;
}
.form-fale input,
.form-fale textarea {
  background: #f3fff0;
  border:1.4px solid var(--cinza-soft);
}
.form-fale input:focus,
.form-fale textarea:focus {
  border:1.3px solid var(--verde-folha-claro);
}
.form-fale button {
  background: var(--verde-folha-claro);
}
.form-fale button:hover, 
.form-fale button:focus {
  background: #326254;
}

/* Footer */
.main-footer {
  background: #2C443F;
  color: #F3FFF0;
}
.footer-logo,
.main-footer nav ul li a {
  color: #F3FFF0;
}

/* Responsividade */
@media (max-width: 800px) {
  .about-flex {
    flex-direction: column;
    gap: 24px;
    align-items: stretch;
  }
  .about-flex > div, .about-illustration {
    max-width: 99vw !important;
    float: none !important;
    margin-left: 0;
  }
  .metrics-animated {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-end;
    max-width: 97vw;
    gap: 14px;
    margin-top: 20px;
    margin-bottom: 10px;
    float: none;
    padding: 0;
  }
  .metric-block {
    min-width: 102px;
    padding: 7px 0 5px 0;
  }
}
@media (max-width: 600px) {
  .metrics-animated, .metrics-animated * {
    min-width: 69px;
  }
  .metric-block { padding: 3px 0 4px 0; min-width: 79px; }
  .metric-value { font-size:1.1em;}
  .metric-label {font-size:.81em;}
}

/* SERVIÇOS */
.servicos-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 34px 50px;
  justify-content: center;
  align-items: stretch;
  margin-top: 38px;
}
.servico-item {
  flex: 1 1 220px;
  max-width: 320px;
  min-width: 220px;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 2px 12px #a9b79e18;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 34px 22px 24px 22px;
  transition: box-shadow .16s, transform .15s;
  text-align: center;
}
.servico-item:hover, .servico-item:focus-within {
  box-shadow: 0 8px 32px #A9B79E38;
  transform: translateY(-9px) scale(1.035);
}
.servico-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 15px;
  width: 61px;
  height: 61px;
  border-radius: 50%;
  background: #F3FFF0;
  box-shadow: 0 2px 12px #A9B79E22;
  font-size: 2.2em;
  transition: all 0.53s cubic-bezier(.41,1.41,.47,1.01);
  will-change: transform, opacity;
}
.servico-item h4 {
  color: var(--verde-folha-claro);
  font-size: 1.15em;
  margin: 0 0 0.5em 0;
  letter-spacing: 0.04em;
  font-weight: 700;
}
.servico-item p {
  color: var(--cinza-base);
  font-size: 1.03em;
  font-weight: 500;
  margin: 0;
  margin-bottom: 0;
  background: transparent;
}
@media (max-width: 950px) {
  .servicos-grid {
    gap: 22px 1vw;
  }
  .servico-item {
    max-width: 260px;
    min-width: 160px;
    padding: 23px 11px 16px 11px;
  }
}
@media (max-width: 700px) {
  .servicos-grid {
    flex-direction: column;
    gap: 19px 0;
    align-items: stretch;
    margin-top: 24px;
  }
  .servico-item {
    min-width: 0;
    max-width: 99vw;
    padding: 17px 7vw 12px 7vw;
    margin: 0 auto;
  }
  .servico-icon {
    width: 45px; height: 45px; font-size: 1.3em;}
}

/* ----------- LOGO MAIN HEADER ----------- */
.logo-link {
  display: block;
  transition: filter 0.21s, transform 0.26s cubic-bezier(.61,.13,.41,1.39);
  border-radius: 13px;
}
.logo-image-animated {
  height: 50px !important;
  transition: filter 0.19s, transform 0.27s cubic-bezier(.41,1.16,.46,1.09), box-shadow 0.22s cubic-bezier(.44,1.31,.44,1.02);
  will-change: filter, transform;
  border-radius: 11px;
}
.logo-link:hover .logo-image-animated,
.logo-link:focus .logo-image-animated {
  filter: drop-shadow(0 6px 24px #A9B79E55) brightness(1.19) contrast(1.13);
  transform: scale(1.13) rotate(-2.5deg);
  box-shadow: 0 3px 28px #79947140, 0 0 0 10px #F3FFF012;
}
.logo-link:focus-visible {
  outline: 2px solid var(--verde-folha-claro);
  outline-offset: 3px;
  filter: drop-shadow(0 2px 11px #A9B79E44);
}

@media (max-width: 800px) {
  .logo-image-animated {
    height: 38px !important;
  }
}

/* ---------- CONTACT CARD LOGO ---------- */
.contact-card-logo {
  display: block;
  margin: 0 auto 10px auto;
  height: 38px;
  border-radius: 9px;
}
@media (max-width: 700px) {
  .contact-card-logo {
    height: 29px;
    margin-bottom:7px;
  }
}

/* =========== CONTATO LOGO OVERRIDE ============ */
.contact-info .contact-card-logo,
.contact-info .contact-card-logo--big {
  height: 137px !important;
  max-width: 100% !important;
  margin-bottom: 18px !important;
  margin-top: 0 !important;
  display: block;
  border-radius: 19px;
}

/* Further reduce on breakpoints */
@media (max-width: 900px) {
  .contact-info .contact-card-logo,
  .contact-info .contact-card-logo--big {
    height: 92px !important;
  }
}
@media (max-width: 700px) {
  .contact-info .contact-card-logo,
  .contact-info .contact-card-logo--big {
    height: 57px !important;
  }
}

/* --- NOSSO PROJETOS: Card title reduction --- */
.el__heading {
  font-size: 1.4em;
}
@media (max-width: 950px) {
  .el__heading { font-size: 0.91em; }
}
@media (max-width: 700px) {
  .el__heading { font-size: 0.74em; }
}

/* ==== BACKGROUND PATTERN FOR SECTIONS ==== */
.solucoes-bg,
.servicos-bg,
.sobrenos-bg {
  position: relative;
  z-index: 1;
  background-color: var(--verde-folha-bg);
}
.solucoes-bg::before,
.servicos-bg::before,
.sobrenos-bg::before {
  content: "";
  position: absolute;
  z-index: 0;
  inset: 0;
  pointer-events: none;
  opacity: 0.23;
  background-image: url('/back.png');
  background-position: center;
  background-repeat: repeat;
  background-size: 340px auto;
}
.solucoes-bg > .container,
.servicos-bg > .container,
.sobrenos-bg > .container {
  position: relative;
  z-index: 2;
}