/*
Theme Name: cgrabarros
Theme URI: http://blisq.pt
Author: Blisq
Author URI: http://blisq.pt
Description: Tema desenvolvido para uso exclusivo da Blisq Creative no projeto cgrabarros
Version: V7.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Tags: Blisq
Text Domain: Blisq
*/

@import url("https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap");

* {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
}

::selection {
  background-color: #083344;
  color: #fff;
}

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

html.no-overflow {
  overflow: hidden;
}

body {
  font-family: "Poppins", sans-serif;
  counter-reset: section;
}

body.error404,
body.page-template-front-page {
  overflow-x: hidden;
}

main {
  background-color: #eef5f7;
}

button {
  border: none;
  font-family: "Poppins", sans-serif;
}

input {
  font-family: "Poppins", sans-serif;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

ul {
  list-style: none;
}

h1 {
  color: #083344;
  font-size: 37px;
  font-style: normal;
  font-weight: 600;
  line-height: 117%;
}

h1.title-secondary {
  font-size: 15px;
  line-height: 20px;
  /* 133.333% */
  letter-spacing: 1.05px;
  text-transform: uppercase;
}

h1>span {
  display: block;
  color: #073244;
  font-size: 30px;
  font-weight: 500;
  line-height: 38px;
}

.faq-theme-title,
h3 {
  color: #073244;
  font-family: 'Lora';
  font-size: 32px;
  font-style: italic;
  font-weight: 500;
  line-height: 125%;
  text-transform: none;
  letter-spacing: normal;
}

.faq-theme,
h2 {
  color: #127199ff;
  font-size: 15px;
  font-style: normal;
  font-weight: 600;
  line-height: 143.333%;
  letter-spacing: 1.05px;
  text-transform: uppercase;
}

a {
  color: inherit;
  text-decoration: none;
}

address {
  font-style: normal;
}

.general-section {
  background-color: #eef5f7;
}

.general-content h2 {
  color: #083344;
  font-size: 26px;
  font-style: normal;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  line-height: 110%;
  margin-bottom: 20px;
  counter-reset: h3;
}

.general-content h2::before {
  counter-increment: section;
  content: counter(section, decimal-leading-zero) ". ";
  color: #127199ff;
}

.general-content h3 {
  color: #083344;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: 120%;
  margin-bottom: 15px;
  text-transform: none;
  letter-spacing: normal;
}

.general-content h3::before {
  counter-increment: h3;
  content: counter(h3, lower-alpha) ". ";
  color: #5b8393;
}

.general-content table {
  margin-bottom: 30px;
  width: 100%;
}

.general-content table tr:nth-child(even) {
  background-color: rgba(8, 51, 68, 0.06);
}

.general-content table td {
  padding: 8px;
  font-size: 10px;
  color: #083344;
  font-weight: 400;
  line-height: 110%;
}

.general-content table tr:first-child td strong {
  color: #127199ff;
  font-size: 14px;
  font-weight: 600;
  line-height: 100%;
}

.general-content p:not(.general-intro-p) {
  color: #083344;
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 170%;
  margin-bottom: 15px;
}

.general-content p:last-child {
  margin-bottom: 30px;
}

.common-content ul {
  list-style: disc;
  padding-left: 20px;
  margin-top: 15px;
}

.common-content li {
  margin-bottom: 10px;
}

p,
.general-intro-p {
  color: #295661;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 168.75%;
}

.general-intro-p {
  margin-bottom: 30px;
}

p.lg {
  color: #175f71;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 172.222%;
}

p.dark-blue-text,
.dark-blue-text-content p {
  color: #073244;
  font-weight: 400;
}

p.dark-blue-text strong,
.dark-blue-text-content p strong {
  color: #000;
  font-weight: 500;
}

.f500 p {
  font-weight: 500;
}

li:not(.sub-menu li, .breadcrumb > li, .frontpage-hero-list) {
  color: #073244;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 168.75%;
}

figure>img {
  width: 100%;
  height: 100%;
  position: relative;
  object-fit: cover;
}

input:focus {
  outline: none;
}

.grey-span {
  color: #405761;
  text-align: center;
  font-size: 11px;
  font-style: italic;
  font-weight: 500;
  line-height: 81.818%;
  display: block;
}

/* Nice Select */
.nice-select {
  -webkit-tap-highlight-color: transparent;
  background-color: #fff;
  border-radius: 5px;
  border: solid 1px #e8e8e8;
  box-sizing: border-box;
  clear: both;
  cursor: pointer;
  display: block;
  float: left;
  font-family: inherit;
  font-size: 16px;
  font-weight: 400;
  height: 42px;
  line-height: 40px;
  outline: none;
  padding-left: 18px;
  padding-right: 30px;
  position: relative;
  text-align: left !important;
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  white-space: nowrap;
  width: auto;
}

.nice-select:hover {
  border-color: #dbdbdb;
}

.nice-select:active,
.nice-select.open,
.nice-select:focus {
  border-color: #999;
}

.nice-select:after {
  border-bottom: 2px solid #999;
  border-right: 2px solid #999;
  content: "";
  display: block;
  height: 5px;
  margin-top: -4px;
  pointer-events: none;
  position: absolute;
  right: 12px;
  top: 50%;
  -webkit-transform-origin: 66% 66%;
  -ms-transform-origin: 66% 66%;
  transform-origin: 66% 66%;
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transition: all 0.15s ease-in-out;
  transition: all 0.15s ease-in-out;
  width: 5px;
}

.nice-select.open:after {
  -webkit-transform: rotate(-135deg);
  -ms-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

.nice-select.open .list {
  opacity: 1;
  pointer-events: auto;
  -webkit-transform: scale(1) translateY(0);
  -ms-transform: scale(1) translateY(0);
  transform: scale(1) translateY(0);
}

.nice-select.disabled {
  border-color: #ededed;
  color: #999;
  pointer-events: none;
}

.nice-select.disabled:after {
  border-color: #cccccc;
}

.nice-select.wide {
  width: 100%;
}

.nice-select.wide .list {
  left: 0 !important;
  right: 0 !important;
}

.nice-select.right {
  float: right;
}

.nice-select.right .list {
  left: auto;
  right: 0;
}

.nice-select.small {
  font-size: 12px;
  height: 36px;
  line-height: 34px;
}

.nice-select.small:after {
  height: 4px;
  width: 4px;
}

.nice-select.small .option {
  line-height: 34px;
  min-height: 34px;
}

.nice-select .list {
  background-color: #fff;
  border-radius: 5px;
  box-shadow: 0 0 0 1px rgba(68, 68, 68, 0.11);
  box-sizing: border-box;
  margin-top: 4px;
  opacity: 0;
  overflow: hidden;
  padding: 0;
  pointer-events: none;
  position: absolute;
  top: 100%;
  left: 0;
  -webkit-transform-origin: 50% 0;
  -ms-transform-origin: 50% 0;
  transform-origin: 50% 0;
  -webkit-transform: scale(0.75) translateY(-21px);
  -ms-transform: scale(0.75) translateY(-21px);
  transform: scale(0.75) translateY(-21px);
  -webkit-transition: all 0.2s cubic-bezier(0.5, 0, 0, 1.25),
    opacity 0.15s ease-out;
  transition: all 0.2s cubic-bezier(0.5, 0, 0, 1.25), opacity 0.15s ease-out;
  z-index: 9;
}

.nice-select .option {
  cursor: pointer;
  font-weight: 400;
  line-height: 40px;
  list-style: none;
  outline: none;
  padding-left: 18px;
  padding-right: 29px;
  text-align: left;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}

.nice-select .option:hover,
.nice-select .option.focus,
.nice-select .option.selected.focus {
  background-color: #f6f6f6;
}

.nice-select .option.selected {
  font-weight: bold;
}

.nice-select .option.disabled {
  background-color: transparent;
  color: #999;
  cursor: default;
}

.no-csspointerevents .nice-select .list {
  display: none;
}

.no-csspointerevents .nice-select.open .list {
  display: block;
}

/* Buttons */
.btn-primary {
  padding: 12px 30px;
  background-color: #073244;
  color: #eef5f7;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  line-height: 143%;
  border-radius: 82px;
  display: block;
  width: fit-content;
  transition: all 0.2s;
  white-space: nowrap;
  border: none;
}

.btn-primary:hover {
  background-color: #205e6e;
}

.btn-secondary {
  padding: 12px 23px;
  background-color: #127199ff;
  color: #eef5f7;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  line-height: 143%;
  border-radius: 82px;
  display: block;
  width: fit-content;
  transition: all 0.2s;
}

.btn-secondary:hover {
  background-color: #073244;
}

.btn-border {
  border-radius: 82px;
  border: 1px solid #175f71;
  color: #073244;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 142.857%;
  padding: 15px 45px;
  flex: 1;
  white-space: nowrap;
  transition: all 0.2s;
}

.btn-border:hover {
  background-color: #083344;
  border: 1px solid #083344;
  color: #ecf4f6;
}

.btn-border.online:hover {
  color: #127199ff;
}

.btn-border.online:hover::after {
  filter: invert(0.7);
}

.btn-secondary.online,
.btn-border.online,
.btn-primary.online {
  display: flex;
  gap: 10px;
  justify-content: center;
  align-items: center;
}

.maps-location .btn-primary {
  display: flex;
  align-items: center;
  gap: 14px;
}

.btn-secondary.online::after,
.btn-border.online::after,
.btn-primary.online::after {
  content: "";
  background-image: url(assets/images/icons/icon-seta.svg);
  background-size: contain;
  height: 12px;
  width: 12px;
  background-repeat: no-repeat;
  display: block;
  transition: all 0.2s;
}

.contacts-content .btn-secondary.online::after,
.btn-primary.online::after {
  background-image: url(assets/images/icons/icon-seta-branca.svg);
}

.btn-secondary.online {
  border: 1px solid #127199ff;
}

.btn-secondary.online:hover {
  background-color: #127199ff;
  color: #073244;
}

.btn-secondary.online:hover::after,
.maps-location .btn-primary.online:hover::after {
  transform: translate(3px, -2px);
}

.btn-more {
  color: #127199ff;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  line-height: 91%;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 11px;
  transition: all 0.2s;
}

.btn-more-primary {
  color: #083344;
}

.btn-more::after {
  content: "";
  height: 7px;
  width: 24px;
  background-image: url(assets/images/icons/icon-saber-mais.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.2s;
}

.btn-more-primary::after {
  filter: brightness(0);
}

.btn-donate {
  color: #073244;
  font-size: 17px;
  font-weight: 700;
  line-height: 19px;
  /* 111.765% */
  border-radius: 32px;
  background: linear-gradient(90deg, #127199ff 68.99%, #205e6e 167.28%);
  padding: 13px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

/* Container */
.container {
  max-width: 1366px;
  margin: 0 auto;
  position: relative;
}

.container-md {
  max-width: 1088px;
  margin: 0 auto;
}

.container-md-secondary {
  max-width: 1150px;
  margin: 0 auto;
}

.container-md-tertiary {
  max-width: 950px;
  margin: 0 auto;
}

.container-sm {
  max-width: 812px;
  margin: 0 auto;
}

.content-sm {
  max-width: 812px;
}

.treatment-detail-content p:not(:last-of-type),
.content-sm>p:not(:last-of-type) {
  margin-bottom: 15px
}

.container-sm-secondary {
  max-width: 665px;
  margin: 0 auto;
  position: relative;
}

/* Cores */
.color-primary {
  color: #083344 !important;
}

.color-light {
  color: #175f71;
}

.color-light-secondary {
  color: #eef5f7 !important;
}

.color-blue {
  color: #127199ff !important;
}

.color-blue-light{
  color: #3EB6D4 !important;
}

.content-white>p,
.color-white {
  color: #fff !important;
}

.color-black{
  color: #000;
}

.bg-light {
  background-color: #e0ecf0;
}

/* Ajustes */
.title-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

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

.pt-50 {
  padding-top: 50px;
}

.pt-80 {
  padding-top: 80px;
}

.py-80 {
  padding: 80px 0;
}

.mb-5 {
  margin-bottom: 5px;
}

.mb-8 {
  margin-bottom: 8px;
}

.mt-10 {
  margin-top: 10px;
}

.mb-10 {
  margin-bottom: 10px;
}

.mb-15 {
  margin-bottom: 15px;
}

.mb-20 {
  margin-bottom: 20px;
}

.mb-25 {
  margin-bottom: 25px;
}

.mt-15 {
  margin-top: 15px;
}

.mt-40 {
  margin-top: 40px;
}

.mt-70 {
  margin-top: 70px;
}

.mr-5 {
  margin-right: 5%;
}

.ml-5n {
  margin-left: -5%;
}

.mt-auto {
  margin-top: auto;
}

.mx-auto {
  margin: 0 auto;
}

.flex {
  display: flex;
  position: relative;
}

.d-none {
  display: none;
}

.flex-common {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px 10%;
  flex-wrap: wrap;
}

.flex-common.align-baseline {
  align-items: baseline;
}

.flex-content>p {
  margin-bottom: 15px;
}

.flex-md {
  flex: 0 0 40%;
}

.d-flex-slider {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scrollbar-width: none;
}

.d-flex-slider.active {
  cursor: grabbing;
}

.d-flex-slider.active>.flex-5 {
  pointer-events: none;
}

.d-flex-slider::-webkit-scrollbar {
  display: none;
}

.d-flex-slider .flex-5 {
  flex: 0 0 calc(20% - 16px);
}

.d-flex-slider .flex-6 {
  flex: 0 0 calc(16.6% - 16px);
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.grid-4 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 20px;
}

.grid-5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}

.grid-6 {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 20px;
}

.grid-2-fr {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}

/* Footer */
footer {
  background-image: url(assets/images/mask/mask-footer.svg);
  background-size: cover;
  background-repeat: no-repeat;
  padding: 85px 0 55px 0;
  position: relative;
}

footer::before {
  content: "";
  position: absolute;
  left: 0;
  top: -10%;
  height: 100%;
  width: 100%;
  display: block;
  background: linear-gradient(180deg,
      rgb(238 245 247 / 50%) 0%,
      #d7ebf1 31.17%,
      #9fc0ca 100%);
  z-index: -1;
}

.footer-donate {
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 24px;
  border: 1px solid #9eb9c0;
  max-width: 225px;
  padding-top: 48px;
  margin: 40px 0 178px 0;
}
.license-number{
    color: #073244;
    font-size: 14px;
    font-weight: 500;
    line-height: 19px;
    transition: all 0.2s;
    display: block;
}
.btn-donate-title {
  all: unset;
  width: 100%;
}

.btn-donate-footer {
  margin-top: 30px;
  display: flex;
  position: relative;
  gap: 10px;
  align-items: center;
}

.btn-donate-footer::after {
  content: " ";
  position: relative;
  display: inline-block;
  width: 14px;
  height: 14px;
  background-image: url(assets/images/icons/icon-seta-branca.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.5s;
  right: 0;
}

.btn-donate-footer:hover::after {
  transform: translate(5px, -5px);
}

.footer-container {
  max-width: 1820px;
  margin: 0 auto;
  position: relative;
}

.back-to-top {
  position: absolute;
  top: -25px;
  right: 50px;
  background-color: transparent;
  cursor: pointer;
  border: none;
  height: 55px;
  width: 55px;
  transition: all 0.2s;
}

.back-to-top>img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}

.back-to-top:hover {
  scale: 1.1;
}

.footer-content {
  background-color: #fff;
  border-radius: 15px;
  padding: 50px;
  background-image: url(assets/images/mask/mask-footer-bottom.svg);
  background-repeat: no-repeat;
  background-position: bottom right;
}

.footer-pdf {
  position: relative;
  transition: all 0.2s;
  display: flex;
  gap: 5px;
  align-items: center;
  flex-wrap: wrap;
  text-wrap: nowrap;
}

.footer-pdf:after {
  content: "PDF";
  color: #073244;
  font-size: 11px;
  font-style: normal;
  font-weight: 500;
  line-height: 14px;
  letter-spacing: 0.44px;
  padding: 4px 9px;
  border-radius: 6px;
  background-color: #ccdfe4;
  display: inline-block;
  transition: all 0.2s;
}

.footer-pdf:hover::after {
  background-color: #127199ff;
}

.footer-grid {
  display: grid;
  grid-template-columns: 222px 18% 15% 12% 15%;
  gap: 5%;
}

.footer-title,
.contacts-info h2 {
  font-size: 14px;
  font-family: "Poppins", sans-serif;
  font-weight: 600;
  line-height: 20px;
  /* 142.857% */
  letter-spacing: 0.14px;
  text-transform: uppercase;
  margin-bottom: 8px;
  font-style: normal;
}

.footer-menu>address {
  color: #073244;
  font-size: 14px;
  font-weight: 500;
  line-height: 22px;
  /* 157.143% */
  margin-bottom: 20px;
}

.footer-menu>h5 {
  color: #073244;
  font-size: 14px;
  font-weight: 700;
  line-height: 22px;
  /* 157.143% */
  margin-bottom: 5px;
}

.footer-menu>.menu {
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.footer-menu>.menu>li {
  all: unset;
}

.footer-menu>.menu>li {
  line-height: 130%;
}

.footer-menu>span,
.footer-contact>a,
.footer-menu>.menu a {
  color: #073244;
  font-size: 14px;
  font-weight: 500;
  line-height: 19px;
  /* 135.714% */
  transition: all 0.2s;
}

#menu-footer-informacoes .online a {
  position: relative;
  display: flex;
  gap: 7px;
  align-items: center;
}

#menu-footer-informacoes .online a::after {
  content: " ";
  position: relative;
  display: inline-block;
  width: 11px;
  height: 11px;
  background-image: url(assets/images/icons/icon-seta.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.footer-contact>a:hover,
.footer-menu>.menu a:hover {
  color: #127199ff;
}

.footer-menu>span {
  display: block;
  margin-bottom: 10px;
}

.footer-item {
  position: relative;
}

.footer-item::after {
  content: "";
  width: 1px;
  background-color: #b1cbd3;
  height: 100%;
  display: block;
  position: absolute;
  right: -10%;
  top: -5%;
}

.footer-bottom {
  display: flex;
  align-items: flex-end;
}

.footer-social-media {
  flex: 0 0 222px;
}

.footer-social-media a,
.socials-flex a {
  height: fit-content;
}

.footer-social-media img,
.socials-flex img {
  transition: all 0.2s;
}

.footer-social-media a:hover img,
.socials-flex a:hover img {
  transform: scale(1.1);
}

#menu-footer-legal {
  display: flex;
  gap: 40px;
  margin: 0 40px 0 5%;
}

#menu-footer-legal>li>a {
  color: #9eb9c0;
  font-size: 11px;
  font-weight: 600;
  line-height: 12px;
  /* 109.091% */
  letter-spacing: 0.77px;
  text-transform: uppercase;
  transition: all 0.2s;
}

#menu-footer-legal>li>a:hover {
  color: #073244;
}

.footer-certification {
  position: relative;
  top: 15px;
}

.footer-blisq {
  display: block;
  margin-left: auto;
}

.footer-blisq:hover svg path {
  fill: #127199ff;
  opacity: 1;
}

.footer-contact-secondary {
  display: none;
}

/* Header */
#nav-icon1 {
  display: none;
}

header {
  background-color: #eaf2f4;
  filter: drop-shadow(0px 4px 24.5px rgba(0, 0, 0, 0.06));
  border-radius: 0 0 35px 35px;
  position: relative;
  z-index: 5;
}

.header-container {
  max-width: 1642px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header-navigation .menu {
  display: flex;
  gap: 20px;
}

.header-navigation-top {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 20px;
  margin-bottom: 15px;
}

.header-bottom-tools,
.header-navigation-bottom {
  display: flex;
  align-items: baseline;
  gap: 15px;
}

.header-navigation-bottom .btn-primary:hover {
  background-color: #c3dce2;
  color: #083344;
}

#menu-menu-header-top {
  padding-top: 20px;
}

ul#menu-menu-header-bottom>li {
  padding-bottom: 30px;
}

#menu-menu-header-top>li>a {
  color: #2b5667;
  font-size: 13px;
  font-weight: 400;
  line-height: 154%;
  letter-spacing: 0.65px;
  display: flex;
  align-items: center;
  gap: 6px;
  text-transform: uppercase;
  transition: all 0.2s;
}

#menu-menu-header-top>li>a:hover {
  color: #083344;
}

#menu-menu-header-top>li.menu-item-faq>a::before {
  content: "";
  width: 20px;
  height: 20px;
  background-image: url(assets/images/icons/icon-menu-faq.svg);
  border-radius: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.2s;
}

#menu-menu-header-top>li.menu-item-faq>a:hover::before {
  background-image: url(assets/images/icons/icon-menu-faq-hover.svg);
}

#menu-menu-header-top>li.menu-item-online>a {
  color: #083344;
  font-weight: 700;
}

#menu-menu-header-top>li.menu-item-online>a:hover {
  color: #127199ff;
}

#menu-menu-header-top>li.menu-item-online>a::after {
  content: "";
  width: 12px;
  height: 12px;
  background-image: url(assets/images/icons/icon-seta.svg);
  background-repeat: no-repeat;
  background-size: contain;
  transition: all 0.2s;
}

#menu-menu-header-top>li.menu-item-online>a:hover::after {
  background-image: url(assets/images/icons/icon-seta-hover.svg);
}

#menu-menu-header-top>li:not(:last-child)>a {
  border-right: 1px solid #bed4da;
  padding-right: 20px;
}

#menu-menu-header-top>li.only-mobile {
  display: none;
}

#menu-menu-header-bottom>li>a {
  color: #073244;
  font-size: 15px;
  font-weight: 500;
  line-height: 187%;
  display: flex;
  align-items: center;
  gap: 5px;
}

#menu-menu-header-bottom>li.menu-item-has-children>a::after {
  content: "";
  height: 26px;
  width: 26px;
  background-image: url(assets/images/icons/icon-menu.svg);
  background-repeat: no-repeat;
  background-size: contain;
  border-radius: 50%;
}

.header-search.only-mobile {
  display: none;
}

.header-search-input {
  width: 100%;
  height: 46px;
  border-radius: 82px;
  border: none;
  background-color: #c3dce2;
  padding: 8px 8px 8px 45px;
  background-image: url(assets/images/icons/icon-pesquisar.svg);
  background-size: 34px;
  background-position: 6px;
  background-repeat: no-repeat;
}

.header-search-input::-webkit-search-cancel-button,
.search-bar::-webkit-search-cancel-button {
  -webkit-appearance: none;
  background-color: transparent;
  width: 26px;
  height: 26px;
  background-image: url("assets/images/icons/close.svg");
  background-size: contain;
  opacity: 0;
  transition: opacity 0.3s ease;
  position: absolute;
  right: 10px;
  top: 10px;
  cursor: pointer;
}

.search-bar::-webkit-search-cancel-button {
  right: 120px;
}

.header-search-input:not(:placeholder-shown)::-webkit-search-cancel-button,
.search-bar:not(:placeholder-shown)::-webkit-search-cancel-button {
  opacity: 1;
}

.header-search-input::-moz-search-cancel-button,
.search-bar::-moz-search-cancel-button {
  background-color: transparent;
  width: 26px;
  height: 26px;
  opacity: 0;
  transition: opacity 0.3s ease;
  position: absolute;
  right: 10px;
  top: 10px;
  cursor: pointer;
}

.search-bar::-moz-search-cancel-button {
  right: 120px;
}

.header-search-input:not(:placeholder-shown)::-moz-search-cancel-button,
.search-bar:not(:placeholder-shown).search-bar::-moz-search-cancel-button {
  opacity: 1;
}

.header-search-input::placeholder {
  color: #083344;
  font-family: "Poppins", sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 133.333%;
}

.header-donation {
  color: #083344;
  font-size: 14px;
  font-weight: 700;
  line-height: 143%;
  letter-spacing: 0.7px;
  text-transform: uppercase;
  background: linear-gradient(90deg, #127199ff 69%, #205e6e 126.16%);
  border-radius: 0px 0px 22px 22px;
  padding: 25px 20px 10px 20px;
  display: flex;
  gap: 5px;
  position: relative;
  top: -3px;
  transition: all 0.2s;
}

.header-donation:hover {
  top: 0;
}

.header-donation>span {
  color: #fff;
  display: flex;
  gap: 5px;
}

.header-donation>span::before {
  content: "-";
  color: #568295;
  font-size: 14px;
  font-weight: 400;
}

.header-donation>span::after {
  content: "";
  height: 20px;
  width: 20px;
  background-image: url(assets/images/icons/icon-doar.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.menu .menu-item-has-children:focus-within .sub-menu,
.menu .menu-item-has-children:hover .sub-menu {
  opacity: 1;
  visibility: visible;
  display: block;
}

.menu>li {
  position: relative;
}

.menu .sub-menu {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  background-color: #fff;
  border-radius: 15px;
  padding: 27px 30px;
  width: 302px;
  top: 40px;
  transition: all 0.5s;
}

.menu .sub-menu::before {
  content: " ";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 15px;
  background-color: #c3dce2;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.menu .sub-menu a {
  color: #16485d;
  font-size: 14px;
  font-weight: 500;
  line-height: 135.714%;
  transition: all 0.2s;
  left: 0;
  position: relative;
  display: block;
}

.menu .sub-menu a:hover {
  color: #073244;
  left: 10px;
}

.menu .sub-menu li {
  padding: 9px 0;
  border-bottom: 1px solid #b4cdd3;
  transition: all 0.2s;
}

.menu .sub-menu li:hover {
  border-bottom: 1px solid #083344;
}

.menu .sub-menu li,
.menu .sub-menu a {
  width: 100%;
}

.search-mobile-button {
  width: 30px;
  height: 30px;
  background-image: url(assets/images/icons/lupa.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  display: none;
  border-radius: 50px;
}

/* 404 */
.page-not-found {
  padding: 160px 0 80px 0;
  position: relative;
  margin-top: -30px;
}

.page-not-found::before,
.page-not-found::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
  height: 150%;
}

.page-not-found::before {
  background-image: url(assets/images/mask/mask-404-l.svg);
  background-position: left;
}

.page-not-found::after {
  background-image: url(assets/images/mask/mask-404-r.svg);
  background-position: right;
}

.container-buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

/* Breadcrumb */
.breadcrumb {
  margin-bottom: 30px;
  padding-top: 30px;
}

.breadcrumb-section {
  margin-top: -30px;
}

.breadcrumb>li,
.breadcrumb {
  display: flex;
  gap: 9px;
  align-items: center;
  flex-wrap: wrap;
}

.breadcrumb>li,
.breadcrumb a {
  color: #083344;
  font-size: 13px;
  font-weight: 500;
  line-height: 16px;
  /* 92.308% */
  transition: all 0.2s;
}

.breadcrumb.breadcrumb-white>li,
.breadcrumb.breadcrumb-white a {
  color: #fff;
}

.breadcrumb a:hover {
  opacity: 0.5;
}

.breadcrumb-home {
  height: 14px;
  width: 14px;
  background-image: url(assets/images/icons/icon-home.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
}

.breadcrumb.breadcrumb-white>li:not(:last-child)::after,
.breadcrumb-white .breadcrumb-home {
  filter: brightness(0) invert(1);
}

.breadcrumb-home:hover {
  filter: opacity(0.5);
}

.breadcrumb>li:not(:last-child)::after {
  content: "";
  height: 5px;
  width: 5px;
  background-image: url(assets/images/icons/icon-breadcrumb.svg);
  background-size: contain;
  background-repeat: no-repeat;
  display: block;
}

/* Blog */
.btns-navigations {
  position: absolute;
  top: 20px;
  right: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.btn-navigation {
  border: none;
  width: 40px;
  aspect-ratio: 1;
  height: 100%;
  border-radius: 50%;
  background-image: url(assets/images/icons/icon-nav.svg);
  background-repeat: no-repeat;
  background-size: contain;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-navigation:hover {
  scale: 1.05;
}

.btn-navigation.btn-prev {
  rotate: -180deg;
}

.single-post-articles,
.single-post-services {
  overflow-x: hidden;
}

.single-banner-image {
  aspect-ratio: 8 / 3;
  height: 100%;
  width: 100%;
  object-fit: cover;
  border-radius: 15px;
}

.blog-banner {
  padding: 215px 0 40px 0;
}

.blog-author-content {
  display: flex;
  flex-direction: column;
  padding-top: 5px;
}

.blog-content p strong {
  color: #083344;
  font-size: 19px;
  font-weight: 600;
  line-height: 157.895%;
}

.blog-author {
  display: flex;
  gap: 20px;
}

.blog-author-message {
  color: #083344;
  font-size: 12px;
  font-weight: 500;
  line-height: 19px;
  margin-top: auto;
}

.blog-author-image {
  background: linear-gradient(180deg,
      rgba(223, 236, 239, 0) 0%,
      #d7e5e9 65.99%);
  display: flex;
  width: 120px;
  height: 100%;
  aspect-ratio: 1;
}

.blog-author-image>img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.blog-author-message>a {
  text-decoration-line: underline;
}

.blog-author-content>small {
  color: #127199ff;
  font-size: 12px;
  font-weight: 700;
  line-height: 83.333%;
  text-transform: uppercase;
  margin-bottom: 20px;
  display: block;
}

.blog-author-role {
  color: #6e8f9d;
  font-size: 16px;
  font-weight: 400;
  line-height: 20px;
  /* 125% */
}

.blog-author-name {
  color: #073244;
  font-size: 17px;
  font-weight: 600;
  line-height: 135.294%;
  letter-spacing: -0.17px;
  text-transform: none;
}

.blog-tags {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding-bottom: 15px;
  border-bottom: 1px solid #175f71;
  margin-bottom: 20px;
  margin-top: 30px;
}

.blog-tag {
  color: #175f71;
  font-size: 12px;
  font-weight: 500;
  line-height: 19px;
  /* 158.333% */
}

.blog-tag-items {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
}

.blog-tag-item {
  border-radius: 8px;
  background: #ccdfe4;
  padding: 3px 11px;
}

.blog-tag-item a {
  color: #073244;
  font-size: 14px;
  font-weight: 500;
  line-height: 135.714%;
}

.search-container {
  margin-top: 30px;
}

.search-form {
  display: flex;
  width: 100%;
  gap: 25px;
}

.search-bar-container {
  position: relative;
  flex: 1;
}

.search-bar {
  width: 100%;
  border-radius: 65px;
  background-color: #fff;
  height: 45px;
  border: none;
  padding: 0 115px 0 50px;
  background-image: url(assets/images/icons/icon-pesquisar-2.svg);
  background-size: 20px;
  background-position: 15px;
  background-repeat: no-repeat;
}

.search-bar::placeholder,
.search-bar {
  font-family: "Poppins", sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 114.286%;
  color: #073244;
}

.search-bar::placeholder {
  color: #93a1a7;
}

.search-button {
  color: #eef5f7;
  text-align: center;
  font-size: 13px;
  font-weight: 500;
  line-height: 153.846%;
  padding: 8px 20px;
  border-radius: 62px;
  background-color: #083344;
  position: absolute;
  right: 5px;
  top: 5px;
  cursor: pointer;
  transition: all 0.2s;
}

.search-button:hover {
  background-color: #2b5667;
}

.blog-content>p {
  margin-bottom: 15px;
  color: rgba(8, 51, 68, 0.8);
  text-wrap: pretty;
}

.blog-content>div>p {
  color: rgba(8, 51, 68, 0.8);
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 187.5%;
}

.blog-content>div {
  margin-top: 30px;
}

.gallery-item~br {
  display: none !important;
}

.gallery-icon>a {
  pointer-events: none;
}

.gallery-icon img {
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 16 / 9;
  border-radius: 15px;
}

.single-post .gallery {
  margin: 0 -75px;
}

.single-post .gallery-caption {
  margin: 10px 0 20px 75px;
  color: #859ba3;
  font-size: 13px;
  font-weight: 500;
  line-height: 22px;
  /* 169.231% */
}

.slick-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  font-size: 0;
  background-image: url(assets/images/icons/icon-carousel.svg);
  height: 40px;
  width: 40px;
  border-radius: 50%;
  border: none;
  filter: drop-shadow(0px 0px 47.5px rgba(0, 0, 0, 0.25));
  cursor: pointer;
}

.slick-prev {
  left: 20px;
  scale: -1;
  transform-origin: top;
}

.slick-next {
  right: 20px;
}

.single-post-services {
  padding: 80px 0 40px 0;
}

/* Centro de Genética e Reprodução */
#the-center {
  padding: 100px 0;
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: -50px;
  position: relative;
}

.center-gallery {
  background: linear-gradient(180deg,
      rgba(227, 240, 244, 0) 6.29%,
      #d5e2e6 100%);
  padding-bottom: 100px;
}

.center-gallery-items {
  margin-top: 35px;
}

.center-gallery-items img {
  border-radius: 20px;
  margin-right: 20px;
  aspect-ratio: 7 / 5;
  max-height: 405px;
  object-fit: cover;
}

/* Equipa */
#team {
  margin: 60px 0 100px 0;
}

.team-card {
  display: flex;
  flex-direction: column;
}

.team-card:hover .btn-more {
  color: #9db9c0;
}

.team-card:hover .btn-more::after {
  background-image: url(assets/images/icons/icon-saber-mais-hover.svg);
}

.team-card-image {
  background-image: url(assets/images/mask/mask-equipa.webp);
  background-repeat: no-repeat;
  background-size: contain;
  display: flex;
  position: relative;
}

.team-card-image::after {
  content: " ";
  position: absolute;
  bottom: -3px;
  left: 2px;
  width: 100%;
  height: 100%;
  display: block;
  background: linear-gradient(180deg, rgba(223, 236, 239, 0) 50%, #d7e5e9 100%);
  mask-image: url(assets/images/mask/mask-black-equipa.svg);
  mask-repeat: no-repeat;
  mask-size: cover;
  mix-blend-mode: multiply;
  opacity: 0;
  transition: all 0.2s;
}

.team-card:hover .team-card-image::after {
  opacity: 1;
}

.team-card-image>img {
  mask-image: url(assets/images/mask/mask-black-equipa.svg);
  mask-repeat: no-repeat;
  mask-size: cover;
  position: relative;
  top: 2px;
  right: -2px;
}

.team-card-name {
  color: #073244;
  font-size: 16px;
  font-weight: 600;
  line-height: 139%;
  letter-spacing: 0;
  margin: 10px 0;
  text-transform: none;
  font-style: normal;
  font-family: 'Poppins', sans-serif;
}

.team-card-specialty {
  color: #40616f;
  font-size: 14px;
  font-weight: 400;
  line-height: 142.857%;
  margin-bottom: 30px;
  font-family: 'Poppins', sans-serif;
  font-style: normal;
}

/* Single Equipa */
.single-team-banner {
  background-color: #e0ecf0;
  position: relative;
}

.single-team-banner::before {
  content: "";
  width: 100%;
  height: 170px;
  position: absolute;
  bottom: -1px;
  left: 0;
  display: block;
  background-image: url(assets/images/mask/mask-single-equipa.svg);
  background-size: cover;
  z-index: 1;
  pointer-events: none;
}

.single-team-banner::after {
  content: "";
  width: 25%;
  aspect-ratio: 1;
  position: absolute;
  top: -50%;
  right: 0;
  display: block;
  background-image: url(assets/images/mask/mask-before-banner-single-equipa.svg);
  background-repeat: no-repeat;
  background-size: cover;
  z-index: 0;
}

.single-team-image {
  position: relative;
  margin-left: 5%;
}

.single-team-image::before {
  content: "";
  position: absolute;
  left: -30%;
  bottom: 0;
  aspect-ratio: 2 / 1;
  width: 100%;
  display: block;
  background-image: url(assets/images/mask/mask-before-single-equipa.svg);
  background-size: contain;
}

.single-team-image>img {
  object-fit: contain;
}

.single-team-grid {
  display: grid;
  grid-template-columns: 24% 1fr;
  gap: 25px;
  margin-left: 5%;
}

.single-team-intro {
  max-width: 800px;
  position: relative;
  z-index: 1;
  padding-bottom: 20px;
}

.single-team-intro>h1 {
  margin-bottom: 20px;
}

.single-team-intro>p:not(:last-child) {
  margin-bottom: 15px;
}

.single-team-intro>p>strong {
  color: #127199ff;
  font-weight: 500;
}

.single-team-content {
  padding: 60px 0 100px 0;
}

.single-team-aside {
  margin-left: -20%;
  max-width: 280px;
  top: 20px;
  height: fit-content;
  position: sticky;
}

.single-team-aside>h2 {
  color: #083344;
  font-family: "Poppins";
  font-size: 28px;
  font-weight: 600;
  line-height: 107.143%;
  font-style: normal;
}

.single-team-aside>h3 {
  text-transform: none;
  letter-spacing: normal;
  color: #127199ff;
  font-family: 'Poppins';
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 24px;
  /* 150% */
}

.single-team-aside>p {
  margin-bottom: 20px;
  padding-bottom: 20px;
  font-size: 15px;
  border-bottom: 1px solid #175f71;
}

.box-content {
  border-radius: 15px;
  border: 1px solid #175f71;
  padding: 40px;
  margin-bottom: 25px;
  transition: all 0.2s;
}

.box-content:hover {
  background-color: #e0ecf0;
  border: 1px solid #e0ecf0;
}

.box-content>ul {
  list-style: disc;
  padding-left: 20px;
}

.vision {
  background-image: url(assets/images/vision-before.svg);
  background-repeat: no-repeat;
  background-size: 900px 100%;
  background-position: 80px;
}

/* Select */
.custom-select-container {
  width: 255px;
  position: relative;
}

.custom-select-container>label {
  color: #083344;
  font-size: 9px;
  font-weight: 400;
  line-height: 10px;
  /* 111.111% */
  position: absolute;
  top: 9px;
  left: 20px;
  z-index: 1;
}

.custom-select {
  border-radius: 65px;
  background: #fff;
  height: 45px;
  width: 100%;
  position: relative;
  display: flex;
  cursor: pointer;
}

.custom-select .list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.custom-select>span {
  padding: 20px 20px 20px 0;
  color: #4d5f67;
  font-size: 13px;
  font-weight: 400;
  line-height: 16px;
  /* 123.077% */
  padding-top: 20px;
}

.nice-select:after {
  all: unset;
  content: "";
  display: block;
  height: 18px;
  width: 18px;
  pointer-events: none;
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
  background-image: url(assets/images/icons/icon-select.svg);
  background-size: contain;
  background-repeat: no-repeat;
  transition: all 0.2s;
}

.nice-select .option {
  text-wrap: auto;
  line-height: 25px;
}

.nice-select.open:after {
  -webkit-transform: translateY(-50%) rotate(-135deg);
  -ms-transform: translateY(-50%) rotate(-135deg);
  transform: translateY(-50%) rotate(180deg);
}

/* Search */
.search-title {
  display: flex;
  gap: 5px;
  margin-bottom: 10px;
}

.search-title>span {
  color: #083344;
  font-size: inherit;
  font-weight: 600;
  line-height: 116.216%;
}

.searched-item {
  margin: 20px 0;
  padding-bottom: 20px;
  border-bottom: 1px solid #175f71;
}

.searched-item-label {
  color: #073244;
  font-size: 12px;
  font-weight: 700;
  line-height: 12.44px;
  /* 103.67% */
  letter-spacing: 0.48px;
  text-transform: uppercase;
  border-radius: 5px;
  background: #70cae1;
  padding: 8px;
  display: flex;
  align-items: center;
  width: fit-content;
  margin-bottom: 7px;
}

.searched-title {
  color: #083344;
  font-size: 26px;
  font-family: "Poppins";
  font-style: normal;
  font-weight: 600;
  line-height: 139%;
  margin-bottom: 7px;
}

.searched-item>p {
  color: #083344;
  font-size: 14px;
  font-weight: 400;
  line-height: 170%;
  /* 23.8px */
}

/* Frontpage Hero */
#frontpage-hero {
  position: relative;
  background: linear-gradient(to top, rgba(229, 242, 246, 0) 0%, #d7ebf1 100%);
  min-height: calc(80vh + 30px);
  display: flex;
  align-items: center;
  padding: 135px 0 175px;
  position: relative;
  margin-top: -30px;
}

#frontpage-hero .container {
  width: 100%;
}

.frontpage-hero-image {
  position: absolute;
  top: -105px;
  right: 0;
  width: 85%;
  height: auto;
  z-index: 1;
  pointer-events: none;
  z-index: 4;
}

.frontpage-hero-content h1 span {
  margin-top: 5px;
}

.frontpage-hero-content {
  max-width: 380px;
  position: relative;
  z-index: 1;
}

.frontpage-hero-content>span {
  color: #073244;
  font-size: 30px;
  font-weight: 500;
  line-height: 38px;
}

#frontpage-list {
  position: relative;
  background: linear-gradient(to bottom, #ffffff, #eef5f7);
}

#frontpage-list::before {
  content: "";
  position: absolute;
  top: -175%;
  left: 0;
  background-image: url(assets/images/mask/mask-hero.svg);
  background-repeat: no-repeat;
  width: 1715px;
  height: 810px;
  pointer-events: none;
  z-index: 1;
}

.frontpage-hero-lists {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;
  position: relative;
  z-index: 1;
}

.frontpage-hero-list {
  color: #073244;
  font-size: 14px;
  font-weight: 500;
  line-height: 18px;
  /* 133.171% */
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 10px;
  background-color: #dfecef;
  position: relative;
  padding: 12px 18px;
  flex: 0 0 365px;
}

.frontpage-hero-list:last-child {
  flex: 0 0 55%;
}

.frontpage-hero-list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  height: 100%;
  width: 6px;
  background-color: #127199ff;
  border-radius: 10px;
}

/* Frontpage FAQ */
#frontpage-faq {
  padding: 100px 0;
  position: relative;
  z-index: 3;
}

.frontpage-faq-items {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.service-item,
.frontpage-faq-item {
  color: #073244;
  font-size: 16px;
  font-weight: 500;
  line-height: 143.75%;
  padding: 20px;
  display: flex;
  flex-direction: column;
  background-color: #e0ecf0;
  flex: 0 0 255px;
  transition: all 0.2s;
  min-height: 137px;
}

.service-item{
  justify-content: space-between;
}

.frontpage-faq-item:hover {
  background-color: #fff;
}

.service-item::after,
.frontpage-faq-item::after {
  content: "";
  height: 40px;
  width: 40px;
  aspect-ratio: 1;
  border-radius: 50%;
  background-image: url(assets/images/icons/icon-faq.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin-top: 10px;
  align-self: flex-end;
}

.frontpage-faq-item::after {
  margin-top: auto;
}

/* Frontpage Blog */
#frontpage-blog {
  padding: 110px 0 80px 0;
}

.blog-card:hover img {
  scale: 1.1;
}

.blog-card:hover .btn-more::after {
  transform: translateX(10px);
}

.blog-figure {
  aspect-ratio: 2;
  overflow: hidden;
}

.blog-figure>img {
  transition: all 0.2s;
}

.blog-item {
  padding: 20px 15px 15px 15px;
}

.blog-content-time,
.blog-content-date {
  color: #3b4c51;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.2;
  display: flex;
  align-items: center;
  gap: 6px;
}

.blog-content-time::before,
.blog-content-date::before {
  content: "";
  width: 12px;
  height: 12px;
  aspect-ratio: 1;
  background-repeat: no-repeat;
  background-size: contain;
}

.blog-content-date::before {
  background-image: url(assets/images/icons/icon-calendario.svg);
}

.blog-content-time::before {
  background-image: url(assets/images/icons/icon-tempo.svg);
}

.blog-card-title {
  margin: 8px 0 16px 0;
  color: #073244;
  font-size: 15px;
  font-weight: 500;
  line-height: 140%;
  font-family: 'Poppins', sans-serif;
  font-style: normal;
  letter-spacing: normal;
  text-transform: none;
}

.blog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 15px;
  margin: 25px 0 20px 0;
}

/* Blog */
.single-banner {
  padding-top: 45px;
  background-image: url(assets/images/mask/mask-blog.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

/* Faq */
.faq-icon-before::before {
  content: "";
  background-image: url(assets/images/icons/icon-faq-before.svg);
  height: 46px;
  width: 46px;
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  margin: 0 auto 10px auto;
}

.faq-btn-donate {
  float: right;
  border-radius: 82px;
  background: linear-gradient(93deg, #127199ff 2.51%, #205e6e 255.36%);
  padding: 12px 20px;
  color: #eef5f7;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
  /* 142.857% */
  display: flex;
  gap: 10px;
  margin-top: -35px;
}

.faq-btn-donate::after {
  content: "";
  height: 20px;
  width: 20px;
  background-image: url(assets/images/icons/icon-doar.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.faq-item {
  margin: 15px 0;
}

.faq-block {
  margin-bottom: 30px;
}

.faq-title {
  padding: 18px 20px;
  background-color: #e0ecf0;
  cursor: pointer;
  transition: all 0.2s;
  border-left: 7px solid transparent;
}

.faq-title.open,
.faq-title:hover {
  border-color: #127199ff;
}

.faq-title>h3 {
  all: unset;
  color: #073244;
  font-size: 16px;
  font-weight: 500;
  line-height: 143.75%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.faq-title>h3::after {
  content: "";
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(assets/images/icons/icon-faq.svg);
  rotate: 90deg;
  transition: all 0.2s;
}

.faq-title.open>h3::after {
  rotate: -90deg;
}

.faq-content {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  padding: 0 10px;
}

.faq-title.open~.faq-content {
  max-height: 500px;
  opacity: 1;
  transform: translateY(0);
  padding: 10px;
}

.faq-content p {
  line-height: 177%;
}

.faq-content p>a {
  text-decoration: underline;
  color: #2b5667;
  transition: all .2s;
}

.faq-content p>a:hover {
  color: #073244;
}

.cta-contact {
  margin-top: 80px;
  border-radius: 15px;
  background: linear-gradient(180deg,
      #e0ecf0 36.17%,
      rgba(224, 236, 240, 0) 100%);
  padding: 40px;
  position: relative;
}

.cta-contact::before {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  background-color: #175f71;
  position: absolute;
  top: -40px;
  left: 0;
}

.page-template-page-precario #cta-booking {
  background-color: #11465b;
  padding-bottom: 50px;
}

.page-template-page-apoio-psicologico #cta-booking {
  background-color: #3EB6D4;
}

.page-template-page-precario footer {
  background-color: #11465b;
}

.page-template-page-apoio-psicologico footer {
  background-color: #3EB6D4;
}

.page-template-page-precario #cta-booking::before,
.page-template-page-apoio-psicologico #cta-booking::before {
  display: none;
}

#cta-booking {
  padding-top: 100px;
  position: relative;
}

#cta-booking::before {
  content: "";
  background-image: url(assets/images/mask/mask-faq-contacto.webp);
  background-repeat: no-repeat;
  background-size: cover;
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  bottom: 0;
  left: 0;
  mix-blend-mode: soft-light;
}

.cta-booking-grid {
  border-radius: 15px;
  background-color: #083344;
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.cta-booking-content {
  padding: 80px;
}

.cta-booking-text {
  color: rgba(255, 255, 255, 0.70);
  font-weight: 400;
}

.cta-booking-image {
  overflow: hidden;
  border-radius: 0 15px 15px 0;
}

/* Tratamento */

.treatment {
  margin-top: 40px;
}

.treatment-item {
  display: flex;
  min-height: 165px;
}

.treatment-item:hover .btn-more::after {
  transform: translateX(10px);
}

.treatment-item>img {
  flex: 0 0 250px;
  height: 100%;
  width: 250px;
  object-fit: cover;
  border-top-left-radius: 15px;
  border-bottom-left-radius: 15px;
}

.treatment-item-content {
  padding: 20px 30px;
  background-color: #fff;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* border-top-right-radius: 15px;
  border-bottom-right-radius: 15px; */
  border-radius: 15px;
}

.treatment-item-title {
  color: #073244;
  font-size: 19px;
  font-weight: 500;
  line-height: 136.842%;
  text-transform: none;
  letter-spacing: normal;
}

.treatment-process {
  padding: 130px 0 140px 0;
  background-color: #e0ecf0;
  position: relative;
}

.treatment-process::before {
  content: " ";
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 168px;
  background-image: url(assets/images/mask/mask-top.svg);
  background-repeat: no-repeat;
  background-position: center;
}

.treatment-process::after {
  content: " ";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 168px;
  background-image: url(assets/images/mask/mask-bottom.svg);
  background-repeat: no-repeat;
  background-position: center;
}

.treatment-process-list {
  margin-top: 80px;
  display: flex;
  flex-direction: column;
  gap: 25px;
  position: relative;
}

.treatment-process-list::before {
  content: " ";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: 100%;
  width: 2px;
  background-color: #073244;
  top: -50px;
  border-radius: 50%;
}

.treatment-process-card {
  background-color: #eef5f7;
  border-radius: 15px;
  padding: 40px;
  z-index: 2;
}

.treatment-process-card p {
  color: rgba(8, 51, 68, 0.8);
  font-size: 16px;
  font-weight: 400;
  line-height: 187.5%;
}

.treatment-process-description>p {
  font-size: 18px;
  color: #175f71;
  font-weight: 400;
}

.treatment-process-description>ul,
.treatment-process-description>ol {
  margin: 10px 0;
  padding-left: 20px;
}

.treatment-process-description li {
  color: #175f71 !important;
  font-weight: 500 !important;
}

.process-card {
  padding: 20px;
  border-radius: 15px;
  background: #fff;
  display: flex;
  flex-direction: column;
}

.process-card>h3 {
  color: #073244;
  font-size: 17px;
  font-weight: 500;
  line-height: 135.294%;
  text-transform: capitalize;
  margin-bottom: 30px;
  letter-spacing: normal;
  font-style: normal;
  font-family: 'Poppins', sans-serif;
}

.treatment-details {
  padding: 40px 0 82px 0;
}

.treatment-details .container {
  display: flex;
  flex-direction: column;
  gap: 80px;
}

.treatment-detail {
  display: flex;
  justify-content: space-between;
  gap: 40px;
  align-items: center;
}

.treatment-detail-images {
  width: 46%;
}

.treatment-detail-images .image-caption {
  color: #5a6f77;
  font-size: 13px;
  font-weight: 500;
  line-height: 169.231%;
  margin-top: 10px;
}

.treatment-detail-images .slick-list {
  /* height: 420px; */
  border-radius: 15px;
}

/* .treatment-detail-images .slick-track {
  height: 100%;
} */

.video-slide > video{
  height: 100%;
  width: 100%;
  display: flex;
}

.treatment-detail-content {
  width: 37%;
}

.treatment-detail-content p {
  font-weight: 400;
  color: rgba(8, 51, 68, 0.8);
  line-height: 187.5%;
}

.treatment-detail-content p > a{
  text-decoration: underline;
}

.treatment-detail-content li{
  color: rgba(8, 51, 68, 0.8) !important;
}

.treatment-detail-content ul {
  list-style: disc;
  padding-left: 20px;
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.treatment-detail-images img {
  width: 100%;
  object-fit: cover;
  border-radius: 15px;
  height: 100%;
  aspect-ratio: 15 / 9;
  position: relative;
}

.treatment-video {
  aspect-ratio: 16 / 9;
  width: 100%;
  border-radius: 15px;
  object-fit: cover;
}

/* Frontpage Sobre Nós */
#frontpage-aboutus {
  padding: 90px 0;
}

#frontpage-aboutus .dark-blue-text-content p:first-child {
  margin-bottom: 15px;
}

.fronpage-aboutus-right {
  padding-left: 10%;
}

.fronpage-aboutus-right>p {
  margin-bottom: 20px;
}

/* Frontpage Testemunhos */
#frontpage-testimonials {
  padding: 70px 0;
  position: relative;
}

#frontpage-testimonials::before {
  content: "";
  position: absolute;
  bottom: -50px;
  left: 0;
  top: 0;
  right: 0;
  background-image: url(assets/images/mask/mask-testemunhos.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom;
  pointer-events: none;
  z-index: 0;
}

.testimonials-items {
  margin-top: 60px;
}

.testimonials-items>.slick-list {
  overflow: visible;
}

.testimonial-item {
  background-color: #073244;
  padding: 40px;
  min-height: 465px;
  gap: 20px;
  display: flex !important;
  flex-direction: column;
  margin: 0 10px;
  transition: all 1s;
  position: relative;
}

.testimonial-item>p {
  color: #eef5f7;
  font-size: 15px;
  font-weight: 300;
  line-height: 167%;
}

.testimonial-item>p strong {
  font-weight: 700;
}

.testimonial-item>p:first-child::before {
  content: "";
  background-image: url(assets/images/icons/icon-testemunho.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 36px;
  height: 30px;
  display: block;
  margin-bottom: 10px;
}

.testimonial-item:nth-child(odd) {
  transform: translateY(130px);
}

.testimonial-author {
  display: block;
  color: #3eb6d4;
  font-size: 13px;
  font-weight: 700;
  line-height: 176.923%;
  margin-top: auto;
}

/* Frontpage Preservar */
#frontpage-preserve {
  padding: 100px 0;
  position: relative;
  background-image: url(assets/images/mask/mask-preservar-o-futuro.webp);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: bottom;
  z-index: 1;
  position: relative;
  overflow: hidden;
}

#frontpage-preserve::after {
  content: "";
  background-image: url(assets/images/mask/mask-figure-preservar-o-futuro.svg);
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  aspect-ratio: 4 / 3;
  position: absolute;
  bottom: -1px;
  right: 15%;
  width: 450px;
  transform: rotateZ(-94deg);
  transform-origin: bottom center;
  transition: transform 2.6s ease;
}

#frontpage-preserve.active::after {
  transform: rotateZ(0);
}

.frontpage-preserve-left {
  max-width: 375px;
}

.frontpage-preserve-items {
  margin-top: 55px;
}

.frontpage-preserve-content>h4 {
  max-width: 228px;
  color: #eef5f7;
  font-size: 17px;
  font-weight: 500;
  line-height: 141.176%;
}

.frontpage-preserve-content {
  padding: 16px 0 12px 0;
  border-bottom: 1px solid #2b5667;
  display: flex;
  align-items: baseline;
  justify-content: space-between;
}

.frontpage-preserve-content:hover .btn-more::after {
  transform: translateX(10px);
}

/* Frontpage Tratamentos */
#frontpage-treatment {
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}

.frontpage-treatment-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 105%;
  object-fit: cover;
  pointer-events: none;
}

.frontpage-treatment-video:focus {
  outline: none;
}

#frontpage-treatment .container-sm-secondary {
  z-index: 3;
  position: relative;
}

.frontpage-treatment-items {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 30px;
  z-index: 3;
  position: relative;
}

.frontpage-treatment-item {
  min-height: 220px;
  flex: 0 0 260px;
}

.frontpage-treatment-item>a {
  padding: 20px;
  border-radius: 15px;
  background-color: #fff;
  color: #073244;
  font-size: 19px;
  font-weight: 500;
  line-height: 137%;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: all 0.2s;
  gap: 10px;
}

.frontpage-treatment-item>a:hover {
  background-color: #d1e1e4;
}

.frontpage-treatment-item>a:hover .btn-more::after {
  transform: translateX(10px);
}

/* Página: Contactos */
.contacts-intro {
  position: relative;
  padding-bottom: 136px;
}

.contacts-intro>img {
  position: absolute;
  top: -95px;
  right: 0;
}

.contacts-content {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}

.contacts-info-grid {
  display: flex;
  justify-content: space-between;
}

.contact-info-card:not(:first-child, :last-child) {
  padding: 0 96px;
}

.contact-info-card:first-child {
  padding-right: 96px;
}

.contact-info-card:last-child {
  padding-left: 96px;
}

.contact-info-card:not(:last-child) {
  border-right: 1px solid #175f71;
}

.contacts-info-grid span,
.contacts-info-grid a {
  color: #073244;
  font-size: 14px;
  font-weight: 500;
  line-height: 157.143%;
}

.contacts-info-grid a {
  display: block;
  padding: 2px 0;
}

.contact-timetable h3 {
  white-space: pre;
  color: #073244;
  font-size: 14px;
  font-weight: 700;
  line-height: 157.143%;
  font-style: normal;
  font-family: 'Poppins', sans-serif;
}

.contact-timetable-flex {
  display: flex;
  gap: 40px;
}

.socials-flex {
  display: flex;
  gap: 7px;
}

.contact-us .container-sm p {
  color: #073244;
}

.contact-us {
  padding: 70px 0 0 0;
}

.contact-us form {
  border-radius: 15px;
  background: linear-gradient(180deg,
      #e0ecf0 7.26%,
      rgba(224, 236, 240, 0) 85.04%);
  padding: 60px 70px 0 70px;
}

.contact-form-flex {
  width: 100%;
  display: flex;
  gap: 20px;
  justify-content: space-between;
}

.input-content {
  position: relative;
  width: 100%;
  margin-bottom: 24px;
}

.input-content label,
.input-label {
  color: #073244;
  font-size: 13px;
  font-weight: 500;
  line-height: 100%;
  background-color: #fff;
  border-radius: 4px;
  padding: 6px 9px;
  position: absolute;
  top: -12px;
  left: 19px;
  z-index: 1;
}

.input-content input[type="text"],
.input-content input[type="email"],
.input-content input[type="date"] {
  padding: 21px 28px 16px 28px;
  background-color: transparent;
  border-radius: 6px;
  border: 1px solid #97aeb5;
  width: 100%;
}

.input-content input[type="text"].error,
.input-content input[type="email"].error,
.input-content input[type="date"].error {
  border: 1px solid red;
}

.input-content.full input {
  width: 100%;
}

.input-content input::placeholder,
.input-content input,
.input-content input[type="date"] {
  color: rgba(7, 50, 68, 0.4);
  font-family: "Poppins", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 168.75%;
}

.input-content input {
  color: #073244;
}

.contact-custom-select {
  display: block;
  width: 100%;
  border-radius: 6px;
  background: transparent;
  height: 60px;
  display: flex;
  align-items: center;
  border: none;
  margin-bottom: 27px;
  padding-left: 30px !important;
  padding: 21px 28px 16px 28px; background-color: transparent; border-radius: 6px; border: 1px solid #97aeb5; width: 100%; 
}
.contact-custom-select.open {

  background: #fff;

}
.contact-custom-select li[data-value="option-disabled"] {
  display: none;
}

.contact-custom-select li {
  position: relative;
  display: flex;
  gap: 10px;
  align-items: center;
}

.contact-custom-select li::before {
  content: " ";
  position: relative;
  display: inline-block;
  left: 0;
  top: 0;
  width: 10px;
  height: 10px;
  border: 1px solid rgba(7, 40, 68, 0.6);
  border-radius: 50%;
}

.contact-custom-select li.selected::before {
  background-color: rgba(7, 40, 68, 0.6);
}

.contact-custom-select .list li:nth-child(odd) {
  background-color: #e0ecf0;
}

.contact-custom-select .list li:nth-child(even) {
  background-color: #eef5f7;
}

.contact-custom-select .list li:hover {
  background-color: #fff !important;
}

.contact-custom-select::after {
  background-image: url(assets/images/icons/icon-select-contact.svg);
  height: 40px;
  width: 40px;
}

.contact-custom-select .option {
	color: #073244;
    font-size: 16px;
    font-weight: 400;
    line-height: 192.857%;
    padding: 12px 15px;
}

.nice-select .list {
  width: 100%;
  padding: 10px 0;
}

.validations label {
  color: #073244;
  font-size: 13px;
  font-weight: 400;
  line-height: 123.077%;
  width: 95%;
}

.validations>div {
  display: flex;
  align-items: center;
  gap: 12px;
}

.validations label a {
  font-weight: 600;
}

.validations input[type="checkbox"] {
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid #083344;
  cursor: pointer;
}

.validations input[type="checkbox"].error {
  border: 1px solid red;
}

.validations input[type="checkbox"]:checked {
  background-color: #083344;
}

.contact-us input[type="submit"] {
  margin-top: 27px;
  cursor: pointer;
}
.contact-us input[type="submit"]:disabled,
.contact-us input[type="submit"][disabled]{
  background-color: #cccccc;
  color: #666666;
  pointer-events:none;
}
.maps-location {
  padding-top: 70px;
}

.maps-location .maps {
  padding: 100px 80px;
  border-radius: 15px;
  background-image: linear-gradient(90deg,
      #e0ecf0 16.33%,
      rgba(224, 236, 240, 0) 69.78%),
    url(assets/images/maps-block.webp);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.maps-location .wrapper {
  max-width: 273px;
}

.maps-location p {
  color: #073244;
}

.response-ajax {
  text-align: center;
  margin: 30px auto 0 auto;
}

.response-ajax.error p {
  color: red;
}

.loader {
  width: 48px;
  height: 48px;
  border: 5px solid #205e6e;
  border-bottom-color: transparent;
  border-radius: 50%;
  display: inline-block;
  box-sizing: border-box;
  animation: rotation 1s linear infinite;
}

@keyframes rotation {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

/* Página: Preçário */

.prices {
  padding-top: 70px;
}

.price-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-top: 30px;
}

.price-card {
  flex: 0 0 213px;
  background-color: #deebf0;
  padding: 18px 11px 18px 16px;
  min-height: 192px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  border-radius: 12.44px;
  box-shadow: 0px 0px 61.8px 0px rgba(255, 255, 255, 0.35);
}

.price-card h4 {
  color: #073244;
  font-family: "Lora", sans-serif;
  font-size: 14.928px;
  font-style: italic;
  font-weight: 400;
  line-height: 138.889%;
}

.price-card p {
  color: #586b73;
  font-size: 11.611px;
  font-weight: 400;
  line-height: 150%;
}

.price-obs {
  padding-top: 50px;
}

.price-obs-container {
  max-width: 734px;
  margin: 0 auto;
}

.price-obs-content>p {
  text-align: center;
  color: #405761;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.4;
}

.price-obs-content>p>strong {
  font-weight: 700;
}

.price-obs-content>p:not(:last-child) {
  margin-bottom: 20px;
}

.price-list .price {
  margin-top: auto;
  color: #073244;
  font-family: "Lora", sans-serif;
  font-size: 14.928px;
  font-style: italic;
  font-weight: 700;
  line-height: 100%;
}

.price-list .label {
  color: #073244;
  font-size: 9.952px;
  font-weight: 700;
  line-height: 125%;
  letter-spacing: 0.398px;
  border-radius: 3.659px;
  background: #70cae1;
  padding: 4.5px 6px;
  width: fit-content;
  text-transform: uppercase;
}

.price-faqs .btn-primary {
  background-color: #dae6e9;
  color: #083344;
}

.price-faqs .btn-primary:hover {
  background-color: #073244;
  color: #eef5f7;
}

.certificates {
  padding: 80px 0 65px 0;
}

.certificates .container-sm-secondary {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.certificates img {
  margin-top: 35px;
}

.section-useful-links {
  background-color: #11465b;
  padding: 103px 0 100px 0;
  position: relative;
}

.infertility {
  position: relative;
}

.section-useful-links::before,
.infertility::before {
  content: " ";
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 168px;
  background-image: url(assets/images/mask/mask-top.svg);
  background-repeat: no-repeat;
  background-position: center;
  pointer-events: none;
}

.useful-links-list {
  display: flex;
  flex-direction: column;
  margin-top: 16px;
  border-top: 1px solid rgba(123, 151, 157, 0.6);
  border-bottom: 1px solid rgba(123, 151, 157, 0.6);
}

.useful-link {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  color: #eef5f7;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  line-height: 172.222%;
  padding: 18px 10px 15px 10px;
  transition: all 0.2s;
  position: relative;
}

.useful-link::after {
  content: " ";
  position: relative;
  display: inline-block;
  right: 0;
  top: 0;
  width: 12px;
  height: 12px;
  background-image: url(assets/images/icons/icon-seta-branca.svg);
  background-repeat: no-repeat;
  background-size: contain;
}

.useful-link:not(:last-child) {
  border-bottom: 1px solid rgba(123, 151, 157, 0.6);
}

.useful-link:hover {
  background-color: #083344;
  border-bottom: 1px solid #083344;
}

.prices .btn-primary {
  margin: 40px auto 0 auto;
}

/* Página: Apoio Psicológico */

.responsible {
  padding: 100px 85px;
  background-color: #e0ecf0;
  border-radius: 15px;
  display: flex;
  gap: 47px;
  align-items: center;
  min-width: 670px;
}

.responsible figure {
  max-width: 223px;
}

.responsible img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.responsible h4 {
  color: #073244;
  font-size: 20.67px;
  font-weight: 600;
  line-height: 143.75%;
  letter-spacing: -0.207px;
}

.responsible h5 {
  color: #273f49;
  font-size: 18.086px;
  font-weight: 400;
  line-height: 142.857%;
}

.responsible .btn-more {
  margin-top: 33px;
}

.infertility {
  padding: 110px 0 0 0;
  background-color: #3EB6D4;
}

.chronology {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
}

.chronology-card {
  flex: 0 0 204px;
  position: relative;
}

.chronology-card-content {
  display: flex;
  flex-direction: column;
  gap: 9px;
  background-color: #eef5f7;
  padding: 25px;
  border-radius: 15px;
  margin-right: 61px;
  position: relative;
}

.chronology-card-content::after {
  content: " ";
  position: absolute;
  width: 10px;
  height: 10px;
  background-color: #073244;
  bottom: -27px;
  left: 50%;
  transform: translateX(-50%);
  border-radius: 50%;
}

.chronology-text {
  color: #415359;
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  line-height: 127.273%;
}

.below-chronology p:not(:last-of-type) {
  margin-bottom: 8px;
}

.chronology-card .value {
  color: #073244;
  text-align: center;
  font-size: 23px;
  font-weight: 500;
  line-height: 100%;
}

.chronology-card .year {
  color: #eef5f7;
  text-align: center;
  font-family: "Lora", sans-serif;
  font-size: 36px;
  font-style: italic;
  font-weight: 500;
  line-height: 111.111%;
  display: block;
  margin-right: 61px;
}

.chronology-card .line {
  width: 100%;
  height: 2px;
  background: #073244;
  margin: 21px 0;
  display: block;
}

.chronology-card:first-of-type .line {
  background: linear-gradient(90deg,
      rgba(62, 182, 212, 1) 36%,
      rgba(7, 50, 68, 1) 0%);
}

.chronology-card:last-of-type .line {
  background: linear-gradient(270deg,
      rgba(62, 182, 212, 1) 64%,
      rgba(7, 50, 68, 1) 65%);
}

.chronology-info {
  position: relative;
}

.black-span {
  color: #000;
  text-align: center;
  font-size: 12px;
  font-style: italic;
  font-weight: 500;
  line-height: 81.818%;
  margin-bottom: 30px;
  display: block;
  margin-top: 25px;
}

/* Nice Select */

@media (min-height: 1081px) {
  #frontpage-hero {
    min-height: 60vh;
  }
}

@media (min-width: 1921px) {

  .treatment-process::before,
  .treatment-process::after {
    background-size: 100vw;
  }

  .frontpage-hero-image {
    width: 65%;
  }
}

@media (max-width: 1820px) {

  /* Footer */
  footer {
    padding-bottom: 0;
  }

  /* Header */
  .header-container {
    padding: 0 3%;
  }

  .frontpage-hero-image {
    top: -90px;
  }

  .footer-container {
    padding: 0 30px 30px 30px;
  }

  .back-to-top {
    right: 90px;
  }
}

@media (max-width: 1680px) {

  /* Header */
  #menu-menu-header-bottom>li>a {
    font-size: 14px;
  }

  .custom-logo {
    max-width: 165px;
  }

  .header-bottom-tools {
    justify-content: flex-end;
    gap: 5px;
  }

  .header-search {
    width: 50%;
  }

  .header-navigation-bottom {
    gap: 0;
  }

  /* Frontpage Hero */
  .frontpage-hero-image {
    width: 90%;
  }

  /* Frontpage Preservar */
  #frontpage-preserve::after {
    right: 0;
  }

  /* Frontpage Testemunhos */
  .testimonial-item>p {
    font-size: 14px;
  }

  .testimonial-item {
    padding: 25px 30px;
    min-height: 400px;
  }

  /* Footer */
  .footer-content {
    background-size: 15%;
  }

  .footer-item::after {
    right: -15%;
  }

  /* 404 */
  .page-not-found {
    padding: 100px 0;
  }

  .page-not-found::before,
  .page-not-found::after {
    height: 120%;
  }

  /* FAQ */
  .cta-booking-content {
    padding: 60px 100px 60px 60px;
  }

  .contacts-intro>img {
    max-width: 530px;
  }

  #the-center .mb-20 {
    margin-bottom: 10px;
  }

  .breadcrumb {
    padding-top: 20px;
    margin-bottom: 20px;
  }

  .grid-6 {
    row-gap: 30px;
  }

  .single-team-intro>h1 {
    margin-bottom: 15px;
  }
}

@media (max-width: 1550px) {
  .header-navigation-top {
    margin-bottom: 10px;
    gap: 10px;
  }

  .treatment-item-title {
    font-size: 18px;
  }

  .contact-info-card:first-child {
    padding-right: 40px;
  }

  .contact-info-card:not(:first-child, :last-child) {
    padding: 0 40px;
  }

  .contact-info-card:last-child {
    padding-left: 40px;
  }

  .contacts-intro .container {
    padding: 0 6%;
  }

  #frontpage-faq {
    padding: 100px 0 30px 0;
  }

  .chronology {
    overflow-x: auto;
  }

  .chronology::-webkit-scrollbar {
    display: none;
  }

  .vision {
    background-size: 700px 100%;
  }
}

@media (max-width: 1440px) {
  h1 {
    font-size: 34px;
  }

  h1>span {
    font-size: 28px;
  }

  .faq-theme-title,
  h3 {
    font-size: 30px;
  }

  .container,
  .treatment-process .container-md-tertiary {
    padding: 0 6%;
  }

  .infertility .container {
    padding: 0;
  }

  .infertility .chronology {
    padding: 0 6%;
  }

  .btn-primary {
    font-size: 13px;
  }

  .btns-navigations {
    right: 6%;
  }

  /* Header */
  .header-donation {
    font-size: 13px;
    padding: 20px 20px 10px 20px;
  }

  #menu-menu-header-bottom>li>a {
    font-size: 13px;
  }

  #menu-menu-header-top {
    padding-top: 10px;
  }

  /* Frontpage Tratamentos */
  .frontpage-treatment-item>a {
    font-size: 17px;
  }

  /* Blog */
  .blog-banner {
    padding: 110px 0 40px 0;
  }

  /* FAQ */
  .cta-booking-content {
    padding: 30px;
  }

  .faq-icon-before::before {
    height: 40px;
    width: 40px;
  }

  /* Footer */
  #menu-footer-legal {
    gap: 0 20px;
    flex-wrap: wrap;
  }

  .footer-certification {
    top: 0;
    margin-right: 25px;
  }

  /* Equipa */
  .single-team-banner::before {
    height: 120px;
  }

  .single-team-content {
    padding: 50px 0;
  }

  .treatment-item>img {
    flex: 0 0 200px;
    width: 200px;
  }

  .contacts-intro .content-sm {
    max-width: 650px;
  }

  #frontpage-treatment {
    padding: 100px 0 30px 0;
  }

  .d-flex-slider {
    gap: 16px;
  }

  .treatment-process-description>p {
    font-size: 17px;
  }

  .process-card>h3 {
    font-size: 16px;
  }

  .chronology-card .year {
    font-size: 32px;
  }

  .chronology-card .value {
    font-size: 22px;
  }

  .responsible figure {
    max-width: 175px;
    height: fit-content;
  }

  .responsible h4 {
    font-size: 19px;
  }

  .responsible h5 {
    font-size: 17px;
  }

  .responsible {
    min-width: 580px;
  }
}

@media (max-width: 1440px) and (min-height: 901px) {
  #frontpage-hero {
    min-height: 60vh;
  }
}

@media (max-width: 1376px) {
  h1 {
    font-size: 32px;
  }

  h1>span {
    font-size: 26px;
  }

  .faq-theme-title,
  h3 {
    font-size: 28px;
  }

  .btn-secondary {
    font-size: 14px;
  }

  .mr-5 {
    margin-right: 0;
  }

  .ml-5n {
    margin-left: 0;
  }

  .initial .md-flex-1 {
    flex: 0 0 40%;
  }

  .md-flex-1 {
    flex: 1;
  }

  /* 404 */
  .container-buttons {
    gap: 10px;
  }

  /* Blog */
  .blog-banner {
    padding: 65px 0 30px 0;
  }

  /* Header */
  .header-navigation-bottom {
    gap: 15px;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  ul#menu-menu-header-bottom {
    order: 1;
  }

  .header-navigation .menu {
    font-size: 12px;
  }

  .header-search {
    width: 78%;
  }

  .custom-logo-link {
    margin-top: 20px;
  }

  .header-bottom-tools {
    flex: 1 0 100%;
  }

  /* Equipa */
  .single-team-grid {
    grid-template-columns: 20% 1fr;
    gap: 5%;
  }

  .single-team-banner::before {
    height: 110px;
  }

  .box-content {
    padding: 30px;
    margin-bottom: 20px;
  }

  /* Frontpage Hero */
  .frontpage-hero-content {
    max-width: 355px;
  }

  /* Frontpage Tratamentos */
  .frontpage-treatment-item {
    flex: 0 0 260px;
    min-height: 200px;
  }

  .frontpage-treatment-item>a {
    font-size: 16px;
  }

  /* Footer */
  .footer-grid {
    grid-template-columns: 200px 18% 15% 12% auto;
  }

  .footer-social-media {
    flex: 0 0 200px;
  }

  .footer-menu>address,
  .footer-title,
  .footer-menu>h5,
  .footer-menu>span,
  .footer-contact>a,
  .footer-menu>.menu a {
    font-size: 13px;
    line-height: 20px;
  }

  .footer-logo {
    max-width: 160px;
  }

  .footer-donate>img {
    max-width: 140px;
  }

  .footer-content {
    padding: 50px 30px;
  }

  .btn-donate {
    font-size: 16px;
  }

  .treatment-process-description>p {
    font-size: 16px;
  }

  .menu>li:last-of-type .sub-menu {
    right: 0;
  }

  .menu .sub-menu a {
    font-size: 13px;
  }

  .section-useful-links {
    padding: 100px 0 70px 0;
  }

  .treatment-process {
    padding: 80px 0;
  }

  li,
  p {
    font-size: 15px;
  }

  .general-content table tr:first-child td {
    font-size: 13px;
  }

  .general-content h3 {
    font-size: 19px;
  }

  .general-content h2 {
    font-size: 24px;
  }

  li:not(.sub-menu li, .breadcrumb > li) {
    font-size: 13px;
  }

  .service-item,
  .frontpage-faq-item {
    font-size: 15px;
  }

  .treatment-item-title {
    font-size: 17px;
  }

  .chronology-card-content {
    padding: 20px;
  }

  .light-blue-span {
    margin-bottom: 20px;
  }

  #menu-menu-header-top>li>a {
    font-size: 12px;
  }

  .input-content input[type="text"],
  .input-content input[type="email"],
  .input-content input[type="date"] {
    font-size: 14px;
  }

  .single-team-aside>p {
    font-size: 14px;
  }

  .team-card-name {
    font-size: 15px;
  }

  .single-team-aside>h2 {
    font-size: 26px;
  }

  .vision {
    background-size: 500px 100%;
  }

  .blog-content p strong {
    font-size: 17px;
  }

  .blog-content>div>p {
    font-size: 15px;
  }

  ul#menu-menu-header-bottom>li {
    padding-bottom: 20px;
  }

  .testimonial-item:nth-child(odd) {
    transform: translateY(75px);
  }

  #the-center .breadcrumb {
    padding-top: 15px;
    margin-bottom: 15px;
  }

  .testimonial-item {
    gap: 10px;
  }

  .team-card-name {
    margin-bottom: 5px;
  }

  .cta-booking-content {
    padding: 30px 120px 30px 30px;
  }

  #cta-booking {
    padding-top: 50px;
  }

  .single-team-intro {
    padding-bottom: 60px;
  }

  .single-team-grid {
    grid-template-columns: 23% 1fr;
  }
}

@media (max-width: 1280px) {
  .container-md-secondary {
    padding: 0 6%;
  }

  /* Equipa */
  .single-team-aside {
    margin-left: -26%;
  }

  .footer-blisq svg path {
    fill: #688e9d;
  }

  /* Footer */
  .footer-content {
    background-image: none;
  }

  .treatment-detail-content {
    width: 45%;
  }

  /* .treatment-detail-images .slick-list {
    height: 380px;
  } */

  /* .treatment-detail-images img:not(.treatment-detail-images.help img) {
    height: 350px;
  } */

  .treatment-process-card {
    font-size: 15px;
  }

  .contacts-intro .content-sm {
    max-width: 550px;
  }

  li:not(.sub-menu li, .breadcrumb > li) {
    font-size: 14px;
  }

  .responsible {
    padding: 70px;
  }

  .responsible {
    min-width: 100%;
  }

  .responsible figure {
    max-width: 130px;
  }

  .responsible h4 {
    font-size: 18px;
  }

  .responsible h5 {
    font-size: 16px;
  }

  .treatment-process-card p {
    font-size: 15px;
  }

  .process-card>h3 {
    font-size: 13px;
  }

  .footer-menu>.menu {
    gap: 7px;
  }

  .footer-menu>.menu>li {
    line-height: 135%;
  }

  .team-card-name {
    font-size: 14px;
  }

  .team-card-specialty {
    font-size: 13px;
  }

  #team {
    margin: 60px 0;
  }

  #frontpage-blog {
    padding: 110px 0 0px 0;
  }

  #frontpage-aboutus {
    padding-bottom: 50px;
  }

  .testimonials-items {
    margin-top: 40px;
  }

  .treatment-details .container {
    gap: 60px;
  }

  .treatment-details {
    padding: 40px 0 60px 0;
  }

  .frontpage-hero-image {
    top: -60px;
  }

  ul#menu-menu-header-bottom>li {
    padding-bottom: 15px;
  }

  .header-donation {
    padding: 15px 20px 10px 20px;
  }

  .frontpage-treatment-items {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 1180px) {

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 35px 10%;
  }

  .footer-item::after,
  .footer-social-media,
  .footer-contact {
    display: none;
  }

  .footer-contact-secondary {
    display: flex;
    flex-direction: column;
  }

  .footer-social-media-secondary {
    display: block;
    flex: 0;
    margin-top: 20px;
  }

  .footer-info {
    grid-area: 1 / 2;
  }

  .footer-donate {
    margin: 40px 0 0 0;
  }

  #menu-footer-legal {
    margin: 0;
  }

  .footer-certification {
    margin: 0 20px;
    top: 15px;
  }

  .footer-bottom {
    margin-top: 20px;
  }

  .btn-donate {
    font-size: 15px;
  }

  .btn-navigation {
    width: 35px;
  }

  .single-post .slick-arrow {
    width: 35px;
    height: 35px;
    background-position: center;
  }

  .container-md {
    padding: 0 6%;
  }

  .grid-6 {
    grid-template-columns: repeat(5, 1fr);
  }

  .flex-common {
    align-items: flex-start;
  }

  .flex-common>figure {
    height: fit-content;
    top: 30px;
    position: sticky;
  }

  /* 404 */
  .page-not-found::before {
    left: -115px;
  }

  .page-not-found::after {
    right: -130px;
  }

  /* Equipa */
  .team-card-name {
    font-size: 15px;
  }

  /* Frontpage Hero */
  #frontpage-hero {
    padding: 130px 0 175px 0;
  }

  .frontpage-hero-image {
    right: -60px;
  }

  /* Frontpage Faq */
  .service-item,
  .frontpage-faq-item {
    flex: 0 0 200px;
    font-size: 15px;
    padding: 15px;
  }

  .service-item::after,
  .frontpage-faq-item::after {
    height: 35px;
    width: 35px;
  }

  .d-flex-slider .flex-6,
  .d-flex-slider .flex-5 {
    flex: 0 0 200px;
  }

  /* FAQ */
  .faq-icon-before::before {
    height: 35px;
    width: 35px;
  }

  .treatment-item>img {
    flex: 0 0 180px;
    width: 180px;
  }

  .contacts-info-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    row-gap: 40px;
  }

  .contact-info-card:not(:first-child, :last-child) {
    padding: 0;
  }

  address.contact-info-card {
    margin-left: 40px;
    border-right: none !important;
  }

  .contact-form-flex {
    flex-wrap: wrap;
    gap: 5px;
  }

  .contact-us form {
    padding: 50px 60px;
  }

  .contacts-intro .content-sm {
    max-width: 812px;
  }

  .contacts-intro {
    padding-bottom: 70px;
  }

  .contacts-intro img {
    display: none;
  }

  .contacts-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
  }

  .frontpage-preserve-content>h4 {
    font-size: 15px;
  }

  .chronology-card .year {
    font-size: 28px;
  }

  .chronology-card .value {
    font-size: 20px;
  }

  .chronology-text {
    font-size: 10px;
  }

  .responsible figure {
    max-width: 120px;
  }

  .responsible {
    padding: 50px;
  }

  .certificates img {
    max-width: 200px;
  }

  .section-useful-links {
    padding: 100px 0 30px 0;
  }

  .related-treatment .container {
    padding: 0;
  }

  .related-treatment .d-flex-slider {
    padding: 0 6%;
  }

  .related-treatment .container>h3,
  .related-treatment h2 {
    padding: 0 6%;
  }
}

@media (max-width: 1080px) {
  h1 {
    font-size: 30px;
  }

  h1>span {
    font-size: 24px;
  }

  .faq-theme-title,
  h3 {
    font-size: 26px;
  }

  .md-grid-2-fr {
    grid-template-columns: 45% 55%;
  }

  .md-invert-grid-2-fr {
    grid-template-columns: 60% 40%;
  }

  .container-sm {
    padding: 0 6%;
  }

  .contact-us .container-sm,
  .page-template-page-faq .container-sm,
  .prices .container-sm {
    padding: 0;
  }

  .grid-6,
  .grid-5 {
    grid-template-columns: 1fr 1fr 1fr 1fr;
  }

  /* Equipa */
  .team-card-name {
    font-size: 14px;
  }

  .team-card-specialty {
    font-size: 13px;
  }

  /* Header */
  .header-donation,
  #menu-menu-header-top>li>a {
    font-size: 12px;
  }

  .custom-logo {
    max-width: 150px;
  }

  .header-donation {
    padding: 16px 15px 10px 15px;
  }

  .header-navigation .menu {
    gap: 15px;
  }

  /* FAQ */
  .faq-icon-before::before {
    height: 30px;
    width: 30px;
  }

  /* Frontpage Hero */
  .frontpage-hero-content {
    max-width: 320px;
  }

  .frontpage-hero-image {
    top: -40px;
  }

  /* Frontpage Blog */
  .blog-item {
    padding: 10px;
  }

  .blog-card-title {
    font-size: 14px;
  }

  /* Frontpage Preservar */
  #frontpage-preserve::after {
    width: 330px;
  }

  /* Frontpage Tratamentos */
  .frontpage-treatment-item {
    min-height: 180px;
  }

  .frontpage-hero-list,
  .frontpage-hero-list:last-child {
    flex: 1 0 350px;
  }

  /* Frontpage Testemunhos */
  .testimonial-item>p:first-child::before {
    width: 30px;
    height: 24px;
  }

  .testimonial-item {
    margin: 0 10px;
  }

  .testimonial-item {
    padding: 25px;
  }

  /* FAQ */
  .cta-booking-grid {
    grid-template-columns: 60% 40%;
  }

  .frontpage-hero-lists {
    align-items: revert;
  }

  .chronology-card .year {
    font-size: 26px;
  }

  .infertility {
    padding: 80px 0 0 0;
  }

  .center-gallery-items img {
    aspect-ratio: 7/4;
    max-height: 320px;
  }

  .vision {
    background-image: none;
  }

  .frontpage-treatment-items {
    grid-template-columns: repeat(3, 1fr);
  }

  .footer-grid {
    gap: 35px 4%;
  }

  #the-center {
    padding: 80px 0;
  }

  .initial .flex-md {
    flex: 0 0 45%;
  }

  .cta-booking-content {
    padding: 30px 100px 30px 30px;
  }
}

@media (max-width: 980px) {

  /* Header */
  .header-navigation {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 96px;
    left: 0;
    height: calc(100vh - 96px);
    width: 100vw;
    background-color: #eef5f7;
    padding: 40px 6%;
    border-radius: 0;
    opacity: 0;
    visibility: hidden;
    transition: all 0.5s;
  }

  .menu .sub-menu {
    display: none;
  }

  .menu-item-has-children>a {
    pointer-events: none;
  }

  #nav-icon1.open~.header-navigation {
    opacity: 1;
    visibility: visible;
    padding-top: 0;
  }

  header {
    padding: 10px 0;
  }

  .custom-logo-link {
    margin-top: 0;
  }

  .header-container {
    padding: 0 6%;
  }

  /* 404 */
  .page-not-found::before {
    left: 0;
    background-position: top;
    transform: rotate(90deg);
    transform-origin: top;
    height: auto;
    width: 100%;
    top: 20px;
  }

  .page-not-found {
    padding: 135px 0 100px 0;
  }

  .page-not-found::after {
    left: 0;
    background-position: 0;
    width: 100%;
    height: 314px;
    top: auto;
    right: 0;
    bottom: -200px;
    background-size: cover;
    background-repeat: no-repeat;
    background-image: url(assets/images/mask/mask-404-bottom.svg);
  }

  /* Frontpage Hero */
  #frontpage-hero {
    padding: 130px 0;
  }

  .frontpage-hero-image {
    top: -30px;
  }

  /* Icon 1 */
  #nav-icon1 {
    width: 50px;
    height: 35px;
    position: relative;
    transform: rotate(0deg);
    cursor: pointer;
    display: block;
  }

  #nav-icon1 span {
    display: block;
    position: absolute;
    height: 3px;
    width: 100%;
    background: #073244;
    border-radius: 9px;
    opacity: 1;
    left: 0;
    transform: rotate(0deg);
    transition: 0.25s ease-in-out;
  }

  #nav-icon1 span:nth-child(1) {
    top: 0px;
  }

  #nav-icon1 span:nth-child(2) {
    top: 14px;
  }

  #nav-icon1 span:nth-child(3) {
    top: 28px;
  }

  #nav-icon1.open span:nth-child(1) {
    top: 14px;
    transform: rotate(135deg);
  }

  #nav-icon1.open span:nth-child(2) {
    opacity: 0;
    left: -60px;
  }

  #nav-icon1.open span:nth-child(3) {
    top: 14px;
    transform: rotate(-135deg);
  }

  /* Menu Mobile */
  .header-navigation-bottom {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    order: 0;
    position: relative;
    max-height: 55vh;
    overflow-y: auto;
    padding-top: 40px;
  }

  .header-navigation-bottom::-webkit-scrollbar {
    display: none;
  }

  /* .header-navigation-bottom::after {
    content: " ";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 90px;
    background: linear-gradient(0deg, #eef5f7 0%, rgba(238, 245, 247, 0) 100%);
  } */

  .header-navigation-top {
    order: 1;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    margin-top: auto;
    gap: 0;
    position: relative;
    margin-bottom: 10px;
  }

  .header-navigation-top::before {
    content: " ";
    position: absolute;
    top: -80px;
    left: 0;
    width: 100%;
    height: 90px;
    background: linear-gradient(0deg, #eef5f7 0%, rgba(238, 245, 247, 0) 100%);
  }

  .header-bottom-tools {
    display: none;
  }

  #menu-menu-header-bottom {
    display: flex;
    flex-direction: column;
    width: 100%;
  }

  #menu-menu-header-bottom>li>a {
    justify-content: space-between;
    border-bottom: 1px solid #b3cbd0;
    font-size: 15px;
    padding-bottom: 15px;
  }

  #menu-menu-header-top {
    margin: 20px 0 0 0;
    flex-wrap: nowrap;
    justify-content: center;
    width: 100%;
    flex-direction: column;
  }

  #menu-menu-header-top li {
    border-bottom: 1px solid #b3cbd0;
    padding-bottom: 15px;
  }

  #menu-menu-header-top>li:not(:last-child)>a {
    border-right: none;
  }

  #menu-menu-header-top>li.menu-item-contact>a {
    height: fit-content;
  }

  .header-donation {
    width: 100%;
    justify-content: center;
  }

  .header-search.only-mobile {
    display: block;
    width: 50%;
    margin-left: auto;
    margin-right: 20px;
  }

  #menu-menu-header-top>li.only-mobile {
    display: flex;
  }

  .header-donation,
  #menu-menu-header-top>li>a {
    font-size: 13px;
  }

  #menu-menu-header-top>li.menu-item-contact>a {
    display: flex;
    padding: 15px 40px;
    justify-content: center;
    align-items: center;
    color: #eef5f7;
    text-align: center;
    font-size: 15px;
    font-style: normal;
    font-weight: 700;
    line-height: 20px;
    border-radius: 82px;
    background-color: #083344;
    width: 100%;
  }

  /* Blog */
  .single-post .gallery {
    margin: 0;
  }

  /* Equipa */
  .single-team-intro>p:not(:last-child),
  .single-team-intro>h1 {
    margin-bottom: 10px;
  }

  .single-team-banner::before {
    display: none;
  }

  .single-team-intro {
    padding-bottom: 30px;
  }

  .single-team-image {
    position: relative;
    margin-left: 0;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: #c7dbe0;
    overflow: hidden;
    border: 1px solid #175f71;
  }

  .single-team-grid {
    margin-left: 0;
  }

  .single-team-content .single-team-grid {
    display: grid;
    grid-template-columns: 100%;
    gap: 0;
  }

  .single-team-aside {
    margin-left: 0;
    position: relative;
    max-width: 100%;
    margin-bottom: 25px;
    order: 1;
  }

  .treatment-item>img {
    flex: 0 0 165px;
    width: 165px;
  }

  .treatment-item-title {
    font-size: 16px;
  }

  .treatment-detail {
    flex-direction: column;
    align-items: flex-start;
  }

  .treatment-detail-content {
    width: 100%;
  }

  .treatment-detail-images {
    width: 60%;
    align-self: center;
  }

  .treatment-details .treatment-detail:nth-of-type(2) {
    flex-direction: column-reverse;
  }

  .menu .sub-menu {
    position: relative;
    top: 0;
    padding: 18px 0 0 0;
    width: 100%;
    background-color: #eef5f7;
    border-radius: 0;
    border-top: 2px solid #083344;
    border-bottom: 2px solid #083344;
  }

  .menu .menu-item-has-children:hover .sub-menu {
    display: none;
  }

  .menu .menu-item-has-children:hover .sub-menu.active {
    display: block;
  }

  .menu .sub-menu::before {
    display: none;
  }

  .menu .sub-menu li:first-child {
    padding-top: 0;
  }

  ul#menu-menu-header-bottom>li {
    padding-bottom: 0;
  }

  .header-donation {
    margin-top: 0px;
    margin-bottom: 0px;
  }

  #menu-menu-header-top>li.menu-item-contact>a {
    padding: 0;
    display: block;
    background-color: transparent;
    color: #568295;
    font-size: 13px;
    letter-spacing: 0.65px;
    line-height: 154%;
    text-transform: uppercase;
    font-weight: 400;
    display: block;
    text-align: start;
  }

  .single-team-aside>h2 {
    font-size: 24px;
  }

  .menu .sub-menu a {
    display: block;
  }
}

@media (max-width: 820px) {
  .general-content h2 {
    font-size: 24px;
    line-height: 1.2;
  }

  .general-content h3 {
    font-size: 18px;
  }

  h1 {
    font-size: 26px;
  }

  h1>span {
    font-size: 20px;
  }

  .grid-2.treatment {
    grid-template-columns: 1fr;
  }

  .treatment-item>img {
    flex: 0 0 200px;
    width: 200px;
  }

  .useful-link {
    font-size: 17px;
  }

  .section-useful-links {
    padding-bottom: 0px;
  }

  .maps-location .maps {
    padding: 80px 40px;
  }

  .chronology-card .year {
    font-size: 24px;
  }

  .frontpage-hero-lists {
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
  }

  .frontpage-hero-lists::-webkit-scrollbar {
    display: none;
  }

  #frontpage-list .container-md-secondary {
    padding: 0;
  }

  .frontpage-hero-lists {
    padding: 0 6%;
  }

  .custom-logo {
    max-width: 130px;
  }

  .frontpage-hero-content {
    max-width: 260px;
  }

  li:not(.sub-menu li, .breadcrumb > li) {
    font-size: 12px;
  }

  #frontpage-hero {
    min-height: auto;
  }

  .testimonial-item:nth-child(odd) {
    transform: translateY(35px);
  }

  .pt-80 {
    padding-top: 50px;
  }

  .frontpage-treatment-item {
    min-height: 155px;
  }

  .blog-item {
    padding: 10px 0;
  }

  header {
    border-radius: 0 0 25px 25px;
  }

  .center-gallery {
    padding-bottom: 70px;
  }

  .vision .flex-common,
  .quality-policy .flex-common {
    flex-direction: column;
  }

  .vision .flex-common>figure,
  .quality-policy .flex-common>figure {
    position: relative;
    top: 0;
  }

  .vision figure,
  .quality-policy figure {
    margin: 0 auto;
    width: 60%;
    height: auto;
  }

  .py-80 {
    padding: 50px 0;
  }

  .custom-select-container {
    width: 200px;
  }

  .custom-select li {
    font-size: 13px !important;
  }

  .team-card-name {
    margin-top: 12px;
  }

  .single-team-banner::after {
    top: -35%;
  }

  .box-content li {
    margin-bottom: 5px;
  }
}

@media (max-width: 768px) {

  .faq-theme-title,
  .searched-title,
  h3 {
    font-size: 24px;
  }

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

  .grid-2-fr {
    grid-template-columns: 100%;
  }

  .grid-6,
  .grid-5 {
    grid-template-columns: 1fr 1fr 1fr;
  }

  .container-sm-secondary {
    padding: 0 6%;
  }

  .btn-border,
  .btn-secondary {
    font-size: 13px;
  }

  /* Centro de Genética */
  #the-center {
    padding-bottom: 50px;
  }

  .center-gallery-items img {
    aspect-ratio: 16 / 9;
  }

  /* 404 */
  .container-buttons {
    flex-wrap: wrap;
  }

  /* Frontpage Hero */
  .frontpage-hero-image {
    right: -120px;
  }

  #frontpage-hero {
    padding: 115px 0 85px;
  }

  /* Frontpage Sobre Nós */
  .fronpage-aboutus-right {
    padding-left: 0;
    margin-top: 40px;
  }

  .frontpage-preserve-left {
    max-width: 100%;
  }

  #frontpage-aboutus {
    padding-top: 0;
  }

  /* Frontpage Preservar */
  .frontpage-preserve-items,
  .frontpage-preserve-image {
    margin-top: 35px;
  }

  #frontpage-preserve {
    background-color: #083244;
    padding: 70px 0;
  }

  /* Frontpage Testemunhos */
  .testimonial-item:nth-child(odd),
  .testimonial-item.active:nth-child(even) {
    transform: translateY(50px);
  }

  .testimonial-item.active:nth-child(odd) {
    transform: translateY(0);
  }

  #frontpage-testimonials::before {
    background-size: cover;
  }

  /* Blog */
  .blog-card-title {
    font-size: 13px;
  }

  .search-form {
    gap: 10px;
  }

  .custom-select-container {
    width: 195px;
  }

  .btns-navigations {
    display: none;
  }

  /* Footer */
  .back-to-top {
    height: 45px;
    width: 45px;
    right: 6%;
  }

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

  .footer-first-column {
    grid-column: span 2;
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .footer-contact {
    display: flex;
    flex-direction: column;
  }

  .footer-info {
    grid-area: auto;
  }

  .footer-donate {
    margin: 0;
    width: 100%;
    max-width: 100%;
  }

  .footer-contact-secondary {
    display: none;
  }

  /* Faq */
  .cta-booking-image {
    border-radius: 15px 15px 0 0;
    max-height: 165px;
  }

  .cta-booking-grid {
    grid-template-columns: 100%;
  }

  .cta-booking-content {
    order: 1;
  }

  /* Blog */
  .single-post .gallery-caption {
    margin-left: 20px;
  }

  #cta-booking {
    padding-top: 50px;
  }

  .treatment-detail-images {
    width: 100%;
  }

  .treatment-details .container {
    gap: 40px;
  }

  /* .treatment-detail-images .slick-list {
    height: 300px;
  } */

  /* .treatment-detail-images img {
    height: 270px;
  } */

  .treatment-detail-images.help img {
    height: 170px;
  }

  .treatment-process {
    padding: 80px 0;
  }

  .treatment-process-description>p {
    font-size: 15px;
  }

  .prices {
    padding-top: 50px;
  }

  .contact-timetable-flex {
    flex-direction: column;
    gap: 15px;
  }

  .input-content input::placeholder,
  .input-content input {
    font-size: 15px;
  }

  .single-team-grid {
    display: block;
  }

  .single-team-image {
    max-width: 120px;
    float: left;
    margin-right: 20px;
  }

  .single-team-intro>p {
    text-wrap: pretty;
    hyphens: auto;
  }

  .blog-content p strong {
    font-size: 15px;
  }

  .blog-content>div>p {
    font-size: 14px;
  }

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

@media (max-width: 650px) {
  .py-80 {
    padding: 50px 0;
  }

  .py-80.quality-policy {
    padding-bottom: 35px;
  }

  .flex-common {
    flex-direction: column;
  }

  .flex-common>figure {
    position: relative;
    top: 0;
  }

  .sm-order-1 {
    order: 1;
  }

  /* Frontpage Hero */
  #frontpage-hero {
    padding: 0;
    padding-bottom: 50px;
    display: flex;
    flex-direction: column;
  }

  .frontpage-hero-image {
    right: 0;
    position: relative;
    width: 125%;
    top: -60px;
  }

  #frontpage-hero .container {
    margin-top: -110px;
  }

  .frontpage-hero-content {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .treatment-process-description>p {
    font-size: 14px;
  }

  .treatment-process-card p {
    font-size: 15px;
  }

  .certificates img {
    max-width: 200px;
  }

  .maps-location .maps {
    padding: 50px 30px;
  }

  .center-gallery-items img {
    aspect-ratio: unset;
    max-height: 280px;
    width: auto;
  }

  .mb-15 {
    margin-bottom: 8px;
  }

  .treatment-detail-content p {
    line-height: 177%;
  }
}

@media (max-width: 600px) {

  .faq-theme,
  h2 {
    font-size: 13px;
  }

  .faq-theme-title,
  .searched-title,
  h3 {
    font-size: 22px;
  }

  .general-content h2 {
    font-size: 23px;
  }

  .general-content h3 {
    font-size: 17px;
  }

  .grid-6,
  .grid-5 {
    grid-template-columns: 1fr 1fr;
  }

  #team .grid-6 {
    row-gap: 40px;
  }

  .custom-select-container,
  .search-bar-container {
    flex: 1 0 100%;
  }

  .search-container {
    margin-top: 20px;
  }

  .search-form {
    flex-wrap: wrap;
  }

  /* Nice Select */
  .list>li {
    font-size: 14px;
  }

  /* Header */
  #nav-icon1 {
    width: 35px;
    margin-top: 8px;
  }

  #nav-icon1 span:nth-child(2) {
    top: 12px;
  }

  #nav-icon1 span:nth-child(3) {
    top: 24px;
  }

  header {
    border-radius: 0 0 15px 15px;
  }

  .header-navigation {
    border-radius: 0;
    top: 84px;
    height: calc(100dvh - 84px);
  }

  .header-search.only-mobile {
    width: fit-content;
  }

  .custom-logo {
    max-width: 125px;
  }

  .header-donation {
    font-size: 13px;
    padding: 15px 10px;
  }

  /* Frontpage Hero */
  .frontpage-hero-image {
    width: 135%;
    top: -50px;
  }

  #frontpage-hero .container {
    margin-top: -90px;
  }

  /* Frontpage Faq */
  #frontpage-blog,
  #frontpage-preserve,
  #frontpage-treatment,
  #frontpage-faq {
    padding: 50px 0;
  }

  #frontpage-testimonials {
    padding-top: 0;
  }

  #frontpage-aboutus {
    padding-bottom: 50px;
  }

  #frontpage-testimonials::before {
    background-size: contain;
    background-position: 0 95%;
  }

  /* Frontpage Blog */
  .frontpage-faq-items {
    gap: 15px;
  }

  .frontpage-faq-item {
    font-size: 13px;
    flex: 1 0 180px;
  }

  .service-item {
    font-size: 15px;
  }

  .service-item::after,
  .frontpage-faq-item::after {
    height: 30px;
    width: 30px;
    min-width: 30px;
  }

  .d-flex-slider .flex-6,
  .d-flex-slider .flex-5 {
    flex: 0 0 180px;
  }

  /* Frontpage Preservar */
  .frontpage-preserve-content>h4 {
    max-width: 300px;
    font-size: 14px;
  }

  #frontpage-preserve::after {
    width: 250px;
  }

  /* Frontpage Tratamentos */
  .frontpage-treatment-item {
    min-height: 110px;
    flex: 1 0 100%;
  }

  /* Frontpage Testemunhos */
  .testimonial-item:nth-child(odd),
  .testimonial-item.active:nth-child(even),
  .testimonial-item.active:nth-child(odd) {
    transform: translateY(0);
  }

  .testimonials-items {
    margin-top: 35px;
  }

  /* Footer */
  .footer-logo-cgrabarros {
    display: none;
  }

  .footer-first-column {
    gap: 20px;
    grid-column: auto;
  }

  .footer-grid {
    grid-template-columns: 100%;
    gap: 20px;
  }

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

  .footer-certification {
    margin: 0;
    top: 0;
  }

  #menu-footer-legal {
    margin-bottom: 20px;
    flex-direction: column;
  }

  .footer-blisq {
    margin-top: -40px;
  }

  .footer-content {
    background-size: 60%;
  }

  /* Blog */
  .blog-author-name {
    font-size: 15px;
  }

  .blog-author-role {
    font-size: 13px;
  }

  .single-post .slick-arrow {
    display: none;
  }

  .blog-tag-item {
    font-size: 12px;
  }

  .blog-author-content>small {
    margin-bottom: 10px;
  }

  .blog-author-name {
    font-size: 14px;
  }

  .blog-content {
    padding-top: 0;
  }

  /* FAQ */
  .cta-contact {
    padding: 30px;
  }

  /* Equipa */
  .single-team-grid {
    grid-template-columns: 25% 1fr;
  }

  .treatment-item {
    min-height: 150px;
  }

  .treatment-item>img {
    flex: 0 0 150px;
    width: 150px;
  }

  .treatment-item-content {
    padding: 20px;
  }

  .process-card>h3 {
    font-size: 15px;
  }

  .useful-link {
    justify-content: space-between;
    text-align: start;
    gap: 20px;
    font-size: 16px;
  }

  .contacts-info-grid {
    grid-template-columns: 1fr;
    row-gap: 20px;
  }

  address.contact-info-card {
    margin-left: 0px;
    border-right: none !important;
  }

  .contact-info-card:not(:last-child) {
    border-right: none;
    border-bottom: 1px solid #175f71;
    padding-bottom: 10px;
  }

  .contact-info-card:last-child {
    padding-left: 0px;
  }

  .contact-us form {
    padding: 40px;
  }

  .contact-custom-select::after {
    height: 25px;
    width: 25px;
  }

  .input-content input[type="text"],
  .input-content input[type="email"] {
    padding: 16px 20px;
  }

  .faq-title>h3 {
    font-size: 15px;
  }

  .responsible figure {
    max-width: 100px;
  }

  .responsible h4 {
    font-size: 17px;
  }

  .responsible h5 {
    font-size: 15px;
  }

  .chronology-card-content,
  .chronology-card .year {
    margin-right: 30px;
  }

  .chronology-card {
    flex: 0 0 160px;
  }

  .chronology-card:first-of-type .line {
    background: linear-gradient(90deg,
        rgba(62, 182, 212, 1) 39%,
        rgba(7, 50, 68, 1) 0%);
  }

  .chronology-card:last-of-type .line {
    background: linear-gradient(270deg,
        rgba(62, 182, 212, 1) 58%,
        rgba(7, 50, 68, 1) 60%);
  }

  .contact-us {
    padding-bottom: 0;
  }

  .general-content p {
    font-size: 13px;
  }

  .general-content h2 {
    font-size: 22px;
  }

  .testimonial-item {
    min-height: 370px;
  }

  .footer-menu>.menu {
    gap: 10px;
  }

  .footer-menu>.menu>li {
    line-height: 100%;
  }

  .footer-title,
  .contacts-info h2 {
    margin-bottom: 5px;
  }

  .center-gallery {
    padding-bottom: 50px;
  }

  #team {
    margin-bottom: 30px;
  }

  .search-bar {
    background-size: 15px;
  }

  .treatment-process-list {
    margin-top: 30px;
  }

  .treatment-process-list::before {
    top: -20px;
  }

  .mt-70 {
    margin-top: 50px;
  }

  .process-card {
    padding: 15px;
  }

  .mb-10 {
    margin-bottom: 5px;
  }

  .price-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .price-card {
    height: 100%;
  }

  .certificates {
    padding: 50px 0;
  }

  .section-useful-links {
    padding: 50px 0 20px 0;
  }

  .contacts-intro {
    padding-bottom: 50px;
  }

  .contact-us {
    padding: 50px 0 0 0;
  }

  .treatment-detail-images.help img {
    height: 110px;
  }

  .treatment-process {
    padding: 60px 0;
  }

  .treatment-process-card {
    padding: 30px;
  }

  h1>span {
    font-size: 18px;
  }

  .blog-item {
    padding: 10px 0;
  }

  .breadcrumb>li,
  .breadcrumb a {
    font-size: 11px;
  }

  #frontpage-hero {
    min-height: auto;
  }

  .footer-container {
    padding: 0;
  }

  .frontpage-treatment-items {
    grid-template-columns: repeat(1, 1fr);
  }

  .frontpage-faq-items {
    flex-direction: column;
  }

  .frontpage-faq-item {
    width: 100%;
    flex: auto;
  }

  .search-mobile-button {
    display: block;
  }

  .header-search-input {
    display: none;
  }

  .initial figure>img {
    width: 75%;
    margin: 0 auto;
  }

  .initial figure {
    display: flex;
    justify-content: center;
  }

  .center-gallery-items img {
    max-height: 240px;
  }

  .service-item,
  .frontpage-faq-item {
    min-height: auto;
    flex-direction: row;
    justify-content: space-between;
  }
}

@media (max-width: 450px) {
  .pt-50 {
    padding-top: 35px;
  }

  /* Header */
  .header-navigation {
    padding: 20px;
  }

  .header-navigation-top {
    height: fit-content;
  }

  #menu-menu-header-top {
    flex-direction: column;
    width: 100%;
    margin-top: auto;
  }

  #menu-menu-header-top>li.menu-item-contact {
    flex: 0;
  }

  #menu-menu-header-top>li:not(:last-child)>a {
    border-right: none;
  }

  /* Search */
  .searched-item-label {
    font-size: 10px;
  }

  /* Equipa */
  .team-card-name {
    line-height: 1.2;
    font-size: 13px;
  }

  .team-card-specialty {
    font-size: 12px;
  }

  .treatment-item-title {
    font-size: 15px;
  }

  .treatment-process-card {
    padding: 25px;
  }

  .treatment-process-card p {
    font-size: 14px;
    line-height: 175%;
  }

  .maps-location {
    padding-top: 50px;
  }

  .contact-us form {
    padding: 40px 20px 0 20px;
  }

  .contact-custom-select .option {
    font-size: 12px;
  }

  .input-content label {
    font-size: 11px;
  }

  li:not(.sub-menu li, .breadcrumb > li) {
    font-size: 14px;
  }

  .container-md .container-sm {
    padding: 0;
  }

  .treatment-details {
    padding: 40px 0;
  }

  .treatment-process {
    padding: 50px 0;
  }

  .frontpage-preserve-items,
  .frontpage-preserve-image {
    margin-top: 20px;
  }

  .responsible {
    flex-direction: column;
    gap: 30px;
    padding: 30px;
  }

  .treatment-detail-images.help img {
    height: fit-content;
  }

  .responsible .btn-more {
    justify-content: center;
  }

  .center-gallery-items img {
    max-height: 150px;
    margin-right: 10px;
  }

  li:not(.sub-menu li, .breadcrumb > li) {
    font-size: 12px;
  }

  .frontpage-hero-list {
    font-size: 12px;
    line-height: 155%;
  }

  li,
  p {
    font-size: 13px;
  }

  .faq-title {
    padding: 13px;
  }

  .faq-title>h3 {
    font-size: 13px;
  }

  .service-item,
  .frontpage-faq-item {
    min-height: fit-content;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
  }

  .service-item::after,
  .frontpage-faq-item::after {
    margin-top: 0;
  }

  .treatment-process-description>p {
    font-size: 13px;
  }

  .frontpage-hero-list,
  .frontpage-hero-list:last-child {
    flex: 1 0 300px;
  }

  #frontpage-testimonials {
    padding: 0 0 20px 0;
  }

  #frontpage-blog {
    padding: 50px 0 0 0;
  }

  .header-search-input {
    background-size: 28px;
  }

  .header-search-input::placeholder {
    font-size: 12px;
  }

  .custom-logo {
    max-width: 110px;
  }

  .faq-title>h3::after {
    width: 30px;
    height: 30px;
  }

  .search-bar::placeholder,
  .search-bar {
    font-size: 12px;
  }

  .btn-primary {
    font-size: 12px;
  }

  .faq-content {
    font-weight: 400;
  }

  .cta-booking-content {
    padding: 25px;
  }

  .useful-link {
    line-height: 150%;
  }

  .price-card {
    min-height: 165px;
  }

  .general-content table {
    overflow-x: auto;
    display: block;
  }

  .frontpage-treatment-item>a {
    font-size: 15px;
  }

  .single-team-aside>h2 {
    font-size: 20px;
  }

  .box-content {
    padding: 25px;
  }

  .single-team-intro>h1 {
    font-size: 24px;
  }

  .header-navigation {
    top: 78px;
  }

  .footer-first-column {
    display: block;
  }

  #nav-icon1 span {
    height: 2px;
  }

  .frontpage-hero-content h1 span {
    margin-top: 0;
  }

  .frontpage-hero-content {
    max-width: 260px;
    margin: 0 auto;
  }

  .footer-donate>img {
    max-width: 160px;
  }

  .footer-donate {
    margin: 20px 0;
  }

  #frontpage-hero .container {
    margin-top: -50px;
  }

  .frontpage-hero-image {
    top: -20px;
  }

  #frontpage-preserve {
    background-image: none;
  }

  .footer-content {
    border-radius: 0;
  }

  .blog-item {
    flex: 1;
  }

  .blog-item .btn-more {
    margin-top: auto;
  }

  .blog-card {
    display: flex;
    flex-direction: column;
  }

  .search-bar {
    padding: 0 115px 0 40px;
  }

  #team {
    margin-top: 40px;
  }

  .cta-booking-image {
    max-height: 190px;
  }

  .breadcrumb {
    padding-top: 10px;
  }

  .single-team-content {
    padding: 40px 0 0 0;
  }

  #frontpage-testimonials h2 br {
    display: none;
  }
}

@media (max-width: 435px) {

  /* 404 */
  .page-not-found {
    padding: 80px 0;
  }

  /* Frontpage Hero */
  .frontpage-hero-image {
    width: 150%;
    top: -40px;
  }

  #frontpage-hero .container {
    margin-top: -65px;
  }

  h1 {
    font-size: 23px;
  }

  h1>span {
    font-size: 15px;
  }

  /* Frontpage Blog */
  .blog-content-date {
    font-size: 10px;
  }

  /* Frontpage Preservar */

  .btn-more {
    font-size: 10px;
  }

  /* Footer */

  .footer-contact {
    margin: 0;
  }

  .useful-link {
    font-size: 15px;
  }

  .contact-custom-select::after {
    display: none;
  }

  .general-content h2 {
    margin-bottom: 10px;
    font-size: 19px;
  }

  .process-card>h3 {
    font-size: 13px;
  }

  .responsible h4 {
    font-size: 16px;
  }

  .responsible h5 {
    font-size: 14px;
  }

  .responsible {
    gap: 20px;
  }

  .faq-btn-donate {
    display: none;
  }

  .price-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 440px) and (max-height: 680px) {}

@media (max-width: 380px) {
  .header-search.only-mobile {
    display: none;
  }
}