.kmwc-calendar-wrapper {
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 16px 20px;
background: #ffffff;
box-shadow: 0 10px 25px rgba(15, 23, 42, 0.08);
max-width: 900px;
margin: 0 auto 2rem;
font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
box-sizing: border-box;
}
.kmwc-calendar-loading {
text-align: center;
padding: 20px;
color: #6b7280;
font-size: 0.95rem;
} .kmwc-cal-header {
display: flex;
justify-content: space-between;
align-items: center;
gap: 12px;
margin-bottom: 12px;
flex-wrap: wrap;
}
.kmwc-cal-title {
font-size: 1.25rem;
font-weight: 600;
color: #111827;
}
.kmwc-cal-month-select {
padding: 4px 10px;
border-radius: 999px;
border: 1px solid #d1d5db;
font-size: 0.9rem;
background: #f9fafb;
color: #111827;
} .kmwc-cal-grid {
display: grid;
grid-template-columns: repeat(7, minmax(0, 1fr));
background: #f9fafb;
border-radius: 10px;
overflow: hidden;
} .kmwc-cal-weekday {
padding: 6px 4px;
text-align: center;
font-size: 0.8rem;
font-weight: 600;
text-transform: uppercase;
color: #6b7280;
border-bottom: 1px solid #e5e7eb;
background: #f3f4f6;
} .kmwc-cal-day {
height: 90px;
padding: 6px 6px 8px;
border-right: 1px solid #e5e7eb;
border-bottom: 1px solid #e5e7eb;
background: #ffffff;
font-size: 0.85rem;
position: relative;
box-sizing: border-box;
display: flex;
flex-direction: column;
}
.kmwc-cal-day:nth-child(7n) {
border-right: none;
} .kmwc-cal-day-number {
font-weight: 600;
font-size: 0.8rem;
color: #111827;
margin-bottom: 4px;
flex: 0 0 auto;
} .kmwc-cal-day.is-today .kmwc-cal-day-number {
background: #2563eb;
color: #ffffff;
border-radius: 999px;
display: inline-block;
padding: 2px 7px;
} .kmwc-cal-day.is-other-month .kmwc-cal-day-number {
color: #9ca3af;
} .kmwc-cal-events {
flex: 1 1 auto;
overflow: hidden; } .kmwc-cal-event {
margin-bottom: 2px;
padding: 1px 2px;
border-radius: 4px;
background: #eff6ff;
color: #1e40af;
font-size: 0.7rem;
line-height: 1.2;
cursor: pointer;
} .kmwc-cal-event-time {
font-weight: 600;
display: block;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
} .kmwc-cal-event-title {
display: block;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
} .kmwc-event-overlay {
position: fixed;
inset: 0;
background: rgba(15, 23, 42, 0.45);
display: flex; align-items: center; justify-content: center; z-index: 9999;
opacity: 0;
pointer-events: none; transition: opacity 0.15s ease-out;
}
.kmwc-event-overlay.kmwc-visible {
opacity: 1;
pointer-events: auto; }
.kmwc-event-overlay-inner {
background: #ffffff;
border-radius: 12px;
padding: 16px 20px;
max-width: 360px;
width: calc(100% - 40px);
box-shadow: 0 20px 40px rgba(15, 23, 42, 0.45);
font-size: 0.85rem;
color: #111827;
box-sizing: border-box;
}
.kmwc-event-overlay-time {
font-weight: 600;
margin-bottom: 4px;
color: #1f2937;
}
.kmwc-event-overlay-title {
margin-bottom: 6px;
font-weight: 500;
}
.kmwc-event-overlay-meta {
font-size: 0.8rem;
color: #4b5563;
}
.kmwc-event-overlay-meta p {
margin: 0 0 3px;
}
.kmwc-event-overlay-meta p:last-child {
margin-bottom: 0;
} @media (max-width: 768px) {
.kmwc-calendar-wrapper {
padding: 12px 10px;
}
.kmwc-cal-title {
font-size: 1.05rem;
}
.kmwc-cal-day {
height: 80px;
padding: 4px;
}
.kmwc-cal-event {
font-size: 0.65rem;
}
}
@media (max-width: 480px) {
.kmwc-cal-header {
flex-direction: column;
align-items: flex-start;
}
.kmwc-cal-month-select {
align-self: flex-end;
}
.kmwc-cal-day {
height: 72px;
}
}