/***************************** Partie Research et Filters ******************************/

/* === Titre de la section recherche === */

.research-filters-section {
  @media (max-width: 767.98px) {
    padding: 0 20px;
  }
}

.research-title {
  h1 {
    padding: 10px 0;
    font-size: var(--font-size-title-section);

    @media (max-width: 767.98px) {
      padding-top: 30px;
    }
  }

  p {
    font-weight: 400;
  }
}

/* === Formulaire de recherche === */

.research-form {
  display: flex;
  align-items: center;
  margin: 30px 0;

  .icon-map-container {
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 48px;
    height: 49px;
    border-radius: 15px 0 0 15px;
    background-color: var(--main-bg-color);
    border: 1px solid var(--main-bg-color);

    #icone-maps {
      font-size: 20px;
      color: var(--black);
    }
  }

  #user-input {
    width: 150px;
    padding-left: 20px;
    border-top: 1px solid var(--main-bg-color);
    border-bottom: 1px solid var(--main-bg-color);
    border-left: none;
    border-right: none;
    height: 49px;
    color: var(--black);

    @media (max-width: 767.98px) {
      width: 220px;
      min-width: 100px;
    }

    &::placeholder {
      color: var(--black);
    }
  }

  .btn-research {
    width: 132px;
    height: 49px;
    border-radius: 0 15px 15px 0;
    border: 1px solid var(--main-color);
    background-color: var(--main-color);
    color: var(--white);
    cursor: pointer;
    transition: all 0.2s ease;

    @media (max-width: 767.98px) {
      min-width: 48px;
      width: 48px;
      font-size: 16px;
      border-radius: 15px;
      box-shadow: 0px 4px 2px 0px rgba(0, 0, 0, 0.3);
    }

    &:hover {
      background-color: var(--dark-blue);
      border: 1px solid var(--dark-blue);
    }

    span {
      @media (max-width: 767.98px) {
        font-size: 16px;
      }
    }

    #research {
      display: inline;
      transition: all 0.3s ease;

      @media (max-width: 767.98px) {
        display: none;
      }
    }

    #glass {
      display: none;

      @media (max-width: 767.98px) {
        display: inline;

        i {
          color: var(--white);
        }
      }
    }
  }
}


/* === Section des filtres === */

.filter-section {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(10px, 2vw, 40px);
  /* = gap dynamique: 2vw = 2% de la largeur de l'écran et compris entre 10px et 40px */
  margin-bottom: 30px;

  @media (max-width: 1024px) {
    flex-direction: column;
    align-items: flex-start;
  }

  @media (max-width: 767.98px) {
    gap: 20px;
    font-size: 16px;
  }

  h2 {
    font-size: var(--font-size-title-section);
  }

  .filter-list {
    display: flex;
    gap: clamp(10px, 1.4vw, 60px);
    margin: 0;

    @media (max-width: 767.98px) {
      flex-wrap: wrap;
      gap: 15px;
    }

    .filter-button {
      display: flex;
      flex-wrap: wrap;
      align-items: center;
      padding: 0em 1.3em;
      gap: 10px;
      width: auto;
      height: 50px;
      border-radius: 25px;
      background-color: var(--white);
      border: 2px solid var(--dark-grey);
      cursor: pointer;
      transition: background-color 0.4s ease, transform 0.2s ease;

      @media (max-width: 1024px) {
        font-size: 14px;
      }

      @media (max-width: 767.98px) {
        width: 160px;
      }

      &:hover {
        background-color: var(--filter-bg-color);
      }

      &:active {
        transform: scale(0.8);
      }

      i {
        font-size: 20px;
        color: var(--main-color);
      }

      @media (max-width: 767.98px) {
        span {
          font-size: 14px;
        }
      }
    }
  }
}

/* === Petite zone point informations logements === */

.info-message {
  display: flex;
  gap: 10px;
  margin: 30px 0;
  align-items: center;

  @media (max-width: 767.98px) {
    margin-top: 30px;
  }

  span {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 15px;
    color: var(--main-color);
    background-color: var(--white);
    border: 2px solid var(--dark-grey);
    border-radius: 50%;
    padding: 5px;
    width: 15px;
    height: 15px;
  }

  p {
    font-weight: 400;
    margin: 0;
  }
}


/* CSS classique, pour le validator W3, car il ne comprends pas le nesting === checked */
/* 
@media (max-width: 767.98px) {
  .research-filters-section {
    padding: 0 20px;
  }
}

.research-title h1 {
  padding: 10px 0;
  font-size: var(--font-size-title-section);
}

@media (max-width: 767.98px) {
  .research-title h1 {
    padding-top: 30px;
  }
}

.research-title p {
  font-weight: 400;
}

.research-form {
  display: flex;
  align-items: center;
  margin: 30px 0;
}

.research-form .icon-map-container {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 48px;
  height: 49px;
  border-radius: 15px 0 0 15px;
  background-color: var(--main-bg-color);
  border: 1px solid var(--main-bg-color);
}

.research-form .icon-map-container #icone-maps {
  font-size: 20px;
  color: var(--black);
}

.research-form #user-input {
  width: 150px;
  padding-left: 20px;
  border-top: 1px solid var(--main-bg-color);
  border-bottom: 1px solid var(--main-bg-color);
  border-left: none;
  border-right: none;
  height: 49px;
  color: var(--black);
}

@media (max-width: 767.98px) {
  .research-form #user-input {
    width: 220px;
    min-width: 100px;
  }
}

.research-form #user-input::placeholder {
  color: var(--black);
}

.research-form .btn-research {
  width: 132px;
  height: 49px;
  border-radius: 0 15px 15px 0;
  border: 1px solid var(--main-color);
  background-color: var(--main-color);
  color: var(--white);
  cursor: pointer;
  transition: all 0.2s ease;
}

@media (max-width: 767.98px) {
  .research-form .btn-research {
    min-width: 48px;
    width: 48px;
    font-size: 16px;
    border-radius: 15px;
    box-shadow: 0px 4px 2px 0px rgba(0, 0, 0, 0.3);
  }
}

.research-form .btn-research:hover {
  background-color: var(--dark-blue);
  border: 1px solid var(--dark-blue);
}

@media (max-width: 767.98px) {
  .research-form .btn-research span {
    font-size: 16px;
  }
}

.research-form .btn-research #research {
  display: inline;
  transition: all 0.3s ease;
}

@media (max-width: 767.98px) {
  .research-form .btn-research #research {
    display: none;
  }
}

.research-form .btn-research #glass {
  display: none;
}

@media (max-width: 767.98px) {
  .research-form .btn-research #glass {
    display: inline;
  }

  .research-form .btn-research #glass i {
    color: var(--white);
  }
}

.filter-section {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(10px, 2vw, 40px);
  margin-bottom: 30px;
}

@media (max-width: 1024px) {
  .filter-section {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 767.98px) {
  .filter-section {
    gap: 20px;
    font-size: 16px;
  }
}

.filter-section h2 {
  font-size: var(--font-size-title-section);
}

.filter-section .filter-list {
  display: flex;
  gap: clamp(10px, 1.4vw, 60px);
  margin: 0;
}

@media (max-width: 767.98px) {
  .filter-section .filter-list {
    flex-wrap: wrap;
    gap: 15px;
  }
}

.filter-section .filter-list .filter-button {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 0em 1.3em;
  gap: 10px;
  width: auto;
  height: 50px;
  border-radius: 25px;
  background-color: var(--white);
  border: 2px solid var(--dark-grey);
  cursor: pointer;
  transition: background-color 0.4s ease, transform 0.2s ease;
}

@media (max-width: 1024px) {
  .filter-section .filter-list .filter-button {
    font-size: 14px;
  }
}

@media (max-width: 767.98px) {
  .filter-section .filter-list .filter-button {
    width: 160px;
  }
}

.filter-section .filter-list .filter-button:hover {
  background-color: var(--filter-bg-color);
}

.filter-section .filter-list .filter-button:active {
  transform: scale(0.8);
}

.filter-section .filter-list .filter-button i {
  font-size: 20px;
  color: var(--main-color);
}

@media (max-width: 767.98px) {
  .filter-section .filter-list .filter-button span {
    font-size: 14px;
  }
}

.info-message {
  display: flex;
  gap: 10px;
  margin: 30px 0;
  align-items: center;
}

@media (max-width: 767.98px) {
  .info-message {
    margin-top: 30px;
  }
}

.info-message span {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  color: var(--main-color);
  background-color: var(--white);
  border: 2px solid var(--dark-grey);
  border-radius: 50%;
  padding: 5px;
  width: 15px;
  height: 15px;
}

.info-message p {
  font-weight: 400;
  margin: 0;
} */