#ipi-bp-search-box {
  padding: 20px;
  background-color: #f7f7f7;
  position: relative;
}

#ipi-bp-search-box h2 {
  margin-top: 0px;
  position: relative;
  padding-left: 30px;
}

#ipi-bp-search-box h2::before {
  content: "\f002";
  font-family: "FontAwesome";
  position: absolute;
  left: 5px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
}

#ipi-bp-search-box #ipi-bp-filter-toggle {
  position: absolute;
  top: 20px;
  right: 20px;
  line-height: 30px;
  font-weight: 500;
  font-size: 18px;
  cursor: pointer;
}

.ipi-bp-filter-row {
  display: grid;
  grid-template-columns: repeat(3, calc((100% - 20px) / 3));
  grid-gap: 10px;
  margin-top: 10px;
  margin-bottom: 0px;
  overflow: hidden;
  max-height: 0px;
  transition: max-height 0.4s;
  border: none;
}

.ipi-bp-filter-row.open {
  max-height: initial;
  margin-bottom: 10px;
}

.ipi-bp-filter-row select {
  border: 1px solid #b5b5b5;
  outline: none;
}

@media only screen and (max-width: 1200px) {
  .ipi-bp-filter-row {
    grid-template-columns: repeat(2, calc((100% - 10px) / 2));
  }
}

@media only screen and (max-width: 1000px) {
  .ipi-bp-filter-row {
    grid-template-columns: 100%;
    grid-gap: 5px;
  }
}

#ipi-bp-search-btn {
  padding: 6px 12px;
  border: 1px solid #009ab2;
  background-color: white;
  width: 100%;
  text-align: center;
  color: #009ab2;
  transition: color 0.4s, background-color 0.4s;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 500;
  box-shadow: none!important;
  float: none;
}

#ipi-bp-search-btn:hover {
  background-color: #009ab2;
  color: white;
}

#ipi-bp-counter {
  display: flex;
  justify-content: space-between;
}

#ipi-bp-counter > div {
  position: relative;
  width: 30%;
}

#ipi-bp-counter > div > div {
  position: relative;
  padding-bottom: 100%;
  background-color: #009ab2;
}

#ipi-bp-counter > div > div > .ipi-bp-count-inner {
  position: absolute;
  color: white;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  width: 100%;
  padding: 0 4px;
}

#ipi-bp-counter > div > div > .ipi-bp-count-inner .ipi-bp-count-nr {
  font-size: 50px;
  font-weight: 500;
}

#ipi-bp-counter > div > div > .ipi-bp-count-inner .ipi-bp-count-label {
  font-size: 18px;
  font-weight: 400;
}

@media only screen and (max-width: 1450px) {
  #ipi-bp-counter > div > div > .ipi-bp-count-inner .ipi-bp-count-nr {
    font-size: 40px;
  }

  #ipi-bp-counter > div > div > .ipi-bp-count-inner .ipi-bp-count-label {
    font-size: 15px;
  }
}

.bp-remove-filter-row {
  margin-top: 10px;
  text-align: right;
}

.bp-remove-filter-row a {
  font-size: 14px;
  font-weight: 500;
  color: #009ab2;
}

#bp-search-result-count {
  font-size: 24px;
  font-weight: 400;
}

#bp-search-result-count span {
  font-weight: 600;
}

.bp-count-filter-val span {
  font-weight: 500;
}

#ipa-prog-filter {
  line-height: 0;
  display: inline;
  border: none;
  font-style: italic;
  margin-left: 20px;
}

#ipa-prog-filter input:not(:first-child) {
  margin-left: 5px;
}

.bp-back-links {
  padding: 5px 0;
}

.bp-back-links a {
  font-size: 14px;
  color: #c4c4c4;
  opacity: 0.8;
  text-transform: uppercase;
  padding: 4px 0;
}

.bp-back-links a:hover {
  opacity: 1;
}

.bp-back-links a::before {
  font-family: "FontAwesome";
  content: "\f177";
  margin-right: 5px;
}

.single-ipi_project .entry-header {
  margin-bottom: 20px;
}
