.month-calendar-container{margin:20px 0;background:#fff;border-radius:8px;overflow:hidden}.month-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:#e0e0e0;min-width:700px}.month-grid-header{background:#f5f5f5;padding:12px 8px;text-align:center;font-weight:600;font-size:12px;color:#666;border-bottom:2px solid #e0e0e0}.month-grid-day{background:#fff;min-height:100px;max-height:100px;padding:8px;position:relative;cursor:pointer;transition:background-color 0.2s;overflow:hidden;display:flex;flex-direction:column}.month-grid-day:hover{background:#f9f9f9}.month-grid-day .day-number{display:inline-block;font-size:14px;font-weight:500;color:#333;margin-bottom:4px;flex-shrink:0}.month-grid-day.other-month{background:#fafafa;opacity:.5}.month-grid-day.other-month .day-number{color:#999}.month-grid-day.past{opacity:.6}.month-grid-day.today .day-number{background:#007cff;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;line-height:1}.day-events{display:flex;flex-direction:column;gap:1px;margin-top:3px;flex:1;overflow:hidden}.day-event{display:block;padding:2px 4px;color:#fff;font-size:11px;line-height:1.2;border-radius:3px;text-decoration:none;transition:filter 0.2s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0;margin-bottom:1px}.event-content-desktop{display:inline}.event-content-mobile{display:none}.day-event .event-time{font-weight:600;font-size:10px}.day-event .event-title{display:inline;font-size:12px;font-weight:500}.day-event.event-span{position:relative;margin-bottom:0}.day-event.span-start{border-top-right-radius:0;border-bottom-right-radius:0;margin-right:-1px}.day-event.span-middle{border-radius:0;margin-left:-1px;margin-right:-1px}.day-event.span-end{border-top-left-radius:0;border-bottom-left-radius:0;margin-left:-1px}.day-event.span-start.span-end{border-radius:3px;margin-left:0;margin-right:0}.day-event:hover{filter:brightness(.9)}.selected-day-details{border-top:1px solid #e0e0e0;background:#fff;animation:slideDown 0.3s ease}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.details-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.details-date{font-weight:600;font-size:16px;color:#333}.close-details{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color 0.2s}.close-details:hover{background:#f5f5f5;color:#333}.details-content{padding:20px}@media (min-width:769px){.selected-day-details{margin-top:20px;border-top:2px solid #e0e0e0;box-shadow:0 -2px 10px rgb(0 0 0 / .1)}.details-header{padding:16px 20px;background:#f8f9fa}.details-date{font-size:18px}.details-content{padding:20px}.selected-day-details .event-list .event-item{margin-bottom:15px}.selected-day-details .event-list .event-item:last-child{margin-bottom:0}}@media (max-width:768px){.month-grid{min-width:600px}.month-grid-day{min-height:80px;max-height:80px;padding:5px}.day-events{gap:1px;margin-top:2px}.day-event{font-size:10px;padding:2px 3px;line-height:1.1}.day-event .event-time{font-size:9px}.day-event .event-title{font-size:10px}}@media (max-width:480px){.month-grid{min-width:350px}.month-grid-header{padding:6px 4px;font-size:10px}.month-grid-day{min-height:70px;max-height:70px;padding:3px}.month-grid-day .day-number{font-size:12px;margin-bottom:2px}.day-events{gap:2px;margin-top:3px}.day-event{padding:0;height:6px;min-height:6px;border-radius:2px;margin-bottom:2px;cursor:pointer}.event-content-desktop{display:none}.event-content-mobile{display:block;height:6px;width:100%}.day-event .event-time,.day-event .event-title{display:none}.day-event.span-start,.day-event.span-middle,.day-event.span-end{height:6px;border-radius:2px}.day-event.span-start{border-top-right-radius:0;border-bottom-right-radius:0}.day-event.span-middle{border-radius:0}.day-event.span-end{border-top-left-radius:0;border-bottom-left-radius:0}}@media (min-width:1024px){.month-grid{min-width:900px}.month-grid-day{min-height:120px;max-height:120px;padding:8px}.day-event{font-size:11px;padding:2px 5px}.day-event .event-time{font-size:10px}.day-event .event-title{font-size:11px}}.day-event[style*="display: none"]{display:none!important}@media print{.month-calendar-container{box-shadow:none}.month-grid-day:hover{background:#fff}.selected-day-details{display:none!important}}