/*
Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
Click nbfs://nbhost/SystemFileSystem/Templates/ClientSide/css.css to edit this template
*/
/* 
    Created on : 02.12.2025, 13:56:09
    Author     : Kalle
*/


:root {
    --red: #ec0016;
    --blue: #2b5e8c;
    --white: #ffffff;
    --black: #000000;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: var(--white);
    color: var(--black);
}

.wrapper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 1.5rem;
}

header {
    text-align: center;
    margin-bottom: 2rem;
}

.logo {
    max-width: 220px;
    height: auto;
    margin-bottom: 1rem;
}

h1 {
    margin: 1em 0 0 0;
    color: var(--blue);
    font-size: clamp(1.8rem, 4vw, 2.6rem);
}

h2 {
    margin: 0 0 1em 0;
    color: var(--red);
}

.intro {
    max-width: 700px;
    margin: 0.5rem auto 0;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Kalender-Layout */
.calendar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1.5rem;
}

.month {
    border: 1px solid #ddd;
    border-radius: 12px;
    overflow: visible; /* wichtig für Popover */
    background: #f9fafb;
    display: flex;
    flex-direction: column;
}

.month-header {
    background: var(--blue);
    color: var(--white);
    padding: 0.6rem 0.8rem;
    text-align: center;
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.95rem;
}

.month-body {
    padding: 0.5rem 0.6rem 0.7rem;
}

.weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    font-size: 0.7rem;
    text-align: center;
    margin-bottom: 0.3rem;
    color: var(--blue);
    font-weight: 600;
}

.weekdays div {
    padding: 0.2rem 0;
}

.days {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 2px;
}

.day {
    position: relative;
    min-height: 40px;
    padding: 0.2rem;
    font-size: 0.75rem;
    background: var(--white);
    border-radius: 6px;
    border: 1px solid #eee;
    display: flex;
    align-items: center;       /* vertikal zentrieren */
    justify-content: center;   /* horizontal zentrieren */
    text-align: center;
}

.day.empty {
    background: transparent;
    border: none;
}

.day-number {
    font-weight: 600;
    font-size: 0.85rem;
}

.day.has-events,
.day.has-holiday,
.day.has-holiday-events {
    cursor: pointer;
}

/* Tage mit Veranstaltungen: rote Umrandung + leichte Tönung */
.day.has-holiday {
    border: #2b5e8c 1px dashed;
    background: rgba(43, 94, 140, 0.08);
}

.day.has-events {
    border-color: #ec0016;
    background: rgba(236, 0, 22, 0.08);
}

.day.has-holiday-events {
    border: #ec0016 1px dashed;
    background: rgba(236, 0, 22, 0.08);
}

.day.has-holiday-events .day-number, .day.has-events .day-number {
    color: var(--red);
}

/* Popover / Details */
.event-details {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translate(-50%, 10px);
    width: 260px;      /* hier Breite für Desktop einstellen */
    max-width: 90vw;

    background: var(--white);
    border: 1px solid var(--blue);
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
    border-radius: 8px;
    padding: 0.5rem 0.6rem;
    z-index: 20;
    font-size: 0.75rem;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 180ms ease, transform 180ms ease;
}

.day.show-details .event-details {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translate(-50%, 6px);
}

.event-details h4 {
    margin: 0 0 0.1rem;
    font-size: 0.78rem;
    color: var(--blue);
}

.event-details .club {
    margin: 0 0 0.2rem;
    font-size: 0.7rem;
    font-style: italic;
    color: var(--red);
}

.event-details .text {
    margin: 0 0 0.2rem;
    font-size: 0.72rem;
}

.event-details hr {
    border: none;
    border-top: 1px solid #eee;
    margin: 0.3rem 0;
}

.legend {
    margin-top: 1.5rem;
    font-size: 0.8rem;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    justify-content: center;  /* horizontal zentrieren */
    text-align: center;       /* Text in den divs zentrieren */
    flex-direction: column;   /* untereinander statt nebeneinander (optional, aber oft schöner) */
    margin-top:4em;
}

.event-list {
    margin-top: 3rem;
    margin-left: 20%;
    margin-right: 20%;
    background: #f9fafb;
    border: 1px solid #ddd;
    border-radius: 12px;
    padding: 1rem;
}

.event-list h3 {
    margin: 0 0 1rem 0;
    color: var(--blue);
}

.event-list-item {
    padding: 0.25rem 0;
}

.event-list-date {
    margin: 0 0 0.25rem 0;
    font-size: 0.85rem;
    color: #333;
    font-weight: 600;
}

.event-list-item h4 {
    margin: 0 0 0.1rem 0;
    color: var(--blue);
    font-size: 0.95rem;
}

.event-list-item.is-custom h4 {
    font-size: 1.08rem;
}

.event-list-item.is-holiday h4 {
    font-size: 0.9rem;
}

.event-list .club {
    margin: 0 0 0.2rem;
    font-style: italic;
    color: var(--red);
}

.event-list .text {
    margin: 0;
}

.event-list hr {
    border: none;
    border-top: 1px solid #ddd;
    margin: 0.8rem 0;
}

.legend .dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--red);
    display: inline-block;
    margin-right: 0.3rem;
}

.hint {
    margin-top: 0.3rem;
    font-size: 0.75rem;
    color: #444;
}


@media (max-width: 600px) {
    .event-list {
        margin-left: 0;
        margin-right: 0;
    }

    .month {
        border-radius: 10px;
    }

    .month-body {
        padding: 0.5rem;
    }

    .day {
        min-height: 34px;
    }

    /* Auf dem Handy: große, gut lesbare Infobox als Bottom-Sheet */
    .event-details {
        position: fixed;
        left: 50%;
        bottom: 0;
        top: auto;
        transform: translateX(-50%) translateY(10px);
        width: 100%;
        max-width: 100%;

        padding: 1rem 1.2rem;
        font-size: 0.95rem;

        border-radius: 16px 16px 0 0;
        box-shadow: 0 -4px 18px rgba(0, 0, 0, 0.25);
        z-index: 999;
    }

    .day.show-details .event-details {
        transform: translateX(-50%) translateY(0);
    }

    .event-details h4 {
        font-size: 1.05rem;
        margin-bottom: 0.3rem;
    }

    .event-details .club,
    .event-details .text {
        font-size: 0.9rem;
    }
}
