.gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}

.gallery-item {
    border: 1px solid #e0e0e0;
    padding: 10px;
}

.gallery-item .title {
    font-weight: bold;
    margin-bottom: 5px;
}

.gallery-item .title a {
    text-decoration: none;
}

.gallery-item span {
    display: block;
    margin-bottom: 5px;
    font-size: 0.8em;
}

.gallery-item .image {
    margin-bottom: 10px;
}

.gallery-item .html {
    margin-bottom: 10px;
}

.gallery-item .file {
    margin-bottom: 10px;
}

.station-list {
    display: flex;
    flex-wrap: wrap;
}

.station-info {
    width: 25%;
    padding: 5px;
    box-sizing: border-box;
}
.station-info a {
    text-decoration: none;
}
