
body { font-family: 'Inter', sans-serif; max-width: 1200px; margin: 20px auto; color: #113F67; }
input[type="text"], select { margin-bottom: 10px; padding: 6px; width: 100%; box-sizing: border-box; color: #113F67; border: 1px solid #113F67; }
a { text-decoration: none; color: #113F67; }

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 15px;
}
.card {
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 0;
  background: #fff;
}

.card:hover { transform: translateY(-4px); }
.card img {
  max-width: 100%;
  height: auto;
  display: block;
  margin-bottom: 8px;
}
.card h3 { margin: 0 0 5px; }
.card p {
  margin: 0;
  font-size: 0.9em;
  color: #555;
  padding: 5px;
}

.card h3 {  padding: 5px 10px; }
.card small {
  display: block;
  margin-bottom: 6px;
  font-size: 0.85em;
  padding: 0 10px 5px 10px;
  line-height: 1.4;
}

footer { font-size: 0.85rem; margin: 1rem 0; }

.filters { display: flex; gap: 10px; max-width: 60%; wrap; margin: 2rem 0 1rem 0; }
.filters > * { flex: 1; }


@media only screen and (max-width: 1044px) {
  .grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media only screen and (max-width: 768px) {
    body: padding { 1rem;}
    .grid {
      grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    }
  }
  
  @media only screen and (max-width: 480px) {
    .filters { max-width: none; }
    body { padding: 0 1rem; }
    .grid {
      grid-template-columns: 1fr;
    }
  }