@import url(./fonts.css);
:root {
  /************************************** FuentesPrincipales ******************************************/
  --poppins: Poppins, cursive;
  --amaranth: Amaranth, regular;
  --monserrat: Montserrat, regular;
  --open_sans: Open_sans;
  /**************************************x FuentesPrincipalesx ******************************************/
}

html,
body {
  font-family: var(--poppins);
}

body {
  background: #fff;
  color: black;
  font-size: 16px;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
/* COLORS */
.vino-lighten-2 {
  background-color: #e6dfe7;
}

.vino-lighten-1 {
  background-color: #c3b0c5;
}
.vino {
  background-color: #a080a3;
}

.vino-dark-1 {
  background-color: #865b8b;
}

.vino-dark-2 {
  background-color: #6f3a74;
}

.service p {
  font-size: 20px !important;
}

.service img {
  width: 70% !important;
  height: 70% !important;
}

.company {
  padding-top: 1em;
  padding-bottom: 1em;
}

.company .container blockquote {
  font-family: var(--monserrat);
  font-size: 22px;
}

.product {
  margin-top: 3em;
}

.product .card-title {
  color: black !important;
  font-weight: bold;
}

.product .row .col .card .card-content span {
  text-align: center;
}

.product .row .col .card .card-content p {
  font-family: var(--monserrat);
  text-align: center;
}

.product .row{
  margin-bottom: 5%;
}

/* COMPANY PAGE */

.company-page {
  margin: 40px;
}

.company-page-cards {
  margin: 60px;
}

.company-page #comp-content {
  display: flex;
  align-items: center;
}

.company-page.row .col h3 {
  font-family: var(--poppins);
}

.company-page .row p {
  font-family: var(--open_sans);
  text-align: justify;
  font-size: 17px;
}

.company-page-cards .card-panel h4 {
  font-family: var(--poppins);
  text-align: center;
}

.company-page-cards .card-panel p {
  font-family: var(--open_sans);
  text-align: justify;
}

.company-page #comp-logo {
  max-width: 300px;
  width: 100%;
  height: 100%;
  display: block;
}

.company-page #comp-img {
  max-width: 600px;
  width: 100%;
  height: 100%;
  display: block;
}

.company-page .row {
  font-size: 20px;
  margin-left: 4em;
  margin-right: 4em;
}

.company-page .row:first-child {
  padding-top: 3em;
}

.company-page .row:last-child {
  padding-bottom: 3em;
}

/* Products PAGE */
.product-page {
  margin: 5vw;
}

.product-page-title h3 {
  width: 100%;
  text-align: center;
  border-bottom: 1px solid #000;
  line-height: 0.1em;
  margin: 1em 0 2em 0;
  font-family: var(--open_sans);
  transform: translateX(0%);
}

.product-page-title h3 span {
  background: #fff;
  padding: 0 10px;
}

.product-page .input-field .prefix.active {
  color: #6f3a74;
}

.product-page .input-field input[type="search"]:not(.browser-default):focus {
  border-bottom: 1px solid #6f3a74;
}

.product-page button {
  width: 100%;
  text-align: left;
}

.product-page button:hover {
  background-color: #865b8b;
  color: #fff;
}

.dropdown-product {
  text-decoration: none;
}

.dropdown-product:hover {
  background-color: #6f3a74;
}

.dropdown-product:focus {
  background-color: #865b8b;
}

.product-page .dropdown-content li {
  min-height: auto;
}

.filterDiv {
  display: none; /* Hidden by default */
  margin-top: 40px;
  padding: 25px;
  background-color: #e6dfe7;
}

.filterDiv h3 {
  font-size: 25px;
}

.filterDiv .collapsible-header {
  display: block;
  text-align: center;
  align-items: center;
}

.filterDiv img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 200px;
  object-fit: contain;
  background-color: white;
  box-shadow: 0 1px 3px rgba(34, 25, 25, 0.4);
  -moz-box-shadow: 0 1px 2px rgba(34, 25, 25, 0.4);
  -webkit-box-shadow: 0 1px 3px rgba(34, 25, 25, 0.4);
}

/* The "show" class is added to the filtered elements */
.show {
  display: block;
}

/* Add a dark background to the active button */
.btn.active {
  background-color: #666;
  color: white;
}

/* SERVICE PAGE */

.service-page{
  margin-bottom: 5%;
}

.service-page h3 {
  width: 100%;
  text-align: center;
  border-bottom: 1px solid #000;
  line-height: 0.1em;
  margin: 1em 0 2em 0;
  font-family: var(--open_sans);
  transform: translateX(0%);
}

.service-page h3 span {
  background: #fff;
  padding: 0 10px;
}

.service-page h4 {
  display: block;
  text-align: center;
}

.service-img img {
  display: block;
  margin: auto;
  width: 100%;
  height: 100%;
  max-width: 150px;
  max-height: 150px;
}

/* CONTACT PAGE */
.contact{
  margin-bottom: 5%;
}

.contact h3 {
  width: 100%;
  text-align: center;
  border-bottom: 1px solid #000;
  line-height: 0.1em;
  margin: 1em 0 2em 0;
  font-family: var(--open_sans);
  transform: translateX(0%);
}

.contact h3 span {
  background: #fff;
  padding: 0 10px;
}

.send-success {
  margin-top: 20vh;
  margin-bottom: 30vh;
  padding: 5vh;
  background-color: #7ebb7a;
}

.contact .send-failed {
  padding: 1em;
  background-color: #f78b8b;
}

/* label focus color */
.contact .input-field input[type="text"]:focus + label {
  color: #6f3a74;
}

.contact .input-field textarea:focus + label {
  color: #6f3a74;
}

/* label underline focus color */
.contact .input-field input[type="text"]:focus {
  border-bottom: 1px solid #6f3a74;
  box-shadow: 0 1px 0 0 #000;
}

.contact .input-field textarea:focus {
  border-bottom: 1px solid #6f3a74;
  box-shadow: 0 1px 0 0 #000;
}

/* icon prefix focus color */
.contact .input-field .prefix.active {
  color: #6f3a74;
}

.contact .btn[type="submit"]:hover {
  background-color: #c3b0c5;
}

/* FOOTER SECTION */

footer {
  margin-top: auto;
}

footer .info {
  font-weight: bold;
}

footer .material-icons {
  margin-right: 7px;
}

footer .footer-info p {
  display: flex;
  padding-top: 15px;
}

footer .footer-info a {
  text-decoration: none;
  color: #fff;
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .company-page #comp-content {
    display: block;
  }
}

@media only screen and (max-width: 767px) {
  /* Footer */
  footer {
    margin-top: 3em;
  }

  footer .material-icons {
    font-size: 16px;
  }

  footer .footer-info p {
    padding-top: 0;
    font-size: 14px;
  }

  footer .footer-info a {
    font-size: 14px;
  }

  footer .footer-nav h5 {
    padding-top: 15px;
    font-size: 14px;
  }

  footer .footer-nav li {
    padding-bottom: 7px;
  }

  footer .footer-nav a {
    font-size: 13px;
  }

  .footer-copyright {
    font-size: 12px;
  }

  /* Home page */

  .service p {
    font-size: 16px !important;
  }

  .service img {
    width: 50% !important;
    height: 50% !important;
  }

  .company .container blockquote {
    font-size: 16px;
  }

  .product .card-title {
    font-size: 20px;
  }

  .product .card-content {
    font-size: 14px;
  }

  /* COMPANY PAGE */
  .company-page {
    margin: 20px;
  }

  .company-page #comp-content {
    display: block;
  }

  .company-page-cards {
    margin: 20px;
  }

  .company-page .row {
    margin-left: 20px;
    margin-right: 20px;
  }

  .company-page #comp-logo {
    max-width: 100%;
    max-height: 100%;
    display: block;
  }

  .company-page #comp-img {
    margin-top: 2%;
    margin-bottom: 2%;
    max-width: 100%;
    max-height: 100%;
    display: block;
  }

  .company-page .row .col h3 {
    font-family: var(--poppins);
    font-size: 24px;
  }

  .company-page .row p {
    font-family: var(--open_sans);
    text-align: justify;
    font-size: 14px;
  }

  .company-page-cards .card-panel h4 {
    font-family: var(--poppins);
    font-size: 22px;
    text-align: center;
  }

  .company-page-cards .card-panel p {
    font-family: var(--open_sans);
    font-size: 14px;
    text-align: justify;
  }

  .company-page .row:first-child {
    padding-top: 1em;
  }

  .company-page .row:last-child {
    padding-bottom: 1em;
  }

  /* SERVICE PAGE */

  .service-page h3 {
    font-size: 30px;
  }

  .service-page h4 {
    font-size: 20px;
  }

  .service-page P {
    font-size: 16px;
  }

  /* PRODUCT PAGE */
  .product-page h4 {
    font-size: 22px;
  }

  .product-page .filterDiv {
    padding: 15px;
  }

  /* CONTACT PAGE */
  .contact h3 {
    font-size: 30px;
  }

  /* PRODUCT PAGE */
  .product-page-title h3 {
    font-size: 30px;
  }
}
.contenedor {
  width: 300px; /* Ancho deseado para el div */
  height: 200px; /* Alto deseado para el div */
  position: relative; /* Importante para el posicionamiento */
  overflow: hidden; /* Oculta el exceso de imagen si es más grande que el div */
}

.contenedor img {
  width: 100%; /* Establece el ancho de la imagen al 100% del div */
  height: 100%; /* Establece el alto de la imagen al 100% del div */
  object-fit: cover; /* Escala la imagen para que cubra todo el div */
  position: absolute; /* Permite el posicionamiento absoluto */
  top: 0; /* Alinea la imagen en la parte superior del div */
  left: 0; /* Alinea la imagen en la parte izquierda del div */
}
