/* Grundlegendes Reset und Schriftart */
* {
    box-sizing: border-box;
}

body {
    background-color: #2c3e50; /* Dunkler Hintergrund für Kontrast */
    font-family: 'Arial', sans-serif;
    padding: 20px;
    color: white;
}

/* Der Kalender-Container */
.advent-calendar {
    display: grid;
    /* Erstellt so viele Spalten wie passen, mindestens 150px breit */
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    grid-auto-rows: 150px;
    gap: 15px;
    max-width: 1000px;
    margin: 0 auto;

    /* --- DAS IST DIE MAGIE --- */
    /* Sagt dem Grid: Fülle Lücken mit späteren Elementen auf! */
    grid-auto-flow: dense;
}

/* --- Mobile Optimierung --- */
/* Auf kleinen Handys (unter 500px) machen wir das Raster einfacher */
@media (max-width: 500px) {
    .advent-calendar {
        grid-template-columns: repeat(2, 1fr); /* Immer 2 Spalten auf Handy */
        grid-auto-rows: 120px; /* Etwas flacher */
    }

    /* Auf Handys sollten breite Karten nicht mehr breit sein,
       sonst passen sie nicht gut rein */
    .card-w-2 {
        grid-column: span 1 !important; /* Breite zurücksetzen */
    }

    /* Hohe Karten dürfen hoch bleiben, das stört beim Scrollen nicht */
}
/* Die einzelne Karte */
.card {
    position: relative;
    margin: 0;
    cursor: pointer;
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.3);
    background-color: #fff; /* Fallback */
}

/* Größen-Modifikatoren (Grid Spans) */
.card-w-2 {
    grid-column: span 2; /* Doppelte Breite */
}

.card-h-2 {
    grid-row: span 2; /* Doppelte Höhe */
}

/* Farben */
.card-black figcaption { background-color: #34495e; color: #fff; }
.card-green figcaption { background-color: #27ae60; color: #fff; }
.card-red figcaption   { background-color: #c0392b; color: #fff; }
.card.white figcaption { background-color: #ecf0f1; color: #2c3e50; }

/* Standard-Farbe für Karten ohne Farb-Klasse */
.card figcaption {
    background-color: #e67e22;
    color: white;
}

/* Das Innere (Geschenk/Icon) - liegt HINTER dem Türchen */
.inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #fff; /* Heller Hintergrund für das Icon */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1; /* Liegt unten */
}

.icon {
    width: 50%;
    height: 50%;
    fill: #333; /* Farbe der Icons */
}

/* Das Türchen (Vorderseite mit Nummer) */
figcaption {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2; /* Liegt oben drauf */
    transition: transform 0.6s cubic-bezier(0.4, 0.2, 0.2, 1);
    transform-origin: left; /* Tür öffnet sich nach links */
    border: 1px dashed rgba(255,255,255,0.3);
}

/* Hilfsklassen für die Zentrierung der Nummer */
.display-table {
    display: table;
    width: 100%;
    height: 100%;
}
.display-table-cell {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    font-size: 2.5rem;
    font-weight: bold;
}

/* --- Interaktion: Wenn das Türchen "offen" ist --- */
.card.is-open figcaption {
    transform: rotateY(-110deg); /* Tür klappt auf */
}

/* --- Zusatz für Logik --- */

/* Cursor zeigt an, dass man klicken kann, aber wir regeln das jetzt per JS */
.card {
    cursor: default; /* Standard-Cursor, wird per JS geändert */
}

.card.allowed {
    cursor: pointer; /* Hand-Cursor nur bei erlaubten Tagen */
}

.card.locked {
    opacity: 0.9;
}

/* Rüttel-Animation für "Zu früh!" */
@keyframes shake {
    0% { transform: translateX(0); }
    25% { transform: translateX(-5px); }
    50% { transform: translateX(5px); }
    75% { transform: translateX(-5px); }
    100% { transform: translateX(0); }
}

.card.shake {
    animation: shake 0.4s ease-in-out;
}

/* --- Header & Button Styling --- */
.calendar-header {
    text-align: center;
    margin-bottom: 30px;
    color: white;
}

.calendar-header h1 {
    margin: 0 0 15px 0;
    font-family: 'Georgia', serif; /* Etwas weihnachtlicher */
    text-shadow: 2px 2px 4px rgba(0,0,0,0.5);
}

.btn-reset {
    background-color: #e74c3c;
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 20px;
    cursor: pointer;
    font-size: 1rem;
    transition: background 0.3s;
    box-shadow: 0 4px 6px rgba(0,0,0,0.2);
}

.btn-reset:hover {
    background-color: #c0392b;
}

/* --- Toast Nachrichten Styling --- */
#toast-container {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.toast {
    background-color: #333;
    color: #fff;
    padding: 12px 24px;
    border-radius: 4px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    opacity: 0;
    transform: translateY(20px);
    animation: toast-in-out 3s forwards; /* 3 Sekunden sichtbar */
    font-size: 0.9rem;
    min-width: 250px;
    text-align: center;
}

/* Toast Varianten */
.toast.error {
    background-color: #e74c3c; /* Rot für Fehler */
}
.toast.success {
    background-color: #27ae60; /* Grün für Erfolg */
}

/* Animation für das Ein- und Ausblenden */
@keyframes toast-in-out {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    10%, 90% {
        opacity: 1;
        transform: translateY(0);
    }
    100% {
        opacity: 0;
        transform: translateY(-20px);
    }
}



/* =========================================
   🍞 TOAST NOTIFICATIONS (Meldungen)
   ========================================= */

/* Der Container, der alle Toasts sammelt (unten mitte) */
#toast-container {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%); /* Exakt zentrieren */
    z-index: 9999; /* Immer ganz oben */
    display: flex;
    flex-direction: column; /* Untereinander stapeln */
    gap: 10px; /* Abstand zwischen Meldungen */
    pointer-events: none; /* Klicks gehen durch leere Bereiche durch */
}

/* Der einzelne Toast */
.toast {
    min-width: 280px; /* Mindestbreite */
    padding: 12px 20px;
    border-radius: 50px; /* Pillen-Form */
    color: white;
    font-weight: bold;
    text-align: center;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
    opacity: 0; /* Startet unsichtbar */

    /* Die Animation läuft 3 Sekunden */
    animation: toast-animation 3s forwards;
}

/* Farben je nach Typ */
.toast.success {
    background-color: #27ae60; /* Grün */
}

.toast.error {
    background-color: #e74c3c; /* Rot */
}

/* Die Animation:
   0%   -> Rutscht von unten rein
   10%  -> Ist da und sichtbar
   90%  -> Ist immer noch da
   100% -> Rutscht nach oben weg und wird unsichtbar
*/
@keyframes toast-animation {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    10% {
        opacity: 1;
        transform: translateY(0);
    }
    90% {
        opacity: 1;
        transform: translateY(0);
    }
    100% {
        opacity: 0;
        transform: translateY(-20px);
    }
}


/* =========================================
   🎄 FINALE (Overlay & Animation)
   ========================================= */

#christmas-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.9); /* Fast schwarz, transparent */
    z-index: 10000; /* Ganz oben über allem */
    display: flex;
    justify-content: center;
    align-items: center;
    transition: opacity 0.5s ease;
    backdrop-filter: blur(5px); /* Macht den Hintergrund unscharf */
}

/* Versteckter Zustand */
.overlay-hidden {
    opacity: 0;
    pointer-events: none; /* Klicks gehen durch */
}

/* Sichtbarer Zustand */
.overlay-visible {
    opacity: 1;
    pointer-events: all;
}

.overlay-content {
    text-align: center;
    color: #f1c40f; /* Goldene Farbe */
    transform: scale(0.5);
    transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); /* Bouncig */
}

/* Wenn sichtbar, ploppt der Text auf */
.overlay-visible .overlay-content {
    transform: scale(1);
}

.overlay-content h1 {
    font-family: 'Brush Script MT', cursive;
    font-size: 5rem;
    margin-bottom: 20px;
    text-shadow: 0 0 20px rgba(241, 196, 15, 0.8);
}

.overlay-content p {
    font-size: 1.5rem;
    color: white;
    margin-bottom: 30px;
}

#close-overlay {
    padding: 10px 30px;
    font-size: 1.2rem;
    background: white;
    border: none;
    border-radius: 50px;
    cursor: pointer;
    color: #333;
}

#close-overlay:hover {
    background: #f1c40f;
}