@import url("./colors.css");

.card p {
  color: var(--color-secondary);
  font-size: initial;
}

/* Solutions */

.card-solutions {
  width: 300px;
  height: 222px;
  border-radius: 1em;
  overflow: hidden;

  background-size: 300px;
  background-position: center;
  background-repeat: no-repeat;

  transition: background-size 0.4s ease;
}

.card-solutions:hover {
  background-size: 330px;
}

.card-solutions-our-services {
  width: 16em !important;
  border-radius: 1em !important;
  border: 1px solid var(--color-blue-light) !important;
  background-color: var(--color-blue) !important;
  height: auto !important;
  margin: 0 0.25rem 2rem 0.25rem !important;
}

.card-solutions-img-div {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}

.card-solutions-img-div-our-services {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  max-width: 75% !important;
  height: auto !important;
}

.card-solutions-img-div-our-services img {
  transition: transform 0.35s ease;
}

.card-solutions-our-services:hover .card-solutions-img-div-our-services img {
  transform: scale(1.1);
}

.card-solutions-info {
  height: 3rem;
  display: flex;
  justify-content: center;
}

/* Card clients */

#card-clients {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--color-white);
  width: 300px;
  height: 150px;
  border: 2px solid var(--color-secondary) !important;
  transition: all 0.4s;
}

#card-clients:hover {
  border: 2px solid var(--color-primary) !important;
}

#card-clients .card-body {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 150px;
  height: auto;
}

#card-clients .card-body .card-img {
  max-width: 150px;
  height: auto;
}

#card-clients .card-img img {
  filter: grayscale(100%) contrast(100%) brightness(100%);
  transition: filter 0.3s ease;
}

#card-clients:hover .card-img img {
  filter: grayscale(0%) contrast(1) brightness(1);
}

/* Clients */

#clients {
  border: 2px solid var(--color-primary);
  background: var(--color-bg-grey);
}

#clients .card {
  max-width: 289px;
  min-width: 289px;
  min-height: 180px;
  max-height: 180px;
  border: 2px solid transparent;
  transition: all 0.4s;
}

#clients .card .client-image-container {
  max-width: 289px;
  height: 200px;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

#clients .card .client-image-container img {
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: grayscale(100%);
  transform: scale(1);
  transition: all 0.4s;
}

#clients .card:hover .client-image-container img {
  filter: grayscale(0%);
}

/* Principles */

#card-about .card {
  background: none;
  border: none;
}

#card-about .card-body .card-text {
  margin: 0;
}

#card-about .card .card-body {
  background: var(--color-bg-grey-light);
}

#card-about .card .card-body.card-body-principle {
  background: none !important;
}

#card-about .card .card-body p {
  text-align: justify;
  min-height: 150px;
  max-height: 150px;
  overflow-y: auto;
  font-size: initial !important;
}

#card-about .card .card_icon img {
  max-height: 100px;
}

/* Cards Blog */

#blog .card {
  max-height: 280px;
  min-height: 280px;
  width: 100%;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  background: var(--color-white);
  overflow: hidden;
  box-shadow: 5px 5px 16px -4px rgba(0, 0, 0, 0.397);
}

#blog .card .card-image {
  width: 100%;
  min-width: 300px;
  max-width: 300px;
}

#blog .card .card-body {
  display: flex;
  flex-direction: column;
  width: 100%;
  flex: content !important;
  align-items: flex-start;
}

#blog .card .card-body {
  width: 100%;
  flex: content !important;
}

#blog .card .card-body .title p {
  font-size: 22px !important;
  color: var(--color-primary);
}

#blog .card .date {
  position: absolute;
  top: 10px;
  left: 10px;
  font-size: 15px;
  color: var(--color-white);
}

#blog .card .card-body .desc p {
  text-align: justify;
  color: var(--color-secondary);
  font-size: 16px !important;
}

/* Testimonial */

#testimonial .card {
  border: none;
  background: var(--color-white);
}

#testimonial .card .card-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 150px;
  height: 150px;
  border-radius: 100%;
  border: 2px solid var(--color-primary);
  background: var(--color-bg-grey-light);
  overflow: hidden;
}

#testimonial .card p {
  color: var(--color-secondary);
  text-align: justify !important;
}

/* Marcas */

#card-brands {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 120px;
  max-height: 120px;
  overflow: hidden;
  border-radius: 15px;
  background: var(--color-white);
  box-shadow: -7px 9px 8px #00000040 !important;
}

#card-brands img {
  max-width: 100%;
  max-height: 100%;
  height: auto;
  width: auto;
  object-fit: contain;
  display: block;
}

/* Card Differences */

.card-overlay-content {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.card-overlay-content p,
.card-overlay-content h5 {
  max-width: 200px;
}

/* Card blog home */
.news-card {
  max-width: 380px;
  border-radius: 20px;
  overflow: hidden;
  background-color: var(--color-bg-grey-light);
  transition: all 0.3s ease;
}

.news-card:hover .news-image {
  transform: scale(1.05);
}

.news-image-wrapper {
  position: relative;
  overflow: hidden;
  height: 300px;
}

.news-image {
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease;
}

.news-title {
  font-size: 20px;
  height: 55px;
  color: var(--color-primary-dark);
  text-align: center;
}

.news-summary {
  font-size: 16px;
  color: var(--color-primary-dark);
  text-align: justify;
}

/* Card diferencias */

.difference-link {
  max-width: 380px;
  text-decoration: none;
  display: block;
}

.difference-link:hover .difference-image {
  transform: scale(1.05);
}

.card-difference-overlay {
  height: 400px;
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}

.difference-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: all 0.3s ease;
}

.difference-placeholder {
  width: 100%;
  height: 100%;
  background-color: var(--bs-secondary);
}

.card-overlay-content {
  position: absolute;
  bottom: 15px;
}

.difference-title {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: 0;
}

.difference-subtitle {
  font-size: 13px;
  color: #fff;
  margin-top: 5px;
  margin-bottom: 0;
}
