/* === Theme Variablen === */
:root {
  --bg: linear-gradient(15deg, forestgreen 0%, white 50%);
  --text: forestgreen;
  --link: grey;
  --link-hover: forestgreen;
  --box-bg: white;
  --shadow: 2px 5px 10px grey;
}

/* === Grundlayout === */
html, body {
    margin: 0;
    padding: 0;
    font: normal 10pt Verdana, sans-serif;
    color: var(--text);
    background: var(--bg);
    background-attachment: fixed;
    min-height: 100%;
    scroll-behavior: smooth;
}

a {
    color: var(--link);
    text-decoration: none;
}
a:hover {
    color: var(--link-hover);
}

/* === Box / Shadow === */
.shadow {
    border-radius: 20px;
    padding: 10px;
    box-shadow: var(--shadow);
    background: var(--box-bg);
}

/* === Layout Container / Items === */
.container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    gap: 1rem;
    margin: 1rem 0;
}

.item {
    flex: 1 1 45%;
    min-width: 200px;
}

/* === Zentrierung === */
.center {
    text-align: center;
    margin: auto;
}

.logo {
    width: 90%;
    max-width: 600px;
    height: auto;
	text-align: center;
    margin: auto;
}

/* === Subpage Content === */
.subpage-content {
    width: 100%;
    display: block;
}

/* === Footer / sonstige Elemente === */
footer {
    margin: 2rem 0;
}

/* === Clock Widget === */
.clock {
    border: 0;
}

/* === Recipe Boxen === */
.recipe-box {
    background: var(--box-bg);
    color: var(--text);
    border-radius: 15px;
    padding: 15px;
    box-shadow: var(--shadow);
    flex: 1 1 300px; /* Basisbreite 300px, wächst aber flexibel */
    max-width: 350px; /* feste maximale Breite */
    margin: 10px;
    box-sizing: border-box;
}

.container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center; /* zentriert die Boxen */
    gap: 15px;
}

.recipe-box:hover {
    transform: translateY(-5px);
    box-shadow: 4px 8px 15px rgba(0,0,0,0.3);
}

.recipe-box h3 {
    margin-top: 0;
    font-size: 1.1rem;
}

.recipe-box ul {
    padding-left: 1.2rem;
}

.recipe-box p {
    margin-top: 0.5rem;
    font-size: 0.95rem;
}

/* === Kalender Box === */
.calendar-box {
    background: var(--box-bg);
    color: var(--text);
    border-radius: 15px;
    padding: 15px;
    box-shadow: var(--shadow);
    flex: 1 1 90%;  /* immer 90% der Breite */
    margin: 10px auto;
    box-sizing: border-box;
}
.calendar-box iframe {
    width: 100%;
    height: 1500px;
    border-radius: 10px;
    box-shadow: var(--shadow);
}

/* === News Feed === */
.news-box {
    background: var(--box-bg);
    color: var(--text);
    border-radius: 15px;
    padding: 15px;
    box-shadow: var(--shadow);
    flex: 1 1 300px;
    margin: 10px;
    box-sizing: border-box;
    max-width: 400px;
}

.news-box h3 {
    margin-top: 0;
    font-size: 1.1rem;
}

.news-box ul {
    padding-left: 1.2rem;
    list-style: disc;
}

.news-box ul li {
    margin-bottom: 0.5rem;
}

.news-button {
    display: inline-block;
    padding: 10px 20px;
    background: forestgreen;
    color: white;
    border-radius: 10px;
    text-decoration: none;
    font-weight: bold;
}

.news-button:hover {
    background: darkgreen;
}

/* Responsive */
@media screen and (max-width: 1200px) {
    .news-box { flex: 1 1 45%; }
}
@media screen and (max-width: 800px) {
    .news-box { flex: 1 1 90%; }
}
