/**calendar.wxss**/ .container { min-height: 100vh; background-color: #f5f5f5; } .calendar-header { background-color: #fff; padding: 32rpx; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid #f0f0f0; } .month-navigation { display: flex; align-items: center; gap: 32rpx; } .nav-btn { font-size: 48rpx; color: #07c160; font-weight: 300; width: 60rpx; text-align: center; } .month-title { font-size: 36rpx; font-weight: 600; color: #333; min-width: 240rpx; text-align: center; } .today-btn { padding: 12rpx 32rpx; background-color: #f5f5f5; color: #666; border-radius: 40rpx; font-size: 24rpx; border: none; } .today-btn::after { border: none; } .week-header { display: flex; background-color: #fff; border-bottom: 1px solid #f0f0f0; } .week-title { flex: 1; text-align: center; padding: 20rpx 0; font-size: 24rpx; color: #999; font-weight: 500; } .calendar-content { height: calc(100vh - 200rpx); } .calendar-grid { display: grid; grid-template-columns: repeat(7, 1fr); background-color: #fff; } .calendar-cell { min-height: 120rpx; border: 1px solid #f0f0f0; padding: 8rpx; display: flex; flex-direction: column; align-items: center; justify-content: center; } .calendar-cell.other-month { background-color: #fafafa; } .calendar-cell.today .date-num { background-color: #07c160; color: #fff; border-radius: 50%; width: 48rpx; height: 48rpx; line-height: 48rpx; text-align: center; } .date-num { font-size: 28rpx; color: #333; margin-bottom: 8rpx; } .calendar-cell.other-month .date-num { color: #ccc; } .events { display: flex; gap: 4rpx; } .event-dot { width: 12rpx; height: 12rpx; border-radius: 50%; } .more-text { font-size: 20rpx; color: #999; margin-top: 4rpx; } /* 事件列表 */ .events-list { padding: 32rpx; } .section-title { font-size: 32rpx; font-weight: 600; color: #333; margin-bottom: 24rpx; } .empty-state { text-align: center; padding: 120rpx 40rpx; } .empty-state .icon { font-size: 120rpx; display: block; margin-bottom: 32rpx; } .empty-state .text { font-size: 28rpx; color: #999; } .event-card { background-color: #fff; border-radius: 16rpx; padding: 32rpx; margin-bottom: 24rpx; box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.06); } .event-header { display: flex; align-items: center; } .event-icon { font-size: 40rpx; margin-right: 16rpx; } .event-title { flex: 1; font-size: 28rpx; font-weight: 600; color: #333; } .event-date { font-size: 24rpx; color: #999; } .event-info { display: flex; align-items: center; gap: 16rpx; margin-top: 16rpx; } .lunar-badge { padding: 4rpx 12rpx; background-color: #e3f2fd; color: #1976d2; border-radius: 4rpx; font-size: 20rpx; } .status { font-size: 22rpx; padding: 4rpx 12rpx; border-radius: 4rpx; } .status.urgent { background-color: #fff3f0; color: #ff5722; } .status.warning { background-color: #fff8e6; color: #ff9800; }