html, body {
    max-width: 100vw;
    overflow-x: hidden;
    margin: 0;
    background-color: #F3F4F6;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
  }

 .grid-container {
  display: grid;
  grid-template-columns: repeat(3, 1fr); /* 3 columnas */
  grid-auto-rows: 150px; /* altura base de las filas */
  gap: 5px;
  padding: 5px;
  min-height: 100vh; height: auto;
  box-sizing: border-box;
}

.item {
  border: 1px solid black;
  overflow: hidden;
  border-radius: 5px;
}
.item img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}

.item:hover img {
  transform: scale(1.1);
}

/* Diferentes tamaños para imitar tu imagen */
.item1 {
  grid-row: span 2; /* ocupa 2 filas */
}

.item2 {
  grid-row: span 1;
 }

.item3 {
  grid-row: span 2;
}

.item4 {
  grid-row: span 1;
}

.item5 {
  grid-row: span 1;
}

.item6 {
  grid-column: span 2; /* ocupa 2 columnas */
  grid-row: span 1;
}

/* Responsivo: en pantallas pequeñas que se apilen */
@media (max-width: 768px) {
  .grid-container {
  grid-template-columns: repeat(2, 1fr); /* 2 columnas en tablets */
  }
}

@media (max-width: 480px) {
  .grid-container {
  grid-template-columns: 1fr; /* 1 columna en móviles */
  }
}

  .container section {
    flex: 1;
  }
  
.container {
    max-width: 1100px;
    margin: auto;
	margin-top: 5px;
    background-color: #fff;
    display: flex;
	flex-wrap: wrap;
  }
  
header h1 {
    margin: 0;
  }
  
.consumo-info {
    padding: 10px;
    background-color: #f3f3f3;
  }
  
.grafico {
    padding: 10px;
  } 
 
.bar-chart {
    display: flex;
    align-items: flex-end;
    justify-content: space-around;
    height: 150px;
    background: white;
    border: 1px solid #ccc;
    margin-bottom: 5px;
  }
  
.bar {
    width: 25px;
    background-color: #2ea9cc;
  }
  
.days {
    display: flex;
    justify-content: space-around;
    font-size: 12px;
  }
  
.calendario {
    padding: 10px;
  }
  
.calendario h2 {
    margin: 0;
    font-size: 24px;
  }
  
.calendario h2 span {
    float: right;
    font-size: 16px;
    color: #333;
  }
  
.calendario table {
    width: 100%;
    text-align: center;
    border-collapse: collapse;
    margin-top: 10px;
  }
  
.calendario td, .calendario th {
    padding: 8px;
  }
  
.rojo {
    color: red;
  }
  
.azul {
    color: blue;
  }
  
.add-btn {
    position: fixed;
    bottom: 20px;
    right: 20px;
    background-color: white;
    border: 2px solid #ccc;
    border-radius: 50%;
    font-size: 24px;
    width: 50px;
    height: 50px;
    cursor: pointer;
  }
 
 footer {
   width: 100%;
   box-sizing: border-box;
   margin-top: auto;
   background-color: #fff;
   border-top: 1px solid #ccc;
   text-align: center;
   padding: 15px;
   font-size: 14px;
   color: #333;
 }
