.repozytorium {
    max-width: 1200px;
    margin: 0 auto;
    padding: 2.5rem 2.5rem;
    flex: 1 0 auto;
}

.repozytorium h1 {
    font-size: 2.2rem;
    margin-bottom: 1.2rem;
    text-align: center;
}

/* --- Filters form --- */
form.filtry {
    display: grid;
    grid-template-columns: repeat(auto-fit,minmax(180px,1fr));
    gap: 1rem 1.6rem;
    background:#fff;
    padding:1rem 1.2rem;
    border-radius:8px;
    box-shadow:0 2px 6px rgba(0,0,0,.04);
    margin-bottom:2rem;
}

form.filtry .kol { 
    display:flex;
    flex-direction:column;
}

form.filtry label {
    font-size:.85rem;
    color:#666;
    margin-bottom:.3rem;
}

form.filtry select,
form.filtry input[type="text"] {
    padding:.45rem .55rem;
    border:1px solid #ccd;
    border-radius:4px;
    font-size:.95rem;
}

form.filtry .akcje { 
    display:flex;
    align-items:start;
    gap:.7rem;
}

form.filtry button {
    background:#0069ff;
    color:#fff;
    border:none;
    padding:.55rem 1.1rem;
    border-radius:4px;
    cursor:pointer;
    transition:background .2s;
}

form.filtry button:hover {
    background:#004ec7;
}

form.filtry a.reset {
    color:#555;
    font-size:.9rem;
    text-decoration:underline;
}

/* --- Results count --- */
.results-count {
    background: #f0f7ff;
    border-left: 4px solid #0069ff;
    padding: .9rem 1.2rem;
    margin-bottom: 1.5rem;
    border-radius: 4px;
}

.results-count p {
    margin: 0;
    color: #333;
    font-size: .95rem;
}

.results-count strong {
    color: #0069ff;
    font-size: 1.1rem;
}

/* --- Cards grid --- */
.grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:1.4rem;
}

.karta {
    background:#fff;
    border-radius:8px;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    box-shadow:0 2px 6px rgba(0,0,0,.06);
    transition:transform .15s ease-in-out, box-shadow .15s;
}

.karta:hover {
    transform:translateY(-4px);
    box-shadow:0 6px 18px rgba(0,0,0,.10);
}

.karta header img {
    width:100%;
    height:160px;
    object-fit:cover;
}

.karta-body {
    flex:1;
    padding:1rem .9rem;
    display:flex;
    flex-direction:column;
}

.karta-body h2 {
    font-size:1.05rem;
    margin:.1rem 0 .4rem;
}

.karta-body .meta {
    font-size:.8rem;
    color:#666;
    margin-bottom:.6rem;
}

.karta-body .opis {
    font-size:.9rem;
    color:#333;
    flex:1;
}

.karta footer {
    padding:.8rem .9rem;
    border-top:1px solid #eef;
    background:#f8f9ff;
}

.karta .cta {
    display:inline-block;
    background:#004ec7;
    color:#fff;
    padding:.4rem .9rem;
    border-radius:4px;
    font-size:.85rem;
    text-decoration:none;
    transition:background .2s;
}

.karta .cta:hover {
    background:#003b9a;
}

.cta.disabled {
    display: none;
}

/* Empty-state message */
.brak {
    grid-column:1/-1;
    text-align:center;
    color:#555;
    font-style:italic;
}

/* --- Load More Button --- */
.load-more-container {
    display: flex;
    justify-content: center;
    margin-top: 2.5rem;
    margin-bottom: 1.5rem;
}

.load-more-btn {
    background: #0069ff;
    color: #fff;
    border: none;
    padding: .75rem 2rem;
    border-radius: 6px;
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    transition: all .2s ease;
    box-shadow: 0 2px 8px rgba(0, 105, 255, .2);
}

.load-more-btn:hover:not(:disabled) {
    background: #004ec7;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 105, 255, .3);
}

.load-more-btn:active:not(:disabled) {
    transform: translateY(0);
}

.load-more-btn:disabled {
    background: #ccc;
    cursor: not-allowed;
    box-shadow: none;
}

.month-section {
    margin-bottom: 2.5rem;
}

.month-header {
    font-size: 1.4rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid #0069ff;
}

.month-header:first-of-type {
    margin-top: 0;
}
