:root{
  --bg:#f7f8f7;
  --surface:#ffffff;
  --surface-2:#f0f4f1;
  --text:#111418;
  --muted:#5d6672;
  --line:#d9e0db;
  --line-strong:#c7d0c9;
  --accent:#18a34a;
  --accent-2:#0d7d33;
  --accent-soft:rgba(24,163,74,.08);
  --shadow:0 16px 44px rgba(18, 24, 23, .08);
  --shadow-soft:0 8px 24px rgba(18, 24, 23, .05);
  --radius:24px;
  --radius-lg:32px;
  --radius-sm:14px;
  --container:min(1200px, calc(100vw - 40px));
  --transition:220ms ease;
}
html[data-theme="dark"]{
  --bg:#0f1115;
  --surface:#151921;
  --surface-2:#1a2028;
  --text:#f5f7f6;
  --muted:#b4bfbb;
  --line:#273028;
  --line-strong:#354037;
  --accent:#2fd46f;
  --accent-2:#1fb85b;
  --accent-soft:rgba(47,212,111,.12);
  --shadow:0 16px 44px rgba(0,0,0,.34);
  --shadow-soft:0 8px 24px rgba(0,0,0,.22);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at top right, rgba(24,163,74,.08), transparent 28%),
    linear-gradient(180deg, rgba(24,163,74,.03), transparent 160px),
    var(--bg);
  color:var(--text);
  font:400 16px/1.6 Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit;color:inherit}
button{cursor:pointer}
::selection{background:var(--accent);color:#fff}
.skip-link{position:absolute;left:20px;top:-100px;background:var(--text);color:#fff;padding:10px 14px;border-radius:12px;z-index:99}
.skip-link:focus{top:20px}
.container{width:var(--container);margin-inline:auto}
.section{padding:72px 0}
.section.compact-top{padding-top:40px}
.soft-section{background:linear-gradient(180deg, transparent, var(--surface-2));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-head{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;max-width:760px}
.section-head h2,.content h2,.page-hero h1,.hero h1,.hero-showcase-card h2,.cta-inner h2,.calendar-toolbar h2,.calendar-toolbar h3,.panel h2,.card h3,.event-content h3,.event-detail-copy h2,.faq-list summary,.blog-item h3{line-height:1.15;margin:0}
.section-head p,.content p,.lead,.hero-showcase-card p,.panel p,.card p,.cta-inner p,.footer-mini,.blog-item p,.event-content p{margin:0;color:var(--muted)}
.eyebrow{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:7px 12px;border:1px solid var(--line);background:var(--surface);border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-2)}
.eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.hero,.page-hero{padding:48px 0 26px}
.hero-grid,.split,.contact-grid,.grid-2,.grid-3,.footer-grid,.metric-grid,.directory-grid{display:grid;gap:20px}
.hero-grid{grid-template-columns:minmax(0,1.1fr) minmax(330px,.9fr);align-items:stretch}
.hero-copy,.hero-showcase,.hero-card,.panel,.card,.article-box,.calendar-teaser-card,.event-card,.month-card,.faq-list details,.blog-item,.content,.form,.event-detail-copy,.contact-grid > *{
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
}
.hero-copy,.hero-showcase-card,.hero-card,.panel,.content,.event-detail-copy,.article-content{border-radius:var(--radius-lg)}
.hero-copy{padding:34px 34px 30px;position:relative;overflow:hidden}
.hero-copy::after{content:"";position:absolute;right:-80px;top:-70px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle, rgba(24,163,74,.16), transparent 65%);pointer-events:none}
.hero-home .hero-copy h1{font-size:clamp(2.3rem, 2rem + 1.6vw, 4.35rem);max-width:12ch;margin:16px 0 14px}
.page-hero h1{font-size:clamp(2rem, 1.8rem + 1vw, 3.25rem);margin-top:14px;margin-bottom:12px;max-width:13ch}
.page-hero .container,.hero .container{display:flex;flex-direction:column;gap:14px}
.page-hero .lead{max-width:780px}
.breadcrumb{display:flex;flex-wrap:wrap;gap:8px;color:var(--muted);font-size:14px}
.lead{font-size:1.08rem;max-width:64ch}
.hero-actions,.cta-actions,.event-actions,.nav-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.btn,.text-link,.footer-cookie-button,.view-switch button,.calendar-quick-links button,.gcal-controls button,.menu-toggle,.theme-toggle,.gcal-more{
  appearance:none;border:0;transition:var(--transition)
}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 18px;border-radius:16px;background:var(--text);color:#fff;font-weight:700;border:1px solid var(--text);box-shadow:var(--shadow-soft)}
.btn:hover{transform:translateY(-1px);background:#000}
.btn-outline{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-outline:hover{background:var(--surface-2);border-color:var(--accent);color:var(--accent-2)}
.btn-light{background:#fff;color:#111;border-color:#fff}
.btn-small{padding:11px 14px;border-radius:14px;font-size:14px}
.text-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent-2);font-weight:700}
.text-link::after{content:"→";font-size:14px}
.trust-row,.footer-badges,.service-links,.source-mini-list,.hero-kpis,.process-steps{display:flex;flex-wrap:wrap;gap:10px}
.trust-row span,.footer-badges li,.service-links a,.source-mini-list a,.hero-kpis .metric,.process-steps div,.event-meta span,.mini-filter-tags span{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line);font-size:13px}
.hero-kpis{margin:22px 0 18px}
.metric{min-width:140px;flex-direction:column;align-items:flex-start!important;border-radius:20px!important;background:var(--surface)!important;padding:16px 18px!important;box-shadow:var(--shadow-soft)}
.metric strong{font-size:1.6rem;line-height:1;color:var(--text)}
.metric span{margin-top:4px;padding:0!important;background:none!important;border:0!important;color:var(--muted);font-size:13px}
.hero-showcase{display:grid;gap:20px}
.hero-showcase-card,.hero-card,.panel,.content,.event-detail-copy{padding:28px}
.dark-card{background:linear-gradient(180deg, #121417, #0f1114);border-color:#181b1f;color:#fff;box-shadow:0 22px 60px rgba(0,0,0,.26)}
.dark-card .eyebrow{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:#d7ffe5}
.dark-card .eyebrow::before{background:#2fd46f;box-shadow:0 0 0 4px rgba(47,212,111,.14)}
.dark-card p,.dark-card span{color:rgba(255,255,255,.82)}
.mini-event{display:flex;flex-direction:column;gap:4px;padding:14px 0;border-top:1px solid rgba(255,255,255,.12)}
.mini-event:first-of-type{margin-top:12px}
.header-topline{border-bottom:1px solid var(--line);background:rgba(255,255,255,.55);backdrop-filter:blur(16px)}
html[data-theme="dark"] .header-topline{background:rgba(16,19,25,.66)}
.header-topline-inner{display:flex;justify-content:space-between;gap:18px;padding:10px 0;color:var(--muted);font-size:13px}
.site-header{position:sticky;top:0;z-index:30;background:rgba(247,248,247,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
html[data-theme="dark"] .site-header{background:rgba(15,17,21,.86)}
.nav-wrap{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand-copy{display:flex;flex-direction:column;gap:2px}
.brand strong{font-size:1rem;line-height:1.1}
.brand small{color:var(--muted);font-size:12px}
.brand-mark{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg, var(--text), #2d333c);color:#fff;font-weight:800;letter-spacing:.04em;box-shadow:0 10px 30px rgba(0,0,0,.12);position:relative;overflow:hidden}
.brand-mark::after{content:"";position:absolute;inset:auto -6px -12px auto;width:28px;height:28px;background:var(--accent);border-radius:50%;opacity:.9}
.site-nav{display:flex;justify-content:center;align-items:center;gap:6px;min-width:0}
.site-nav > a,.nav-parent{display:inline-flex;align-items:center;padding:12px 14px;border-radius:14px;color:var(--muted);font-weight:600}
.site-nav > a:hover,.nav-parent:hover,.site-nav a.active{color:var(--text);background:var(--surface-2)}
.nav-group{position:relative}
.nav-dropdown{position:absolute;left:0;top:calc(100% + 12px);min-width:320px;display:grid;gap:10px;padding:14px;border:1px solid var(--line);border-radius:22px;background:var(--surface);box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(10px);transition:var(--transition)}
.nav-dropdown a{display:grid;gap:2px;padding:12px 14px;border-radius:16px;background:var(--surface-2)}
.nav-dropdown a:hover{background:var(--accent-soft)}
.nav-dropdown a span{font-size:13px;color:var(--muted)}
.nav-group:hover .nav-dropdown,.nav-group:focus-within .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.nav-dropdown-compact{min-width:280px}
.nav-actions{justify-content:flex-end}
.theme-toggle,.menu-toggle{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--line);color:var(--text)}
.theme-toggle:hover,.menu-toggle:hover,.gcal-controls button:hover,.calendar-quick-links button:hover,.view-switch button:hover{border-color:var(--accent);background:var(--accent-soft)}
.menu-toggle{display:none}
.nav-cta{white-space:nowrap}
.card,.article-box,.calendar-teaser-card,.faq-list details,.blog-item,.form{padding:22px;border-radius:24px}
.card h3,.blog-item h3,.panel h2,.content h2,.calendar-toolbar h2,.calendar-toolbar h3{font-size:clamp(1.25rem, 1rem + .5vw, 1.8rem)}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.service-grid-modern .card,.region-grid-modern .card{height:100%}
.tag{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:8px 12px;border-radius:999px;background:var(--accent-soft);border:1px solid rgba(24,163,74,.16);color:var(--accent-2);font-size:12px;font-weight:700}
.service-card p,.region-card-modern p{margin:12px 0 18px}
.directory-grid{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:22px}
.article-box{display:grid;gap:8px}
.event-type-box strong{font-size:1.02rem}
.check-list{padding:0;margin:18px 0 0;list-style:none;display:grid;gap:12px}
.check-list li{position:relative;padding-left:28px;color:var(--text)}
.check-list li::before{content:"";position:absolute;left:0;top:.45em;width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.compact-list{gap:10px}
.compact-list li{font-size:15px}
.process-panel{position:relative;overflow:hidden}
.process-panel::after{content:"";position:absolute;right:-50px;bottom:-60px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle, rgba(24,163,74,.14), transparent 70%)}
.process-steps{margin-top:22px;display:grid;gap:12px}
.process-steps div{justify-content:flex-start;padding:16px 18px!important;border-radius:18px!important;background:var(--surface)!important}
.process-steps strong{font-size:1rem;color:var(--accent-2)}
.calendar-teaser-grid{display:grid;gap:16px}
.calendar-teaser-card h3{margin:12px 0 10px;font-size:1.1rem}
.teaser-date{display:inline-flex;align-items:flex-end;gap:8px;font-size:1.6rem;font-weight:800;line-height:1}
.teaser-date small{font-size:.82rem;color:var(--muted);font-weight:600}
.page-directory .card,.directory-grid .article-box{height:100%}
.panel.sticky-panel{position:sticky;top:130px}
.content{display:grid;gap:16px}
.contact-grid{grid-template-columns:360px minmax(0,1fr);align-items:start}
.form{display:grid;gap:16px}
.field{display:grid;gap:8px}
.field label{font-weight:700;font-size:14px}
.field input,.field textarea,.field select,.calendar-filters input,.calendar-filters select{width:100%;border:1px solid var(--line);background:var(--surface);color:var(--text);padding:14px 15px;border-radius:16px;outline:none;transition:var(--transition)}
.field input:focus,.field textarea:focus,.field select:focus,.calendar-filters input:focus,.calendar-filters select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.field textarea{min-height:180px;resize:vertical}
.consent-line{display:flex;gap:10px;align-items:flex-start}
.fine{font-size:14px;color:var(--muted)}
.faq-list{display:grid;gap:14px}
.faq-list details{padding:0;overflow:hidden}
.faq-list summary{padding:20px 22px;cursor:pointer;list-style:none;font-weight:700}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list p{padding:0 22px 22px;margin:0;color:var(--muted)}
.blog-list{display:grid;gap:16px}
.blog-item{display:grid;grid-template-columns:1fr auto;align-items:start;gap:20px}
.blog-item time{color:var(--muted);font-size:14px;white-space:nowrap}
.blog-item:hover,.card:hover,.calendar-teaser-card:hover,.article-box:hover,.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.article-content{display:grid;gap:16px;padding:30px 32px}
.article-content p,.article-content li{color:var(--text)}
.article-content h2{margin-top:10px}
.article-box strong{font-size:1rem}
.local-strip{display:grid;gap:16px}
.calendar-app{display:grid;gap:18px}
.calendar-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:20px;align-items:end;padding:28px;border-radius:32px;background:linear-gradient(180deg, var(--surface), color-mix(in srgb, var(--surface) 55%, var(--accent-soft)));border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.calendar-toolbar-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:flex-end}
.calendar-count{display:flex;flex-direction:column;align-items:flex-end;padding:12px 16px;border-radius:18px;background:var(--surface);border:1px solid var(--line)}
.calendar-count strong{font-size:1.65rem;line-height:1}
.calendar-count span{font-size:13px;color:var(--muted)}
.view-switch{display:flex;gap:8px;padding:6px;border-radius:16px;background:var(--surface);border:1px solid var(--line)}
.view-switch button{padding:11px 14px;border-radius:12px;background:transparent;color:var(--muted);font-weight:700}
.view-switch button.active{background:var(--text);color:#fff}
.calendar-quick-links{display:flex;flex-wrap:wrap;gap:10px}
.calendar-quick-links button{padding:11px 14px;border-radius:14px;background:var(--surface);border:1px solid var(--line);font-weight:600;color:var(--muted)}
.calendar-filters{display:grid;grid-template-columns:2fr repeat(4, minmax(0,1fr));gap:14px;padding:18px;border-radius:26px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.calendar-filters label{display:grid;gap:8px;font-weight:700;font-size:13px;color:var(--muted)}
.gcal-shell{display:grid;gap:16px;padding:20px;border-radius:30px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-soft);overflow:hidden}
.gcal-topbar{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:8px 6px 0}
.gcal-title-group{display:grid;gap:8px}
.gcal-controls{display:flex;gap:10px}
.gcal-controls button{padding:11px 14px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line)}
.gcal-month{display:grid;gap:14px}
.gcal-weekdays,.gcal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
.gcal-weekdays span{padding:12px 10px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);font-size:13px;font-weight:700;text-align:center;color:var(--muted)}
.gcal-day{min-height:150px;padding:12px;border-radius:20px;border:1px solid var(--line);background:linear-gradient(180deg, var(--surface), var(--surface-2));position:relative;display:flex;flex-direction:column;gap:10px;overflow:hidden}
.gcal-day.is-empty{background:transparent;border-style:dashed;min-height:96px;opacity:.55}
.gcal-day.is-today{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent), 0 12px 30px rgba(24,163,74,.08)}
.gcal-day.filtered-empty{opacity:.45}
.gcal-day-head{display:flex;justify-content:space-between;align-items:center;gap:10px;position:relative;z-index:2}
.gcal-day-head strong{font-size:1rem}
.gcal-day-head span{padding:5px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent-2);font-size:12px;font-weight:700}
.gcal-day-open{position:absolute;inset:0;z-index:1;background:none;border:0}
.gcal-events{position:relative;z-index:2;display:grid;gap:8px}
.gcal-pill{position:relative;display:flex;flex-direction:column;gap:2px;padding:9px 10px 9px 12px;border-radius:14px;background:var(--text);color:#fff;font-size:12px;line-height:1.35;border-left:4px solid var(--accent);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.gcal-pill span{font-weight:700;color:#a6ffca}
.gcal-pill em{font-style:normal;color:rgba(255,255,255,.72)}
.gcal-more{position:relative;z-index:2;justify-self:start;padding:8px 10px;border-radius:12px;background:var(--surface);border:1px solid var(--line);font-weight:700;color:var(--muted)}
.event-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.event-card{position:relative;display:grid;grid-template-columns:88px minmax(0,1fr);gap:18px;padding:20px;border-radius:28px;overflow:hidden}
.event-card-link{position:absolute;inset:0;z-index:1}
.event-card > *:not(.event-card-link){position:relative;z-index:2}
.event-card.is-featured{border-color:rgba(24,163,74,.35);box-shadow:0 16px 40px rgba(24,163,74,.08)}
.event-date{display:flex;flex-direction:column;justify-content:flex-start;gap:4px;padding:16px 10px;border-radius:20px;background:var(--surface-2);border:1px solid var(--line);text-align:center}
.event-date strong{font-size:1.55rem;line-height:1;font-weight:800}
.event-date span{font-size:13px;color:var(--muted)}
.event-content{display:grid;gap:12px}
.event-meta{display:flex;flex-wrap:wrap;gap:8px}
.event-meta span{font-weight:700;color:var(--muted)}
.event-info{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:14px}
.event-actions{position:relative;z-index:2}
.event-actions a{font-weight:700;color:var(--accent-2)}
.empty-state{padding:26px;border-radius:26px;background:var(--surface);border:1px dashed var(--line-strong);text-align:center;color:var(--muted)}
.day-dialog[hidden]{display:none!important}
.day-dialog{position:fixed;inset:0;z-index:60}
.day-dialog-backdrop{position:absolute;inset:0;background:rgba(10,12,16,.5);backdrop-filter:blur(6px)}
.day-dialog-panel{position:absolute;right:16px;top:16px;bottom:16px;width:min(520px, calc(100vw - 32px));background:var(--surface);border:1px solid var(--line);border-radius:30px;box-shadow:var(--shadow);padding:24px;display:grid;gap:12px;overflow:auto}
.day-dialog-close{position:absolute;right:14px;top:14px;width:42px;height:42px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);font-size:24px;line-height:1}
.day-dialog-events{display:grid;gap:12px}
.day-dialog-event{display:grid;gap:4px;padding:16px;border-radius:18px;background:var(--surface-2);border:1px solid var(--line)}
.day-dialog-event span,.day-dialog-event small,.day-dialog-event em{color:var(--muted)}
.day-dialog-event em{font-style:normal;font-weight:700;color:var(--accent-2);margin-top:4px}
.event-detail-hero .hero-grid{align-items:start}
.event-facts dl{display:grid;gap:14px;margin:12px 0 0}
.event-facts dt{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:4px}
.event-facts dd{margin:0;font-weight:700}
.footer-grid{grid-template-columns:1.3fr repeat(4, minmax(0,1fr));align-items:start;padding:0 0 26px}
.site-footer{padding:32px 0 24px;background:linear-gradient(180deg, transparent, color-mix(in srgb, var(--surface) 80%, var(--surface-2)));border-top:1px solid var(--line)}
.site-footer h3{margin:0 0 14px;font-size:15px}
.site-footer a{display:block;padding:6px 0;color:var(--muted)}
.site-footer a:hover{color:var(--text)}
.footer-badges{padding:0;margin:18px 0 0;list-style:none}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;padding-top:20px;border-top:1px solid var(--line);font-size:14px;color:var(--muted)}
.footer-cookie-button{padding:0;margin-top:8px;background:none;color:var(--accent-2);font-weight:700;text-align:left}
.cta-band{padding:28px 0 18px}
.cta-inner{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:20px;padding:30px 32px;border-radius:32px;background:linear-gradient(135deg, var(--text), #1d242c);color:#fff;box-shadow:0 24px 60px rgba(0,0,0,.16)}
.cta-inner p{color:rgba(255,255,255,.78)}
.cta-inner .eyebrow{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#d6ffe4}
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:80;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;padding:18px 20px;border-radius:24px;background:rgba(17,20,24,.96);color:#fff;box-shadow:0 24px 60px rgba(0,0,0,.28)}
.cookie-banner p{margin:6px 0 0;color:rgba(255,255,255,.74)}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.cookie-actions .btn-outline{color:#fff;border-color:rgba(255,255,255,.24)}
.cookie-actions .btn-outline:hover{background:rgba(255,255,255,.1)}
html.has-day-dialog,html.has-day-dialog body{overflow:hidden}
@media (max-width: 1100px){
  .calendar-filters{grid-template-columns:repeat(2,minmax(0,1fr))}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))}
  .footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width: 960px){
  .header-topline{display:none}
  .nav-wrap{grid-template-columns:auto auto auto;gap:12px}
  .site-nav{position:absolute;left:20px;right:20px;top:calc(100% + 10px);display:none;flex-direction:column;align-items:stretch;padding:16px;border-radius:24px;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow)}
  .site-nav.open{display:flex}
  .site-nav > a,.nav-parent{width:100%;justify-content:space-between;padding:14px 16px;background:var(--surface-2)}
  .nav-group{width:100%}
  .nav-dropdown{position:static;opacity:1;visibility:visible;transform:none;display:grid;min-width:0;box-shadow:none;background:transparent;border:0;padding:8px 0 0}
  .nav-actions{justify-content:flex-end}
  .menu-toggle{display:inline-flex}
  .nav-cta{display:none}
  .hero-grid,.split,.cta-inner{grid-template-columns:1fr}
  .panel.sticky-panel{position:static}
  .hero-home .hero-copy h1{max-width:none}
  .event-grid{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .container{width:min(100vw - 28px, 1200px)}
  .section{padding:54px 0}
  .hero,.page-hero{padding:32px 0 16px}
  .hero-copy,.hero-showcase-card,.hero-card,.panel,.content,.event-detail-copy,.article-content,.calendar-toolbar,.gcal-shell,.calendar-filters,.card,.blog-item,.faq-list details,.event-card{padding:20px}
  .grid-2,.grid-3,.directory-grid,.gcal-weekdays,.gcal-grid,.footer-grid{grid-template-columns:1fr}
  .gcal-weekdays{display:none}
  .gcal-grid{gap:12px}
  .gcal-day{min-height:unset}
  .gcal-day.is-empty{display:none}
  .calendar-toolbar{grid-template-columns:1fr}
  .calendar-toolbar-actions,.calendar-count{justify-content:flex-start;align-items:flex-start}
  .calendar-filters{grid-template-columns:1fr}
  .view-switch{width:100%}
  .view-switch button{flex:1}
  .cookie-banner{left:14px;right:14px;bottom:14px;grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
  .event-card{grid-template-columns:1fr}
  .event-date{flex-direction:row;align-items:center;justify-content:space-between}
  .day-dialog-panel{left:14px;right:14px;top:auto;bottom:14px;width:auto;height:min(80vh, 760px)}
}


/* v26 cookie + public polish fixes */
.cookie-banner[hidden],
[hidden] {
  display: none !important;
}
.cookie-banner {
  z-index: 9999;
  pointer-events: auto;
}
.cookie-banner * {
  pointer-events: auto;
}
.cookie-close {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.08);
  color: #fff;
  font-size: 24px;
  line-height: 1;
  display: grid;
  place-items: center;
}
.cookie-close:hover {
  background: rgba(255,255,255,.16);
}
.cookie-banner {
  padding-right: 64px;
}
@media (max-width: 720px) {
  .cookie-banner {
    padding: 18px;
    padding-top: 54px;
  }
}


/* v27 compact usability + nearby filter */
.section { padding: 56px 0; }
.section.compact-top { padding-top: 30px; }
.hero, .page-hero { padding: 36px 0 18px; }
.hero-copy, .hero-showcase-card, .hero-card, .panel, .content, .event-detail-copy, .article-content { padding: 24px; }
.card, .article-box, .calendar-teaser-card, .faq-list details, .blog-item, .form { padding: 20px; }
.hero-home .hero-copy h1 { font-size: clamp(2.05rem, 1.75rem + 1.35vw, 3.55rem); max-width: 13.5ch; }
.page-hero h1 { font-size: clamp(1.85rem, 1.55rem + 1vw, 2.85rem); max-width: 14.5ch; }
.lead { font-size: 1.02rem; }
.nav-wrap { padding: 11px 0; }
.brand-mark { width: 42px; height: 42px; border-radius: 14px; }
.site-nav > a, .nav-parent { padding: 10px 12px; }
.btn { padding: 12px 16px; border-radius: 14px; }
.btn-small { padding: 10px 12px; }
.calendar-toolbar { padding: 22px; border-radius: 26px; }
.calendar-filters { padding: 14px; border-radius: 22px; gap: 12px; }
.gcal-shell { padding: 16px; border-radius: 26px; }
.gcal-day { min-height: 132px; padding: 10px; border-radius: 17px; }
.gcal-weekdays span { padding: 9px; }
.gcal-weekdays, .gcal-grid { gap: 8px; }
.event-card { padding: 18px; border-radius: 24px; }
.event-date { padding: 14px 9px; border-radius: 17px; }
.footer-grid { gap: 18px; }
.site-footer { padding-top: 26px; }
.cta-inner { padding: 24px; border-radius: 26px; }
.nearby-status {
  padding: 13px 16px;
  border-radius: 18px;
  border: 1px solid rgba(24,163,74,.24);
  background: var(--accent-soft);
  color: var(--accent-2);
  font-weight: 700;
}
.nearby-status.is-error {
  border-color: rgba(170,40,40,.25);
  background: rgba(170,40,40,.08);
  color: #b3261e;
}
.calendar-quick-links button[data-nearby-filter] {
  background: var(--text);
  color: #fff;
  border-color: var(--text);
}
.blog-list .blog-item {
  position: relative;
}
.blog-list .blog-item::after {
  content: "Artikel öffnen →";
  color: var(--accent-2);
  font-weight: 800;
  align-self: end;
}
@media (max-width: 720px) {
  .section { padding: 42px 0; }
  .hero, .page-hero { padding: 26px 0 12px; }
  .hero-copy, .hero-showcase-card, .hero-card, .panel, .content, .event-detail-copy, .article-content, .calendar-toolbar, .gcal-shell, .calendar-filters, .card, .blog-item, .faq-list details, .event-card { padding: 18px; }
  .hero-home .hero-copy h1 { max-width: none; }
  .calendar-quick-links { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .calendar-quick-links button { white-space: nowrap; }
}


/* v28 enhanced service pages */
.service-hero .container {
  max-width: 980px;
}
.service-hero h1 {
  max-width: 15ch;
}
.service-longform {
  gap: 18px;
}
.service-longform p {
  font-size: 1.02rem;
}
.service-highlight-box {
  display: grid;
  gap: 8px;
  padding: 20px 22px;
  border-radius: 22px;
  border: 1px solid rgba(24,163,74,.22);
  background:
    linear-gradient(135deg, var(--accent-soft), transparent 75%),
    var(--surface);
  box-shadow: var(--shadow-soft);
}
.service-highlight-box strong {
  color: var(--accent-2);
  font-size: .96rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.service-highlight-box span {
  color: var(--text);
  font-weight: 650;
}
.takeover-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 12px;
  margin: 4px 0 8px;
}
.takeover-grid div {
  position: relative;
  min-height: 76px;
  padding: 16px 16px 16px 46px;
  border-radius: 18px;
  background: var(--surface-2);
  border: 1px solid var(--line);
}
.takeover-grid div::before {
  content: "";
  position: absolute;
  left: 16px;
  top: 19px;
  width: 15px;
  height: 15px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 5px var(--accent-soft);
}
.takeover-grid strong {
  display: block;
  line-height: 1.35;
}
.service-side-panel {
  display: grid;
  gap: 16px;
}
.mini-question-list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.mini-question-list li {
  padding: 12px 13px;
  border-radius: 15px;
  background: var(--surface-2);
  border: 1px solid var(--line);
  color: var(--muted);
  font-weight: 650;
}
.compact-service-card {
  display: grid;
  gap: 10px;
  min-height: 100%;
}
.compact-service-card p {
  margin: 0;
}
@media (max-width: 720px) {
  .takeover-grid {
    grid-template-columns: 1fr;
  }
  .service-hero h1 {
    max-width: none;
  }
}


/* v29 detail pages, CTA band, footer and legal polish */
.event-detail-hero-v29 {
  padding-bottom: 18px;
}
.event-detail-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, .65fr);
  gap: 22px;
  align-items: stretch;
}
.event-detail-main,
.event-facts-card,
.event-copy-card,
.event-side-panel {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--shadow-soft);
}
.event-detail-main {
  padding: 26px;
  display: grid;
  gap: 14px;
}
.event-detail-main h1 {
  margin: 0;
  max-width: 14ch;
  line-height: 1.08;
  font-size: clamp(2rem, 1.5rem + 1.8vw, 3.5rem);
}
.event-detail-main .lead {
  max-width: 72ch;
}
.event-facts-card {
  padding: 22px;
  align-self: start;
  position: sticky;
  top: 112px;
}
.event-fact-list {
  display: grid;
  gap: 10px;
  margin: 16px 0 0;
}
.event-fact-list div {
  padding: 13px 14px;
  border-radius: 16px;
  background: var(--surface-2);
  border: 1px solid var(--line);
}
.event-fact-list dt {
  margin: 0 0 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.event-fact-list dd {
  margin: 0;
  font-weight: 750;
  line-height: 1.35;
}
.event-detail-section {
  padding-top: 24px;
}
.event-detail-split {
  grid-template-columns: minmax(0, 1fr) 340px;
  align-items: start;
}
.event-copy-card {
  padding: 28px;
  display: grid;
  gap: 16px;
}
.event-copy-card h2 {
  margin-top: 6px;
  margin-bottom: 0;
}
.event-copy-card p {
  margin: 0;
  max-width: 74ch;
}
.event-side-stack {
  display: grid;
  gap: 16px;
}
.event-side-panel {
  padding: 22px;
  display: grid;
  gap: 12px;
}
.event-side-panel h2,
.event-side-panel p {
  margin: 0;
}
.cta-band {
  padding: 24px 0 18px;
}
.cta-inner {
  background:
    radial-gradient(circle at top right, rgba(24,163,74,.12), transparent 34%),
    linear-gradient(135deg, var(--surface), var(--surface-2));
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
}
.cta-inner p {
  color: var(--muted);
}
.cta-inner .eyebrow {
  background: var(--surface);
  border-color: var(--line);
  color: var(--accent-2);
}
.cta-inner .btn-outline {
  background: var(--surface);
}
.footer-grid-enhanced {
  grid-template-columns: 1.35fr 1fr 1.1fr .85fr .85fr;
}
.footer-contact a {
  color: var(--accent-2);
  font-weight: 800;
}
.footer-address,
.footer-badges {
  display: none !important;
}
.legal-content h2 {
  margin-top: 22px;
}
.legal-content h3 {
  margin: 16px 0 0;
}
.legal-content p,
.legal-content li {
  max-width: 82ch;
}
@media (max-width: 1000px) {
  .event-detail-layout,
  .event-detail-split {
    grid-template-columns: 1fr;
  }
  .event-facts-card {
    position: static;
  }
  .footer-grid-enhanced {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}
@media (max-width: 720px) {
  .event-detail-main,
  .event-facts-card,
  .event-copy-card,
  .event-side-panel {
    padding: 18px;
    border-radius: 22px;
  }
  .event-detail-main h1 {
    max-width: none;
  }
  .footer-grid-enhanced {
    grid-template-columns: 1fr;
  }
}


/* v29 final spacing and button consistency */
.cta-inner .btn {
  background: var(--text);
  color: #fff;
}
.cta-inner .btn-outline {
  background: var(--surface);
  color: var(--text);
}
.event-actions a[href*="http"],
.event-side-panel .btn {
  position: relative;
  z-index: 3;
}
.site-footer .brand small {
  color: var(--muted);
}


/* v30 corporate polish */
.cookie-banner-v30 {
  left: 50%;
  right: auto;
  bottom: 18px;
  width: min(720px, calc(100vw - 28px));
  transform: translateX(-50%);
  grid-template-columns: minmax(0,1fr) auto;
  gap: 14px;
  padding: 16px 58px 16px 18px;
  border-radius: 22px;
  background: color-mix(in srgb, var(--surface) 94%, transparent);
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: 0 22px 60px rgba(0,0,0,.18);
  backdrop-filter: blur(18px);
}
.cookie-banner-v30 p {
  color: var(--muted);
  font-size: 14px;
  margin: 4px 0 0;
}
.cookie-banner-v30 strong {
  font-size: 15px;
}
.cookie-banner-v30 .cookie-actions {
  align-items: center;
}
.cookie-banner-v30 .cookie-actions .btn {
  padding: 10px 13px;
  border-radius: 13px;
}
.cookie-banner-v30 .cookie-actions .btn-outline {
  color: var(--text);
  border-color: var(--line-strong);
}
.cookie-banner-v30 .cookie-close {
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--line);
}
html[data-theme="dark"] .btn,
html[data-theme="dark"] .nav-cta,
html[data-theme="dark"] .cta-inner .btn,
html[data-theme="dark"] .event-side-panel .btn,
html[data-theme="dark"] .panel .btn {
  background: #f5f7f6;
  color: #0f1115;
  border-color: #f5f7f6;
}
html[data-theme="dark"] .btn-outline,
html[data-theme="dark"] .cta-inner .btn-outline,
html[data-theme="dark"] .event-side-panel .btn-outline,
html[data-theme="dark"] .panel .btn-outline {
  background: transparent;
  color: #f5f7f6;
  border-color: var(--line-strong);
}
html[data-theme="dark"] .view-switch button.active {
  background: #f5f7f6;
  color: #0f1115;
}
.event-type-side {
  gap: 18px;
}
.event-type-side h2,
.event-type-side p {
  margin: 0;
}
.event-type-side .mini-question-list {
  margin: 2px 0;
}
.event-type-content {
  gap: 18px;
}
.about-story {
  gap: 18px;
}
.about-profile-card {
  gap: 16px;
}
.about-profile-card h2,
.about-profile-card p {
  margin: 0;
}
@media (max-width: 960px) {
  .site-nav .nav-dropdown {
    display: none !important;
  }
  .site-nav .nav-group {
    display: block;
  }
  .site-nav .nav-parent::after {
    content: none;
  }
}
@media (max-width: 720px) {
  .cookie-banner-v30 {
    grid-template-columns: 1fr;
    padding: 52px 16px 16px;
    border-radius: 20px;
  }
  .cookie-banner-v30 .cookie-actions {
    justify-content: stretch;
  }
  .cookie-banner-v30 .cookie-actions .btn {
    flex: 1;
  }
}
