.kw-calendar-container {
max-width: 800px;
margin: 20px auto;
background: var(--kw-bg) !important;
color: var(--kw-text) !important;
padding: 30px;
border-radius: 20px;
font-family: sans-serif;
box-shadow: 0 15px 35px rgba(0,0,0,0.08);
} .kw-calendar-nav {
display: flex !important;
flex-direction: row !important;
justify-content: space-between !important;
align-items: center !important;
margin-bottom: 30px;
width: 100%;
}
#kw-month-label {
font-size: 1.8rem;
font-weight: 900;
text-transform: uppercase;
margin: 0 !important;
padding: 0 !important;
flex-grow: 1;
text-align: center;
letter-spacing: -0.03em;
} .kw-calendar-nav button {
width: 50px !important;
height: 50px !important;
min-width: 50px !important;
border-radius: 50% !important;
border: none !important;
background-color: var(--kw-btn-bg) !important;
color: var(--kw-btn-arrow) !important;
cursor: pointer;
display: flex !important;
align-items: center;
justify-content: center;
font-size: 1.4rem;
transition: transform 0.2s ease, filter 0.2s ease;
box-shadow: 0 4px 10px rgba(0,0,0,0.12);
padding: 0 !important;
line-height: 0;
}
.kw-calendar-nav button:hover {
filter: brightness(0.9);
transform: scale(1.1);
} #kw-calendar-grid {
display: grid !important;
grid-template-columns: repeat(7, 1fr) !important;
gap: 12px !important;
width: 100%;
}
.kw-day-header {
text-align: center;
font-weight: 800;
font-size: 0.95rem;
padding-bottom: 15px;
opacity: 0.7;
} .kw-day {
aspect-ratio: 1 / 1;
border-radius: 12px;
padding: 10px !important;
display: flex !important;
flex-direction: column !important;
justify-content: space-between !important;
align-items: flex-start !important;
box-sizing: border-box !important;
position: relative;
overflow: hidden;
}
.kw-day strong { 
font-size: 1.3rem; 
line-height: 1; 
margin: 0;
}
.kw-day span { font-size: 0.8rem;
line-height: 1.2; 
font-weight: 600; 
text-align: left;
width: 100%;
word-wrap: break-word;
}
.kw-day.kw-status-closed span {
font-size: 0.65rem;
} .kw-day-adjacent {
color: var(--kw-adj) !important;
background: transparent !important;
border: 1px solid var(--kw-adj) !important;
opacity: 0.4;
} .kw-status-open { background-color: var(--kw-open); color: #fff; }
.kw-status-closed { background-color: var(--kw-closed); color: #fff; } .kw-is-today {
box-shadow: 0 0 0 5px var(--kw-today) !important;
} .kw-disclaimer {
margin-top: 25px;
text-align: center;
font-size: 0.9rem;
opacity: 0.8;
}
@media (max-width: 600px) {
.kw-calendar-container { padding: 15px; }
#kw-month-label { font-size: 1.4rem; }
#kw-calendar-grid { gap: 6px !important; }
.kw-day { padding: 6px !important; }
.kw-day strong { font-size: 1rem; }
.kw-day span { font-size: 0.5rem; }
.kw-calendar-nav button { width: 42px !important; height: 42px !important; min-width: 42px !important; }
} @media (max-width: 600px) {
.kw-calendar-container { 
padding: 12px !important; 
}
#kw-month-label { 
font-size: 1.2rem !important; 
letter-spacing: 0;
}
#kw-calendar-grid { 
gap: 6px !important; }
.kw-day { 
padding: 5px 3px !important; 
min-height: 60px; aspect-ratio: auto !important;
display: flex !important;
flex-direction: column !important;
justify-content: space-between !important; align-items: flex-start !important; } .kw-day strong { 
font-size: 0.9rem !important; 
line-height: 1;
margin-bottom: 4px;
} .kw-day span { 
font-size: 0.58rem !important; line-height: 1.1 !important;
display: block !important;
width: 100%;
white-space: normal !important; 
word-break: break-word !important; hyphens: auto !important; text-align: left !important;
font-weight: 600;
}
.kw-calendar-nav button { 
width: 38px !important; 
height: 38px !important; 
min-width: 38px !important; 
font-size: 1rem !important;
}
} @media (max-width: 380px) {
.kw-day { min-height: 55px; padding: 4px 2px !important; }
.kw-day strong { font-size: 0.8rem !important; }
.kw-day span { font-size: 0.5rem !important; }
#kw-calendar-grid { gap: 4px !important; }
}