/* 全局样式 */
body {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    background-color: #f8f9fa;
}

.footer {
    margin-top: auto;
}

/* 日历样式 */
.calendar-container {
    margin-top: 1rem;
    /* 移除水平滚动 */
}

/* 恢复正常换行 */
.calendar-container .row {
    flex-wrap: wrap;
    /* 移除最小宽度限制 */
}

.calendar-day {
    border: 1px solid #dee2e6;
    border-radius: 4px;
    padding: 0.5rem;
    height: 100%;
    min-height: 90px; /* 确保足够高度 */
    transition: all 0.2s;
    display: flex;
    flex-direction: column;
}

/* 移除日期头部样式，不再需要 */
/* .day-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
} */

/* 日期数字样式 - 居中显示 */
.day-number {
    font-weight: bold;
    font-size: 1.1rem;
    /* 添加居中样式 */
    text-align: center;
}

/* 报名徽章样式 */
.signup-badge {
    font-size: 0.75rem;
    padding: 0.25em 0.5em;
    /* 添加居中样式 */
    display: inline-block;
}

/* 已报名人员名称区域 */
.signup-names {
    margin-top: auto;
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
}

/* 响应式调整 */
@media (max-width: 768px) {
    .calendar-container {
        /* 移除左右边距调整 */
    }
    
    .calendar-day {
        min-height: 70px;
        padding: 0.25rem;
    }
    
    .day-number {
        font-size: 0.9rem;
    }
    
    .signup-badge {
        font-size: 0.7rem;
        padding: 0.2em 0.4em;
    }
    
    .signup-names .badge {
        font-size: 0.65rem;
    }
}

.calendar-day:hover:not(.full) {
    border-color: #0d6efd;
    box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
}

.calendar-day.full {
    background-color: #f8f9fa;
    opacity: 0.7;
}

/* 添加过期日期的特殊样式 */
.calendar-day.past {
    background-color: #f5f5f5;
    opacity: 0.6;
}

/* 优化日期显示 */
.date-display {
    text-align: center;
    margin-bottom: 0.5rem;
}

.weekday-badge {
    margin-top: 0.25rem;
}

/* 优化已报名信息显示 */
.signup-info {
    border-top: 1px dashed #dee2e6;
    padding-top: 0.5rem;
}

.signup-count {
    text-align: center;
    margin-bottom: 0.25rem;
    font-weight: 500;
}

.signup-names {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    justify-content: center;
}

.signup-names .badge {
    margin: 0.1rem;
}

/* 区分过期和已满日期的样式 */
.calendar-day.full {
    background-color: #fff5f5;
    opacity: 0.8;
}

.calendar-day.past {
    background-color: #f5f5f5;
    opacity: 0.7;
}

/* 响应式调整 */
@media (max-width: 768px) {
    .calendar-day {
        min-height: 100px;
    }
    
    .signup-names .badge {
        font-size: 0.7rem;
    }
}