body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0; /* Убрали отступы */
    background-color: #f4f4f4;
    text-align: center;
}

#year-header {
    font-size: 1.2rem; /* Уменьшили шрифт для года */
    margin: 5px 0; /* Минимальные отступы */
}

#calendar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 5px; /* Уменьшили отступы между месяцами */
    max-width: 960px;
    margin: 0 auto;
    padding: 5px; /* Уменьшили отступы */
}

.month {
    background-color: #fff;
    padding: 5px; /* Уменьшили отступы внутри месяца */
    border-radius: 5px;
    box-sizing: border-box;
    min-height: 140px; /* Уменьшили минимальную высоту */
}

.month h2 {
    text-align: center;
    margin: 3px 0; /* Уменьшили отступы */
    font-size: 0.9rem; /* Уменьшили шрифт для названий месяцев */
}

.week {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px; /* Уменьшили отступы между днями */
}

.day {
    text-align: center;
    padding: 2px; /* Уменьшили отступы внутри дней */
    border-radius: 3px;
    font-size: 0.8rem; /* Уменьшили шрифт для дней */
}

.day.weekend {
    color: red; /* Выходные дни красным */
}

@media (max-width: 960px) {
    #calendar {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 720px) {
    #calendar {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    #calendar {
        grid-template-columns: 1fr;
    }
}