@charset "UTF-8";

body {
  padding-top: 40px;
  background: linear-gradient(to right, #1e3c72, #2a5298);
  font-family: "Roboto", sans-serif;
}

.icon-img {
  width: 170px;
  height: 170px;
  object-fit: contain;
  transition: transform 0.3s ease;
}

.icon-container:hover .icon-img {
  transform: scale(1.15);
}

h1, h2 {
  color: white;
  text-align: center;
  margin: 0;
  padding: 0;
  font-weight: 300;
  text-decoration: none;
}

h1 {
  margin-bottom: 40px;
}

h2 {
  transition: transform 0.3s ease, color 0.3s ease;
}

a {
  text-decoration: none;
  color: inherit;
}

.wrapper {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
}

.main-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 10px;
}

.container {
  flex: 1 1 100%;
  margin-bottom: 20px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.container:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.3);
  border-radius: 20px;
}

.container:hover h2 {
  color: #f3f0d9;
  transform: scale(1.05);
}

.container h2 {
  margin-top: 20px;
  color: white;
  text-align: center;
  font-size: 1.2em;
}

/* Tamaño y estilo del contenedor del ícono */
.icon-container {
  width: 170px;
  height: 170px;
  border-radius: 20%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  transition: transform 0.3s ease;
}

.icon-container i {
  font-size: 5.5em;
  transition: transform 0.3s ease;
  color: white;
}

.icon-container:hover i {
  transform: scale(1.15);
}

/* Fondo de cada cuadro con degradado */
.timeslip {
  background: linear-gradient(#19b2a8, #56cec6);
}

.grau {
  background: linear-gradient(#0d535f, #1cafc9);
}

.dertec {
  background: linear-gradient(#2196f3, #64b5f6);  
}

.begonias {
  background: linear-gradient(#f44336, #e57373);
}

.consulting {
  background: linear-gradient(#4caf50, #81c784);
}

.glpi {
  background: linear-gradient(#d46dfb, #842cc2);
}

/* Pantallas pequeñas < 480px: 1 por fila */
@media (max-width: 479px) {
  .container {
    flex: 1 1 100%;
  }

  .icon-container {
    width: 140px;
    height: 140px;
  }

  .container h2 {
    font-size: 1.1em;
  }
}

/* Pantallas >= 480px: 2 por fila */
@media (min-width: 480px) {
  .container {
    flex: 1 1 calc(50% - 20px);
  }
}

/* Pantallas >= 768px: 3 por fila */
@media (min-width: 768px) {
  .container {
    flex: 1 1 calc(33.333% - 20px);
  }
}

/* Pantallas >= 1024px: 4 por fila */
@media (min-width: 1024px) {
  .container {
    flex: 1 1 calc(25% - 20px);
  }
}

/* Pantallas grandes >= 1440px: 5 por fila */
@media (min-width: 1440px) {
  .container {
    flex: 1 1 calc(20% - 20px);
  }
}
