/* ==========================================================================
   Kirchengemeinde Kalender – Stylesheet

   Die folgenden CSS-Variablen können im Theme überschrieben werden, um
   die Farben an die bestehende Website anzupassen, z. B. im
   Customizer-CSS oder in der style.css des Child-Themes:

   :root {
     --kg-ink: #222222;
     --kg-brass: #b08d3e;
     --kg-paper: #faf8f3;
   }
   ========================================================================== */

:root {
    --kg-paper: #F8F5EC;
    --kg-ink: #22324A;
    --kg-ink-soft: #5C6C82;
    --kg-brass: #B98B3E;
    --kg-brass-soft: #F1E3C2;
    --kg-vestry: #46614C;
    --kg-line: #DCD2B8;
    --kg-radius: 10px;

    /* Farben je Terminart – steuern Punkte im Kalender und Rahmenfarbe in
       den Listen. Können einzeln überschrieben werden, z. B.:
       :root { --kg-color-gottesdienst: #7a2f2f; } */
    --kg-color-gottesdienst: #B98B3E;
    --kg-color-gruppe: #46614C;
    --kg-color-veranstaltung: #3C5C82;
    --kg-color-sonstiges: #8A8A8A;
}

/* ---------- Banner: nächste Gottesdienste ---------- */
.kg-banner {
    background: linear-gradient(135deg, #EDE0C4, #E8D5B0);
    color: var(--kg-ink);
    border-radius: var(--kg-radius);
    padding: 22px 28px;
    max-width: 100%;
    box-sizing: border-box;
    border-left: 5px solid var(--kg-brass);
}
.kg-banner-eyebrow {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--kg-brass-deep, #8C661F);
    font-weight: 700;
    margin-bottom: 14px;
}
.kg-banner-range {
    font-size: 0.85rem;
    color: var(--kg-ink-soft);
    margin-bottom: 12px;
}
.kg-banner-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 10px 20px;
}
.kg-banner-row {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 10px 14px;
    background: rgba(255,255,255,0.55);
    border-radius: 8px;
    border-left: 3px solid var(--kg-brass);
}
.kg-banner-day  { font-weight: 700; font-size: 0.95rem; color: var(--kg-ink); }
.kg-banner-time { font-size: 0.88rem; color: var(--kg-brass-deep, #8C661F); font-weight: 600; }
.kg-banner-place { font-size: 0.82rem; color: var(--kg-ink-soft); }
.kg-banner-title { font-size: 0.82rem; font-weight: 600; color: var(--kg-ink); }
.kg-banner-note  { font-size: 0.8rem; color: var(--kg-ink-soft); font-style: italic; }
.kg-banner--empty {
    background: var(--kg-paper);
    color: var(--kg-ink-soft);
    text-align: center;
    padding: 24px;
}
@media (max-width: 480px) {
    .kg-banner { padding: 16px; }
    .kg-banner-list { grid-template-columns: 1fr; }
}

/* ---------- Kalender ---------- */
.kg-kalender { color: var(--kg-ink); max-width: 760px; }

.kg-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.kg-filter-chip {
    border: 1px solid var(--kg-line);
    background: #fff;
    border-radius: 999px;
    padding: 6px 14px;
    font-size: 0.85rem;
    color: var(--kg-ink-soft);
    cursor: pointer;
}
.kg-filter-chip.active { background: var(--kg-ink); border-color: var(--kg-ink); color: #fff; }

.kg-agenda {
    background: #fff;
    border: 1px solid var(--kg-line);
    border-radius: var(--kg-radius);
    padding: 14px 16px;
    margin-bottom: 18px;
}
.kg-agenda h4 { margin: 0 0 10px; font-size: 0.95rem; }
.kg-agenda-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.kg-agenda-item {
    border-left: 3px solid var(--kg-brass);
    padding: 4px 0 4px 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    font-size: 0.88rem;
}
.kg-agenda-date { font-weight: 600; min-width: 120px; }
.kg-agenda-title { color: var(--kg-ink); }
.kg-agenda-ort { color: var(--kg-ink-soft); font-size: 0.82rem; }
.kg-agenda-note { color: var(--kg-ink-soft); font-size: 0.82rem; font-style: italic; width: 100%; }
.kg-empty { color: var(--kg-ink-soft); font-size: 0.85rem; }

.kg-grid-wrap { background: #fff; border: 1px solid var(--kg-line); border-radius: var(--kg-radius); padding: 14px 16px; }
.kg-grid-nav { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.kg-grid-nav button {
    background: none;
    border: 1px solid var(--kg-line);
    border-radius: 6px;
    width: 30px;
    height: 30px;
    font-size: 0.95rem;
    color: var(--kg-ink);
}
.kg-grid-nav button:disabled { opacity: 0.3; cursor: default; }
.kg-grid-nav button:focus-visible { outline: 2px solid var(--kg-brass); outline-offset: 1px; }

.kg-weekday-row {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    font-size: 0.72rem;
    color: var(--kg-ink-soft);
    text-align: center;
    margin-bottom: 4px;
}
.kg-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.kg-day {
    position: relative;
    border: none;
    background: var(--kg-paper);
    border-radius: 6px;
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    color: var(--kg-ink);
    padding: 0;
    cursor: pointer;
}
.kg-day:focus-visible { outline: 2px solid var(--kg-brass); outline-offset: 1px; }
.kg-day--blank { background: transparent; cursor: default; }
.kg-day.is-today { box-shadow: inset 0 0 0 2px var(--kg-brass); font-weight: 700; }
.kg-day.is-selected { background: var(--kg-ink); color: #fff; }
.kg-day-dots { display: flex; gap: 2px; margin-top: 3px; }
.kg-dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; }

.kg-day-panel { margin-top: 14px; border-top: 1px solid var(--kg-line); padding-top: 12px; }
.kg-day-panel h4 { margin: 0 0 8px; font-size: 0.92rem; }
.kg-day-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.kg-day-list li {
    border-left: 3px solid var(--kg-brass);
    padding: 4px 0 4px 10px;
    display: flex;
    flex-direction: column;
    font-size: 0.88rem;
}
.kg-day-list-time { font-weight: 700; }
.kg-day-list-typ { font-size: 0.74rem; color: var(--kg-ink-soft); text-transform: uppercase; letter-spacing: 0.03em; }
.kg-day-list-ort { color: var(--kg-ink-soft); font-size: 0.82rem; }
.kg-day-list-desc { color: var(--kg-ink-soft); font-size: 0.82rem; font-style: italic; }

@media (max-width: 480px) {
    .kg-day { font-size: 0.72rem; }
    .kg-banner-date { font-size: 1.1rem; }
}
@media (prefers-reduced-motion: reduce) {
    .kg-kalender * { transition: none !important; }
}
