:root {
    --eh-cream: #fff7e3;
    --eh-cream-strong: #fff1cb;
    --eh-forest: #3f6f3c;
    --eh-moss: #729c49;
    --eh-sky: #d8eef9;
    --eh-sun: #f2bf55;
    --eh-bark: #6d4524;
    --eh-bark-dark: #4b2e16;
    --eh-terra: #d97830;
    --eh-berry: #b54f5e;
    --eh-ink: #3d362a;
    --eh-border: rgba(109, 69, 36, 0.16);
    --eh-shadow: 0 12px 30px rgba(72, 46, 19, 0.12);
    --eh-radius: 26px;
    --eh-radius-sm: 18px;
    --eh-container: min(1180px, calc(100% - 2rem));
    --eh-transition: 180ms ease;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    color: var(--eh-ink);
    background:
        radial-gradient(circle at 15% 10%, rgba(255, 255, 255, 0.72), transparent 18rem),
        radial-gradient(circle at 85% 12%, rgba(255, 255, 255, 0.55), transparent 16rem),
        linear-gradient(180deg, #edf8ff 0%, #f8fbef 24%, var(--eh-cream) 60%, #fffdf6 100%);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    font-size: 1.0625rem;
    line-height: 1.75;
    min-height: 100vh;
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

a {
    color: var(--eh-forest);
    text-decoration-thickness: 0.09em;
    text-underline-offset: 0.18em;
}

a:hover,
a:focus {
    color: var(--eh-bark);
}

button,
input,
textarea,
select {
    font: inherit;
}

.screen-reader-text {
    position: absolute !important;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    width: 1px;
    height: 1px;
    margin: 0;
    overflow: hidden;
    word-wrap: normal !important;
}

.skip-link:focus {
    clip: auto;
    clip-path: none;
    width: auto;
    height: auto;
    left: 1rem;
    top: 1rem;
    z-index: 9999;
    padding: 0.85rem 1rem;
    border-radius: 999px;
    background: var(--eh-bark);
    color: #fff;
    text-decoration: none;
}

.container {
    width: var(--eh-container);
    margin-inline: auto;
}

.site {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.site-shell,
.site-main {
    flex: 1 0 auto;
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 60;
    backdrop-filter: saturate(150%) blur(10px);
}

.site-header__bar {
    background:
        linear-gradient(180deg, rgba(54, 95, 45, 0.96) 0%, rgba(49, 86, 40, 0.95) 100%);
    box-shadow: 0 6px 18px rgba(38, 60, 29, 0.18);
    border-bottom: 4px solid rgba(255, 223, 142, 0.45);
}

.site-header__inner {
    min-height: 5.25rem;
    display: flex;
    align-items: center;
    gap: 1.25rem;
    justify-content: space-between;
}

.site-branding {
    display: flex;
    align-items: center;
    gap: 0.95rem;
    min-width: 0;
}

.site-logo img,
.custom-logo {
    width: 3.4rem;
    height: 3.4rem;
    object-fit: cover;
    border-radius: 50%;
    border: 3px solid rgba(255, 245, 216, 0.9);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.18);
}

.site-branding__text {
    min-width: 0;
}

.site-title,
.site-description {
    margin: 0;
}

.site-title {
    font-size: clamp(1.15rem, 1vw + 1rem, 1.65rem);
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1.2;
}

.site-title a,
.site-description {
    color: #fff7ea;
    text-decoration: none;
}

.site-description {
    font-size: 0.96rem;
    opacity: 0.9;
}

.menu-toggle {
    display: none;
    align-items: center;
    gap: 0.65rem;
    border: 0;
    border-radius: 999px;
    padding: 0.72rem 1rem;
    color: var(--eh-bark-dark);
    background: linear-gradient(180deg, #f8d683 0%, #efb64a 100%);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.65);
    cursor: pointer;
    transition: transform var(--eh-transition), box-shadow var(--eh-transition);
}

.menu-toggle:hover,
.menu-toggle:focus-visible,
.button:hover,
.button:focus-visible,
.wp-block-button__link:hover,
.wp-block-button__link:focus-visible {
    transform: translateY(-2px);
}

.menu-toggle__icon,
.menu-toggle__icon::before,
.menu-toggle__icon::after {
    display: block;
    width: 1.15rem;
    height: 2px;
    background: currentColor;
    border-radius: 999px;
    content: "";
}

.menu-toggle__icon {
    position: relative;
}

.menu-toggle__icon::before {
    position: absolute;
    top: -0.35rem;
}

.menu-toggle__icon::after {
    position: absolute;
    top: 0.35rem;
}

.main-navigation {
    margin-left: auto;
}

.main-navigation .menu,
.footer-navigation .menu {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin: 0;
    padding: 0;
}

.main-navigation .menu a,
.footer-navigation .menu a,
.main-navigation .page_item > a {
    display: inline-flex;
    align-items: center;
    padding: 0.68rem 1rem;
    border-radius: 999px;
    color: #fff8e8;
    text-decoration: none;
    font-weight: 700;
    line-height: 1.2;
    transition: background var(--eh-transition), color var(--eh-transition);
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a,
.main-navigation a:hover,
.main-navigation a:focus-visible {
    background: rgba(255, 248, 224, 0.14);
    color: #fff;
}

.hero {
    position: relative;
    overflow: clip;
    padding: clamp(3.5rem, 7vw, 6rem) 0 clamp(2.5rem, 5vw, 4.5rem);
}

.hero::before {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 10rem;
    background:
        radial-gradient(circle at 10% 60%, rgba(114, 156, 73, 0.23), transparent 10rem),
        radial-gradient(circle at 50% 80%, rgba(114, 156, 73, 0.18), transparent 12rem),
        radial-gradient(circle at 90% 60%, rgba(114, 156, 73, 0.22), transparent 9rem);
    pointer-events: none;
}

.hero__inner {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.95fr);
    align-items: center;
    gap: clamp(1.75rem, 4vw, 3.5rem);
}

.hero__badge,
.section-heading__eyebrow,
.site-footer__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-size: 0.8rem;
    color: var(--eh-forest);
    background: rgba(255, 255, 255, 0.78);
    padding: 0.45rem 0.8rem;
    border-radius: 999px;
    border: 1px solid rgba(63, 111, 60, 0.14);
    box-shadow: 0 8px 18px rgba(109, 69, 36, 0.08);
}

.hero__title,
.page-banner h1 {
    font-size: clamp(2.5rem, 4vw, 4.55rem);
    line-height: 1.04;
    letter-spacing: -0.03em;
    color: var(--eh-bark);
    margin: 1rem 0 0.9rem;
    max-width: 12ch;
}

.hero__text,
.page-banner p {
    max-width: 56ch;
    font-size: 1.1rem;
    margin: 0 0 1.5rem;
    color: rgba(61, 54, 42, 0.92);
}

.hero__actions,
.section-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
}

.button,
.wp-block-button__link,
input[type="submit"],
button[type="submit"] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: 0.85rem 1.2rem;
    border: 0;
    border-radius: 999px;
    background: linear-gradient(180deg, #f8d683 0%, #efb64a 100%);
    color: var(--eh-bark-dark);
    font-weight: 800;
    text-decoration: none;
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.68);
    transition: transform var(--eh-transition), box-shadow var(--eh-transition), background var(--eh-transition), color var(--eh-transition);
    cursor: pointer;
}

.button:active,
.wp-block-button__link:active,
input[type="submit"]:active,
button[type="submit"]:active {
    transform: translateY(1px);
    box-shadow: 0 3px 0 rgba(95, 58, 18, 0.68);
}

.button--ghost,
.is-style-outline > .wp-block-button__link,
.wp-block-button.is-style-outline > .wp-block-button__link {
    background: rgba(255, 255, 255, 0.74);
    color: var(--eh-forest);
    box-shadow: none;
    border: 2px solid rgba(63, 111, 60, 0.2);
}

.button--ghost:hover,
.button--ghost:focus-visible,
.wp-block-button.is-style-outline > .wp-block-button__link:hover,
.wp-block-button.is-style-outline > .wp-block-button__link:focus-visible {
    background: rgba(255, 255, 255, 0.92);
    color: var(--eh-bark);
}

.hero__visual {
    position: relative;
}

.hero__frame {
    overflow: hidden;
    border-radius: calc(var(--eh-radius) + 4px);
    background: #fff;
    border: 10px solid rgba(255, 250, 240, 0.92);
    box-shadow: 0 28px 55px rgba(88, 58, 26, 0.16);
}

.hero__frame img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.hero__mascot {
    position: absolute;
    max-width: clamp(170px, 34%, 260px);
    right: -0.5rem;
    bottom: -2.2rem;
    filter: drop-shadow(0 16px 26px rgba(75, 46, 22, 0.22));
}

.section-space {
    padding: clamp(1.2rem, 3vw, 2.2rem) 0 clamp(2.8rem, 5vw, 4.2rem);
}

.section-heading {
    margin-bottom: 1.5rem;
}

.section-heading h2 {
    font-size: clamp(1.95rem, 3vw, 3rem);
    line-height: 1.1;
    margin: 0.85rem 0 0.7rem;
    color: var(--eh-bark);
}

.section-heading p,
.prose-card > :first-child {
    margin-top: 0;
}

.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card {
    position: relative;
    background: rgba(255, 255, 255, 0.8);
    border: 1px solid var(--eh-border);
    border-radius: var(--eh-radius);
    box-shadow: var(--eh-shadow);
}

.prose-card,
.article-card,
.empty-state,
.post-navigation-card {
    padding: clamp(1.35rem, 3vw, 2.4rem);
}

.prose-card::before,
.article-card::before,
.feature-card::before,
.card-widget::before,
.post-card::before,
.notice-callout::before,
.empty-state::before,
.post-navigation-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.quick-links {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.feature-card {
    padding: 1.5rem;
    overflow: hidden;
}

.feature-card::after {
    content: "";
    position: absolute;
    inset: auto -2rem -2rem auto;
    width: 8rem;
    height: 8rem;
    background: radial-gradient(circle, rgba(114, 156, 73, 0.18), transparent 70%);
    pointer-events: none;
}

.feature-card__number {
    display: inline-flex;
    width: 2.5rem;
    height: 2.5rem;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    border-radius: 50%;
    font-weight: 800;
    color: var(--eh-bark-dark);
    background: linear-gradient(180deg, #ffe6a2 0%, #efbf55 100%);
    box-shadow: 0 4px 10px rgba(109, 69, 36, 0.16);
}

.feature-card h3 {
    margin: 0 0 0.55rem;
    font-size: 1.35rem;
}

.feature-card p {
    margin: 0 0 1rem;
}

.feature-card__link,
.post-card__link {
    font-weight: 800;
    text-decoration: none;
}

.news-section .posts-grid {
    margin-top: 1.2rem;
}

.posts-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.25rem;
}

.posts-grid--archive {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.post-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.post-card__media {
    display: block;
    overflow: hidden;
    background: linear-gradient(180deg, rgba(216, 238, 249, 0.92) 0%, rgba(255, 247, 227, 0.92) 100%);
}

.post-card__media img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
    transition: transform 220ms ease;
}

.post-card:hover .post-card__media img,
.post-card:focus-within .post-card__media img {
    transform: scale(1.04);
}

.post-card__placeholder {
    display: grid;
    place-items: center;
    min-height: 13rem;
    padding: 1rem;
    font-size: 1.35rem;
    font-weight: 800;
    color: var(--eh-bark);
    text-align: center;
    background:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.48), transparent 12rem),
        linear-gradient(180deg, rgba(216, 238, 249, 0.95) 0%, rgba(255, 247, 227, 0.96) 100%);
}

.post-card__body {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    padding: 1.35rem;
    flex: 1;
}

.post-card__meta,
.entry-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.92rem;
    color: rgba(61, 54, 42, 0.78);
}

.meta-separator {
    opacity: 0.5;
}

.post-card__title {
    margin: 0;
    font-size: 1.35rem;
    line-height: 1.25;
}

.post-card__title a {
    color: var(--eh-bark);
    text-decoration: none;
}

.post-card__body p {
    margin: 0;
}

.notice-callout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(220px, 0.8fr);
    gap: 1rem;
    align-items: center;
    padding: clamp(1.4rem, 4vw, 2.6rem);
    background:
        radial-gradient(circle at 15% 20%, rgba(216, 238, 249, 0.6), transparent 20rem),
        linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 247, 227, 0.95) 100%);
}

.notice-callout__visual {
    justify-self: center;
    width: min(100%, 320px);
}

.notice-callout__visual img {
    width: 100%;
    filter: drop-shadow(0 14px 22px rgba(75, 46, 22, 0.18));
}

.page-banner {
    padding: clamp(2.4rem, 5vw, 4.2rem) 0 1.25rem;
}

.page-banner--inner {
    padding-bottom: 0.6rem;
}

.page-banner h1 {
    max-width: 15ch;
    margin-bottom: 0.6rem;
}

.content-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
    gap: 1.5rem;
    align-items: start;
    padding-bottom: 4rem;
}

.narrow-layout {
    width: min(860px, calc(100% - 2rem));
    margin-inline: auto;
    padding-bottom: 4rem;
}

.content-area > * + * {
    margin-top: 1.25rem;
}

.article-figure {
    margin: -2rem -2rem 1.5rem;
    overflow: hidden;
    border-radius: calc(var(--eh-radius) - 6px) calc(var(--eh-radius) - 6px) 0 0;
}

.article-figure img {
    width: 100%;
    max-height: 34rem;
    object-fit: cover;
}

.entry-content > :where(h2, h3, h4) {
    color: var(--eh-bark);
    margin-top: 1.9em;
    margin-bottom: 0.55em;
}

.entry-content > :where(ul, ol) {
    padding-left: 1.35rem;
}

.entry-content > :where(figure, .wp-block-image, .wp-block-gallery, .wp-block-cover) {
    margin: 1.5rem 0;
}

.entry-content blockquote,
.wp-block-quote {
    margin: 1.6rem 0;
    padding: 1rem 1.25rem;
    border-left: 5px solid var(--eh-moss);
    border-radius: 0 var(--eh-radius-sm) var(--eh-radius-sm) 0;
    background: rgba(114, 156, 73, 0.08);
}

.entry-content table,
.wp-block-table table {
    width: 100%;
    border-collapse: collapse;
    overflow: hidden;
    border-radius: 18px;
}

.entry-content th,
.entry-content td,
.wp-block-table th,
.wp-block-table td {
    padding: 0.8rem 0.95rem;
    border: 1px solid rgba(109, 69, 36, 0.14);
}

.entry-content th,
.wp-block-table th {
    background: rgba(216, 238, 249, 0.55);
    text-align: left;
}

.entry-footer--article {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    justify-content: space-between;
    margin-top: 1.8rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(109, 69, 36, 0.12);
}

.tag-cloud a,
.wp-block-tag-cloud a {
    display: inline-flex;
    align-items: center;
    padding: 0.34rem 0.7rem;
    margin: 0 0.35rem 0.35rem 0;
    border-radius: 999px;
    background: rgba(216, 238, 249, 0.7);
    color: var(--eh-bark);
    text-decoration: none;
    font-size: 0.92rem !important;
}

.post-navigation-card .nav-links {
    display: grid;
    gap: 0.75rem;
}

.post-navigation-card .nav-links a {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 0.2rem 0;
}

.nav-subtitle {
    display: block;
    font-size: 0.82rem;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--eh-forest);
    font-weight: 800;
}

.nav-title {
    color: var(--eh-bark);
    font-size: 1.08rem;
    font-weight: 700;
}

.sidebar,
.widget-area {
    display: grid;
    gap: 1rem;
}

.widget,
.card-widget {
    padding: 1.25rem;
}

.widget-title,
.wood-title {
    margin: 0 0 0.9rem;
}

.wood-title {
    display: inline-flex;
    align-items: center;
    padding: 0.55rem 0.95rem;
    border-radius: 16px;
    background: linear-gradient(180deg, #5f8d49 0%, #406f3c 100%);
    color: #fff8e8;
    box-shadow: 0 6px 0 rgba(74, 54, 24, 0.32);
}

.wood-title--small {
    font-size: 1rem;
    padding: 0.5rem 0.8rem;
}

.widget ul {
    margin: 0;
    padding-left: 1.1rem;
}

.pagination-wrap {
    padding-top: 0.8rem;
}

.nav-links,
.page-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
}

.nav-links .page-numbers,
.page-links a,
.page-links > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.65rem;
    min-height: 2.65rem;
    padding: 0.2rem 0.8rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(109, 69, 36, 0.12);
    text-decoration: none;
    color: var(--eh-bark);
    font-weight: 700;
}

.nav-links .current,
.page-links > span {
    background: var(--eh-forest);
    color: #fff;
}

.card-search {
    display: flex;
    gap: 0.75rem;
    padding: 1rem;
    align-items: center;
}

.search-field,
input[type="text"],
input[type="email"],
input[type="url"],
textarea {
    width: 100%;
    border: 1px solid rgba(109, 69, 36, 0.2);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--eh-ink);
    padding: 0.9rem 1rem;
    box-shadow: inset 0 1px 2px rgba(72, 46, 19, 0.04);
}

textarea {
    min-height: 10rem;
}

.search-field:focus,
input:focus,
textarea:focus,
select:focus {
    outline: 3px solid rgba(114, 156, 73, 0.18);
    border-color: rgba(63, 111, 60, 0.35);
}

.comments-area {
    margin-top: 1rem;
}

.comment-list {
    list-style: none;
    padding: 0;
    margin: 1.3rem 0;
}

.comment-list .comment {
    padding: 1rem 0;
    border-top: 1px solid rgba(109, 69, 36, 0.1);
}

.comment-list .comment:first-child {
    border-top: 0;
    padding-top: 0;
}

.comment-meta {
    margin-bottom: 0.5rem;
}

.error-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
    gap: 1.5rem;
    align-items: center;
}

.error-layout__visual img {
    width: 100%;
    max-width: 300px;
    margin-inline: auto;
}

.empty-state p {
    margin-bottom: 1rem;
}

.alignwide {
    width: min(var(--eh-container), 100vw - 2rem);
    margin-left: calc((100% - min(var(--eh-container), 100vw - 2rem)) / 2);
}

.alignfull {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
}

.wp-block-group,
.wp-block-cover,
.wp-block-columns {
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
}

.wp-block-button__link {
    color: var(--eh-bark-dark);
}

.site-footer {
    position: relative;
    margin-top: auto;
    background:
        linear-gradient(180deg, #f7f0db 0%, #f2ead1 100%);
    border-top: 1px solid rgba(109, 69, 36, 0.1);
}

.footer-grass {
    height: 2.75rem;
    background:
        radial-gradient(circle at 5% 110%, #79a94e 0 22px, transparent 23px),
        radial-gradient(circle at 12% 110%, #6d9d48 0 26px, transparent 27px),
        radial-gradient(circle at 19% 110%, #84b257 0 23px, transparent 24px),
        radial-gradient(circle at 28% 110%, #6d9d48 0 28px, transparent 29px),
        radial-gradient(circle at 38% 110%, #7eaa54 0 21px, transparent 22px),
        radial-gradient(circle at 52% 110%, #6d9d48 0 30px, transparent 31px),
        radial-gradient(circle at 62% 110%, #87b95a 0 22px, transparent 23px),
        radial-gradient(circle at 74% 110%, #6f9c47 0 28px, transparent 29px),
        radial-gradient(circle at 84% 110%, #7eaa54 0 24px, transparent 25px),
        radial-gradient(circle at 92% 110%, #709d48 0 20px, transparent 21px),
        linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(114,156,73,0.08) 100%);
}

.site-footer__main {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 1.75rem;
    padding: 2rem 0 2.3rem;
}

.site-footer__about h2 {
    margin: 0.6rem 0;
    font-size: clamp(1.8rem, 3vw, 2.6rem);
}

.site-footer__widgets {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.site-footer__sub {
    border-top: 1px solid rgba(109, 69, 36, 0.1);
    padding: 0.95rem 0;
    background: rgba(255, 255, 255, 0.32);
}

.site-footer__subinner {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    flex-wrap: wrap;
}

.menu--footer {
    gap: 0.2rem;
}

.menu--footer a {
    color: var(--eh-bark);
}

.menu--footer a:hover,
.menu--footer a:focus-visible {
    background: rgba(109, 69, 36, 0.08);
}

@media (max-width: 1040px) {
    .quick-links,
    .posts-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .hero__inner,
    .notice-callout,
    .site-footer__main {
        grid-template-columns: 1fr;
    }

    .hero__visual {
        max-width: 48rem;
    }

    .hero__mascot {
        max-width: 220px;
        right: 1rem;
    }

    .site-footer__widgets {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 820px) {
    .menu-toggle {
        display: inline-flex;
    }

    .main-navigation {
        position: absolute;
        inset: calc(100% + 0.55rem) 1rem auto;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
        transition: opacity var(--eh-transition), transform var(--eh-transition), visibility var(--eh-transition);
    }

    .main-navigation.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .main-navigation .menu,
    .main-navigation .menu ul,
    .main-navigation div.menu ul {
        flex-direction: column;
        align-items: stretch;
        gap: 0.15rem;
        min-width: min(24rem, calc(100vw - 2rem));
        padding: 0.8rem;
        border-radius: 22px;
        background: rgba(52, 88, 43, 0.98);
        box-shadow: 0 18px 36px rgba(45, 30, 12, 0.22);
    }

    .main-navigation .menu a,
    .main-navigation .page_item > a {
        width: 100%;
    }

    .content-layout,
    .error-layout {
        grid-template-columns: 1fr;
    }

    .sidebar {
        order: 2;
    }
}

@media (max-width: 700px) {
    .hero {
        padding-top: 2.6rem;
    }

    .hero__actions,
    .card-search,
    .site-footer__subinner {
        flex-direction: column;
        align-items: stretch;
    }

    .quick-links,
    .posts-grid,
    .posts-grid--archive,
    .site-footer__widgets {
        grid-template-columns: 1fr;
    }

    .hero__title,
    .page-banner h1 {
        max-width: none;
    }

    .hero__mascot {
        position: static;
        max-width: 180px;
        margin: 1rem auto 0;
    }

    .article-figure {
        margin-inline: -1.35rem;
        margin-top: -1.35rem;
    }
}

/* ------------------------------------------------------------
   Garten-frei Redesign: hell, einladend, Plakat-Optik
------------------------------------------------------------- */
:root {
    --eh-cream: #fff8ea;
    --eh-cream-strong: #fff2cf;
    --eh-forest: #547937;
    --eh-forest-dark: #345227;
    --eh-moss: #8fb553;
    --eh-sky: #dff2ff;
    --eh-sky-deep: #b8e3fb;
    --eh-sun: #efc25f;
    --eh-bark: #7d5730;
    --eh-bark-dark: #5f3f21;
    --eh-terra: #d4873f;
    --eh-berry: #b65759;
    --eh-ink: #45351f;
    --eh-border: rgba(98, 125, 65, 0.18);
    --eh-shadow: 0 20px 40px rgba(96, 71, 31, 0.12);
    --eh-radius: 28px;
    --eh-radius-sm: 18px;
    --eh-display: "Trebuchet MS", "Arial Rounded MT Bold", "Segoe UI", sans-serif;
}

body {
    background:
        radial-gradient(circle at 16% 10%, rgba(255,255,255,0.75), transparent 20rem),
        radial-gradient(circle at 86% 14%, rgba(255,255,255,0.64), transparent 18rem),
        linear-gradient(180deg, #dff2ff 0%, #ebf8ff 14%, #f8f9eb 34%, #fff8ea 72%, #fffdf7 100%);
    color: var(--eh-ink);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 80;
}

.site-header__bar {
    background:
        linear-gradient(180deg, rgba(255, 250, 240, 0.92) 0%, rgba(250, 243, 226, 0.9) 100%);
    border-bottom: 1px solid rgba(91, 119, 63, 0.14);
    box-shadow: 0 10px 24px rgba(67, 91, 40, 0.08);
}

.site-branding {
    gap: 1rem;
}

.site-title,
.hero__title,
.page-banner h1,
.section-heading h2,
.wood-title,
.feature-card h3,
.post-card__title,
.notice-callout h2,
.site-footer__about h2 {
    font-family: var(--eh-display);
}

.site-title a,
.site-description {
    color: var(--eh-forest-dark);
}

.site-title {
    font-size: clamp(1.18rem, 1vw + 1rem, 1.7rem);
    letter-spacing: -0.02em;
}

.site-description {
    color: rgba(69, 53, 31, 0.72);
}

.main-navigation .menu a,
.footer-navigation .menu a,
.main-navigation .page_item > a {
    padding: 0.7rem 1.02rem;
    border-radius: 999px;
    color: #fffbee;
    background: linear-gradient(180deg, #6e9647 0%, #4f7537 100%);
    box-shadow: 0 4px 0 rgba(88, 62, 31, 0.3);
    border: 1px solid rgba(255,255,255,0.22);
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a,
.main-navigation a:hover,
.main-navigation a:focus-visible {
    background: linear-gradient(180deg, #7ba64f 0%, #557e39 100%);
    color: #fff;
}

.menu-toggle {
    color: #fffbee;
    background: linear-gradient(180deg, #6f9748 0%, #4f7537 100%);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.42);
}

.hero {
    position: relative;
    padding: clamp(3.6rem, 8vw, 6.5rem) 0 clamp(2.8rem, 5vw, 4.4rem);
    background:
        radial-gradient(circle at 12% 18%, rgba(255,255,255,0.75), transparent 18rem),
        radial-gradient(circle at 92% 20%, rgba(255,255,255,0.55), transparent 16rem),
        linear-gradient(180deg, rgba(208, 238, 255, 0.38) 0%, rgba(255, 255, 255, 0) 58%);
}

.hero::before {
    height: 13rem;
    background:
        radial-gradient(circle at 8% 88%, rgba(143, 181, 83, 0.24), transparent 9rem),
        radial-gradient(circle at 28% 85%, rgba(143, 181, 83, 0.2), transparent 11rem),
        radial-gradient(circle at 54% 88%, rgba(114, 156, 73, 0.18), transparent 12rem),
        radial-gradient(circle at 78% 86%, rgba(143, 181, 83, 0.2), transparent 10rem),
        radial-gradient(circle at 94% 84%, rgba(114, 156, 73, 0.2), transparent 9rem);
}

.hero__garland {
    position: absolute;
    top: 0.6rem;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
    gap: 0.8rem;
    pointer-events: none;
}

.hero__garland span {
    position: relative;
    width: 0;
    height: 0;
    border-left: 1rem solid transparent;
    border-right: 1rem solid transparent;
    border-top: 1.6rem solid #f0c966;
    filter: drop-shadow(0 4px 6px rgba(85, 62, 27, 0.14));
}

.hero__garland span:nth-child(2n) {
    border-top-color: #7fae53;
}

.hero__garland span:nth-child(3n) {
    border-top-color: #f0a96d;
}

.hero__garland span::before {
    content: "";
    position: absolute;
    top: -1.6rem;
    left: -0.04rem;
    width: 0.08rem;
    height: 1.1rem;
    background: rgba(123, 88, 42, 0.35);
}

.hero__inner {
    grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
    gap: clamp(1.8rem, 4vw, 3.4rem);
    align-items: center;
}

.hero__content {
    position: relative;
    z-index: 1;
}

.hero__badge,
.section-heading__eyebrow,
.site-footer__eyebrow {
    color: #fef8eb;
    background: linear-gradient(180deg, #688f44 0%, #4f7538 100%);
    border: 1px solid rgba(255,255,255,0.18);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.24);
    font-family: var(--eh-display);
    font-size: 0.82rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

.hero__title,
.page-banner h1 {
    max-width: 10ch;
    margin: 1rem 0 1rem;
    color: #fffaf0;
    font-weight: 900;
    font-size: clamp(3.15rem, 5vw, 5.3rem);
    line-height: 0.94;
    letter-spacing: -0.045em;
    text-shadow:
        0 2px 0 rgba(255, 255, 255, 0.88),
        0 5px 0 #6d9648,
        0 8px 0 #537639,
        0 16px 22px rgba(74, 54, 24, 0.2);
}

.hero__text,
.page-banner p {
    max-width: 54ch;
    font-size: 1.12rem;
    margin: 0 0 1.45rem;
    padding: 1rem 1.15rem;
    border-radius: 20px;
    background: rgba(255, 250, 240, 0.82);
    border: 1px solid rgba(106, 139, 68, 0.14);
    box-shadow: 0 10px 24px rgba(98, 71, 31, 0.08);
}

.hero__actions,
.section-actions {
    gap: 0.95rem;
}

.button,
.wp-block-button__link,
input[type="submit"],
button[type="submit"] {
    min-height: 3.15rem;
    padding: 0.88rem 1.28rem;
    border-radius: 20px;
    background: linear-gradient(180deg, #f4ddb4 0%, #edc487 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 6px 0 rgba(109, 78, 42, 0.6), 0 16px 24px rgba(91, 66, 31, 0.12);
    border: 2px solid rgba(255, 250, 238, 0.75);
    font-family: var(--eh-display);
    font-weight: 800;
}

.button--ghost,
.is-style-outline > .wp-block-button__link,
.wp-block-button.is-style-outline > .wp-block-button__link {
    background: linear-gradient(180deg, #fefbf1 0%, #f4eedf 100%);
    color: var(--eh-forest-dark);
    border-color: rgba(99, 127, 66, 0.24);
    box-shadow: 0 4px 0 rgba(98, 71, 31, 0.18), 0 12px 22px rgba(91, 66, 31, 0.08);
}

.hero__contact {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.85rem;
    margin-top: 1.2rem;
    max-width: 42rem;
}

.hero__contact-item {
    display: flex;
    flex-direction: column;
    gap: 0.18rem;
    padding: 0.9rem 1rem;
    border-radius: 18px;
    text-decoration: none;
    color: var(--eh-ink);
    background: linear-gradient(180deg, rgba(255, 253, 246, 0.98) 0%, rgba(249, 241, 221, 0.96) 100%);
    border: 2px solid rgba(255, 255, 255, 0.74);
    box-shadow: 0 6px 0 rgba(107, 79, 42, 0.18), 0 12px 20px rgba(91, 66, 31, 0.08);
}

.hero__contact-item:hover,
.hero__contact-item:focus-visible {
    color: var(--eh-bark);
    transform: translateY(-2px);
}

.hero__contact-label {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 800;
    color: var(--eh-forest);
}

.hero__contact-item strong {
    font-size: 1.06rem;
    line-height: 1.35;
}

.hero__plaque {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 1.2rem;
    padding: 0.75rem 1.25rem;
    border-radius: 22px;
    color: #fffbee;
    background: linear-gradient(180deg, #678f43 0%, #486d35 100%);
    border: 3px solid rgba(244, 226, 176, 0.75);
    box-shadow: 0 8px 0 rgba(95, 58, 18, 0.28), 0 16px 28px rgba(82, 61, 32, 0.14);
    font-family: var(--eh-display);
    font-weight: 800;
    font-size: 1.03rem;
}

.hero__visual {
    position: relative;
    justify-self: end;
    width: min(100%, 35rem);
}

.hero__frame {
    overflow: hidden;
    border-radius: 32px;
    background: linear-gradient(180deg, rgba(255, 253, 247, 0.98) 0%, rgba(247, 239, 220, 0.98) 100%);
    border: 12px solid rgba(255, 250, 241, 0.95);
    box-shadow: 0 26px 58px rgba(88, 58, 26, 0.18);
}

.hero__frame img {
    width: 100%;
    aspect-ratio: 4 / 5;
    object-fit: cover;
    object-position: center top;
}

.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 249, 236, 0.97) 100%);
    border: 1px solid rgba(106, 139, 68, 0.14);
    box-shadow: 0 16px 34px rgba(98, 71, 31, 0.1);
}

.section-heading h2 {
    color: var(--eh-bark);
    font-size: clamp(2rem, 3vw, 3rem);
    letter-spacing: -0.035em;
}

.feature-card {
    padding: 1.55rem;
}

.feature-card::after {
    width: 9rem;
    height: 9rem;
    background: radial-gradient(circle, rgba(143, 181, 83, 0.24), transparent 70%);
}

.feature-card__number {
    width: 2.7rem;
    height: 2.7rem;
    background: linear-gradient(180deg, #f8e3b6 0%, #efc263 100%);
    box-shadow: 0 4px 10px rgba(109, 69, 36, 0.12);
}

.feature-card h3,
.post-card__title,
.notice-callout h2 {
    letter-spacing: -0.03em;
}

.feature-card__link,
.post-card__link {
    color: var(--eh-forest-dark);
}

.post-card__media {
    background: linear-gradient(180deg, rgba(223, 242, 255, 0.95) 0%, rgba(255, 248, 234, 0.95) 100%);
}

.post-card__placeholder {
    background:
        radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.58), transparent 12rem),
        linear-gradient(180deg, rgba(223, 242, 255, 0.95) 0%, rgba(255, 248, 234, 0.98) 100%);
}

.notice-callout {
    background:
        radial-gradient(circle at 15% 20%, rgba(223, 242, 255, 0.75), transparent 20rem),
        linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(255, 248, 234, 0.98) 100%);
    gap: 1.3rem;
}

.notice-callout__visual {
    width: min(100%, 290px);
}

.wood-title {
    background: linear-gradient(180deg, #6c9447 0%, #4d7337 100%);
    color: #fff8eb;
    border: 1px solid rgba(255,255,255,0.18);
    box-shadow: 0 6px 0 rgba(74, 54, 24, 0.22);
}

.site-footer {
    background: linear-gradient(180deg, #f9f2e1 0%, #f5edda 100%);
    border-top: 1px solid rgba(109, 69, 36, 0.08);
}

.footer-grass {
    height: 3rem;
}

.site-footer__about {
    padding: 0.3rem 0;
}

.site-footer__about h2 {
    letter-spacing: -0.03em;
}

.site-footer__sub {
    background: rgba(255, 255, 255, 0.42);
}

.menu--footer a {
    background: transparent;
    color: var(--eh-bark);
    box-shadow: none;
    border: 0;
}

@media (max-width: 1040px) {
    .hero__visual {
        justify-self: center;
        width: min(100%, 30rem);
    }

    .hero__frame img {
        aspect-ratio: 4 / 5;
    }
}

@media (max-width: 820px) {
    .hero {
        padding-top: 4.2rem;
    }

    .hero__contact {
        grid-template-columns: 1fr;
    }

    .hero__title,
    .page-banner h1 {
        font-size: clamp(2.7rem, 10vw, 4.2rem);
        max-width: 100%;
    }
}

@media (max-width: 640px) {
    .hero__garland {
        gap: 0.55rem;
    }

    .hero__garland span {
        border-left-width: 0.72rem;
        border-right-width: 0.72rem;
        border-top-width: 1.15rem;
    }

    .hero__garland span::before {
        top: -1.15rem;
        height: 0.8rem;
    }

    .hero__text {
        padding: 0.9rem 1rem;
    }

    .hero__plaque {
        width: 100%;
        text-align: center;
    }
}

/* Version 1.2 - Header logo + wide banner redesign */
:root {
    --eh-cream: #fffaf0;
    --eh-cream-strong: #f8efd8;
    --eh-forest: #5a7f37;
    --eh-forest-dark: #3f5d28;
    --eh-sky: #dff3ff;
    --eh-sun: #efc85e;
    --eh-bark: #7b5734;
    --eh-bark-dark: #5d3f25;
    --eh-border: rgba(110, 84, 44, 0.14);
    --eh-shadow: 0 18px 40px rgba(99, 71, 31, 0.12);
    --eh-radius: 30px;
    --eh-radius-sm: 20px;
    --eh-container: min(1240px, calc(100% - 2rem));
    --eh-display: "Trebuchet MS", "Arial Rounded MT Bold", "Segoe UI", sans-serif;
}

body {
    background:
        radial-gradient(circle at 12% 8%, rgba(255,255,255,0.72), transparent 16rem),
        radial-gradient(circle at 88% 14%, rgba(255,255,255,0.6), transparent 18rem),
        linear-gradient(180deg, #dff4ff 0%, #eef9ff 18%, #f7fae9 36%, #fff8ea 72%, #fffdf8 100%);
}

.site-header {
    position: sticky;
    top: 0;
    z-index: 90;
    backdrop-filter: blur(10px) saturate(150%);
}

.site-header__bar {
    background: linear-gradient(180deg, rgba(255, 251, 244, 0.9) 0%, rgba(248, 241, 226, 0.9) 100%);
    border-bottom: 1px solid rgba(102, 132, 67, 0.12);
    box-shadow: 0 10px 24px rgba(72, 54, 27, 0.08);
}

.site-header__inner {
    min-height: 6.25rem;
    gap: 1rem;
}

.site-branding {
    min-width: 0;
    flex-shrink: 0;
}

.site-branding__mark {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
}

.site-branding__badge,
.site-branding__custom-logo .custom-logo {
    width: clamp(126px, 15vw, 214px);
    height: auto;
    max-height: 88px;
    object-fit: contain;
    border: 0;
    border-radius: 0;
    box-shadow: none;
}

.site-branding__custom-logo .custom-logo-link {
    display: inline-flex;
}

.site-branding__text {
    min-width: 0;
    margin-left: 0.8rem;
}

.site-title {
    font-family: var(--eh-display);
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.site-title a,
.site-description {
    color: var(--eh-bark);
}

.site-description {
    opacity: 0.8;
}

.main-navigation {
    margin-left: auto;
}

.main-navigation .menu,
.footer-navigation .menu {
    gap: 0.45rem;
}

.main-navigation .menu a,
.footer-navigation .menu a,
.main-navigation .page_item > a {
    padding: 0.74rem 1.1rem;
    border-radius: 999px;
    color: var(--eh-forest-dark);
    font-weight: 800;
    background: linear-gradient(180deg, rgba(255,255,255,0.86) 0%, rgba(249,243,230,0.92) 100%);
    border: 1px solid rgba(100, 128, 61, 0.14);
    box-shadow: 0 4px 0 rgba(98, 71, 31, 0.08);
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a,
.main-navigation a:hover,
.main-navigation a:focus-visible {
    color: #fffdf7;
    background: linear-gradient(180deg, #6b9443 0%, #4e7436 100%);
    border-color: rgba(255,255,255,0.18);
}

.menu-toggle {
    color: var(--eh-bark-dark);
    background: linear-gradient(180deg, #f9e1a5 0%, #efc461 100%);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.45);
}

.banner-stage {
    padding: clamp(1.2rem, 2.8vw, 1.8rem) 0 0;
}

.banner-stage__frame {
    position: relative;
    overflow: hidden;
    border-radius: clamp(22px, 2vw, 32px);
    border: 10px solid rgba(255, 252, 245, 0.92);
    box-shadow: 0 24px 56px rgba(86, 63, 30, 0.14);
    background: #fffef9;
}

.banner-stage__frame::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 26%;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(53, 36, 12, 0.08) 100%);
    pointer-events: none;
}

.banner-stage__frame img {
    width: 100%;
    aspect-ratio: 16 / 8.25;
    object-fit: cover;
    object-position: center 54%;
}

.welcome-panel-wrap {
    margin-top: clamp(-2.3rem, -2.8vw, -3rem);
    padding-bottom: 0.4rem;
    position: relative;
    z-index: 2;
}

.welcome-panel {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.65fr);
    gap: clamp(1.25rem, 3vw, 2.5rem);
    align-items: center;
    padding: clamp(1.45rem, 3vw, 2.4rem);
    border-radius: clamp(24px, 2.3vw, 32px);
    background:
        radial-gradient(circle at 12% 8%, rgba(255,255,255,0.64), transparent 16rem),
        linear-gradient(180deg, rgba(255,255,255,0.97) 0%, rgba(250, 244, 230, 0.98) 100%);
    border: 1px solid rgba(109, 79, 34, 0.1);
    box-shadow: 0 22px 48px rgba(86, 61, 26, 0.14);
}

.welcome-panel__content {
    min-width: 0;
}

.welcome-panel__title {
    margin: 1rem 0 0.9rem;
    font-size: clamp(2.35rem, 4vw, 4.45rem);
    line-height: 1.02;
    letter-spacing: -0.04em;
    color: var(--eh-bark);
}

.welcome-panel__text {
    margin: 0 0 1.5rem;
    max-width: 58ch;
    font-size: 1.08rem;
    color: rgba(69, 53, 31, 0.94);
}

.welcome-panel__aside {
    display: grid;
    justify-items: center;
    gap: 1rem;
}

.welcome-panel__logo {
    width: min(100%, 300px);
    filter: drop-shadow(0 12px 20px rgba(73, 51, 19, 0.12));
}

.section-heading__eyebrow,
.site-footer__eyebrow,
.hero__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 0.55rem 0.95rem;
    border-radius: 999px;
    background: linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(247,239,221,0.96) 100%);
    border: 1px solid rgba(99, 125, 67, 0.16);
    box-shadow: 0 8px 18px rgba(95, 66, 27, 0.08);
    color: var(--eh-forest-dark);
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.button,
.wp-block-button__link,
input[type="submit"],
button[type="submit"] {
    background: linear-gradient(180deg, #f8dda0 0%, #efc45f 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.45), 0 12px 20px rgba(95, 58, 18, 0.08);
}

.button--ghost,
.is-style-outline > .wp-block-button__link,
.wp-block-button.is-style-outline > .wp-block-button__link {
    background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(247,240,224,0.98) 100%);
    color: var(--eh-forest-dark);
    border: 1px solid rgba(100, 128, 61, 0.2);
    box-shadow: 0 4px 0 rgba(98, 71, 31, 0.08), 0 10px 18px rgba(98, 71, 31, 0.06);
}

.hero__actions {
    gap: 0.95rem;
}

.hero__contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    max-width: 42rem;
    margin-top: 1.25rem;
}

.hero__contact-item {
    border-radius: 20px;
    padding: 0.95rem 1rem;
    background: linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(248,240,224,0.98) 100%);
    border: 1px solid rgba(104, 129, 67, 0.15);
    box-shadow: 0 8px 20px rgba(96, 71, 31, 0.08);
    color: var(--eh-ink);
}

.hero__contact-item strong {
    font-size: 1.05rem;
    line-height: 1.35;
}

.hero__contact-label {
    color: var(--eh-forest-dark);
}

.wood-plaque,
.wood-title {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.78rem 1.25rem;
    border-radius: 18px;
    background: linear-gradient(180deg, #6c9447 0%, #4b6f35 100%);
    color: #fff8eb;
    border: 3px solid rgba(245, 228, 183, 0.72);
    box-shadow: 0 7px 0 rgba(92, 67, 28, 0.24), 0 14px 24px rgba(92, 67, 28, 0.1);
    font-family: var(--eh-display);
    font-weight: 800;
    letter-spacing: -0.01em;
}

.wood-plaque--hero {
    text-align: center;
    max-width: 20rem;
}

.section-space {
    padding: clamp(1.1rem, 3vw, 2rem) 0 clamp(2.7rem, 5vw, 4rem);
}

.section-space--first-content {
    padding-top: 1.65rem;
}

.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card {
    background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(255,249,236,0.98) 100%);
    border: 1px solid rgba(106, 139, 68, 0.13);
    box-shadow: 0 18px 34px rgba(98, 71, 31, 0.1);
}

.section-heading h2,
.notice-callout h2,
.page-banner h1 {
    color: var(--eh-bark);
    letter-spacing: -0.035em;
}

.feature-card--sign {
    position: relative;
    overflow: hidden;
    padding: 1.55rem;
}

.feature-card--sign::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        radial-gradient(circle at 100% 0, rgba(143,181,83,0.18), transparent 40%),
        radial-gradient(circle at 0 100%, rgba(223,242,255,0.42), transparent 36%);
    pointer-events: none;
}

.feature-card--sign h3 {
    margin-top: 0.3rem;
}

.feature-card__number {
    background: linear-gradient(180deg, #f9e3b4 0%, #efc769 100%);
    box-shadow: 0 4px 10px rgba(109, 69, 36, 0.1);
}

.feature-card__link,
.post-card__link {
    color: var(--eh-forest-dark);
}

.post-card__media {
    background: linear-gradient(180deg, rgba(223,242,255,0.92) 0%, rgba(255,248,234,0.96) 100%);
}

.notice-callout--banner-style {
    align-items: center;
    gap: 1rem;
    background:
        radial-gradient(circle at 85% 18%, rgba(223,242,255,0.78), transparent 18rem),
        linear-gradient(180deg, rgba(255,255,255,0.97) 0%, rgba(255,248,234,0.98) 100%);
}

.notice-callout__visual--badge {
    width: min(100%, 310px);
    justify-self: center;
}

.notice-callout__visual--badge img {
    width: 100%;
}

.page-banner {
    padding: clamp(2rem, 4vw, 3.3rem) 0 1.1rem;
}

.page-banner .container {
    padding: clamp(1.4rem, 3vw, 2rem);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(248,240,223,0.98) 100%);
    border: 1px solid rgba(106, 139, 68, 0.13);
    box-shadow: 0 18px 34px rgba(98, 71, 31, 0.08);
}

.wood-title {
    padding: 0.6rem 0.95rem;
    border-radius: 16px;
}

.site-footer {
    margin-top: 2rem;
    background: linear-gradient(180deg, #fbf5e6 0%, #f4ecd9 100%);
    border-top: 1px solid rgba(109, 69, 36, 0.08);
}

.site-footer__topline {
    height: 0.65rem;
    background: linear-gradient(90deg, #7ca54c 0%, #a3c45c 28%, #efc95b 48%, #a3c45c 68%, #7ca54c 100%);
}

.site-footer__main {
    padding-top: 2.25rem;
}

.site-footer__about {
    display: grid;
    grid-template-columns: minmax(110px, 180px) minmax(0, 1fr);
    gap: 1.2rem;
    align-items: center;
}

.site-footer__logo {
    width: min(100%, 170px);
    filter: drop-shadow(0 10px 18px rgba(74, 54, 24, 0.08));
}

.site-footer__about-copy {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 100%;
}

.site-footer__about-copy h2 {
    margin-bottom: 0.5rem;
}

.site-footer__sub {
    background: rgba(255,255,255,0.42);
}

.menu--footer a {
    background: transparent;
    box-shadow: none;
    border: 0;
}

@media (max-width: 1040px) {
    .welcome-panel {
        grid-template-columns: 1fr;
    }

    .welcome-panel__aside {
        justify-items: start;
    }

    .welcome-panel__logo {
        width: min(100%, 260px);
    }
}

@media (max-width: 820px) {
    .menu-toggle {
        display: inline-flex;
    }

    .main-navigation {
        position: absolute;
        inset: calc(100% + 0.55rem) 1rem auto;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
    }

    .main-navigation.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .main-navigation .menu,
    .main-navigation .menu ul,
    .main-navigation div.menu ul {
        flex-direction: column;
        align-items: stretch;
        min-width: min(24rem, calc(100vw - 2rem));
        padding: 0.75rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 250, 243, 0.98) 0%, rgba(246, 237, 219, 0.98) 100%);
        border: 1px solid rgba(106, 139, 68, 0.14);
        box-shadow: 0 18px 36px rgba(45, 30, 12, 0.18);
    }

    .main-navigation .menu a,
    .main-navigation .page_item > a {
        width: 100%;
    }

    .hero__contact {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .site-header__inner {
        min-height: 5.4rem;
    }

    .site-branding__badge,
    .site-branding__custom-logo .custom-logo {
        width: 134px;
        max-height: 72px;
    }

    .banner-stage__frame {
        border-width: 7px;
    }

    .banner-stage__frame img {
        aspect-ratio: 16 / 10;
        object-position: center 52%;
    }

    .welcome-panel-wrap {
        margin-top: -1.1rem;
    }

    .welcome-panel {
        padding: 1.25rem;
    }

    .welcome-panel__title,
    .page-banner h1 {
        font-size: clamp(2rem, 11vw, 3.2rem);
    }

    .quick-links,
    .posts-grid,
    .posts-grid--archive,
    .site-footer__widgets,
    .site-footer__about {
        grid-template-columns: 1fr;
    }
}

/* --- 1.4.0 illustrated header refresh --- */
.site-header {
    position: relative;
    top: auto;
    z-index: 30;
    backdrop-filter: none;
}

.site-header--illustrated {
    padding-top: clamp(0.8rem, 1.8vw, 1.25rem);
    background:
        radial-gradient(circle at 12% 8%, rgba(255,255,255,0.62), transparent 18rem),
        radial-gradient(circle at 88% 4%, rgba(255,255,255,0.5), transparent 16rem),
        linear-gradient(180deg, #dff1fb 0%, #eef8ef 52%, rgba(255,255,255,0) 100%);
}

.site-header__top {
    padding-bottom: 0.85rem;
}

.site-header__top-inner {
    display: flex;
    justify-content: center;
    align-items: center;
}

.site-branding--stacked {
    display: grid;
    justify-items: center;
    gap: 0.45rem;
}

.site-branding--stacked .site-branding__mark {
    justify-content: center;
}

.site-branding__badge,
.site-branding__custom-logo .custom-logo {
    width: clamp(180px, 20vw, 280px);
    max-height: none;
    filter: drop-shadow(0 12px 20px rgba(74, 54, 24, 0.14));
}

.site-header__art {
    padding-bottom: 0.9rem;
}

.site-header__artframe {
    position: relative;
    overflow: hidden;
    border-radius: clamp(24px, 2.5vw, 36px);
    border: 10px solid rgba(255, 252, 245, 0.92);
    background: #fffef9;
    box-shadow: 0 24px 56px rgba(84, 60, 25, 0.16);
}

.site-header__artframe::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 24%;
    background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(68, 47, 18, 0.08) 100%);
    pointer-events: none;
}

.site-header__artframe img {
    width: 100%;
    aspect-ratio: 16 / 8.3;
    object-fit: cover;
    object-position: center 42%;
}

.site-header__navband {
    position: relative;
    z-index: 5;
    padding-bottom: 0.3rem;
}

.site-header__navband-inner {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 0;
}

.main-navigation {
    margin-left: 0;
}

.main-navigation .menu,
.footer-navigation .menu {
    justify-content: center;
    flex-wrap: wrap;
}

.main-navigation .menu a,
.footer-navigation .menu a,
.main-navigation .page_item > a {
    background: linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(248,241,225,0.98) 100%);
    border: 1px solid rgba(103, 127, 65, 0.18);
    box-shadow: 0 5px 0 rgba(99, 71, 29, 0.1);
}

.main-navigation .current-menu-item > a,
.main-navigation .current_page_item > a,
.main-navigation a:hover,
.main-navigation a:focus-visible {
    color: #fffdf7;
    background: linear-gradient(180deg, #6d9848 0%, #4e7536 100%);
    border-color: rgba(255,255,255,0.14);
}

.section-space--intro {
    padding-top: 0.8rem;
}

.illustrated-intro__card {
    display: grid;
    grid-template-columns: minmax(0, 1.22fr) minmax(260px, 0.78fr);
    gap: clamp(1.4rem, 3.2vw, 2.8rem);
    align-items: center;
    padding: clamp(1.5rem, 3vw, 2.6rem);
    border-radius: clamp(26px, 2.6vw, 36px);
    background:
        radial-gradient(circle at 8% 0, rgba(255,255,255,0.7), transparent 20rem),
        radial-gradient(circle at 95% 100%, rgba(212, 242, 255, 0.55), transparent 16rem),
        linear-gradient(180deg, rgba(255,255,255,0.96) 0%, rgba(252,246,231,0.98) 100%);
    border: 1px solid rgba(106, 139, 68, 0.13);
    box-shadow: 0 22px 46px rgba(94, 68, 28, 0.14);
}

.illustrated-intro__title {
    margin: 1rem 0 0.9rem;
    font-size: clamp(2.15rem, 4vw, 4rem);
    line-height: 1.02;
    letter-spacing: -0.04em;
    color: var(--eh-bark);
}

.illustrated-intro__text {
    margin: 0 0 1.5rem;
    max-width: 60ch;
    font-size: 1.08rem;
    color: rgba(69, 53, 31, 0.94);
}

.illustrated-intro__visual {
    display: grid;
    justify-items: center;
    gap: 1rem;
    text-align: center;
}

.illustrated-intro__mascot {
    width: min(100%, 320px);
    filter: drop-shadow(0 14px 22px rgba(73, 51, 19, 0.12));
}

.wood-plaque--hero {
    max-width: 20rem;
}

.section-heading--friendly {
    text-align: center;
}

.section-heading--friendly p {
    max-width: 52rem;
    margin-inline: auto;
}

@media (max-width: 1040px) {
    .illustrated-intro__card {
        grid-template-columns: 1fr;
    }

    .illustrated-intro__visual {
        justify-items: start;
        text-align: left;
    }
}

@media (max-width: 820px) {
    .site-header__navband-inner {
        justify-content: flex-end;
    }

    .menu-toggle {
        display: inline-flex;
    }

    .main-navigation {
        position: absolute;
        inset: calc(100% + 0.55rem) 0 auto auto;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
    }

    .main-navigation.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .main-navigation .menu,
    .main-navigation .menu ul,
    .main-navigation div.menu ul {
        flex-direction: column;
        align-items: stretch;
        min-width: min(24rem, calc(100vw - 2rem));
        padding: 0.75rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 250, 243, 0.98) 0%, rgba(246, 237, 219, 0.98) 100%);
        border: 1px solid rgba(106, 139, 68, 0.14);
        box-shadow: 0 18px 36px rgba(45, 30, 12, 0.18);
    }

    .main-navigation .menu a,
    .main-navigation .page_item > a {
        width: 100%;
    }

    .hero__contact {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .site-branding__badge,
    .site-branding__custom-logo .custom-logo {
        width: 180px;
    }

    .site-header__artframe {
        border-width: 7px;
    }

    .site-header__artframe img {
        aspect-ratio: 16 / 10;
        object-position: center 40%;
    }

    .illustrated-intro__card {
        padding: 1.25rem;
    }

    .illustrated-intro__title,
    .page-banner h1 {
        font-size: clamp(2rem, 10vw, 3.1rem);
    }

    .illustrated-intro__visual {
        justify-items: center;
        text-align: center;
    }
}

/* --- 1.5.0 header logo layout refresh --- */
.site-header--logo-nav {
    position: relative;
    top: auto;
    z-index: 40;
    background: transparent;
}

.site-topbar {
    background: linear-gradient(180deg, #0f4a1f 0%, #0a3a16 100%);
    color: #eef7de;
    box-shadow: 0 10px 24px rgba(27, 52, 18, 0.14);
}

.site-topbar__inner {
    min-height: 2.9rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding-block: 0.35rem;
}

.site-topbar__left {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    flex-wrap: wrap;
}

.site-topbar__item {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.18rem 0.72rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.09);
    color: #f9fde9;
    text-decoration: none;
    font-size: 0.92rem;
}

.site-topbar__item strong {
    font-weight: 700;
}

.site-topbar__label {
    opacity: 0.82;
}

.site-topbar__note {
    margin: 0;
    font-size: 0.92rem;
    font-weight: 700;
    color: #fbf6cf;
    text-align: right;
}

.site-header__main {
    position: relative;
    background: rgba(255, 255, 255, 0.98);
    border-bottom: 1px solid rgba(94, 68, 27, 0.1);
    box-shadow: 0 14px 34px rgba(60, 46, 22, 0.09);
}

.site-header__main-inner {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 1.5rem;
    min-height: 6.75rem;
}

.site-branding--header {
    display: flex;
    align-items: center;
    min-width: 0;
}

.site-branding--header .custom-logo-link,
.site-branding--header .site-branding__mark {
    display: inline-flex;
    align-items: center;
}

.site-branding--header .custom-logo,
.site-branding--header .site-branding__badge {
    width: clamp(112px, 9vw, 156px);
    height: auto;
    max-height: none;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    filter: drop-shadow(0 10px 18px rgba(72, 55, 24, 0.16));
}

.site-header__main .main-navigation {
    margin-left: 0;
    justify-self: center;
}

.site-header__main .main-navigation .menu,
.site-header__main .footer-navigation .menu {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.site-header__main .main-navigation .menu a,
.site-header__main .main-navigation .page_item > a {
    background: transparent;
    border: 0;
    box-shadow: none;
    color: #4a402f;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    font-size: 0.92rem;
    padding: 0.9rem 1rem;
    border-radius: 16px;
}

.site-header__main .main-navigation .current-menu-item > a,
.site-header__main .main-navigation .current_page_item > a,
.site-header__main .main-navigation a:hover,
.site-header__main .main-navigation a:focus-visible {
    color: #164f20;
    background: rgba(85, 134, 72, 0.12);
}

.site-header__cta {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.button--header {
    padding-inline: 1.25rem;
    white-space: nowrap;
}

.hero-banner {
    position: relative;
    overflow: hidden;
    min-height: clamp(420px, 56vw, 690px);
    background: #d8edf6;
}

.hero-banner__backdrop {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(28, 24, 14, 0.72) 0%, rgba(36, 32, 19, 0.48) 27%, rgba(33, 30, 18, 0.2) 48%, rgba(28, 26, 16, 0.08) 64%, rgba(29, 24, 16, 0.04) 100%),
        var(--hero-image) center 35% / cover no-repeat;
    transform: scale(1.02);
}

.hero-banner__inner {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    min-height: inherit;
    padding-top: clamp(2rem, 5vw, 5rem);
    padding-bottom: clamp(5rem, 10vw, 8.5rem);
}

.hero-banner__content {
    max-width: min(40rem, 100%);
    color: #fffef8;
}

.hero-banner__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    margin-bottom: 1rem;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.18);
    color: #fff4c4;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.86rem;
}

.hero-banner__title {
    margin: 0 0 1rem;
    max-width: 11ch;
    color: #fffef8;
    font-family: "Trebuchet MS", "Arial Rounded MT Bold", "Avenir Next Rounded", "Segoe UI", sans-serif;
    font-size: clamp(2.7rem, 6vw, 5.5rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
    text-shadow: 0 4px 18px rgba(21, 17, 9, 0.28);
}

.hero-banner__text {
    margin: 0;
    max-width: 36rem;
    color: rgba(255, 251, 241, 0.95);
    font-size: clamp(1rem, 1vw + 0.86rem, 1.18rem);
    line-height: 1.65;
    text-shadow: 0 2px 10px rgba(21, 17, 9, 0.24);
}

.hero__actions--banner {
    margin-top: 1.75rem;
}

.button--ghost-light {
    color: #fffef7;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.22);
    box-shadow: 0 8px 18px rgba(21, 16, 8, 0.14);
}

.button--ghost-light:hover,
.button--ghost-light:focus-visible {
    color: #fffdf9;
    background: rgba(255, 255, 255, 0.22);
}

.hero-banner__grass {
    position: absolute;
    inset: auto 0 0;
    height: 34px;
    background:
        radial-gradient(circle at 8px 120%, #fff 16px, transparent 17px) 0 0 / 24px 100% repeat-x,
        radial-gradient(circle at 18px 120%, #fff 18px, transparent 19px) 0 0 / 28px 100% repeat-x,
        linear-gradient(180deg, transparent 0%, #fff 58%);
    z-index: 2;
}

.welcome-card-wrap {
    position: relative;
    margin-top: clamp(-4.4rem, -6vw, -2.4rem);
    z-index: 5;
    padding-bottom: 0.8rem;
}

.welcome-card {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(200px, 0.8fr);
    gap: clamp(1rem, 3vw, 2rem);
    align-items: center;
    padding: clamp(1.3rem, 3vw, 2rem);
    border-radius: clamp(24px, 2.6vw, 32px);
    background: rgba(255, 250, 241, 0.96);
    border: 1px solid rgba(103, 127, 65, 0.18);
    box-shadow: 0 22px 48px rgba(83, 59, 22, 0.14);
}

.welcome-card__title {
    margin: 0.85rem 0 0.85rem;
    font-size: clamp(2rem, 4vw, 3.6rem);
    line-height: 1;
    letter-spacing: -0.04em;
    color: var(--eh-bark);
}

.welcome-card__text {
    margin: 0 0 1.25rem;
    font-size: 1.06rem;
    color: rgba(66, 52, 34, 0.94);
}

.welcome-card__visual {
    display: flex;
    justify-content: center;
    align-items: flex-end;
}

.welcome-card__mascot {
    width: min(100%, 265px);
    filter: drop-shadow(0 14px 22px rgba(72, 53, 18, 0.12));
}

.site-main .section-space:first-of-type {
    padding-top: 2rem;
}


@media (max-width: 1280px) {
    .site-nav-bar .main-navigation .menu a,
    .site-nav-bar .main-navigation .page_item > a {
        padding: 0.76rem 0.78rem;
        font-size: 0.88rem;
    }

    .site-nav-bar__inner {
        gap: 0.8rem;
    }

    .site-header__cta--nav .button--header {
        padding-inline: 1.1rem;
    }
}

@media (max-width: 1120px) {
    .site-topbar__note {
        display: none;
    }

    .site-header__main-inner {
        grid-template-columns: auto 1fr;
    }

    .site-header__cta {
        display: none;
    }

    .hero-banner__title {
        max-width: 13ch;
    }
}

@media (max-width: 900px) {
    .site-header__main-inner {
        grid-template-columns: auto auto;
        justify-content: space-between;
        min-height: 5.75rem;
    }

    .menu-toggle {
        display: inline-flex;
    }

    .site-header__main .main-navigation {
        position: absolute;
        top: calc(100% + 0.55rem);
        right: 1rem;
        left: auto;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
        z-index: 20;
    }

    .site-header__main .main-navigation.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .site-header__main .main-navigation .menu,
    .site-header__main .main-navigation .menu ul,
    .site-header__main .main-navigation div.menu ul {
        flex-direction: column;
        align-items: stretch;
        min-width: min(24rem, calc(100vw - 2rem));
        padding: 0.75rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 252, 246, 0.98) 0%, rgba(246, 238, 222, 0.98) 100%);
        border: 1px solid rgba(106, 139, 68, 0.18);
        box-shadow: 0 18px 36px rgba(45, 30, 12, 0.16);
    }

    .site-header__main .main-navigation .menu a,
    .site-header__main .main-navigation .page_item > a {
        width: 100%;
        color: var(--eh-bark);
    }

    .hero-banner {
        min-height: 520px;
    }

    .hero-banner__backdrop {
        background:
            linear-gradient(180deg, rgba(28, 24, 14, 0.5) 0%, rgba(32, 29, 18, 0.44) 28%, rgba(33, 30, 18, 0.18) 58%, rgba(33, 30, 18, 0.12) 100%),
            var(--hero-image) center 30% / cover no-repeat;
    }

    .hero-banner__content {
        max-width: min(34rem, 100%);
    }

    .welcome-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .site-topbar {
        display: none;
    }

    .site-header__main-inner {
        gap: 0.75rem;
    }

    .site-branding--header .custom-logo,
    .site-branding--header .site-branding__badge {
        width: 98px;
    }

    .hero-banner {
        min-height: 480px;
    }

    .hero-banner__inner {
        align-items: flex-end;
        padding-top: 1.8rem;
        padding-bottom: 4.5rem;
    }

    .hero-banner__title {
        max-width: 9.5ch;
        font-size: clamp(2.3rem, 11vw, 3.6rem);
    }

    .hero-banner__text {
        font-size: 0.98rem;
    }

    .hero__actions--banner {
        flex-direction: column;
        align-items: stretch;
    }

    .welcome-card-wrap {
        margin-top: -2.2rem;
    }

    .welcome-card {
        padding: 1.2rem;
    }

    .welcome-card__title {
        font-size: clamp(1.8rem, 10vw, 2.8rem);
    }

    .hero__contact {
        grid-template-columns: 1fr;
    }
}

/* --- 1.7.0 painted header with menu below --- */
.site-header--painted {
    position: relative;
    top: auto;
    z-index: 40;
    background: transparent;
}

.site-header__art {
    position: relative;
    min-height: clamp(320px, 44vw, 620px);
    overflow: hidden;
    background: #d6eef8;
}

.site-header__art-backdrop {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(34, 44, 18, 0.08) 0%, rgba(34, 44, 18, 0.08) 100%),
        var(--header-art-image) center center / cover no-repeat;
    transform: scale(1.02);
}

.site-header__art::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 54px;
    background: linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,248,232,0.68) 70%, rgba(255,248,232,0.96) 100%);
}

.site-header__art-inner {
    position: relative;
    z-index: 2;
    min-height: inherit;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    padding-top: clamp(1.25rem, 3vw, 2rem);
    padding-bottom: clamp(1rem, 2vw, 1.75rem);
}

.site-header__badge-wrap {
    display: flex;
    align-items: flex-end;
    gap: clamp(1rem, 3vw, 2.25rem);
    max-width: min(760px, 100%);
}

.site-branding--hero .custom-logo,
.site-branding--hero .site-branding__badge {
    width: clamp(110px, 14vw, 175px);
    height: auto;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    filter: drop-shadow(0 14px 28px rgba(72, 55, 24, 0.22));
}

.site-header__welcome {
    max-width: 32rem;
    padding: 1rem 1.15rem 1.1rem;
    border-radius: 24px;
    background: rgba(255, 251, 240, 0.84);
    border: 1px solid rgba(95, 72, 30, 0.12);
    box-shadow: 0 16px 34px rgba(58, 42, 18, 0.12);
    backdrop-filter: blur(6px);
}

.site-header__eyebrow {
    display: inline-flex;
    align-items: center;
    padding: 0.4rem 0.7rem;
    border-radius: 999px;
    font-size: 0.77rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 800;
    color: var(--eh-forest);
    background: rgba(255,255,255,0.78);
}

.site-header__title {
    margin: 0.55rem 0 0.25rem;
    font-size: clamp(1.8rem, 3vw, 3rem);
    line-height: 1;
    color: var(--eh-bark);
}

.site-header__text {
    margin: 0;
    color: rgba(66, 52, 34, 0.9);
    font-size: 0.98rem;
    line-height: 1.55;
}

.site-nav-bar {
    position: relative;
    z-index: 3;
    background: rgba(255, 250, 240, 0.98);
    border-top: 1px solid rgba(92, 68, 27, 0.08);
    border-bottom: 1px solid rgba(92, 68, 27, 0.1);
    box-shadow: 0 12px 28px rgba(60, 46, 22, 0.08);
}

.site-nav-bar__inner {
    min-height: 5.25rem;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 1rem;
}

.site-nav-bar .main-navigation {
    margin-left: 0;
    min-width: 0;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 0.4rem;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.site-nav-bar .main-navigation .menu::-webkit-scrollbar,
.site-nav-bar .footer-navigation .menu::-webkit-scrollbar {
    display: none;
}

.site-nav-bar .main-navigation .menu > li,
.site-nav-bar .footer-navigation .menu > li {
    flex: 0 0 auto;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a {
    padding: 0.8rem 1rem;
    color: var(--eh-bark-dark);
    font-weight: 800;
    letter-spacing: 0.01em;
    text-transform: none;
    font-size: 0.93rem;
    white-space: nowrap;
    border-radius: 18px;
    border: 1px solid rgba(150, 109, 39, 0.18);
    background: linear-gradient(180deg, #f8d683 0%, #efb64a 100%);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.25);
    transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.site-nav-bar .main-navigation .menu-item--accent > a,
.site-nav-bar .main-navigation .menu > li:nth-last-child(2) > a,
.site-nav-bar .main-navigation .menu > li:last-child > a {
    background: linear-gradient(180deg, #f8d683 0%, #efb64a 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 5px 0 rgba(95, 58, 18, 0.25);
}

.site-nav-bar .main-navigation .current-menu-item > a,
.site-nav-bar .main-navigation .current_page_item > a,
.site-nav-bar .main-navigation a:hover,
.site-nav-bar .main-navigation a:focus-visible {
    color: var(--eh-bark-dark);
    background: linear-gradient(180deg, #f9dc92 0%, #f1bd56 100%);
    box-shadow: 0 6px 0 rgba(95, 58, 18, 0.28);
    transform: translateY(-1px);
    filter: saturate(1.03);
}

.site-header__cta--nav {
    justify-self: end;
    display: flex;
    align-items: center;
}

.site-header__cta--nav .button--header {
    white-space: nowrap;
    padding-inline: 1.35rem;
}

.site-main--header-first {
    padding-top: clamp(0.35rem, 1vw, 0.8rem);
}

.welcome-card-wrap--first {
    margin-top: 0;
}

.welcome-card-wrap--first .container {
    position: relative;
}

.welcome-card--header-style {
    grid-template-columns: minmax(0, 1.15fr) minmax(220px, 0.85fr);
    background: linear-gradient(180deg, rgba(255, 250, 241, 0.97) 0%, rgba(255, 247, 232, 0.97) 100%);
}

.welcome-card__visual--large .welcome-card__mascot {
    width: min(100%, 310px);
}

@media (max-width: 1120px) {
    .site-header__badge-wrap {
        max-width: 600px;
    }

    .site-nav-bar__inner {
        grid-template-columns: 1fr;
        padding-block: 0.85rem;
    }

    .site-header__cta--nav {
        display: none;
    }
}

@media (max-width: 900px) {
    .site-header__art {
        min-height: 260px;
    }

    .site-header__badge-wrap {
        align-items: flex-end;
        max-width: 100%;
    }

    .site-header__welcome {
        max-width: 27rem;
    }

    .site-nav-bar__inner {
        grid-template-columns: auto;
        justify-content: stretch;
        min-height: 4.25rem;
    }

    .site-nav-bar .menu-toggle {
        display: inline-flex;
        justify-self: end;
    }

    .site-nav-bar .main-navigation {
        position: absolute;
        top: calc(100% + 0.45rem);
        right: 1rem;
        left: 1rem;
        opacity: 0;
        visibility: hidden;
        transform: translateY(-8px);
        z-index: 20;
    }

    .site-nav-bar .main-navigation.is-open {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }

    .site-nav-bar .main-navigation .menu,
    .site-nav-bar .main-navigation .menu ul,
    .site-nav-bar .main-navigation div.menu ul {
        flex-direction: column;
        align-items: stretch;
        min-width: min(24rem, calc(100vw - 2rem));
        padding: 0.75rem;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 252, 246, 0.99) 0%, rgba(246, 238, 222, 0.99) 100%);
        border: 1px solid rgba(106, 139, 68, 0.18);
        box-shadow: 0 18px 36px rgba(45, 30, 12, 0.16);
    }

    .site-nav-bar .main-navigation .menu a,
    .site-nav-bar .main-navigation .page_item > a {
        width: 100%;
    }

    .welcome-card--header-style {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 700px) {
    .site-topbar {
        display: none;
    }

    .site-header__art {
        min-height: 215px;
    }

    .site-header__art-inner {
        align-items: flex-end;
        padding-bottom: 0.8rem;
    }

    .site-branding--hero .custom-logo,
    .site-branding--hero .site-branding__badge {
        width: 92px;
    }

    .site-header__badge-wrap {
        gap: 0.8rem;
        align-items: flex-end;
    }

    .site-header__welcome {
        padding: 0.75rem 0.85rem;
    }

    .site-header__title {
        font-size: 1.45rem;
    }

    .site-header__text {
        display: none;
    }
}

/* --- 1.7.1 banner style header --- */
.site-header__art--banner-only {
    min-height: auto;
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 252, 244, 0.42), transparent 34rem),
        linear-gradient(180deg, #edf8ff 0%, #f8ecd0 88%, #f4e5c1 100%);
    padding: 0;
}

.site-header__art--banner-only::after,
.site-header__art--banner-only .site-header__art-backdrop,
.site-header__art--banner-only .site-header__welcome,
.site-header__art--banner-only .site-branding--hero {
    display: none;
}

.site-header__art-inner--banner-only {
    min-height: auto;
    display: block;
    width: 100%;
    max-width: none;
    padding: 0;
}

.site-header__banner-link {
    display: block;
    text-decoration: none;
}

.site-header__banner-image {
    display: block;
    width: 100%;
    min-height: clamp(220px, 32vw, 560px);
    max-height: min(36vw, 560px);
    object-fit: cover;
    object-position: center center;
    border-radius: 0;
    border: 0;
    box-shadow: none;
}

.site-nav-bar {
    background: linear-gradient(180deg, rgba(246, 237, 214, 0.98) 0%, rgba(241, 227, 194, 0.98) 100%);
    border-top: 0;
    box-shadow: 0 10px 24px rgba(60, 46, 22, 0.08);
}

.site-nav-bar__inner {
    min-height: 4.9rem;
}

@media (max-width: 900px) {
    .site-header__art--banner-only {
        padding-top: 0.55rem;
    }

    .site-header__banner-image {
        border-radius: 20px;
        border-width: 4px;
    }
}


/* --- 1.8.0 warm center with illustrated side parcels --- */
body {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 251, 241, 0.96), transparent 28rem),
        linear-gradient(180deg, #f8edd3 0%, #f4e7c8 20%, #f3e7c8 100%);
}

.site-shell {
    position: relative;
    isolation: isolate;
    overflow: clip;
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 248, 232, 0.82), transparent 20rem),
        linear-gradient(90deg,
            rgba(205, 228, 188, 0.22) 0%,
            rgba(225, 238, 206, 0.30) 8%,
            rgba(246, 239, 219, 0.92) 16%,
            rgba(249, 242, 226, 0.98) 24%,
            rgba(251, 245, 233, 0.99) 50%,
            rgba(249, 242, 226, 0.98) 76%,
            rgba(246, 239, 219, 0.92) 84%,
            rgba(225, 238, 206, 0.30) 92%,
            rgba(205, 228, 188, 0.22) 100%);
}

.site-shell::before,
.site-shell::after {
    content: "";
    position: absolute;
    top: -2rem;
    bottom: 0;
    width: min(19vw, 280px);
    z-index: -1;
    pointer-events: none;
    background-position: center top;
    background-repeat: repeat-y;
    background-size: cover;
    opacity: 0.96;
}

.site-shell::before {
    left: 0;
    background-image:
        linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 10%, rgba(255,255,255,0.14) 100%),
        linear-gradient(90deg, rgba(246, 240, 223, 0.02) 0%, rgba(246, 240, 223, 0.02) 48%, rgba(249, 244, 232, 0.86) 100%),
        url('../images/side-left.png');
    box-shadow: inset -28px 0 42px rgba(249, 244, 232, 0.94);
}

.site-shell::after {
    right: 0;
    background-image:
        linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 10%, rgba(255,255,255,0.14) 100%),
        linear-gradient(270deg, rgba(246, 240, 223, 0.02) 0%, rgba(246, 240, 223, 0.02) 48%, rgba(249, 244, 232, 0.86) 100%),
        url('../images/side-right.png');
    box-shadow: inset 28px 0 42px rgba(249, 244, 232, 0.94);
}

.site-main,
.welcome-card-wrap,
.section-space {
    position: relative;
    z-index: 1;
}

.welcome-card,
.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card,
.page-banner .container {
    background: linear-gradient(180deg, rgba(251, 246, 236, 0.90) 0%, rgba(244, 234, 212, 0.92) 100%);
    border-color: rgba(138, 99, 56, 0.12);
    backdrop-filter: blur(4px);
}

.welcome-card--header-style,
.notice-callout--banner-style {
    background:
        radial-gradient(circle at 88% 12%, rgba(223, 242, 255, 0.42), transparent 16rem),
        linear-gradient(180deg, rgba(252, 247, 238, 0.90) 0%, rgba(241, 228, 199, 0.92) 100%);
}

.section-space {
    padding-inline: max(0.75rem, 3vw);
}

@media (max-width: 1100px) {
    .site-shell {
        background: linear-gradient(180deg, rgba(249, 244, 232, 0.98) 0%, rgba(244, 235, 214, 0.98) 100%);
    }

    .site-shell::before,
    .site-shell::after {
        width: 140px;
        opacity: 0.78;
    }
}

@media (max-width: 900px) {
    .site-shell::before,
    .site-shell::after {
        display: none;
    }

    .section-space {
        padding-inline: 0;
    }
}


/* --- 1.9.0 fixed illustrated site background --- */
body {
    background: #f6edd7 url('../images/site-background.png') center top / cover fixed no-repeat;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: -1;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(246, 237, 215, 0.20) 0%, rgba(246, 237, 215, 0.14) 18%, rgba(246, 237, 215, 0.28) 100%);
}

.site-header--painted,
.site-shell,
.site-main {
    background: transparent;
}

.site-header__art--banner-only {
    background: transparent;
    padding-top: 0.75rem;
}

.site-header__banner-image {
    width: min(100%, 1420px);
    margin-inline: auto;
    min-height: auto;
    max-height: none;
    height: auto;
    object-fit: contain;
    object-position: center top;
    border-radius: 34px;
    border: 6px solid rgba(248, 240, 222, 0.9);
    box-shadow: 0 18px 40px rgba(74, 52, 24, 0.16);
}

.site-nav-bar {
    background: rgba(246, 237, 214, 0.90);
    backdrop-filter: blur(8px);
    box-shadow: 0 14px 28px rgba(70, 50, 24, 0.10);
}

.site-shell {
    isolation: isolate;
}

.site-shell::before,
.site-shell::after {
    display: none;
}

.welcome-card-wrap--first {
    margin-top: 0.4rem;
}

.welcome-card,
.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card,
.page-banner .container {
    background: linear-gradient(180deg, rgba(252, 247, 236, 0.92) 0%, rgba(243, 231, 204, 0.90) 100%);
    border: 1px solid rgba(138, 99, 56, 0.12);
    box-shadow: 0 18px 38px rgba(80, 56, 24, 0.12);
}

.welcome-card {
    position: relative;
    overflow: hidden;
}

.welcome-card::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(252,247,236,0.10) 0%, rgba(252,247,236,0.00) 15%, rgba(252,247,236,0.00) 85%, rgba(252,247,236,0.10) 100%);
}

@media (max-width: 900px) {
    body {
        background-attachment: scroll;
        background-size: cover;
    }

    .site-header__banner-image {
        border-radius: 24px;
        border-width: 4px;
    }
}


/* --- 2.0.0 refined fixed background layout --- */
:root {
    --eh-cream: #f6f0df;
    --eh-cream-soft: rgba(249, 243, 229, 0.82);
    --eh-cream-strong: rgba(241, 230, 201, 0.92);
}

body {
    background:
        radial-gradient(circle at center, rgba(249, 244, 231, 0.78) 0%, rgba(249, 244, 231, 0.58) 24%, rgba(249, 244, 231, 0.24) 48%, rgba(249, 244, 231, 0.06) 70%, rgba(249, 244, 231, 0.00) 100%),
        url('../images/site-background.png') center top / cover fixed no-repeat;
}

body::before {
    background:
        radial-gradient(circle at center, rgba(250, 245, 233, 0.76) 0%, rgba(250, 245, 233, 0.54) 26%, rgba(250, 245, 233, 0.20) 52%, rgba(250, 245, 233, 0.00) 76%),
        linear-gradient(180deg, rgba(248, 242, 227, 0.16) 0%, rgba(248, 242, 227, 0.10) 100%);
}

.site-header--painted {
    position: sticky;
    top: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
}

.site-header__art--banner-only {
    display: none;
}

.site-topbar {
    background: linear-gradient(180deg, rgba(39, 92, 39, 0.96) 0%, rgba(28, 70, 28, 0.95) 100%);
    box-shadow: 0 10px 24px rgba(44, 62, 28, 0.16);
}

.site-topbar__inner {
    min-height: 2.25rem;
}

.site-nav-bar {
    background: rgba(247, 239, 219, 0.76);
    backdrop-filter: blur(14px) saturate(125%);
    border-top: 1px solid rgba(255, 255, 255, 0.45);
    border-bottom: 1px solid rgba(126, 92, 43, 0.12);
    box-shadow: 0 14px 30px rgba(84, 59, 25, 0.10);
}

.site-nav-bar__inner {
    min-height: 4.7rem;
    justify-content: center;
    gap: 1rem;
}

.site-nav-bar .main-navigation {
    margin-left: 0;
    flex: 1 1 auto;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    justify-content: center;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a {
    min-height: 3rem;
    padding: 0.9rem 1.15rem;
    background: linear-gradient(180deg, #f7d37d 0%, #efbd56 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 4px 0 rgba(103, 66, 24, 0.48);
    border: 1px solid rgba(124, 85, 36, 0.12);
}

.site-nav-bar .main-navigation .current-menu-item > a,
.site-nav-bar .main-navigation .current_page_item > a,
.site-nav-bar .main-navigation a:hover,
.site-nav-bar .main-navigation a:focus-visible {
    background: linear-gradient(180deg, #f8db91 0%, #f1c061 100%);
    color: var(--eh-bark-dark);
}

.site-nav-bar .main-navigation .menu-item--accent > a,
.site-nav-bar .main-navigation .menu > li:nth-last-child(2) > a,
.site-nav-bar .main-navigation .menu > li:last-child > a {
    background: linear-gradient(180deg, #f7d37d 0%, #efbd56 100%);
}

.site-header__cta--nav .button--header {
    min-width: 10.5rem;
}

.site-shell,
.site-main {
    background: transparent;
}

.welcome-card-wrap--first {
    padding-top: 1.5rem;
    margin-top: 0;
}

.welcome-card,
.prose-card,
.article-card,
.feature-card,
.card-widget,
.post-card,
.notice-callout,
.empty-state,
.card-search,
.post-navigation-card,
.page-banner .container {
    background: linear-gradient(180deg, rgba(248, 242, 227, 0.92) 0%, rgba(242, 231, 202, 0.90) 100%);
    border: 1px solid rgba(128, 90, 46, 0.14);
    box-shadow: 0 18px 46px rgba(80, 56, 24, 0.14);
    backdrop-filter: blur(10px);
}

.welcome-card--header-style {
    border-radius: 36px;
    overflow: hidden;
}

.welcome-card__content {
    padding: clamp(2rem, 3vw, 3rem);
}

.welcome-card__visual--large {
    align-self: end;
}

.welcome-card__visual--large .welcome-card__mascot {
    max-height: 29rem;
    object-fit: contain;
    filter: drop-shadow(0 20px 25px rgba(82, 58, 27, 0.16));
}

.section-space {
    padding-top: clamp(2.5rem, 4vw, 4rem);
    padding-bottom: clamp(2.5rem, 4vw, 4rem);
}

.section-heading,
.notice-callout__content {
    position: relative;
    z-index: 1;
}

.hero__badge,
.section-heading__eyebrow,
.site-footer__eyebrow,
.hero__contact-item,
.wood-plaque {
    backdrop-filter: blur(8px);
}

.hero__contact-item {
    background: rgba(255, 250, 238, 0.82);
}

.site-footer {
    background: linear-gradient(180deg, rgba(34, 81, 35, 0.94) 0%, rgba(24, 56, 26, 0.96) 100%);
}

@media (max-width: 1024px) {
    .site-nav-bar__inner {
        justify-content: flex-start;
    }

    .site-nav-bar .main-navigation .menu {
        justify-content: flex-start;
    }
}

@media (max-width: 900px) {
    body {
        background-attachment: scroll;
        background-position: center top;
    }

    .site-nav-bar {
        background: rgba(247, 239, 219, 0.88);
    }
}


/* --- 2.1.0 banner header restored, menu strip removed --- */
body {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 250, 238, 0.72) 0%, rgba(255, 250, 238, 0.55) 30%, rgba(255, 250, 238, 0.32) 55%, rgba(255, 250, 238, 0.18) 100%),
        linear-gradient(180deg, #f7efdc 0%, #f4e7c8 100%);
}

body::before {
    background: linear-gradient(180deg, rgba(248, 242, 227, 0.08) 0%, rgba(248, 242, 227, 0.14) 100%);
}

.site-header--painted {
    position: relative;
    top: auto;
}

.site-header__art--banner-only {
    display: block;
    background: transparent;
    padding-top: 0.9rem;
}

.site-header__art-inner--banner-only {
    width: min(100%, 1680px);
    margin-inline: auto;
    padding-inline: clamp(0.75rem, 2vw, 1.5rem);
}

.site-header__banner-image {
    width: 100%;
    max-width: 1680px;
    margin-inline: auto;
    min-height: auto;
    height: auto;
    max-height: none;
    object-fit: contain;
    object-position: center center;
    border-radius: 34px;
    border: 6px solid rgba(248, 240, 222, 0.95);
    box-shadow: 0 18px 42px rgba(82, 58, 27, 0.16);
}

.site-nav-bar {
    background: transparent;
    backdrop-filter: none;
    border: 0;
    box-shadow: none;
    padding: 0.65rem 0 0.85rem;
}

.site-nav-bar__inner {
    min-height: auto;
    justify-content: center;
    gap: 0.9rem;
    width: min(100%, 1680px);
    margin-inline: auto;
    padding-inline: clamp(0.75rem, 2vw, 1.5rem);
}

.site-nav-bar .main-navigation {
    flex: 0 1 auto;
    margin: 0;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    justify-content: center;
    gap: 0.55rem;
    flex-wrap: nowrap;
}

.site-nav-bar .main-navigation .menu > li,
.site-nav-bar .footer-navigation .menu > li {
    flex: 0 0 auto;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a {
    min-height: 3rem;
    padding: 0.9rem 1.15rem;
    background: linear-gradient(180deg, #f7d37d 0%, #efbd56 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 4px 0 rgba(103, 66, 24, 0.48);
    border: 1px solid rgba(124, 85, 36, 0.12);
    border-radius: 18px;
}

.site-header__cta--nav {
    flex: 0 0 auto;
}

.site-header__cta--nav .button--header {
    min-width: 10.5rem;
}

@media (max-width: 1180px) {
    .site-nav-bar__inner {
        justify-content: flex-start;
    }

    .site-nav-bar .main-navigation {
        flex: 1 1 auto;
        overflow-x: auto;
    }

    .site-nav-bar .main-navigation .menu {
        justify-content: flex-start;
        padding-bottom: 0.2rem;
    }
}

@media (max-width: 900px) {
    .site-header__art--banner-only {
        padding-top: 0.6rem;
    }

    .site-header__banner-image {
        border-radius: 24px;
        border-width: 4px;
    }

    .site-nav-bar {
        padding-top: 0.5rem;
    }
}

/* Final layout: banner plus soft illustrated background without side menu bars */
body {
    background:
        linear-gradient(rgba(247, 241, 222, 0.72), rgba(247, 241, 222, 0.78)),
        url('../images/site-background.png') center top / cover fixed no-repeat !important;
    background-color: #f6f0df !important;
}

body::before {
    content: '';
    position: fixed;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at center, rgba(255, 248, 231, 0.12) 0%, rgba(255, 248, 231, 0.12) 30%, rgba(246, 240, 223, 0.42) 78%, rgba(246, 240, 223, 0.62) 100%);
    z-index: -1;
}

.site,
.site-shell,
.site-main {
    background: transparent !important;
}

.site-shell::before,
.site-shell::after {
    display: none !important;
    content: none !important;
}

.site-header {
    position: relative;
    backdrop-filter: none;
    background: transparent;
}

.site-topbar {
    background: rgba(31, 83, 34, 0.92) !important;
    box-shadow: 0 6px 18px rgba(47, 35, 16, 0.18);
}

.site-header__art--banner-only {
    padding: 1rem 0 0.45rem !important;
    background: transparent !important;
}

.site-header__art-inner--banner-only {
    max-width: min(1400px, calc(100% - 2rem));
    margin-inline: auto;
}

.site-header__banner-image {
    width: 100%;
    border-radius: 26px;
    box-shadow: 0 12px 32px rgba(84, 58, 23, 0.18);
}

.site-nav-bar {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 0 1rem;
}

.site-nav-bar__inner {
    width: fit-content;
    max-width: calc(100% - 2rem);
    margin: 0 auto;
    padding: 0.25rem 0;
    gap: 0.75rem;
    justify-content: center;
    background: transparent !important;
}

.site-nav-bar .main-navigation {
    margin-left: 0;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    flex-wrap: nowrap;
    justify-content: center;
    gap: 0.7rem;
    padding: 0.1rem 0;
}

.site-nav-bar .main-navigation .menu > li,
.site-nav-bar .footer-navigation .menu > li {
    flex: 0 0 auto;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a {
    background: linear-gradient(180deg, #f2c860 0%, #e7b341 100%) !important;
    color: #5a3917 !important;
    border: 1px solid rgba(124, 86, 31, 0.22);
    box-shadow: 0 4px 0 rgba(129, 86, 24, 0.30);
}

.site-nav-bar .main-navigation .current-menu-item > a,
.site-nav-bar .main-navigation .current_page_item > a,
.site-nav-bar .main-navigation a:hover,
.site-nav-bar .main-navigation a:focus-visible,
.site-nav-bar .main-navigation .menu-item--accent > a,
.site-nav-bar .main-navigation .menu > li:nth-last-child(2) > a,
.site-nav-bar .main-navigation .menu > li:last-child > a {
    background: linear-gradient(180deg, #f2c860 0%, #e7b341 100%) !important;
    color: #5a3917 !important;
    box-shadow: 0 6px 0 rgba(129, 86, 24, 0.35);
}

.site-header__cta--nav {
    margin-left: 0.4rem;
}

.site-header__cta--nav .button--header {
    background: linear-gradient(180deg, #f2c860 0%, #e7b341 100%) !important;
    color: #5a3917 !important;
    border: 1px solid rgba(124, 86, 31, 0.22);
    box-shadow: 0 6px 0 rgba(129, 86, 24, 0.35);
}

.hero,
.page-content-card,
.entry-card,
.archive-shell,
.search-shell,
.not-found-card,
.content-panel,
.post-card,
.card-widget,
.comment-respond,
.comments-area,
.sidebar-area .widget,
.site-main article,
.site-main .page,
.site-main .post,
.site-main .type-page,
.site-main .type-post {
    background: rgba(248, 242, 226, 0.92) !important;
    backdrop-filter: blur(3px);
    border: 1px solid rgba(158, 122, 69, 0.16);
    box-shadow: 0 18px 42px rgba(88, 58, 25, 0.12);
}

@media (max-width: 1100px) {
    body {
        background-attachment: scroll !important;
        background-size: cover !important;
    }

    .site-nav-bar__inner {
        width: calc(100% - 1.25rem);
    }
}

@media (max-width: 782px) {
    .site-nav-bar {
        padding-bottom: 0.6rem;
    }

    .site-nav-bar__inner {
        width: calc(100% - 1rem);
    }

    .site-nav-bar .menu-toggle {
        display: inline-flex;
    }

    .site-nav-bar .main-navigation {
        margin-left: auto;
        margin-right: auto;
    }
}


/* --- 2.2.0 content area refined to fit banner + background --- */
.site-main--header-first {
    padding-bottom: clamp(2.5rem, 5vw, 4.5rem);
}

.welcome-card-wrap--first {
    padding-top: 1rem;
}

.welcome-card-wrap--first .container,
.section-space .container,
.section-space--first-content .container {
    max-width: 1120px;
}

.welcome-card--header-style,
.prose-card,
.notice-callout--banner-style,
.posts-grid .post-card,
.quick-links .feature-card,
.empty-state {
    background:
        linear-gradient(180deg, rgba(249, 243, 226, 0.95) 0%, rgba(244, 234, 208, 0.93) 100%),
        radial-gradient(circle at top right, rgba(255,255,255,0.35), transparent 35%);
    border: 1px solid rgba(138, 99, 56, 0.16);
    box-shadow:
        0 22px 44px rgba(85, 58, 24, 0.12),
        inset 0 1px 0 rgba(255,255,255,0.55);
}

.welcome-card--header-style {
    max-width: 1040px;
    margin: 0 auto;
    border-radius: 34px;
    grid-template-columns: minmax(0, 1.15fr) minmax(220px, 0.85fr);
    gap: clamp(1.4rem, 3vw, 2.8rem);
    position: relative;
    overflow: hidden;
}

.welcome-card--header-style::before {
    content: '';
    position: absolute;
    inset: auto auto 0 -2rem;
    width: 11rem;
    height: 11rem;
    background: radial-gradient(circle, rgba(114,156,73,0.16) 0%, rgba(114,156,73,0) 68%);
    pointer-events: none;
}

.welcome-card__content {
    padding: clamp(2rem, 4vw, 3.2rem);
}

.welcome-card__title {
    max-width: 11ch;
    margin-bottom: 0.75rem;
}

.welcome-card__text {
    max-width: 52ch;
}

.welcome-card__visual--large {
    padding: 1.6rem 1.6rem 0 0;
    justify-content: end;
    align-items: end;
}

.welcome-card__visual--large .welcome-card__mascot {
    max-height: 26rem;
    width: auto;
}

.hero__actions--banner {
    gap: 0.8rem;
    flex-wrap: wrap;
}

.hero__contact {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.9rem;
    margin-top: 1.25rem;
    max-width: 38rem;
}

.hero__contact-item {
    min-width: 0;
    padding: 0.95rem 1rem;
    border-radius: 18px;
    border: 1px solid rgba(138, 99, 56, 0.12);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.5);
}

.wood-plaque--hero {
    margin-top: 1.25rem;
}

.section-space--first-content {
    padding-top: 1.5rem;
}

.prose-card {
    max-width: 1040px;
    margin: 0 auto;
    border-radius: 30px;
    padding: clamp(2rem, 4vw, 3rem);
}

.section-heading.section-heading--friendly {
    max-width: 860px;
    margin-inline: auto;
    text-align: center;
    background: linear-gradient(180deg, rgba(248, 242, 227, 0.74) 0%, rgba(248, 242, 227, 0.58) 100%);
    border: 1px solid rgba(138,99,56,0.08);
    border-radius: 26px;
    padding: 1.35rem 1.5rem;
    box-shadow: 0 12px 28px rgba(85,58,24,0.08);
    backdrop-filter: blur(8px);
}

.quick-links {
    margin-top: 1.75rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.2rem;
}

.feature-card--sign {
    border-radius: 24px;
    padding: 1.45rem 1.35rem;
}

.news-section .posts-grid {
    margin-top: 1.75rem;
}

.notice-callout--banner-style {
    max-width: 1040px;
    margin: 0 auto;
    border-radius: 32px;
}

.site-footer {
    margin-top: 2rem;
}

@media (max-width: 1100px) {
    .welcome-card--header-style,
    .prose-card,
    .notice-callout--banner-style {
        max-width: 100%;
    }
}

@media (max-width: 900px) {
    .welcome-card--header-style {
        grid-template-columns: 1fr;
    }

    .welcome-card__visual--large {
        padding: 0 1.25rem 1.25rem;
        justify-content: center;
    }

    .welcome-card__visual--large .welcome-card__mascot {
        max-height: 18rem;
    }

    .hero__contact {
        grid-template-columns: 1fr;
    }

    .quick-links {
        grid-template-columns: 1fr;
    }
}

/* Startseiten-Feinschliff: luftiger, schildartiger, Maskottchen ruhiger */
.welcome-card-wrap--first {
    padding-top: clamp(2rem, 4vw, 3rem);
}

.welcome-card--header-style {
    max-width: 1120px;
    margin-inline: auto;
    grid-template-columns: minmax(0, 1.1fr) minmax(240px, 0.7fr);
    gap: clamp(2rem, 4vw, 4rem);
    padding: clamp(1.6rem, 3vw, 2.2rem);
    border-radius: 38px;
    background:
        linear-gradient(180deg, rgba(252, 246, 232, 0.96) 0%, rgba(245, 234, 209, 0.94) 100%);
    box-shadow: 0 26px 56px rgba(80, 56, 24, 0.16);
}

.welcome-card__content {
    padding: clamp(1.8rem, 2.8vw, 3.2rem);
}

.welcome-card__title {
    font-size: clamp(2.35rem, 4.8vw, 4.4rem);
    line-height: 0.95;
    max-width: 11ch;
    margin-bottom: 1.15rem;
}

.welcome-card__text {
    max-width: 58ch;
    font-size: 1.08rem;
    line-height: 1.8;
    margin-bottom: 1.5rem;
}

.hero__actions--banner {
    gap: 0.9rem;
    flex-wrap: wrap;
    margin-bottom: 1.3rem;
}

.hero__contact {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
    max-width: 40rem;
    margin-top: 1.4rem;
}

.hero__contact-item,
.prose-card,
.notice-callout,
.feature-card--sign {
    border-radius: 24px;
}

.hero__contact-item {
    position: relative;
    overflow: hidden;
    padding: 1rem 1.1rem;
    background: linear-gradient(180deg, rgba(255,248,233,0.94) 0%, rgba(244,233,205,0.92) 100%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.55), 0 10px 24px rgba(92,64,26,0.09);
}

.hero__contact-item::before,
.feature-card--sign::before,
.notice-callout--banner-style::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255,255,255,0.3), transparent 30%, transparent 70%, rgba(122,86,39,0.05));
}

.hero__contact-label {
    color: var(--eh-forest);
    letter-spacing: 0.08em;
    font-size: 0.78rem;
}

.wood-plaque--hero {
    display: inline-flex;
    margin-top: 1.35rem;
    padding: 0.85rem 1.3rem;
    border-radius: 18px;
    background: linear-gradient(180deg, #4b7a30 0%, #33591f 100%);
    color: #fff7e4;
    box-shadow: 0 10px 20px rgba(51, 89, 31, 0.24);
}

.welcome-card__visual--large {
    align-self: center;
    justify-content: center;
    padding-right: clamp(1rem, 2vw, 2rem);
}

.welcome-card__visual--large .welcome-card__mascot {
    width: min(100%, 300px);
    max-height: 25rem;
    transform: translateY(10px);
}

.quick-links {
    gap: 1.5rem;
}

.feature-card--sign {
    position: relative;
    padding-top: 2.2rem;
    background:
        linear-gradient(180deg, rgba(251,244,226,0.96) 0%, rgba(241,228,196,0.94) 100%);
    box-shadow: 0 18px 38px rgba(88, 61, 26, 0.14);
}

.feature-card--sign::after {
    background: linear-gradient(180deg, #e0bc6a 0%, #c99535 100%);
    height: 7px;
    border-radius: 999px;
    left: 1.4rem;
    right: 1.4rem;
    bottom: 1.15rem;
}

.feature-card__number {
    width: 3.1rem;
    height: 3.1rem;
    border-radius: 999px;
    background: linear-gradient(180deg, #4e7d33 0%, #35591f 100%);
    color: #fff8e5;
    box-shadow: 0 8px 18px rgba(53, 89, 31, 0.25);
}

.feature-card--sign h3,
.notice-callout h2 {
    font-size: clamp(1.4rem, 1.5vw + 1rem, 2rem);
}

.notice-callout--banner-style {
    gap: clamp(1.6rem, 3vw, 3rem);
    padding: clamp(1.7rem, 3vw, 2.4rem);
}

.notice-callout__visual--badge {
    align-self: end;
}

.notice-callout__visual--badge img {
    max-height: 16rem;
    width: auto;
}

@media (max-width: 960px) {
    .welcome-card--header-style {
        grid-template-columns: 1fr;
        text-align: left;
        gap: 1.2rem;
    }

    .welcome-card__title,
    .welcome-card__text {
        max-width: none;
    }

    .hero__contact {
        grid-template-columns: 1fr;
        max-width: none;
    }

    .welcome-card__visual--large {
        padding-right: 0;
    }

    .welcome-card__visual--large .welcome-card__mascot {
        max-height: 20rem;
        transform: none;
    }
}

/* April 2026 refinement: stronger warm background + welcome sign in first content block */
body {
    background:
        linear-gradient(rgba(248, 241, 219, 0.84), rgba(248, 241, 219, 0.84)),
        url('../images/site-background.png') center top / cover fixed no-repeat !important;
}

body::before {
    background:
        radial-gradient(circle at 50% 18%, rgba(255, 245, 213, 0.82), transparent 30%),
        radial-gradient(circle at 50% 52%, rgba(247, 233, 193, 0.56), transparent 48%),
        linear-gradient(180deg, rgba(254, 249, 234, 0.18) 0%, rgba(244, 229, 191, 0.34) 100%) !important;
    opacity: 1 !important;
}

.site-shell,
.site-main,
.section-space,
.welcome-card-wrap--first {
    position: relative;
    z-index: 1;
}

.welcome-card--header-style {
    background: linear-gradient(180deg, rgba(252, 245, 227, 0.95) 0%, rgba(247, 236, 207, 0.94) 100%) !important;
    border: 1px solid rgba(149, 108, 56, 0.18);
    box-shadow: 0 24px 60px rgba(90, 60, 20, 0.16);
}

.welcome-card--header-style::before {
    opacity: 0.35 !important;
}

.welcome-card__visual--large {
    align-self: end;
    display: flex;
    justify-content: center;
    align-items: end;
}

.welcome-card__welcome-sign {
    width: min(100%, 480px);
    max-height: none;
    object-fit: contain;
    filter: drop-shadow(0 14px 22px rgba(94, 58, 17, 0.18));
    margin-inline: auto;
}

/* hide older mascot style in first card if cached markup/css conflicts */
.welcome-card__visual--large .welcome-card__mascot {
    max-height: 420px;
    object-fit: contain;
}

.prose-card,
.notice-callout--banner-style,
.feature-card--sign,
.post-card,
.empty-state {
    background: linear-gradient(180deg, rgba(252, 245, 228, 0.95) 0%, rgba(246, 235, 206, 0.93) 100%) !important;
}

@media (max-width: 900px) {
    body {
        background:
            linear-gradient(rgba(248, 241, 219, 0.92), rgba(248, 241, 219, 0.92)),
            url('../images/site-background.png') center top / cover no-repeat !important;
    }

    .welcome-card__welcome-sign {
        width: min(100%, 360px);
    }
}

/* April 2026 refinement: stronger background and centered welcome owl */
body {
    background:
        linear-gradient(rgba(245, 232, 198, 0.58), rgba(245, 232, 198, 0.62)),
        url('../images/site-background.png') center top / cover fixed no-repeat !important;
}

body::before {
    background:
        radial-gradient(circle at 50% 16%, rgba(255, 244, 208, 0.54), transparent 28%),
        radial-gradient(circle at 50% 56%, rgba(239, 216, 164, 0.22), transparent 48%),
        linear-gradient(180deg, rgba(250, 240, 210, 0.06) 0%, rgba(235, 214, 166, 0.18) 100%) !important;
    opacity: 1 !important;
}

.welcome-card--header-style {
    background: linear-gradient(180deg, rgba(253, 245, 224, 0.88) 0%, rgba(245, 231, 194, 0.86) 100%) !important;
}

.welcome-card__visual--large {
    align-self: center !important;
    justify-content: center;
    align-items: center !important;
}

.welcome-card__welcome-sign {
    width: min(100%, 500px);
    max-height: 520px;
    object-fit: contain;
    object-position: center center;
    margin-inline: auto;
    transform: translateY(0) !important;
}

.prose-card,
.notice-callout--banner-style,
.feature-card--sign,
.post-card,
.empty-state {
    background: linear-gradient(180deg, rgba(252, 246, 229, 0.89) 0%, rgba(243, 230, 194, 0.86) 100%) !important;
}

@media (max-width: 900px) {
    body {
        background:
            linear-gradient(rgba(245, 232, 198, 0.74), rgba(245, 232, 198, 0.76)),
            url('../images/site-background.png') center top / cover no-repeat !important;
    }

    .welcome-card__visual--large {
        align-self: center !important;
    }

    .welcome-card__welcome-sign {
        width: min(100%, 360px);
        max-height: none;
    }
}

/* ChatGPT fix: menu without top box and without clipped bottoms */
.site-header__art--banner-only {
    padding-bottom: 0.15rem !important;
}

.site-nav-bar {
    margin-top: -0.15rem;
    padding: 0.15rem 0 1.25rem !important;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
}

.site-nav-bar__inner {
    width: auto !important;
    max-width: min(1400px, calc(100% - 2rem));
    padding: 0 !important;
    gap: 0.9rem;
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    overflow: visible !important;
    align-items: flex-start;
}

.site-nav-bar .main-navigation,
.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu,
.site-header__cta--nav {
    overflow: visible !important;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    padding: 0.1rem 0 0.9rem !important;
    align-items: flex-start;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a,
.site-header__cta--nav .button--header {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
    line-height: 1.15;
    padding: 0.92rem 1.32rem 1.02rem;
    border-radius: 999px;
    border: 1px solid rgba(138, 96, 34, 0.22);
    background: linear-gradient(180deg, #f9dc8f 0%, #efbf55 52%, #e5aa35 100%) !important;
    box-shadow:
        0 8px 16px rgba(105, 72, 28, 0.16),
        0 4px 0 rgba(141, 95, 28, 0.34),
        inset 0 1px 0 rgba(255, 251, 235, 0.75) !important;
}

.site-nav-bar .main-navigation .current-menu-item > a,
.site-nav-bar .main-navigation .current_page_item > a,
.site-nav-bar .main-navigation a:hover,
.site-nav-bar .main-navigation a:focus-visible,
.site-nav-bar .main-navigation .menu-item--accent > a,
.site-nav-bar .main-navigation .menu > li:nth-last-child(2) > a,
.site-nav-bar .main-navigation .menu > li:last-child > a,
.site-header__cta--nav .button--header:hover,
.site-header__cta--nav .button--header:focus-visible {
    transform: translateY(-1px);
    background: linear-gradient(180deg, #fae3a5 0%, #f1c764 54%, #e8b13e 100%) !important;
    box-shadow:
        0 10px 18px rgba(105, 72, 28, 0.18),
        0 5px 0 rgba(141, 95, 28, 0.36),
        inset 0 1px 0 rgba(255, 251, 235, 0.8) !important;
}

@media (max-width: 1180px) {
    .site-nav-bar {
        margin-top: 0;
        padding-bottom: 1rem !important;
    }

    .site-nav-bar__inner {
        gap: 0.75rem;
    }

    .site-nav-bar .main-navigation .menu {
        padding-bottom: 0.65rem !important;
    }
}

/* 2.0.1 refined menu button finish */
.site-nav-bar {
    padding: 0.18rem 0 1.35rem !important;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    gap: 0.55rem;
    padding: 0.18rem 0 1rem !important;
}

.site-nav-bar .main-navigation .menu a,
.site-nav-bar .main-navigation .page_item > a,
.site-header__cta--nav .button--header {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3.35rem;
    padding: 0.9rem 1.42rem 1rem;
    border-radius: 1.15rem;
    border: 1px solid rgba(150, 106, 40, 0.34);
    color: #6b4a1d !important;
    background: linear-gradient(180deg, #fce6a8 0%, #f4cd73 46%, #ebb74a 100%) !important;
    box-shadow:
        0 10px 20px rgba(112, 78, 29, 0.14),
        0 5px 0 rgba(157, 109, 37, 0.34),
        inset 0 1px 0 rgba(255, 252, 239, 0.82),
        inset 0 -1px 0 rgba(185, 130, 42, 0.18) !important;
    text-shadow: 0 1px 0 rgba(255, 248, 229, 0.45);
    transition: transform var(--eh-transition), box-shadow var(--eh-transition), background var(--eh-transition), color var(--eh-transition);
}

.site-nav-bar .main-navigation .menu a::before,
.site-header__cta--nav .button--header::before {
    content: "";
    position: absolute;
    inset: 0.12rem 0.16rem auto;
    height: 44%;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(255,255,255,0.52) 0%, rgba(255,255,255,0.04) 100%);
    pointer-events: none;
}

.site-nav-bar .main-navigation .menu a:hover,
.site-nav-bar .main-navigation .menu a:focus-visible,
.site-nav-bar .main-navigation .current-menu-item > a,
.site-nav-bar .main-navigation .current_page_item > a,
.site-nav-bar .main-navigation .menu-item--accent > a,
.site-nav-bar .main-navigation .menu > li:nth-last-child(2) > a,
.site-nav-bar .main-navigation .menu > li:last-child > a,
.site-header__cta--nav .button--header:hover,
.site-header__cta--nav .button--header:focus-visible {
    transform: translateY(-2px);
    color: #5e3f15 !important;
    background: linear-gradient(180deg, #fdebb8 0%, #f6d583 46%, #efbf55 100%) !important;
    box-shadow:
        0 14px 26px rgba(112, 78, 29, 0.16),
        0 6px 0 rgba(157, 109, 37, 0.36),
        inset 0 1px 0 rgba(255, 253, 241, 0.88),
        inset 0 -1px 0 rgba(185, 130, 42, 0.2) !important;
}

.site-nav-bar .main-navigation .menu > li:last-child > a,
.site-header__cta--nav .button--header {
    min-width: 11.4rem;
}

@media (max-width: 1180px) {
    .site-nav-bar .main-navigation .menu,
    .site-nav-bar .footer-navigation .menu {
        gap: 0.45rem;
    }

    .site-nav-bar .main-navigation .menu a,
    .site-nav-bar .main-navigation .page_item > a,
    .site-header__cta--nav .button--header {
        min-height: 3.1rem;
        padding: 0.82rem 1.18rem 0.9rem;
        border-radius: 1rem;
    }
}

/* --- 2.0.1 lower homepage sections refined --- */
.section-space {
    position: relative;
}

.section-space .container {
    position: relative;
    z-index: 1;
}

.section-space .container::before {
    content: '';
    position: absolute;
    inset: -0.75rem -0.35rem;
    border-radius: 34px;
    background: linear-gradient(180deg, rgba(252, 247, 233, 0.58) 0%, rgba(247, 239, 216, 0.46) 100%);
    box-shadow: 0 18px 40px rgba(88, 60, 25, 0.08);
    backdrop-filter: blur(3px);
    z-index: -1;
    pointer-events: none;
}

.section-space--first-content .container::before,
.welcome-card-wrap--first .container::before {
    display: none;
}

.quick-links,
.posts-grid {
    position: relative;
    z-index: 2;
}

.feature-card--sign,
.posts-grid .post-card,
.notice-callout--banner-style {
    border-radius: 28px;
    overflow: hidden;
}

.feature-card--sign {
    background:
        linear-gradient(180deg, rgba(255, 248, 230, 0.98) 0%, rgba(245, 232, 201, 0.95) 100%),
        radial-gradient(circle at top left, rgba(255,255,255,0.45), transparent 38%);
    border: 1px solid rgba(138, 99, 56, 0.16);
    box-shadow:
        0 18px 36px rgba(92, 63, 25, 0.12),
        inset 0 1px 0 rgba(255,255,255,0.68),
        inset 0 -6px 0 rgba(214, 182, 110, 0.22);
}

.feature-card--sign::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 10px;
    background: linear-gradient(90deg, rgba(103, 141, 63, 0.94), rgba(72, 111, 60, 0.92));
}

.feature-card--sign::after {
    content: '';
    position: absolute;
    right: 1rem;
    bottom: 1rem;
    width: 72px;
    height: 72px;
    background: radial-gradient(circle, rgba(114,156,73,0.14) 0%, rgba(114,156,73,0) 70%);
    pointer-events: none;
}

.feature-card__number {
    background: linear-gradient(180deg, #f4ce72 0%, #e7af3f 100%);
    color: var(--eh-bark-dark);
    box-shadow: 0 6px 0 rgba(107, 67, 22, 0.28);
}

.feature-card h3 {
    font-size: clamp(1.22rem, 0.7vw + 1rem, 1.45rem);
    color: var(--eh-bark-dark);
}

.feature-card__link,
.post-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-weight: 800;
    color: var(--eh-forest);
}

.feature-card__link::after,
.post-card__link::after {
    content: '→';
    font-size: 1.05em;
}

.posts-grid .post-card {
    background:
        linear-gradient(180deg, rgba(255, 248, 231, 0.98) 0%, rgba(244, 232, 205, 0.94) 100%),
        radial-gradient(circle at top right, rgba(255,255,255,0.42), transparent 36%);
    border: 1px solid rgba(138, 99, 56, 0.16);
    box-shadow:
        0 18px 36px rgba(92, 63, 25, 0.11),
        inset 0 1px 0 rgba(255,255,255,0.68);
}

.posts-grid .post-card__media {
    border-bottom: 1px solid rgba(138, 99, 56, 0.12);
}

.post-card__body {
    padding: 1.4rem 1.35rem 1.5rem;
}

.post-card__meta {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.28rem 0.75rem;
    border-radius: 999px;
    background: rgba(115, 151, 71, 0.12);
    color: var(--eh-forest);
    font-weight: 700;
    font-size: 0.85rem;
}

.post-card__title a {
    color: var(--eh-bark-dark);
    text-decoration: none;
}

.post-card__title a:hover,
.post-card__title a:focus-visible {
    color: var(--eh-forest);
}

.notice-callout--banner-style {
    position: relative;
    background:
        linear-gradient(180deg, rgba(252, 245, 224, 0.97) 0%, rgba(242, 228, 191, 0.93) 100%),
        radial-gradient(circle at top right, rgba(255,255,255,0.45), transparent 34%);
    border: 1px solid rgba(138, 99, 56, 0.16);
    box-shadow:
        0 22px 42px rgba(92, 63, 25, 0.12),
        inset 0 1px 0 rgba(255,255,255,0.7);
}

.notice-callout--banner-style::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 16px;
    background: linear-gradient(180deg, rgba(103, 141, 63, 0.92), rgba(72, 111, 60, 0.9));
}

.notice-callout__content {
    padding-left: clamp(2rem, 4vw, 3rem);
}

.notice-callout__visual--badge {
    justify-content: center;
    align-items: center;
    padding: 1.4rem 1.4rem 1.4rem 0;
}

.notice-callout__visual--badge img {
    max-height: 16rem;
    width: auto;
    filter: drop-shadow(0 16px 22px rgba(97, 63, 20, 0.16));
}

.section-actions {
    margin-top: 1.5rem;
    display: flex;
    justify-content: center;
}

.empty-state {
    text-align: center;
    max-width: 720px;
    margin: 1.5rem auto 0;
    border-radius: 24px;
    padding: 1.4rem 1.6rem;
}

@media (max-width: 900px) {
    .section-space .container::before {
        inset: -0.5rem -0.2rem;
        border-radius: 28px;
    }

    .notice-callout__visual--badge {
        padding: 0 1.25rem 1.25rem;
    }
}


/* Footer refresh inspired by illustrated garden footer */
.site-footer {
    position: relative;
    margin-top: auto;
    color: #4b2e16;
    background:
        linear-gradient(180deg, rgba(250, 243, 221, 0.78) 0%, rgba(245, 232, 201, 0.88) 28%, rgba(237, 220, 177, 0.92) 100%),
        url('../images/footer-background.png') center bottom / cover no-repeat;
    border-top: 0;
    overflow: hidden;
    isolation: isolate;
}

.site-footer::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at top center, rgba(255,255,255,0.40) 0, rgba(255,255,255,0) 28%),
        linear-gradient(180deg, rgba(255, 249, 236, 0.08) 0%, rgba(120, 86, 40, 0.08) 100%);
    z-index: -1;
    pointer-events: none;
}

.site-footer__topline {
    height: 12px;
    background: linear-gradient(180deg, rgba(255,250,239,0.88) 0%, rgba(239,223,182,0.55) 100%);
    border-bottom: 1px solid rgba(112, 76, 32, 0.08);
}

.site-footer__main,
.site-footer__sub {
    position: relative;
}

.site-footer__main {
    padding: 2.25rem 0 1.75rem;
}

.site-footer__about,
.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    background: linear-gradient(180deg, rgba(255, 249, 236, 0.84) 0%, rgba(248, 238, 214, 0.86) 100%);
    border: 1px solid rgba(118, 84, 42, 0.12);
    border-radius: 24px;
    box-shadow: 0 14px 30px rgba(88, 59, 23, 0.12);
    backdrop-filter: blur(4px);
}

.site-footer__about {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 1rem;
    align-items: center;
    padding: 1.1rem 1.25rem;
}

.site-footer__logo {
    width: min(220px, 34vw);
    height: auto;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    padding: 0;
}

.site-footer__about-copy {
    display: grid;
    gap: 0.5rem;
}

.site-footer__about-note,
.footer-widget,
.footer-widget p,
.footer-widget li,
.site-footer__copyright,
.footer-navigation .menu a {
    color: #5a3a19;
}

.site-footer__about-note {
    margin: 0;
    font-size: 1rem;
    line-height: 1.6;
}

.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    padding: 1.1rem 1.15rem 1rem;
}

.site-footer .wood-title {
    background: linear-gradient(180deg, #7ca448 0%, #52782d 100%);
    box-shadow: 0 6px 0 rgba(80, 55, 22, 0.28);
}

.site-footer a:hover,
.site-footer a:focus-visible {
    color: #7a4a21;
}

.site-footer__sub {
    margin-top: 0.35rem;
    border-top: 1px solid rgba(118, 84, 42, 0.10);
    padding: 0.9rem 0 1rem;
    background: linear-gradient(180deg, rgba(250,244,226,0.60) 0%, rgba(244,232,201,0.72) 100%);
}

.footer-navigation .menu {
    gap: 0.45rem;
    flex-wrap: wrap;
}

.footer-navigation .menu a {
    background: rgba(255, 248, 228, 0.72);
    border: 1px solid rgba(118, 84, 42, 0.10);
    border-radius: 999px;
    padding: 0.5rem 0.85rem;
    box-shadow: 0 6px 14px rgba(88, 59, 23, 0.08);
}

@media (max-width: 782px) {
    .site-footer {
        background-position: center bottom;
        background-size: cover;
    }

    .site-footer__about {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .site-footer__logo {
        width: min(190px, 60vw);
        margin-inline: auto;
    }
}



/* 2.0.2 cleanup: centered menu without CTA and no hero plaque */
.site-nav-bar {
    padding: 0.22rem 0 1.1rem !important;
}

.site-nav-bar__inner {
    display: flex !important;
    justify-content: center !important;
    align-items: flex-start !important;
    max-width: min(1320px, calc(100% - 2rem));
}

.site-nav-bar .main-navigation {
    margin-left: 0 !important;
    width: 100%;
}

.site-nav-bar .main-navigation .menu,
.site-nav-bar .footer-navigation .menu {
    justify-content: center !important;
    width: 100%;
    padding-inline: 0 !important;
}

.site-header__cta,
.site-header__cta--nav {
    display: none !important;
}

.site-nav-bar .main-navigation .menu > li:last-child > a,
.site-header__cta--nav .button--header {
    min-width: 0 !important;
}

@media (max-width: 1180px) {
    .site-nav-bar__inner {
        justify-content: center !important;
    }

    .site-nav-bar .main-navigation .menu,
    .site-nav-bar .footer-navigation .menu {
        justify-content: flex-start !important;
    }
}


/* 2.0.3 footer compact logo refinement */
.site-footer__main {
    align-items: start;
}

.site-footer__about {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.9rem 1rem;
    min-height: 0;
}

.site-footer__logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
}

.site-footer__logo {
    width: min(180px, 24vw);
    max-width: 180px;
}

.site-footer__about-copy,
.site-footer__about-note {
    display: none !important;
}

@media (max-width: 782px) {
    .site-footer__about {
        padding: 0.85rem;
    }

    .site-footer__logo {
        width: min(150px, 52vw);
        max-width: 150px;
    }
}


/* Grafische Schnellzugriff-Buttons */
.feature-card__graphic-link {
    display: inline-flex;
    align-items: center;
    gap: 0.8rem;
    margin-top: 1.15rem;
    padding: 0.9rem 1.15rem 0.9rem 0.95rem;
    min-height: 58px;
    border-radius: 999px;
    position: relative;
    overflow: hidden;
    text-decoration: none;
    color: #62401f;
    font-weight: 700;
    background: linear-gradient(180deg, rgba(255, 247, 220, 0.98) 0%, rgba(239, 204, 110, 0.96) 100%);
    border: 1px solid rgba(183, 136, 45, 0.5);
    box-shadow: 0 7px 0 rgba(191, 143, 52, 0.62), 0 14px 26px rgba(105, 74, 26, 0.14);
    transition: transform 180ms ease, box-shadow 180ms ease, filter 180ms ease;
}

.feature-card__graphic-link::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.36), rgba(255,255,255,0.04) 38%, transparent 60%);
    pointer-events: none;
}

.feature-card__graphic-link:hover,
.feature-card__graphic-link:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 9px 0 rgba(191, 143, 52, 0.62), 0 18px 30px rgba(105, 74, 26, 0.18);
    filter: saturate(1.04);
}

.feature-card__graphic-link:active {
    transform: translateY(2px);
    box-shadow: 0 4px 0 rgba(191, 143, 52, 0.62), 0 10px 18px rgba(105, 74, 26, 0.14);
}

.feature-card__graphic-icon {
    width: 2.5rem;
    height: 2.5rem;
    flex: 0 0 2.5rem;
    border-radius: 999px;
    background: linear-gradient(180deg, #4f7d33 0%, #35581f 100%);
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.22), 0 6px 12px rgba(53, 88, 31, 0.22);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 1.25rem 1.25rem;
}

.feature-card__graphic-link--garden .feature-card__graphic-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff9e7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21V10'/%3E%3Cpath d='M7 14c-2.5 0-4.5-2-4.5-4.5C5.5 9.5 7 7.5 7 5c3 0 5 2 5 5v4'/%3E%3Cpath d='M17 14c2.5 0 4.5-2 4.5-4.5C18.5 9.5 17 7.5 17 5c-3 0-5 2-5 5v4'/%3E%3C/svg%3E");
}

.feature-card__graphic-link--calendar .feature-card__graphic-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff9e7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='5' width='18' height='16' rx='2'/%3E%3Cpath d='M16 3v4M8 3v4M3 10h18'/%3E%3C/svg%3E");
}

.feature-card__graphic-link--team .feature-card__graphic-icon {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff9e7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M16 21v-2a4 4 0 0 0-4-4H7a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='9.5' cy='7' r='3.5'/%3E%3Cpath d='M22 21v-2a4 4 0 0 0-3-3.87'/%3E%3Cpath d='M16 3.13a3.5 3.5 0 0 1 0 6.74'/%3E%3C/svg%3E");
}

.feature-card__graphic-label {
    position: relative;
    z-index: 1;
    line-height: 1.15;
}

.feature-card__graphic-arrow {
    position: relative;
    z-index: 1;
    margin-left: 0.15rem;
    font-size: 1.15rem;
}

.feature-card__link {
    display: none;
}

@media (max-width: 680px) {
    .feature-card__graphic-link {
        width: 100%;
        justify-content: center;
    }
}


/* remove quick-link number badges and tighten spacing */
.quick-links .feature-card{padding-top:2rem;}
.quick-links .feature-card h3{margin-top:0;}
.quick-links .feature-card__number{display:none !important;}


/* 2.0.4 footer logo + impressum layout */
.site-footer__about {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 1.15rem;
    padding: 1rem 1.15rem;
    min-height: 0;
}

.site-footer__logo-link {
    flex: 0 0 auto;
}

.site-footer__logo {
    width: min(150px, 20vw);
    max-width: 150px;
}

.site-footer__about-copy {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 0.15rem;
}

.site-footer__about-title {
    margin: 0 0 0.35rem;
    font-size: clamp(1.05rem, 1.5vw, 1.25rem);
}

.site-footer__about-note {
    display: block !important;
    margin: 0;
    font-size: 0.98rem;
    line-height: 1.45;
    color: #5b4324;
}

.site-footer__about-link {
    margin: 0.45rem 0 0;
}

@media (max-width: 782px) {
    .site-footer__about {
        flex-direction: column;
        text-align: center;
        align-items: center;
    }

    .site-footer__about-copy {
        align-items: center;
        text-align: center;
    }

    .site-footer__logo {
        width: min(140px, 44vw);
        max-width: 140px;
    }
}


/* 2.0.6 restore footer impressum layout and equal card heights */
.site-footer__main {
    display: grid !important;
    grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr) !important;
    gap: 1.35rem !important;
    align-items: stretch !important;
}

.site-footer__about {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    justify-content: flex-start !important;
    min-height: 100% !important;
    padding: 1.35rem 1.5rem !important;
}

 .site-footer__about-note {
    display: block !important;
}

.site-footer__about-copy {
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-self: center;
    min-height: 100%;
}

.site-footer__logo {
    width: min(165px, 22vw) !important;
    max-width: 165px !important;
}

.site-footer__widgets {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 1.35rem !important;
    align-items: stretch !important;
}

.site-footer__widget-column {
    display: flex !important;
}

.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    width: 100%;
    min-height: 100%;
    display: flex;
    flex-direction: column;
}

.site-footer__about-title {
    margin-bottom: 0.55rem !important;
}

.site-footer__about-note {
    margin: 0 0 0.15rem !important;
}

.site-footer__about-note a {
    color: #5a3a19;
    text-decoration: none;
    font-weight: 600;
}

.site-footer__about-note a:hover,
.site-footer__about-note a:focus-visible {
    color: #7a4a21;
    text-decoration: underline;
}

@media (max-width: 900px) {
    .site-footer__main {
        grid-template-columns: 1fr !important;
    }

    .site-footer__widgets {
        grid-template-columns: 1fr !important;
    }
}


/* 2.1.0 Schnellzugriff als illustrierte Schilder */
.section-space--quick-signs .section-heading {
    margin-bottom: clamp(1.5rem, 3vw, 2.4rem);
}

.quick-signs {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1rem, 2vw, 1.8rem);
    align-items: end;
}

.quick-sign {
    display: block;
    text-decoration: none;
    transition: transform 180ms ease, filter 180ms ease, drop-shadow 180ms ease;
}

.quick-sign img {
    display: block;
    width: 100%;
    height: auto;
    filter: drop-shadow(0 18px 22px rgba(95, 70, 28, 0.16));
}

.quick-sign:hover,
.quick-sign:focus-visible {
    transform: translateY(-6px) scale(1.02);
}

.quick-sign:hover img,
.quick-sign:focus-visible img {
    filter: drop-shadow(0 24px 28px rgba(95, 70, 28, 0.22)) saturate(1.03);
}

.quick-sign:active {
    transform: translateY(-1px) scale(1.005);
}

@media (max-width: 960px) {
    .quick-signs {
        grid-template-columns: 1fr;
        max-width: 520px;
        margin-inline: auto;
    }
}


/* --- page heading cleanup: remove badge look and make headings fit design --- */
.page-banner {
    padding: clamp(1.6rem, 3vw, 2.4rem) 0 1rem;
}

.page-banner .container {
    padding: clamp(1.8rem, 3.2vw, 2.6rem) clamp(1.6rem, 3vw, 2.4rem);
    border-radius: 30px;
    background: linear-gradient(180deg, rgba(248, 242, 227, 0.96) 0%, rgba(242, 231, 202, 0.94) 100%);
    border: 1px solid rgba(128, 90, 46, 0.12);
    box-shadow: 0 16px 34px rgba(80, 56, 24, 0.12);
}

.page-banner h1 {
    max-width: none;
    margin: 0;
    color: #7b5430;
    font-size: clamp(2.5rem, 4.2vw, 4.4rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
    font-weight: 800;
    text-shadow: none;
    text-wrap: balance;
}

.page-banner p {
    max-width: 58ch;
    margin: 1rem 0 0;
    padding: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    color: rgba(83, 64, 39, 0.9);
    font-size: 1.08rem;
}

@media (max-width: 820px) {
    .page-banner h1 {
        font-size: clamp(2.2rem, 8vw, 3.3rem);
    }
}

/* 2.1.1 Footer-Karten auf gleiche Hoehe bringen */
.site-footer__main {
    display: grid !important;
    grid-template-columns: minmax(0, 1.7fr) minmax(240px, 1fr) minmax(240px, 1fr) !important;
    gap: 1.35rem !important;
    align-items: stretch !important;
}

.site-footer__main > * {
    min-height: 100%;
}

.site-footer__widgets {
    display: contents !important;
}

.site-footer__widget-column {
    display: block !important;
    min-height: 100%;
}

.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget),
.site-footer__about {
    height: 100% !important;
    min-height: 100% !important;
    box-sizing: border-box;
}

.site-footer__about {
    align-items: center !important;
}

.site-footer__about-copy {
    justify-content: center !important;
}

@media (max-width: 1100px) {
    .site-footer__main {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    }

    .site-footer__about {
        grid-column: 1 / -1;
    }

    .site-footer__widgets {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
    }
}

@media (max-width: 900px) {
    .site-footer__main {
        grid-template-columns: 1fr !important;
    }

    .site-footer__widgets {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }
}

/* 2.1.2 Startseite ohne Schwarzes Brett und Footer-Besucherzaehler */
.footer-widget--counter {
    justify-content: center;
}

.footer-counter {
    display: flex;
    align-items: center;
    gap: 1rem;
    min-height: 100%;
}

.footer-counter__owl {
    width: 88px;
    max-width: 30%;
    flex: 0 0 auto;
    filter: drop-shadow(0 10px 18px rgba(86, 58, 20, 0.18));
}

.footer-counter__content {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.footer-counter__label {
    margin: 0;
    font-weight: 700;
    color: #5f7732;
}

.footer-counter__number {
    margin: 0;
    font-size: clamp(2rem, 3vw, 2.8rem);
    line-height: 1;
    font-weight: 800;
    color: #7b5430;
}

.footer-counter__hint {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.5;
}

@media (max-width: 640px) {
    .footer-counter {
        flex-direction: column;
        text-align: center;
    }

    .footer-counter__owl {
        max-width: 96px;
        width: 96px;
    }
}


/* 2.1.3 Footer counter owl and aligned widget cards */
.site-footer__widgets {
    align-items: stretch !important;
}

.site-footer__widget-column {
    display: flex !important;
    align-items: stretch !important;
}

.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start;
    height: 100% !important;
    min-height: 310px;
}

.footer-widget {
    padding: 1.2rem 1.25rem 1.3rem;
}

.footer-widget--counter {
    justify-content: flex-start;
}

.footer-counter {
    flex: 1 1 auto;
    align-items: center;
    gap: 0.9rem;
}

.footer-counter__owl {
    width: 110px;
    max-width: 42%;
    align-self: center;
    object-fit: contain;
}

.footer-counter__content {
    justify-content: center;
}

@media (max-width: 1100px) {
    .site-footer__widget-column > .widget,
    .site-footer__widget-column > *:not(.widget) {
        min-height: 280px;
    }
}

@media (max-width: 640px) {
    .site-footer__widget-column > .widget,
    .site-footer__widget-column > *:not(.widget) {
        min-height: 0;
    }

    .footer-counter__owl {
        width: 92px;
        max-width: 92px;
    }
}


/* Footer counter sizing + equal card heights fix */
.site-footer__main {
    align-items: stretch !important;
}

.site-footer__about,
.site-footer__widgets,
.site-footer__widget-column,
.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    height: 100%;
}

.site-footer__about,
.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    min-height: 320px !important;
}

.site-footer__about {
    display: flex !important;
    align-items: center !important;
}

.site-footer__widgets {
    align-items: stretch !important;
}

.site-footer__widget-column {
    display: flex !important;
    align-items: stretch !important;
}

.footer-widget--counter {
    display: flex !important;
    flex-direction: column;
    justify-content: flex-start;
}

.footer-counter {
    flex: 1 1 auto;
    align-items: center;
    gap: 1.25rem;
}

.footer-counter__owl {
    width: 176px !important;
    max-width: 52% !important;
    height: auto;
    object-fit: contain;
}

.footer-counter__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

@media (max-width: 1100px) {
    .site-footer__about,
    .site-footer__widget-column > .widget,
    .site-footer__widget-column > *:not(.widget) {
        min-height: 290px !important;
    }

    .footer-counter__owl {
        width: 144px !important;
        max-width: 48% !important;
    }
}

@media (max-width: 640px) {
    .site-footer__about,
    .site-footer__widget-column > .widget,
    .site-footer__widget-column > *:not(.widget) {
        min-height: 0 !important;
    }

    .footer-counter {
        flex-direction: column;
        text-align: center;
    }

    .footer-counter__owl {
        width: 116px !important;
        max-width: 116px !important;
    }
}

/* Footer visitor counter final sizing + aligned cards */
.site-footer__main {
    display: grid !important;
    grid-template-columns: minmax(0, 1.45fr) minmax(0, 1fr) !important;
    gap: 1.35rem !important;
    align-items: stretch !important;
}

.site-footer__widgets {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 1.35rem !important;
    align-items: stretch !important;
}

.site-footer__about,
.site-footer__widget-column,
.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    min-height: 320px !important;
    height: 100% !important;
}

.site-footer__widget-column {
    display: flex !important;
    align-items: stretch !important;
}

.footer-widget--counter {
    display: flex !important;
    flex-direction: column;
    justify-content: center !important;
}

.footer-counter {
    display: grid !important;
    grid-template-columns: minmax(130px, 170px) 1fr;
    align-items: center !important;
    justify-items: center;
    gap: 1rem !important;
    flex: 1 1 auto;
    min-height: 100%;
}

.footer-counter__owl {
    width: 160px !important;
    max-width: none !important;
    height: auto !important;
    justify-self: center;
    align-self: center;
}

.footer-counter__content {
    align-self: center;
    justify-self: start;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.footer-counter__label {
    margin: 0;
    color: #6b4727;
    font-weight: 800;
    line-height: 1.35;
}

@media (max-width: 1100px) {
    .site-footer__main {
        grid-template-columns: 1fr !important;
    }
    .site-footer__widgets {
        grid-template-columns: 1fr 1fr !important;
    }
    .site-footer__about,
    .site-footer__widget-column,
    .site-footer__widget-column > .widget,
    .site-footer__widget-column > *:not(.widget) {
        min-height: 290px !important;
    }
    .footer-counter {
        grid-template-columns: minmax(110px, 140px) 1fr;
    }
    .footer-counter__owl {
        width: 132px !important;
    }
}

@media (max-width: 782px) {
    .site-footer__widgets {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    .footer-counter {
        grid-template-columns: 1fr !important;
        text-align: center;
    }
    .footer-counter__content {
        justify-self: center;
        align-items: center;
    }
    .footer-counter__owl {
        width: 120px !important;
    }
}


/* Footer layout refinement: remove quick links card and match visitor card to impressum */
.site-footer__main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
}

.site-footer__about,
.site-footer__widgets,
.site-footer__widget-column,
.site-footer__widget-column > .widget,
.site-footer__widget-column > *:not(.widget) {
    height: 100%;
}

.site-footer__widgets--single {
    display: block;
}

.site-footer__widget-column--counter > .widget,
.site-footer__widget-column--counter > *:not(.widget) {
    min-height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.footer-widget--counter {
    padding: 1.15rem 1.25rem 1.1rem;
}

.footer-widget--counter .wood-title {
    margin-bottom: 1.35rem;
}

.footer-counter {
    display: grid;
    grid-template-columns: minmax(150px, 0.95fr) minmax(0, 1fr);
    align-items: center;
    gap: 1.15rem;
    min-height: 100%;
    flex: 1 1 auto;
}

.footer-counter__owl {
    width: min(260px, 100%);
    max-width: 100%;
    height: auto;
    justify-self: center;
    align-self: center;
}

.footer-counter__content {
    align-self: center;
}

@media (max-width: 1040px) {
    .site-footer__main {
        grid-template-columns: 1fr;
    }

    .site-footer__widgets--single {
        display: block;
    }
}


/* visitor box title match impressum style */
.footer-widget--counter {
    justify-content: center;
}

.footer-counter__title {
    margin: 0 0 0.85rem !important;
    color: #6b4727;
    font-size: clamp(1.9rem, 3vw, 2.9rem);
    line-height: 1.05;
    font-weight: 800;
    text-align: center;
}

.footer-widget--counter .wood-title,
.site-footer .footer-widget--counter .wood-title {
    background: transparent !important;
    box-shadow: none !important;
    color: inherit !important;
    padding: 0 !important;
    border-radius: 0 !important;
}

.footer-counter {
    margin-top: 0.15rem;
}

@media (max-width: 640px) {
    .footer-counter__title {
        font-size: clamp(1.7rem, 7vw, 2.2rem);
    }
}


/* 2.3.1 footer equal cards + visitor layout refinement */
.site-footer__main {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    align-items: stretch !important;
}

.site-footer__about,
.site-footer__widgets--single,
.site-footer__widget-column,
.site-footer__widget-column--counter,
.site-footer__widget-column--counter > .widget,
.site-footer__widget-column--counter > *:not(.widget) {
    height: 100% !important;
}

.site-footer__widgets--single {
    display: block !important;
    width: 100% !important;
}

.site-footer__widget-column--counter > .widget,
.site-footer__widget-column--counter > *:not(.widget) {
    padding: 1.35rem 1.5rem !important;
    justify-content: center !important;
}

.site-footer__about-title,
.footer-counter__title {
    margin: 0 0 0.65rem !important;
    font-size: clamp(2.2rem, 3.35vw, 3.6rem) !important;
    line-height: 1.04 !important;
    font-weight: 800 !important;
    color: #6b4727 !important;
    letter-spacing: -0.02em;
}

.footer-counter__title {
    text-align: left !important;
}

.footer-counter {
    display: grid !important;
    grid-template-columns: minmax(180px, 0.9fr) minmax(0, 1fr) !important;
    align-items: center !important;
    gap: 1.35rem !important;
    min-height: 100%;
    flex: 1 1 auto;
}

.footer-counter__owl {
    width: min(260px, 100%) !important;
    max-width: 260px !important;
    justify-self: start !important;
    align-self: center !important;
}

.footer-counter__content {
    display: flex !important;
    flex-direction: column;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    align-self: center !important;
    min-height: 100%;
}

.footer-counter__label {
    text-align: center !important;
}

.footer-counter__number {
    width: 100%;
    text-align: center !important;
}

@media (max-width: 980px) {
    .site-footer__main {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 640px) {
    .footer-counter__title,
    .site-footer__about-title {
        font-size: clamp(1.9rem, 8vw, 2.5rem) !important;
    }

    .footer-counter {
        grid-template-columns: 1fr !important;
    }

    .footer-counter__owl {
        justify-self: center !important;
    }
}
