/* ============================================= */
/* SPEZIFISCHE PROJEKT-STILE             */
/* ============================================= */

/* --- 1. Seiten-spezifische Variablen --- */
/* Wir verwenden Body-Klassen, um die Akzentfarben pro Seite zu steuern. */

body.page-index {
    --primary-color: #007bff;
    --primary-color-dark: #0056b3;
}

body.page-komzent {
    --primary-color: #8e44ad;
    --primary-color-dark: #732d91;
}


/* ============================================= */
/* STILE FÜR index.html                  */
/* ============================================= */

/* --- Missions-Definition --- */
.session-row {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 10px;
}

.session-row input {
    flex-grow: 1;
}

/* --- Tages-Auswahl --- */
.day-selector {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    margin: 20px 0;
}

.day-selector label {
    padding: 10px 15px;
    border: 1px solid var(--border-color);
    border-radius: 25px;
    cursor: pointer;
    transition: all 0.3s;
}

.day-selector input {
    display: none; /* Versteckt die Standard-Checkbox */
}

.day-selector input:checked + label {
    background-color: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* --- Missions-Liste --- */
.goal-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border: 1px solid var(--border-color);
    border-radius: 10px;
    margin-bottom: 15px;
}

.goal-info {
    flex-grow: 1;
}

.goal-info h3 {
    margin: 0 0 5px 0;
}


/* ============================================= */
/* STILE FÜR komzent.html                */
/* ============================================= */

/* --- Kalender-Navigation --- */
.kalender-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 25px;
    padding: 15px;
    background-color: #f1f1f1;
    border-radius: 10px;
}

#wochenanzeige {
    font-size: 1.5em;
    font-weight: 600;
}

/* --- Wochen-Layout (Grid) --- */
#weekdays-wrapper,
#weekend-wrapper {
    display: grid;
    gap: 20px;
    align-items: stretch; /* Sorgt für gleich hohe Karten */
}

#weekdays-wrapper {
    grid-template-columns: repeat(5, 1fr);
    margin-bottom: 20px;
}

#weekend-wrapper {
    grid-template-columns: repeat(2, 1fr);
}

/* --- Tages-Karten --- */
#wochen-container .card {
    height: 100%; /* Stellt sicher, dass die Karte den Platz ausfüllt */
    display: flex;
    flex-direction: column;
}

#wochen-container .card h2 {
    font-size: 1.4em; /* Angepasste Schriftgröße für die Wochentage */
    margin-bottom: 15px;
}

.weekend-card {
    opacity: 0.85;
    border-left: 5px solid var(--secondary-color);
}

/* --- Aufgaben-Liste in den Karten --- */
.task-list {
    list-style: none;
    padding: 0;
    flex-grow: 1; /* Schiebt den Button nach unten */
}

.task-item {
    display: flex;
    align-items: center;
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 10px;
    transition: background-color 0.3s;
}

.task-item.regular:hover {
    background-color: #f8f9fa;
}

.task-item input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin-right: 15px;
    flex-shrink: 0;
}

.task-item label {
    flex-grow: 1;
}

.task-item.extra {
    border-left: 4px solid #f1c40f;
    background-color: #fef9e7;
}

/* --- Fortschrittsanzeige --- */
.progress-bar-container {
    width: 100%;
    background-color: var(--border-color);
    border-radius: 25px;
    height: 30px;
    margin-top: 20px;
    overflow: hidden;
}

#progress-bar {
    width: 0%;
    height: 100%;
    background: linear-gradient(90deg, var(--primary-color), var(--primary-color-dark));
    transition: width 0.5s ease-in-out;
    text-align: center;
    line-height: 30px;
    color: white;
    font-weight: bold;
}

#ergebnis-text {
    text-align: center;
    font-size: 1.2em;
    font-weight: 600;
    margin-top: 15px;
}


/* ============================================= */
/* NEU: Layout & Kalender für komzent.html */
/* ============================================= */


/* --- Stile für den Mini-Kalender --- */
#mini-kalender {
    font-size: 0.9em;
}

#kalender-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 50px;
}

#kalender-header strong {
    font-size: 1.1em;
}

#kalender-header button {
    background: none;
    border: none;
    font-size: 1.5em;
    cursor: pointer;
    color: var(--text-color);
    padding: 0 5px;
}
#kalender-header button:hover {
    color: var(--primary-color);
}

#kalender-tage {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 5px;
}

.kalender-weekday, .kalender-tag {
    text-align: center;
    padding: 8px 5px;
    border-radius: 4px;
}

.kalender-weekday {
    font-weight: 600;
    font-size: 0.8em;
    color: var(--secondary-color);
}

.kalender-tag.leer {
    visibility: hidden; /* Leere Tage vor Monatsanfang */
}

/* Markierung für den heutigen Tag */
.kalender-tag.heute {
    background-color: var(--primary-color);
    color: white;
    font-weight: 700;
}

/* Markierung für Tage mit Aktivität (Bonus oder Checkbox) */
.kalender-tag.aktiv {
    background-color: #fef9e7; /* Passend zur "Bonus Einheit"-Farbe */
    border: 1px solid #f1c40f;
    font-weight: 500;
}

/* Markierung für verpasste Pflichttage (optional, aber nützlich) */
.kalender-tag.verpasst {
    background-color: #fbeeee;
    border: 1px solid #e74c3c;
    opacity: 0.8;
}

/* Heutiger Tag hat Vorrang, wenn er aktiv ist */
.kalender-tag.heute.aktiv {
    background-color: #2c3e50;
    border: 2px solid white;
    box-shadow: 0 0 0 2px var(--primary-color-dark);
}


/* ============================================= */
/* NEU: Globales Layout & Kalender für komzent.html */
/* ============================================= */

body {
    /* WICHTIG: Überschreibt das Padding von unified-styles.css, 
       damit das Layout bis zum Rand gehen kann. */
    padding: 0;
}

/* Definiert das Hauptlayout: Linke Spalte (Kalender) + Rechte Spalte (Inhalt) */
.page-wrapper-komzent {
    display: grid;
    /* Sidebar (min 280px, max 320px) | Hauptinhalt (der .container) */
    grid-template-columns: minmax(280px, 320px) 1fr;
    gap: 30px;
    align-items: start;
    
    /* Zentriert das gesamte Layout und gibt ihm Ränder */
    max-width: 1800px; 
    margin: 0 auto;
    padding: 20px; /* Außenabstand, ersetzt das alte Body-Padding */
}

/* Die linke Kalenderspalte */
.calendar-sidebar .card {
    /* Hält den Kalender beim Scrollen der Hauptseite fest */
    margin-top: 140px;    
}

/* Anpassung für den .container (rechte Spalte) */
.page-komzent .container {
    margin: 0; /* Hebt 'margin: 20px auto' von unified-styles.css auf */
    width: 100%; /* Nimmt den vollen Platz der Grid-Spalte ein */
    max-width: 1300px; /* Behält das maximale Breitenlimit bei */
}

#summary-card {
    margin-top: 25px;
}

/* --- Responsives Verhalten für das neue Layout --- */
@media (max-width: 1800px) {
    .page-wrapper-komzent {
        /* Stapelt Kalender und Hauptinhalt untereinander */
        grid-template-columns: 1fr;
    }
    
    .calendar-sidebar .card {
        /* Sticky-Positionierung im gestapelten Layout aufheben */
        position: static;
        top: auto;
    }
}


/* --- Stile für den Mini-Kalender (unverändert) --- */
#mini-kalender {
    font-size: 0.9em;
}

#kalender-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
}

.box50px{
    margin: 500px;
}

/* ============================================= */
/* NEU: Hervorhebung des aktuellen Tages */
/* ============================================= */

.card.today-card {
    /* 5px breiter, heller Rahmen in Primärfarbe */
    border: 5px solid color-mix(in srgb, var(--primary-color) 70%, white); 
    /* Ein stärkerer Schatten, um die Karte in den Vordergrund zu stellen */
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15); 
    /* Leichter Hintergrund, um sie vom Rest abzuheben 
    background-color: #fffde7;  Sehr helles Gelb/Creme */
    /* Fügt eine kleine Animation hinzu, um die Aufmerksamkeit zu lenken (optional) */
    transform: scale(1.01);
    transition: all 0.3s ease-in-out;
}

/* Anpassung der Überschrift für den Fokus */
.card.today-card h2 {
    color: var(--primary-color-dark);
    text-shadow: 0 0 5px rgba(73, 80, 87, 0.1);
}