/* Hauptcontainer - Zentrierung und saubere Abstände */
.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);
}

/* Fix für die Navigations-Zeile: Buttons und Monat auf einer Linie */
.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;
}

/* Große, runde Buttons ohne Standard-Styles */
.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);
}

/* Kalender-Gitter Fix */
#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;
}

/* Tages-Kachel: Zahl oben links, Status unten links */
.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.65rem;  */
    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;
    }

/* Umrandete Nachbartage */
.kw-day-adjacent {
    color: var(--kw-adj) !important;
    background: transparent !important;
    border: 1px solid var(--kw-adj) !important;
    opacity: 0.4;
}

/* Status-Farben */
.kw-status-open { background-color: var(--kw-open); color: #fff; }
.kw-status-closed { background-color: var(--kw-closed); color: #fff; }
/* .kw-is-today { border: 4px solid var(--kw-today) !important; } */
.kw-is-today {
  box-shadow: 0 0 0 5px var(--kw-today) !important;
}

/* Disclaimer & Mobile Fixes */
.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; }
}

/* ... (vorheriger CSS Teil bleibt gleich bis zu den Media Queries) ... */

@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; /* Etwas mehr Gap für saubere Trennung der Kästchen */
    }

    .kw-day { 
	  padding: 5px 3px !important; 
	  min-height: 60px; /* Leicht erhöht für saubere Trennung von Zahl und Text */
	  aspect-ratio: auto !important;
	  display: flex !important;
	  flex-direction: column !important;
	  justify-content: space-between !important; /* Zahl oben, Text unten */
	  align-items: flex-start !important; /* Wieder linksbündig wie gewünscht */
    }

    /* Datum oben links */
    .kw-day strong { 
	  font-size: 0.9rem !important; 
	  line-height: 1;
	  margin-bottom: 4px;
    }

    /* Uhrzeit/Status unten links mit Silbentrennung */
    .kw-day span { 
	  font-size: 0.58rem !important; /* Tick größer für bessere Lesbarkeit */
	  line-height: 1.1 !important;
	  display: block !important;
	  width: 100%;
	  white-space: normal !important; 
	  word-break: break-word !important; /* Bricht bei Platzmangel */
	  hyphens: auto !important;         /* Trennt "Ge-schlossen" korrekt */
	  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;
    }
}

/* Spezieller Fix für sehr kleine Handys (unter 380px) */
@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; }
}

