/*  Importando as Fontes da pasta "Fonts"  */
@font-face {
  font-family: Poppins-R;
  src: url(fonts/Poppins-Regular.ttf);
}

@font-face {
  font-family: Poppins-SB;
  src: url(fonts/Poppins-SemiBold.ttf);
}

@font-face {
  font-family: CormorantGaramond;
  src: url(fonts/CormorantGaramond-SemiBold.ttf);
}

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

body {
  height: 100%;
  width: 100%;
  overflow-x: hidden;
}

body::-webkit-scrollbar {
  display: none;
}

#main {
  background: #d8e1ec;

}

img,
svg {
  max-width: 100%;
}

button {
  font-family: inherit;
}

/* BARRA DE NAVEGAÇÃO */
.nav-container {
  background: #fff;
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 10vh;
  z-index: 99;
  font-family: Poppins-R;
}

#logo-nav {
  position: absolute;
  width: 14%;
  left: 5%;
}

.nav-toggle {
  display: none;
}

.nav-menu {
  display: flex;
  margin-left: auto;
  flex-direction: row;
  margin-right: 5rem;
}

.nav-menu li {
  list-style-type: none;
}
.nav-menu ul {
  display: flex;
  gap: 5rem;
  align-items: center;
}
.nav-menu a {
  text-decoration: none;
  color: #000;
}

.nav-menu a:hover {
  color: #8aa6c2;
}

#nav-button {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #8aa6c2;
  color: #fff;
  font-size: 12px;
  border-radius: 9px;
  width: 153px;
  height: 36px;
  cursor: pointer;
}

#nav-button:hover {
  background: #455768;
  transition: 0.5s;
}



/* HOME */

#Home {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  overflow: hidden;
}

.container-texto-home {
  position: absolute;
  left: 5%;
  top: 25%;
  width: 100%;
}
span {
  color: #8aa6c2;
}

.psicologia {
  position: absolute;
  font-size: 25px;
  font-family: Poppins-SB;
  /* left: 5%;
  top: 25%; */
}

h1 {
  position: absolute;
  color: #344034;
  font-size: 80px;
  font-family: CormorantGaramond;
  width: 800px;
  margin-top: 45px;
  
  /* top: 30%;
  left: 5%; */
}

#line {
  position: absolute;
  color: #344034;
  width: 113px;
  height: 1px;
  margin-top: 240px;
  /* top: 50%;
  left: 5%; */
}

#text-home {
  position: absolute;
  color: #344034;
  font-size: 20px;
  font-family: Poppins-R;
  width: 450px;
  margin-top: 270px;
  /* top: 55%;
  left: 5%; */
}

#home-button {
  position: absolute;
  border-radius: 9px;
  width: 222px;
  height: 53px;
  background: #8aa6c2;
  color: #fff;
  font-size: 16px;
  margin-top: 400px;
  /* top: 65%;
  left: 5%; */
  z-index: 5;
  cursor: pointer;
}

#home-button:hover {
  background: #455768;
  transition: 0.5s;
}

#logo-lb-home {
  position: absolute;
  width: 300px;
  top: 60%;
  left: 25%;
  z-index: 1;
  opacity: 0.18;
}

#laura-foto-home {
  position: absolute;
  width: min(46vw, 650px);
  bottom: 0;
  left: 40%;
  z-index: 4;
}





/* Sessão 2 */

#session2 {
  position: relative;
  display: flex;
  width: 100%;
  height: 20vh;
  margin-top: 0;
  background: #fff;
  align-items: center;
  justify-content: center;
  gap: 216px;
}


/* Card Acolhimento */
.card-acolhimento {
  display: flex;
  justify-content: center;
  align-items: center;
  width: auto;
  height: auto;
}

.card-acolhimento .acolhimento-icon {
  color: #d7c9b3;
  width: 60px;
  height: 60px;
}

.card-acolhimento p {
  color: #d7c9b3;
  font-family: Poppins-SB;
  font-size: 20px;
  margin-left: 16px;
}


/* Card Crescimento */
.card-crescimento {
  display: flex;
  justify-content: center;
  align-items: center;
  width: auto;
  height: auto;
}

.card-crescimento .crescimento-icon {
  color: #d7c9b3;
  width: 60px;
  height: 60px;
}

.card-crescimento p{
  color: #d7c9b3;
  font-family: Poppins-SB;
  font-size: 20px;
  margin-left: 16px;
}


/* Card Consulta Online */
.card-online {
  display: flex;
  justify-content: center;
  align-items: center;
  width: auto;
  height: auto;
}

.card-online .online-icon {
  color: #d7c9b3;
  width: 60px;
  height: 60px;
}

.card-online p {
  color: #d7c9b3;
  font-family: poppins-sb;
  font-size: 20px;
  margin-left: 16px;
}



/* Sobre Mim */

#Sobre {
  position: relative;
  display: flex;
  width: 100%;
  height: 120vh;
  padding-top: 120px;
  background: #F2ECE6;
}

#foto-laura-sobre {
  position: relative;
  height: auto;
  max-width: 100%;
  border-radius: 25px;
  margin-left: 10%;
  margin-bottom: 100px;
}

.container-sobre-mim {
  position: absolute;
  left: 47%;
}

.container-sobre-mim span {
  font-size: 22px;
  font-family: poppins-SB;
}

.container-sobre-mim h2 {
  font-size: 3.43rem;
  font-family: CormorantGaramond;
  color: #344034;
  width: 350px;
  margin-top: 20px;
  line-height: 50px;
} 

.container-sobre-mim h3 {
  font-size: 100%;
  font-family: Poppins-R;
  color: #151a15;
  margin-top: 15px;
} 

.container-sobre-mim p {
  font-size: 107%;
  font-family: Poppins-R;
  color: #151a15;
  width: 80%;
  margin-top: 50px;
}



/* Serviços */

#Serviços {
  display: flex;
  align-items: center;
  background: #344034;
  width: 100%;
  height: 50vh;
}

.container-texto-serviços {
 margin-left: 5%;
}

.container-texto-serviços span {
  color: #d7c9b3;
  font-family: poppins-SB;
  font-size: 25px;
}

.container-texto-serviços h2 {
  color: #4E674E;
  font-size: 120px;
  font-family: CormorantGaramond;
}

.container-texto-serviços p {
  color: #d7c9b3;
  font-family: Poppins-R;
  font-size: 19px;
  margin-top: 10px;
}

.container-texto-serviços button {
  background: #d7c9b3;
  color: white;
  font-family: Poppins-R;
  font-size: 16px;
  margin-top: 30px;
  border-radius: 9px;
  width: 222px;
  height: 40px;
  cursor: pointer;
}

.container-texto-serviços button:hover {
  background: #a89c88;
  transition: 0.5s;
}

/* Cards */
.container-cards {
  display: flex;
  align-items: center;
  gap: 50px;
  margin-left: 77px;
}

.cards {
  background: #d7c9b3;
  border-radius: 7px;
  width: 290px;
  height: 330px;
  text-align: center;
  padding: 6px;
  cursor: pointer;
}

.cards:hover {
  scale: 1.05;
  transition: 0.5s;
}

.psicoterapia-icon {
  width: 132px;
  height: 132px;
  color: #ffffff;
}

#card-psicoterapia h4 {
  display: block;
  color: #344034;
  font-family: CormorantGaramond;
  font-size: 25px;
  text-align: center;
}

#card-psicoterapia p {
  color: #4E674E;
  font-family: Poppins-R;
  text-align: center;
  font-size: small;
}

.adolescentes-icon {
  width: 132px;
  height: 132px;
  color: #ffffff;
}

#card-Adolescentes h4 {  
  display: block;
  color: #344034;
  font-family: CormorantGaramond;
  font-size: 25px;
  text-align: center;
}

#card-Adolescentes p {  
  color: #4E674E;
  font-family: Poppins-R;
  text-align: center;
  font-size: small;
}

.adultos-icon {
  width: 132px;
  height: 132px;
  color: #ffffff;
}

#card-Adultos h4 {
  display: block;
  color: #344034;
  font-family: CormorantGaramond;
  font-size: 25px;
  text-align: center;
}

#card-Adultos p {
  color: #4E674E;
  font-family: Poppins-R;
  text-align: center;
  font-size: small;
}

.idosos-icon {
  width: 132px;
  height: 132px;
  color: #ffffff;
}

#card-Idosos h4{
  display: block;
  color: #344034;
  font-family: CormorantGaramond;
  font-size: 25px;
  text-align: center;
}

#card-Idosos p {
  color: #4E674E;
  font-family: Poppins-R;
  text-align: center;
  font-size: small;
}


/* Contato */

#Contato {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  /* background: #8AA6C2 ; */
  background: linear-gradient(150deg, #8aa6c2, #d7c9b3);
  width: 100%;
  height:40vh;
  padding-bottom: 58px;
  text-align: center;
}

#Contato h5 {
  color: #fff;
  font-family: CormorantGaramond;
  font-size: 3rem;
}

#Contato p  {
  color: white;
  font-family: Poppins-R;
  font-size: 0.9rem;
}

#Contato button {
    background: #d7c9b3;
  color: white;
  font-family: Poppins-R;
  font-size: 16px;
  margin-top: 30px;
  border-radius: 9px;
  width: 222px;
  height: 40px;
  cursor: pointer;
}

#Contato button:hover {
  scale: 1.07;
  transition: 0.5s;
}

#lb-logo-branco {
  position: relative;
  width: 200px;
  right: 3%;
}


.Contato {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-left: 42px;
  text-align: left;
}

.Contato p {
  position: static;
  margin-left: 0;
}

.contact-link {
  display: grid;
  grid-template-columns: 24px auto;
  align-items: center;
  gap: 10px;
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.contact-link:hover {
  opacity: 0.78;
  transform: translateX(3px);
}

.site-footer {
  position: absolute;
  left: 50%;
  bottom: 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  transform: translateX(-50%);
}

.site-footer img {
  width: 86px;
  opacity: 1;
}

#Contato .site-footer p {
  color: #4f4f4f;
  font-family: Poppins-R;
  font-size: 10px;
  line-height: 1.2;
  opacity: 0.42;
}

html {
  scroll-behavior: smooth;
}

.reveal {
  opacity: 0;
  filter: blur(6px);
  transform: translate3d(0, 28px, 0);
  transition:
    opacity 0.85s ease,
    filter 0.85s ease,
    transform 0.85s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, filter, transform;
}

.reveal-left {
  transform: translate3d(-34px, 0, 0);
}

.reveal-right {
  transform: translate3d(34px, 0, 0);
}

.reveal.is-visible {
  opacity: 1;
  filter: blur(0);
  transform: translate3d(0, 0, 0);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .reveal {
    opacity: 1;
    filter: none;
    transform: none;
    transition: none;
  }
}

/* ------------------------- */
/* Ajustes responsivos */
/* ------------------------- */

@media (max-width: 1280px) {
  .nav-menu ul {
    gap: 2rem;
  }

  h1 {
    font-size: 68px;
    width: 650px;
  }

  #line {
    margin-top: 215px;
  }

  #text-home {
    margin-top: 245px;
  }

  #home-button {
    margin-top: 365px;
  }

  #laura-foto-home {
    width: min(50vw, 620px);
    left: 45%;
  }

  #session2 {
    gap: 90px;
  }

  #Sobre {
    height: auto;
    min-height: 120vh;
    gap: 40px;
  }

  #foto-laura-sobre {
    width: 36%;
    object-fit: cover;
  }

  .container-sobre-mim {
    position: relative;
    left: auto;
    width: 48%;
  }

  .container-sobre-mim p {
    width: 100%;
  }

  #Serviços {
    height: auto;
    min-height: 50vh;
    padding: 70px 5%;
  }

  .container-texto-serviços {
    margin-left: 0;
    min-width: 280px;
  }

  .container-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(230px, 1fr));
    gap: 24px;
    margin-left: 55px;
    width: 100%;
  }

  .cards {
    width: 100%;
    min-height: 300px;
    height: auto;
    padding: 16px;
  }
}

@media (max-width: 900px) {
  .nav-container {
    height: 78px;
    justify-content: center;
    padding: 0 20px;
  }

  #logo-nav {
    position: static;
    width: auto;
    height: 52px;
  }

  .nav-menu,
  .nav-toggle {
    display: none;
  }

  #Home {
    min-height: auto;
    display: block;
    padding: 120px 22px 50px;
    text-align: center;
  }

  .container-texto-home {
    position: relative;
    left: auto;
    top: auto;
    width: min(100%, 620px);
    margin: 0 auto;
    z-index: 6;
  }

  .psicologia,
  h1,
  #line,
  #text-home,
  #home-button {
    position: static;
  }

  .psicologia {
    display: block;
    font-size: 18px;
    margin-bottom: 12px;
  }

  h1 {
    width: 100%;
    font-size: 54px;
    line-height: 0.95;
    margin: 0;
  }

  #line {
    width: auto;
    height: auto;
    margin: 14px 0 18px;
    overflow: hidden;
  }

  #text-home {
    width: 100%;
    max-width: 460px;
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.55;
  }

  #home-button {
    width: min(100%, 260px);
    height: 50px;
    margin-top: 28px;
  }

  #laura-foto-home {
    position: relative;
    display: block;
    width: min(92%, 430px);
    top: 50px;
    bottom: auto;
    left: auto;
    margin: 30px auto 0;
  }

  #logo-lb-home {
    display: block;
    position: absolute;
    width: min(92vw, 430px);
    top: auto;
    left: 50%;
    bottom: 26px;
    z-index: 1;
    opacity: 0.12;
    transform: translateX(-50%);
  }

  #session2 {
    height: auto;
    padding: 28px 22px;
    gap: 18px;
    justify-content: space-between;
  }

  .card-acolhimento,
  .card-crescimento,
  .card-online {
    flex: 1;
    flex-direction: column;
    gap: 10px;
    text-align: center;
  }

  .card-acolhimento .acolhimento-icon,
  .card-crescimento .crescimento-icon,
  .card-online .online-icon {
    width: 42px;
    height: 42px;
  }

  .card-acolhimento p,
  .card-crescimento p,
  .card-online p {
    margin-left: 0;
    font-size: 15px;
    line-height: 1.25;
  }

  #Sobre {
    display: flex;
    flex-direction: column;
    height: auto;
    min-height: 0;
    padding: 70px 22px;
  }

  #foto-laura-sobre {
    width: min(100%, 460px);
    max-height: 620px;
    margin: 0 auto;
    border-radius: 18px;
    object-fit: cover;
  }

  .container-sobre-mim {
    width: min(100%, 640px);
    margin: 0 auto;
  }

  .container-sobre-mim h2 {
    width: 100%;
    font-size: 42px;
    line-height: 0.98;
  }

  .container-sobre-mim p {
    font-size: 16px;
    line-height: 1.75;
    margin-top: 28px;
  }

  #Serviços {
    flex-direction: column;
    align-items: flex-start;
    padding: 70px 22px;
    gap: 38px;
  }

  .container-texto-serviços {
    width: 100%;
  }

  .container-texto-serviços span {
    font-size: 17px;
  }

  .container-texto-serviços h2 {
    font-size: 72px;
    line-height: 0.95;
  }

  .container-texto-serviços p {
    font-size: 17px;
    line-height: 1.6;
  }

  .container-texto-serviços button {
    display: none;
  }

  .container-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-left: 0;
    gap: 18px;
  }

  .cards {
    min-height: 280px;
  }

  .psicoterapia-icon,
  .adolescentes-icon,
  .adultos-icon,
  .idosos-icon {
    width: 92px;
    height: 92px;
  }

  #Contato {
    height: auto;
    min-height: 0;
    flex-direction: column;
    padding: 54px 22px 86px;
    gap: 26px;
  }

  #lb-logo-branco {
    width: 140px;
    right: auto;
  }

  #Contato h5 {
    font-size: 40px;
    line-height: 1;
  }

  #Contato p {
    font-size: 15px;
    line-height: 1.5;
  }

  .Contato {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    margin-left: 0;
    text-align: left;
  }

  .Contato p {
    position: static;
    margin-left: 0;
  }
}

@media (max-width: 560px) {
  .nav-container {
    height: 70px;
  }

  #logo-nav {
    height: 45px;
  }

  #Home {
    padding: 102px 18px 38px;
  }

  h1 {
    font-size: 42px;
  }

  #text-home {
    font-size: 16px;
  }

  #laura-foto-home {
    width: min(100%, 360px);
    margin-top: 24px;
  }

  #logo-lb-home {
    width: min(115vw, 460px);
    bottom: 18px;
    opacity: 0.12;
  }

  #session2 {
    display: grid;
    grid-template-columns: 1fr;
    padding: 30px 18px;
    gap: 22px;
  }

  .card-acolhimento,
  .card-crescimento,
  .card-online {
    flex-direction: row;
    justify-content: flex-start;
    text-align: left;
    max-width: 260px;
    margin: 0 auto;
    width: 100%;
  }

  #Sobre {
    padding: 56px 18px;
  }

  #foto-laura-sobre {
    max-height: none;
  }

  .container-sobre-mim span {
    font-size: 18px;
  }

  .container-sobre-mim h2 {
    font-size: 36px;
  }

  .container-sobre-mim p {
    font-size: 15px;
    line-height: 1.7;
  }

  #Serviços {
    padding: 58px 18px;
  }

  .container-texto-serviços h2 {
    font-size: 58px;
  }

  .container-texto-serviços p br {
    display: none;
  }

  .container-texto-serviços button,
  #Contato button,
  #home-button {
    width: 100%;
    max-width: 290px;
  }

  .container-cards {
    grid-template-columns: 1fr;
  }

  .cards {
    min-height: 0;
    padding: 20px 18px 24px;
  }

  #card-psicoterapia h4,
  #card-Adolescentes h4,
  #card-Adultos h4,
  #card-Idosos h4 {
    font-size: 28px;
  }

  #card-psicoterapia p,
  #card-Adolescentes p,
  #card-Adultos p,
  #card-Idosos p {
    font-size: 14px;
    line-height: 1.55;
  }

  #Contato h5 {
    font-size: 34px;
  }
}
