*{box-sizing:border-box}html,body{height:100%}
:root{--container:1100px;--gutter:clamp(14px,4vw,24px);--panel-bg:#fff;--muted:#667085;--brand:#24633f;--accent:#2aa94a}
body{min-height:100svh;display:flex;flex-direction:column;overflow-x:hidden;background:#f6f7f9;color:#101828;font-family:"Manrope",system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol";line-height:1.55;margin:0}

/* Themes & BG */
body.site-landleben{--brand:#7c0f3b;--accent:#2aa94a;background-image:url("/assets/images/landleben/le-hero-01.jpg");background-attachment:fixed;background-size:cover;background-position:center}
body.site-winzer{--brand:#7c0f3b;--accent:#ffffff;background-image:url("/assets/images/winzer/wi-hero-01.jpg");background-attachment:fixed;background-size:cover;background-position:center}
body.site-hof{--brand:#6e5a45;--accent:#a48a6e;background-image:url("/assets/images/hof/hof-hero-01.jpg");background-attachment:fixed;background-size:cover;background-position:center}

a{color:inherit;text-decoration:none}
a:focus, a:focus-visible, button:focus, button:focus-visible, .btn:focus, .btn:focus-visible, input:focus, textarea:focus, select:focus{outline:none;box-shadow:none}

/* Layout */
#main{flex:1 0 auto;padding-inline:var(--gutter);padding-bottom:clamp(18px,4vw,32px)}
#main > *{margin-block:clamp(14px,3.2vw,24px)}
#main > .hero:first-child{margin-top:0}
#main > .hero.bleed.no-top-gap {
  margin-block-start: 0 !important; /* nur oben */
  margin-top: 0 !important;         /* Fallback für ältere Browser */
}

.wrap,.panel,.events-wrap,.crumbs-wrap,article.event{max-width:var(--container);margin-inline:auto}
.panel,.events-wrap{background:var(--panel-bg);border:1px solid #eaecef;border-radius:1rem;box-shadow:0 12px 32px rgba(0,0,0,.06);padding:clamp(16px,4vw,28px);overflow:hidden}

/* Header */
.site-header{position:sticky;top:0;z-index:50;width:100%;background:rgba(255,255,255,.92);border-bottom:1px solid #eef2f4;backdrop-filter:saturate(1.2) blur(6px)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem var(--gutter)}
.logo img{display:block;height:clamp(40px,6vw,88px);width:auto;max-height:none}
.nav-main .menu{display:flex;gap:clamp(.6rem,2vw,1.2rem);list-style:none;margin:0;padding:0}
.nav-main a{font-weight:600;position:relative;padding:.45rem .6rem;border-radius:.55rem;transition:all .25s ease}
.nav-main a:hover{background:rgba(0,0,0,.05);transform:translateY(-1px)}
.nav-main .menu li.cta>a{background:var(--brand);color:#fff;border:1px solid var(--brand)}
.nav-main .menu li.cta>a:hover{filter:brightness(1.06)}
.burger{display:none;background:none;border:0;padding:.4rem;cursor:pointer;position:relative;z-index:60}
.burger span{display:block;width:24px;height:2px;background:#111;margin:5px 0;transition:transform .25s ease,opacity .2s ease}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-drop{display:none;position:absolute;top:60px;left:0;right:0;background:#fff;border-bottom:1px solid #eaecef;box-shadow:0 14px 30px rgba(0,0,0,.08)}
.nav-drop.open{display:block}.nav-drop .menu{list-style:none;padding:.75rem var(--gutter);margin:0}.nav-drop .menu li{margin:.35rem 0}.nav-drop .menu a{font-weight:600;padding:.6rem .7rem;border-radius:.55rem;display:block}
.nav-drop .menu li.cta>a{background:var(--brand);color:#fff;border:1px solid var(--brand)}
@media (max-width:880px){.nav-main{display:none}.burger{display:block}}

/* Hero */
.hero{position:relative;padding:clamp(16px,4vw,28px) 0;margin-inline:calc(-1*var(--gutter))}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.90),rgba(255,255,255,.72) 45%,rgba(255,255,255,.48));pointer-events:none}
.hero>.panel{position:relative;max-width:var(--container);margin-inline:auto}

/* Grids & Cards */
.events-grid,.vendor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;list-style:none;padding:0;margin:0}
.event-card,.vendor-card{background:#fff;border:1px solid #eaecef;border-radius:1rem;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.06);transition:transform .3s ease,box-shadow .3s ease,opacity .25s ease}
.event-card:hover,.vendor-card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.10)}
.card-link{display:block;color:inherit;padding:0 0 clamp(14px,2.6vw,20px)}
.event-card img,.vendor-card img{width:100%;height:auto;display:block;aspect-ratio:4/3;object-fit:cover}
.event-card h3,.vendor-card h3{margin:.75rem 1rem .25rem}
.event-card .when,.event-card .where,.vendor-card .meta{margin:0 1rem .6rem;color:var(--muted)}
.vendor-card .more{display:inline-block;margin:.25rem 1rem 0}

/* Event article */
article.event{margin-bottom:clamp(14px,3vw,28px)}
article.event .hero-img{display:block;width:100%;max-width:100%;height:auto;border-radius:.8rem}

/* Pagination */
#pager{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}
#pager.hidden{display:none}
#pager a{padding:.4rem .7rem;border:1px solid #eaecef;border-radius:.5rem}
#pager a.active{background:var(--brand);border-color:var(--brand);color:#fff}

/* Map */
.map-embed{width:100%;border-radius:.8rem;overflow:hidden;border:1px solid #e5e7eb;box-shadow:0 8px 18px rgba(0,0,0,.06)}
.map-embed iframe{width:100%;height:min(60vh,520px);display:block;border:0}
@media (max-width:640px){ .map-embed iframe{height:42vh} }

/* Vendor layout */
.vendor-layout{display:grid;grid-template-columns:1fr 1.1fr;gap:1rem;align-items:start}
.vendor{overflow:hidden}
.vendor .vendor-visual img{display:block;width:100%;height:auto;border-radius:.6rem}
@media (max-width:900px){.vendor-layout{grid-template-columns:1fr}}

/* Breadcrumbs */
.crumbs-wrap{background:var(--panel-bg);border:1px solid #eaecef;border-radius:.8rem;box-shadow:0 8px 22px rgba(0,0,0,.05);padding:.6rem .9rem;margin:1rem auto}
.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem .75rem;line-height:1.4}
.breadcrumbs .sep{opacity:.55;margin:0 .15rem}

/* Footer */
.site-footer{border-top:1px solid #eef2f4;background:#fff;margin-top:clamp(14px,3vw,28px)}
.site-footer .wrap{max-width:var(--container);margin-inline:auto;padding:1rem var(--gutter);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem}
.foot-links a{margin-right:1rem}

/* Cookie */
.cookie-banner{position:fixed;z-index:60;left:50%;transform:translateX(-50%);bottom:18px;background:#fff;border:1px solid #e5e7eb;border-radius:.8rem;padding:.7rem 1rem;box-shadow:0 10px 24px rgba(0,0,0,.15);display:flex;gap:.75rem;align-items:center}
.cookie-banner .cookie-actions button{border:1px solid #e5e7eb;background:var(--brand);color:#fff;padding:.35rem .7rem;border-radius:.5rem;cursor:pointer}
.cookie-banner a{text-decoration:underline}

/* Buttons/Links */
a.btn,.dl-link{display:inline-block;padding:.5rem .9rem;border:1px solid var(--brand);border-radius:.55rem;font-weight:600;color:#fff;background:var(--brand)}
.dl-link.pdf .icon{vertical-align:-3px;margin-right:.5rem}
.dl-link.pdf .icon path{fill:#fff}

/* CTA all events */
.cta-all{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1rem;border:1.5px solid var(--brand);border-radius:.6rem;color:var(--brand);font-weight:700;background:#fff;transition:all .25s ease}
.cta-all::after{content:"›";font-weight:700;transform:translateY(1px)}
.cta-all:hover{background:var(--brand);color:#fff;transform:translateY(-1px)}

/* Slider – single image only */
.gallery-slider{position:relative;overflow:hidden}
.gallery-slider .slides{display:flex;gap:0;transition:transform .45s ease}
.gallery-slider .slide{min-width:100%;flex:0 0 100%;margin:0}
.gallery-slider img{display:block;width:100%;height:auto;max-width:100%;border-radius:.8rem}
.gallery-slider .nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(16,24,40,.85);color:#fff;border:0;border-radius:.5rem;width:38px;height:38px;display:grid;place-items:center;cursor:pointer}
.gallery-slider .nav.prev{left:.25rem}
.gallery-slider .nav.next{right:.25rem}
.gallery-slider .dots{display:flex;gap:.5rem;justify-content:center;margin-top:.6rem}
.gallery-slider .dots button{display:inline-block;width:10px;aspect-ratio:1;border-radius:50%;border:0;background:#e5e7eb;opacity:.9}
.gallery-slider .dots button.active{background:var(--brand);opacity:1}


/* --- v28.2 tweaks --- */
@media (max-width: 1160px){
  .hero.bleed > .panel{ margin-inline: var(--gutter); width: auto; }
}

.meta .sep { margin: 0 .5rem; opacity: .6; }
.termin-line { font-size: 1.05rem; margin: .25rem 0 1rem; }
.termin-line .sep { margin: 0 .5rem; opacity: .6; }
.addr { font-style: normal; line-height: 1.5; margin: .5rem 0 1rem; }
.map-actions { margin-top: .5rem; font-size: .95rem; opacity: .9; }
.map-actions a { text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 1px; }
.map-actions a + a { margin-left: .75rem; }