: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;
  }
}


/* v31 logo, spacing, calendar and darkmode refinements */
.brand-logo {
  min-width: 0;
}
.brand-logo-img {
  width: 172px;
  height: auto;
  max-height: 58px;
  object-fit: contain;
}
.footer-logo-img {
  width: 165px;
  height: auto;
  max-height: 74px;
  object-fit: contain;
}
.brand-logo .brand-mark,
.footer-logo .brand-mark {
  display: none;
}
.header-topline {
  display: none;
}
.nav-wrap {
  padding: 13px 0;
}
.site-header {
  box-shadow: 0 8px 30px rgba(0,0,0,.04);
}
.panel,
.content,
.hero-showcase-card,
.hero-card,
.card,
.event-type-side,
.service-side-panel {
  gap: 18px;
}
.panel > *,
.content > *,
.hero-showcase-card > *,
.hero-card > *,
.event-type-side > *,
.service-side-panel > * {
  margin-top: 0;
  margin-bottom: 0;
}
.panel .btn,
.service-side-panel .btn,
.event-type-side .btn {
  margin-top: 4px;
}
.mini-question-list {
  gap: 12px;
}
.service-highlight-box {
  margin: 4px 0 6px;
}
.event-submit-info {
  gap: 18px;
}
.calendar-toolbar {
  grid-template-columns: 1fr;
  gap: 16px;
}
.calendar-toolbar-actions {
  justify-content: flex-start;
}
.calendar-quick-links {
  gap: 12px;
  padding: 2px 2px 6px;
}
.calendar-quick-links button {
  padding: 10px 14px;
}
.calendar-filters {
  grid-template-columns: 1.5fr repeat(3, minmax(0, 1fr));
}
.calendar-filters label:nth-child(5) {
  grid-column: auto;
}
.gcal-shell {
  padding: 14px;
}
.gcal-day {
  min-height: 118px;
}
.gcal-pill {
  padding: 7px 8px 7px 10px;
  font-size: 11px;
  border-radius: 11px;
  background: #0f1720;
  color: #fff;
}
html[data-theme="dark"] .gcal-pill {
  background: #eaf8ef;
  color: #07120d;
}
html[data-theme="dark"] .gcal-pill span {
  color: #087a32;
}
html[data-theme="dark"] .gcal-pill em {
  color: rgba(7,18,13,.72);
}
html[data-theme="dark"] .event-card,
html[data-theme="dark"] .event-content,
html[data-theme="dark"] .calendar-filters,
html[data-theme="dark"] .gcal-shell,
html[data-theme="dark"] .gcal-day,
html[data-theme="dark"] .month-card {
  color: var(--text);
}
html[data-theme="dark"] .event-meta span,
html[data-theme="dark"] .event-info,
html[data-theme="dark"] .event-content p,
html[data-theme="dark"] .calendar-filters label {
  color: var(--muted);
}
html[data-theme="dark"] .field input,
html[data-theme="dark"] .field textarea,
html[data-theme="dark"] .field select,
html[data-theme="dark"] .calendar-filters input,
html[data-theme="dark"] .calendar-filters select {
  background: #10151c;
  color: #f5f7f6;
  border-color: #303a34;
}
html[data-theme="dark"] .calendar-quick-links button {
  color: #f5f7f6;
}
html[data-theme="dark"] .nearby-status {
  color: #b8ffd0;
}
.event-detail-main,
.event-facts-card,
.event-copy-card,
.event-side-panel {
  gap: 18px;
}
.event-copy-card p + h2 {
  margin-top: 12px;
}
.event-fact-list {
  gap: 12px;
}
.footer-grid-enhanced {
  gap: 24px;
}
.faq-list + .panel,
.panel + .faq-list {
  margin-top: 0;
}
@media (max-width: 1100px) {
  .calendar-filters {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}
@media (max-width: 960px) {
  .brand-logo-img {
    width: 150px;
    max-height: 52px;
  }
  .site-nav.open {
    gap: 8px;
  }
  .site-nav .nav-dropdown {
    display: none !important;
  }
}
@media (max-width: 720px) {
  .brand-logo-img {
    width: 135px;
    max-height: 48px;
  }
  .calendar-toolbar,
  .calendar-filters,
  .gcal-shell {
    border-radius: 20px;
  }
  .calendar-filters {
    grid-template-columns: 1fr;
  }
  .gcal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, minmax(44px, 1fr));
    min-width: 720px;
  }
  .gcal-grid {
    display: grid;
    grid-template-columns: repeat(7, minmax(96px, 1fr));
    min-width: 720px;
  }
  .gcal-month {
    overflow-x: auto;
    padding-bottom: 6px;
  }
  .gcal-day {
    min-height: 120px;
  }
  .gcal-day.is-empty {
    display: block;
  }
  .calendar-quick-links {
    gap: 10px;
  }
  .calendar-quick-links button {
    padding: 10px 12px;
    font-size: 14px;
  }
  .event-grid {
    gap: 14px;
  }
}


/* v32 logo sizing, home hero spacing, non-sticky blog orientation */
.brand-logo {
  display: flex;
  align-items: center;
  min-width: 220px;
}
.brand-logo-img {
  width: 224px !important;
  height: auto !important;
  max-height: 82px !important;
  object-fit: contain;
  object-position: left center;
  display: block;
}
.nav-wrap {
  grid-template-columns: minmax(220px, auto) 1fr auto;
  min-height: 82px;
  padding: 10px 0;
}
.footer-logo-img {
  width: 210px !important;
  height: auto !important;
  max-height: 96px !important;
  object-fit: contain;
  object-position: left center;
}
.hero-home .hero-copy {
  display: grid;
  gap: 20px;
}
.hero-home .hero-copy h1 {
  margin: 6px 0 0;
}
.hero-home .hero-copy .lead {
  margin-top: 0;
}
.hero-home .hero-actions {
  margin-top: 6px;
  margin-bottom: 4px;
  gap: 14px;
}
.hero-home .trust-row {
  margin-top: 4px;
}
.blog-orientation-panel {
  position: static !important;
  top: auto !important;
}
.blog-list {
  align-self: start;
}
@media (max-width: 1100px) {
  .brand-logo {
    min-width: 190px;
  }
  .brand-logo-img {
    width: 195px !important;
    max-height: 72px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(190px, auto) auto auto;
  }
}
@media (max-width: 960px) {
  .brand-logo {
    min-width: 175px;
  }
  .brand-logo-img {
    width: 178px !important;
    max-height: 66px !important;
  }
  .nav-wrap {
    min-height: 76px;
  }
}
@media (max-width: 720px) {
  .brand-logo {
    min-width: 150px;
  }
  .brand-logo-img {
    width: 160px !important;
    max-height: 60px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(150px, 1fr) auto auto;
    min-height: 70px;
    gap: 8px;
  }
  .theme-toggle {
    display: none;
  }
  .hero-home .hero-copy {
    gap: 18px;
  }
  .hero-home .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 8px;
  }
  .hero-home .hero-actions .btn {
    width: 100%;
  }
}
@media (max-width: 420px) {
  .brand-logo-img {
    width: 142px !important;
    max-height: 54px !important;
  }
  .brand-logo {
    min-width: 136px;
  }
}


/* v33 logo, spacing, dark switch and mobile calendar usability */
.brand-logo {
  min-width: 270px;
}
.brand-logo-img {
  width: 268px !important;
  max-height: 98px !important;
}
.nav-wrap {
  grid-template-columns: minmax(270px, auto) 1fr auto;
  min-height: 96px;
}
.footer-logo-img {
  width: 230px !important;
  max-height: 108px !important;
}

/* Home hero spacing */
.hero-showcase-card {
  display: grid;
  gap: 18px;
}
.hero-showcase-card h2,
.hero-showcase-card p,
.hero-showcase-card .check-list {
  margin: 0;
}
.hero-showcase-card .check-list {
  margin-top: 4px;
  gap: 14px;
}
.hero-showcase-card .check-list li {
  line-height: 1.5;
}

/* Ablauf / process design */
.process-panel {
  padding: 30px !important;
}
.process-panel h2 {
  margin-bottom: 4px;
}
.process-steps {
  gap: 16px;
  margin-top: 24px;
}
.process-steps div {
  display: grid !important;
  grid-template-columns: 48px 1fr;
  align-items: start !important;
  gap: 14px;
  border-radius: 22px !important;
  padding: 18px !important;
}
.process-steps strong {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: var(--text);
  color: #fff !important;
  font-size: .95rem;
}
html[data-theme="dark"] .process-steps strong {
  background: #f5f7f6;
  color: #0f1115 !important;
}
.process-steps span {
  line-height: 1.45;
  padding-top: 2px;
}

/* Generic sidebar/card spacing fixes */
.sticky-panel,
.panel,
.service-side-panel,
.event-type-side,
.about-profile-card,
.blog-orientation-panel {
  display: grid;
  gap: 18px;
}
.sticky-panel h2,
.panel h2,
.service-side-panel h2,
.event-type-side h2,
.about-profile-card h2,
.blog-orientation-panel h2,
.sticky-panel p,
.panel p,
.service-side-panel p,
.event-type-side p,
.about-profile-card p,
.blog-orientation-panel p {
  margin: 0;
}
.sticky-panel .btn,
.panel .btn,
.service-side-panel .btn,
.event-type-side .btn,
.about-profile-card .btn,
.blog-orientation-panel .btn {
  margin-top: 6px;
}
.service-side-panel .mini-question-list,
.event-type-side .mini-question-list,
.about-profile-card .mini-question-list {
  margin: 4px 0;
}

/* FAQ orientation card spacing */
.faq-list details {
  margin: 0;
}
.faq-list {
  gap: 16px;
}

/* Keep mobile theme switcher visible */
@media (max-width: 1100px) {
  .brand-logo {
    min-width: 238px;
  }
  .brand-logo-img {
    width: 236px !important;
    max-height: 86px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(238px, auto) auto auto;
    min-height: 88px;
  }
}
@media (max-width: 960px) {
  .brand-logo {
    min-width: 210px;
  }
  .brand-logo-img {
    width: 208px !important;
    max-height: 78px !important;
  }
  .nav-wrap {
    min-height: 82px;
    grid-template-columns: minmax(210px, 1fr) auto auto;
  }
  .theme-toggle {
    display: inline-flex !important;
    width: 42px;
    height: 42px;
    padding: 0;
  }
}
@media (max-width: 720px) {
  .brand-logo {
    min-width: 178px;
  }
  .brand-logo-img {
    width: 176px !important;
    max-height: 66px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(178px, 1fr) 42px 58px;
    min-height: 76px;
    gap: 8px;
  }
  .theme-toggle {
    display: inline-flex !important;
    width: 42px;
    height: 42px;
    font-size: 16px;
  }
  .menu-toggle {
    min-width: 58px;
    padding: 10px 11px;
  }
  .process-panel {
    padding: 20px !important;
  }
  .process-steps div {
    grid-template-columns: 40px 1fr;
    gap: 12px;
    padding: 14px !important;
  }
  .process-steps strong {
    width: 36px;
    height: 36px;
    border-radius: 12px;
  }

  /* Mobile calendar: compact Google-like grid */
  .gcal-shell {
    padding: 12px;
  }
  .gcal-topbar {
    align-items: flex-start;
    gap: 12px;
  }
  .gcal-controls button {
    padding: 9px 11px;
    border-radius: 12px;
    font-size: 13px;
  }
  .gcal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, minmax(38px, 1fr));
    min-width: 560px;
    gap: 6px;
  }
  .gcal-weekdays span {
    padding: 7px 4px;
    font-size: 12px;
  }
  .gcal-grid {
    grid-template-columns: repeat(7, minmax(74px, 1fr));
    min-width: 560px;
    gap: 6px;
  }
  .gcal-day {
    min-height: 92px;
    padding: 7px;
    border-radius: 13px;
  }
  .gcal-day-head strong {
    font-size: 13px;
  }
  .gcal-day-head span {
    font-size: 10px;
    padding: 3px 5px;
  }
  .gcal-events {
    gap: 5px;
  }
  .gcal-pill {
    font-size: 10px;
    line-height: 1.25;
    padding: 5px 6px;
    border-radius: 9px;
    border-left-width: 3px;
  }
  .gcal-pill span {
    font-size: 9px;
  }
  .gcal-more {
    padding: 5px 7px;
    font-size: 11px;
    border-radius: 9px;
  }
  .calendar-toolbar {
    padding: 16px;
  }
  .calendar-filters {
    gap: 10px;
  }
}
@media (max-width: 430px) {
  .brand-logo {
    min-width: 154px;
  }
  .brand-logo-img {
    width: 154px !important;
    max-height: 58px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(154px, 1fr) 40px 54px;
  }
  .theme-toggle {
    width: 40px;
    height: 40px;
  }
  .menu-toggle {
    min-width: 54px;
    font-size: 13px;
  }
}


/* v34 mobile calendar, blog covers and contact polish */
.blog-list-rich {
  gap: 18px;
}
.blog-item-rich {
  grid-template-columns: 220px minmax(0,1fr) auto;
  align-items: stretch;
  padding: 16px;
}
.blog-item-rich img {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: var(--surface-2);
}
.blog-item-rich small {
  display: block;
  margin-top: 10px;
  color: var(--accent-2);
  font-weight: 750;
}
.blog-cover {
  width: 100%;
  aspect-ratio: 16 / 8.2;
  object-fit: cover;
  border-radius: 28px;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-soft);
  margin-bottom: 8px;
}
.blog-article-content {
  gap: 18px;
}
.blog-article-content h2 {
  margin-top: 14px;
}
.article-cta {
  margin-top: 10px;
}
.success-box {
  border-color: rgba(24,163,74,.28);
  background: var(--accent-soft);
}
.error-box {
  border-color: rgba(180,40,40,.3);
  background: rgba(180,40,40,.08);
}
.contact-info-panel {
  gap: 18px;
}

/* Truly fit full month on mobile: no horizontal scroll required */
@media (max-width: 720px) {
  .gcal-month {
    overflow: visible !important;
  }
  .gcal-weekdays,
  .gcal-grid {
    min-width: 0 !important;
    width: 100% !important;
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 3px !important;
  }
  .gcal-weekdays span {
    padding: 6px 1px !important;
    font-size: 10px !important;
    border-radius: 8px !important;
  }
  .gcal-day {
    min-height: 68px !important;
    padding: 4px !important;
    border-radius: 9px !important;
    gap: 4px !important;
  }
  .gcal-day-head strong {
    font-size: 11px !important;
  }
  .gcal-day-head span {
    display: none;
  }
  .gcal-events {
    gap: 3px !important;
  }
  .gcal-pill {
    display: block;
    max-width: 100%;
    padding: 3px 4px !important;
    font-size: 8.5px !important;
    line-height: 1.1 !important;
    border-left-width: 2px !important;
    border-radius: 6px !important;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .gcal-pill span,
  .gcal-pill em {
    display: none !important;
  }
  .gcal-more {
    padding: 2px 4px !important;
    font-size: 9px !important;
    border-radius: 6px !important;
  }
  .gcal-shell {
    padding: 9px !important;
    border-radius: 17px !important;
  }
  .gcal-topbar {
    gap: 8px;
  }
  .gcal-title-group h3 {
    font-size: 1.05rem;
  }
  .gcal-title-group p {
    font-size: 12px;
  }
  .gcal-controls {
    gap: 5px;
  }
  .gcal-controls button {
    padding: 7px 8px !important;
    font-size: 12px !important;
    border-radius: 9px !important;
  }
  .blog-item-rich {
    grid-template-columns: 1fr;
  }
  .blog-item-rich img {
    height: auto;
    aspect-ratio: 16 / 9;
  }
  .blog-item-rich time {
    justify-self: start;
  }
}
@media (max-width: 420px) {
  .gcal-day {
    min-height: 58px !important;
    padding: 3px !important;
  }
  .gcal-pill {
    font-size: 7.5px !important;
    padding: 2px 3px !important;
  }
  .gcal-weekdays span {
    font-size: 9px !important;
  }
}


/* v35 final calendar clicks, logo scale and service spacing */
.brand-logo {
  min-width: 288px;
}
.brand-logo-img {
  width: 286px !important;
  max-height: 104px !important;
}
.nav-wrap {
  grid-template-columns: minmax(288px, auto) 1fr auto;
  min-height: 102px;
}
.footer-logo-img {
  width: 244px !important;
  max-height: 112px !important;
}
.service-card {
  display: grid;
  gap: 14px;
}
.service-card .tag {
  margin-bottom: 4px;
}
.service-card h3,
.service-card p {
  margin: 0;
}
.service-card .text-link {
  margin-top: 4px;
}
.gcal-day.has-events,
.gcal-day.has-visible-events {
  cursor: pointer;
}
.gcal-day.has-events:hover,
.gcal-day.has-visible-events:hover {
  border-color: var(--accent);
  box-shadow: inset 0 0 0 1px var(--accent), var(--shadow-soft);
}
.gcal-day-open {
  cursor: pointer;
}
.event-card {
  transition: var(--transition);
}
.event-card:hover {
  border-color: var(--accent);
}
.event-card-link {
  cursor: pointer;
}
.event-actions a[href^="http"] {
  color: var(--accent-2);
}
@media (max-width: 1100px) {
  .brand-logo { min-width: 248px; }
  .brand-logo-img { width: 248px !important; max-height: 92px !important; }
  .nav-wrap { grid-template-columns: minmax(248px, auto) auto auto; min-height: 94px; }
}
@media (max-width: 960px) {
  .brand-logo { min-width: 220px; }
  .brand-logo-img { width: 220px !important; max-height: 82px !important; }
  .nav-wrap { grid-template-columns: minmax(220px, 1fr) auto auto; min-height: 88px; }
}
@media (max-width: 720px) {
  .brand-logo { min-width: 188px; }
  .brand-logo-img { width: 188px !important; max-height: 70px !important; }
  .nav-wrap { grid-template-columns: minmax(188px, 1fr) 42px 58px; min-height: 80px; }
}
@media (max-width: 430px) {
  .brand-logo { min-width: 162px; }
  .brand-logo-img { width: 162px !important; max-height: 62px !important; }
  .nav-wrap { grid-template-columns: minmax(162px, 1fr) 40px 54px; }
}


/* v36 calendar hero spacing + clearer clickable list cards */
.calendar-hero .hero-grid > div:first-child {
  display: grid;
  gap: 20px;
  align-content: start;
}
.calendar-hero h1,
.calendar-hero .lead,
.calendar-hero .hero-actions,
.calendar-hero .trust-row {
  margin: 0;
}
.calendar-hero .lead {
  max-width: 760px;
}
.calendar-hero .hero-actions {
  margin-top: 8px;
  gap: 14px;
}
.calendar-hero .trust-row {
  margin-top: 4px;
  gap: 12px;
}
.calendar-hero .trust-row span {
  padding: 10px 14px;
}
.event-card {
  cursor: pointer;
}
.event-card-link {
  z-index: 1;
}
.event-card .event-content,
.event-card .event-date {
  pointer-events: none;
}
.event-card .event-actions {
  pointer-events: auto;
  z-index: 3;
}
.event-card .event-actions a {
  position: relative;
  z-index: 4;
}
.event-card::after {
  content: "Details öffnen";
  position: absolute;
  right: 18px;
  top: 18px;
  z-index: 2;
  padding: 7px 10px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-2);
  border: 1px solid rgba(24,163,74,.22);
  font-size: 12px;
  font-weight: 800;
  opacity: 0;
  transform: translateY(-3px);
  transition: var(--transition);
}
.event-card:hover::after {
  opacity: 1;
  transform: translateY(0);
}
.event-card:hover {
  transform: translateY(-2px);
}
@media (max-width: 720px) {
  .calendar-hero .hero-grid > div:first-child {
    gap: 18px;
  }
  .calendar-hero .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 4px;
  }
  .calendar-hero .hero-actions .btn {
    width: 100%;
  }
  .calendar-hero .trust-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 10px;
  }
  .calendar-hero .trust-row span {
    width: 100%;
  }
  .event-card::after {
    display: none;
  }
}


/* v37 blog depth and calendar without nearby */
.blog-article-content h2 {
  margin-top: 22px;
}
.blog-article-content p {
  font-size: 1.02rem;
  line-height: 1.72;
}
.calendar-quick-links [data-nearby-filter],
.nearby-status {
  display: none !important;
}


/* v38 blog images, SEO polish, admin cards */
.blog-item-rich img,
.blog-cover {
  background: linear-gradient(135deg,#0b1016,#142133);
}
.admin-topbar nav {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.admin-card .form,
.admin-card form {
  display: grid;
  gap: 16px;
}
.admin-card label {
  display: grid;
  gap: 8px;
}
.admin-note {
  margin: 12px 0 18px;
}


/* v39 admin audit/settings polish */
.admin-top nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.admin-card code {
  white-space: pre-wrap;
  word-break: break-word;
}
.admin-form .wide {
  grid-column: 1 / -1;
}
.admin-table-wrap {
  overflow-x: auto;
}


/* v40 real blog images + German selectable cookie consent */
.blog-item-rich img,
.blog-cover {
  background: var(--surface-2);
}
.blog-cover {
  object-position: center center;
}
.cookie-banner-v40 {
  left: 50%;
  right: auto;
  bottom: 18px;
  width: min(920px, calc(100vw - 28px));
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .82fr);
  gap: 16px 18px;
  padding: 18px 58px 18px 18px;
  border-radius: 24px;
  background: color-mix(in srgb, var(--surface) 96%, transparent);
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: 0 24px 70px rgba(0,0,0,.20);
  backdrop-filter: blur(20px);
  z-index: 1200;
}
.cookie-banner-v40[hidden] { display: none !important; }
.cookie-banner-v40 .cookie-copy { display: grid; gap: 6px; align-content: start; }
.cookie-banner-v40 .cookie-badge {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-2);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.cookie-banner-v40 strong { font-size: 16px; }
.cookie-banner-v40 p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.5; }
.cookie-banner-v40 .cookie-options {
  display: grid;
  gap: 8px;
  grid-column: 2;
  grid-row: 1 / span 2;
}
.cookie-option {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--surface-2);
}
.cookie-option input { margin-top: 3px; accent-color: var(--accent); }
.cookie-option span { display: grid; gap: 3px; }
.cookie-option strong { font-size: 14px; }
.cookie-option small { color: var(--muted); line-height: 1.35; }
.cookie-option.is-required { border-color: rgba(24,163,74,.25); background: var(--accent-soft); }
.cookie-option.is-disabled { opacity: .72; }
.cookie-banner-v40 .cookie-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.cookie-banner-v40 .cookie-actions .btn {
  padding: 10px 13px;
  border-radius: 13px;
}
.cookie-banner-v40 .cookie-actions .btn-outline { color: var(--text); border-color: var(--line-strong); }
.cookie-banner-v40 .cookie-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--line);
  cursor: pointer;
}
html[data-theme="dark"] .cookie-banner-v40 .cookie-actions .btn:not(.btn-outline) {
  background: #f5f7f6;
  color: #0f1115;
}
html[data-theme="dark"] .cookie-option { background: #111821; }
@media (max-width: 760px) {
  .cookie-banner-v40 {
    grid-template-columns: 1fr;
    padding: 52px 16px 16px;
    border-radius: 20px;
  }
  .cookie-banner-v40 .cookie-options {
    grid-column: auto;
    grid-row: auto;
  }
  .cookie-banner-v40 .cookie-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
  .cookie-banner-v40 .cookie-actions .btn {
    width: 100%;
  }
}


/* v41 cookie consent: compact, non-scary, German market optimized */
.cookie-banner-v41 {
  position: fixed;
  left: 50%;
  right: auto;
  bottom: 18px;
  width: min(760px, calc(100vw - 32px));
  transform: translateX(-50%);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px 16px;
  padding: 16px 54px 16px 18px;
  border-radius: 22px;
  background: color-mix(in srgb, var(--surface) 97%, transparent);
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: 0 18px 55px rgba(0,0,0,.18);
  backdrop-filter: blur(18px);
  z-index: 1500;
}
.cookie-banner-v41[hidden] {
  display: none !important;
}
.cookie-banner-v41 .cookie-copy {
  display: grid;
  gap: 5px;
  min-width: 0;
}
.cookie-banner-v41 .cookie-badge {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-2);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .06em;
}
.cookie-banner-v41 strong {
  font-size: 15px;
  line-height: 1.2;
}
.cookie-banner-v41 p {
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.42;
}
.cookie-banner-v41 .cookie-details {
  grid-column: 1 / -1;
  border-top: 1px solid var(--line);
  padding-top: 10px;
}
.cookie-banner-v41 .cookie-details:not([open]) {
  border-top: 0;
  padding-top: 0;
}
.cookie-banner-v41 .cookie-details summary {
  width: fit-content;
  cursor: pointer;
  color: var(--accent-2);
  font-weight: 800;
  font-size: 13px;
  list-style: none;
}
.cookie-banner-v41 .cookie-details summary::-webkit-details-marker {
  display: none;
}
.cookie-banner-v41 .cookie-details summary::after {
  content: " +";
}
.cookie-banner-v41 .cookie-details[open] summary::after {
  content: " –";
}
.cookie-banner-v41 .cookie-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 8px;
  margin-top: 10px;
}
.cookie-banner-v41 .cookie-option {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 9px;
  align-items: start;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--surface-2);
}
.cookie-banner-v41 .cookie-option input {
  margin-top: 3px;
  accent-color: var(--accent);
}
.cookie-banner-v41 .cookie-option span {
  display: grid;
  gap: 2px;
}
.cookie-banner-v41 .cookie-option strong {
  font-size: 13px;
}
.cookie-banner-v41 .cookie-option small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}
.cookie-banner-v41 .cookie-option.is-required {
  border-color: rgba(24,163,74,.25);
  background: var(--accent-soft);
}
.cookie-banner-v41 .cookie-option.is-disabled {
  opacity: .68;
}
.cookie-banner-v41 .cookie-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  justify-content: flex-end;
}
.cookie-banner-v41 .cookie-actions .btn {
  padding: 9px 12px;
  border-radius: 12px;
  font-size: 13px;
  white-space: nowrap;
}
.cookie-banner-v41 .cookie-actions .btn-outline {
  color: var(--text);
  border-color: var(--line-strong);
}
.cookie-banner-v41 .cookie-close {
  position: absolute;
  top: 11px;
  right: 11px;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--line);
  cursor: pointer;
}
html[data-theme="dark"] .cookie-banner-v41 .cookie-option {
  background: #111821;
}
html[data-theme="dark"] .cookie-banner-v41 .cookie-actions .btn:not(.btn-outline) {
  background: #f5f7f6;
  color: #0f1115;
}
@media (max-width: 760px) {
  .cookie-banner-v41 {
    left: 12px;
    right: 12px;
    bottom: 12px;
    width: auto;
    max-height: min(62vh, 430px);
    transform: none;
    grid-template-columns: 1fr;
    align-items: start;
    gap: 10px;
    padding: 14px 46px 14px 14px;
    border-radius: 20px;
    overflow: auto;
    overscroll-behavior: contain;
  }
  .cookie-banner-v41 .cookie-badge {
    font-size: 10px;
    padding: 4px 8px;
  }
  .cookie-banner-v41 strong {
    font-size: 14px;
  }
  .cookie-banner-v41 p {
    font-size: 12.5px;
    line-height: 1.35;
  }
  .cookie-banner-v41 .cookie-options {
    grid-template-columns: 1fr;
    gap: 7px;
  }
  .cookie-banner-v41 .cookie-option {
    padding: 8px 9px;
  }
  .cookie-banner-v41 .cookie-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    gap: 8px;
  }
  .cookie-banner-v41 .cookie-actions .btn {
    width: 100%;
    padding: 9px 10px;
  }
  .cookie-banner-v41 .cookie-actions .btn[data-cookie-accept-all] {
    grid-column: 1 / -1;
  }
}
@media (max-width: 420px) {
  .cookie-banner-v41 {
    max-height: 58vh;
    padding: 13px 44px 13px 13px;
  }
  .cookie-banner-v41 .cookie-actions {
    grid-template-columns: 1fr;
  }
  .cookie-banner-v41 .cookie-actions .btn[data-cookie-accept-all] {
    grid-column: auto;
  }
}


/* v42: Logo at least 1.5x larger + admin/security polish */
.brand-logo {
  min-width: 432px !important;
}
.brand-logo-img {
  width: 430px !important;
  max-height: 156px !important;
}
.nav-wrap {
  grid-template-columns: minmax(432px, auto) 1fr auto !important;
  min-height: 156px !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}
.footer-logo-img {
  width: 366px !important;
  max-height: 168px !important;
}
.admin-top nav,
.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.admin-card form {
  display: grid;
  gap: 14px;
}
.admin-card label {
  display: grid;
  gap: 7px;
}
.admin-card input,
.admin-card select,
.admin-card textarea {
  width: 100%;
}
.admin-table-wrap {
  overflow-x: auto;
}
.admin-card code {
  white-space: pre-wrap;
  word-break: break-word;
}
@media (max-width: 1280px) {
  .brand-logo { min-width: 360px !important; }
  .brand-logo-img { width: 358px !important; max-height: 136px !important; }
  .nav-wrap { grid-template-columns: minmax(360px, auto) 1fr auto !important; min-height: 136px !important; }
}
@media (max-width: 1100px) {
  .brand-logo { min-width: 318px !important; }
  .brand-logo-img { width: 316px !important; max-height: 118px !important; }
  .nav-wrap { grid-template-columns: minmax(318px, auto) auto auto !important; min-height: 118px !important; }
}
@media (max-width: 960px) {
  .brand-logo { min-width: 282px !important; }
  .brand-logo-img { width: 280px !important; max-height: 104px !important; }
  .nav-wrap { grid-template-columns: minmax(282px, 1fr) auto auto !important; min-height: 104px !important; }
}
@media (max-width: 720px) {
  .brand-logo { min-width: 242px !important; }
  .brand-logo-img { width: 240px !important; max-height: 90px !important; }
  .nav-wrap { grid-template-columns: minmax(242px, 1fr) 42px 58px !important; min-height: 96px !important; gap: 8px !important; }
}
@media (max-width: 500px) {
  .brand-logo { min-width: 206px !important; }
  .brand-logo-img { width: 204px !important; max-height: 78px !important; }
  .nav-wrap { grid-template-columns: minmax(206px, 1fr) 40px 54px !important; min-height: 88px !important; }
}
@media (max-width: 390px) {
  .brand-logo { min-width: 180px !important; }
  .brand-logo-img { width: 178px !important; max-height: 68px !important; }
  .nav-wrap { grid-template-columns: minmax(180px, 1fr) 38px 50px !important; min-height: 80px !important; }
}


/* v43: Header logo exact requested scaling
   Desktop: 1.5x stronger visual presence.
   Mobile: 2x stronger top-left header logo presence. */
.brand-logo {
  min-width: 648px !important;
  flex: 0 0 auto !important;
}
.brand-logo-img {
  width: 645px !important;
  max-height: 234px !important;
  object-fit: contain !important;
  object-position: left center !important;
}
.nav-wrap {
  grid-template-columns: minmax(648px, auto) 1fr auto !important;
  min-height: 220px !important;
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}
.site-header .container.nav-wrap {
  max-width: min(1540px, calc(100vw - 32px));
}
@media (max-width: 1380px) {
  .brand-logo { min-width: 540px !important; }
  .brand-logo-img { width: 538px !important; max-height: 196px !important; }
  .nav-wrap { grid-template-columns: minmax(540px, auto) 1fr auto !important; min-height: 188px !important; }
}
@media (max-width: 1180px) {
  .brand-logo { min-width: 460px !important; }
  .brand-logo-img { width: 458px !important; max-height: 166px !important; }
  .nav-wrap { grid-template-columns: minmax(460px, auto) auto auto !important; min-height: 160px !important; }
  .site-nav > a, .nav-parent { padding: 9px 10px !important; }
}
@media (max-width: 980px) {
  .brand-logo { min-width: 390px !important; }
  .brand-logo-img { width: 388px !important; max-height: 142px !important; }
  .nav-wrap { grid-template-columns: minmax(390px, 1fr) 44px 60px !important; min-height: 138px !important; gap: 8px !important; }
  .site-nav { max-height: calc(100vh - 150px); overflow-y: auto; }
}
@media (max-width: 760px) {
  .brand-logo { min-width: 376px !important; }
  .brand-logo-img { width: 376px !important; max-height: 140px !important; }
  .nav-wrap { grid-template-columns: minmax(0, 1fr) 42px 58px !important; min-height: 132px !important; gap: 7px !important; }
  .brand-logo {
    overflow: visible !important;
  }
  .theme-toggle { width: 42px !important; height: 42px !important; }
  .menu-toggle { min-width: 58px !important; padding: 10px 9px !important; }
}
@media (max-width: 520px) {
  .brand-logo { min-width: 320px !important; }
  .brand-logo-img { width: 320px !important; max-height: 118px !important; }
  .nav-wrap { min-height: 116px !important; grid-template-columns: minmax(0, 1fr) 40px 54px !important; }
}
@media (max-width: 430px) {
  .brand-logo { min-width: 276px !important; }
  .brand-logo-img { width: 276px !important; max-height: 102px !important; }
  .nav-wrap { min-height: 104px !important; grid-template-columns: minmax(0, 1fr) 38px 50px !important; }
  .theme-toggle { width: 38px !important; height: 38px !important; }
  .menu-toggle { min-width: 50px !important; font-size: 12px !important; }
}
@media (max-width: 370px) {
  .brand-logo { min-width: 244px !important; }
  .brand-logo-img { width: 244px !important; max-height: 92px !important; }
  .nav-wrap { min-height: 98px !important; grid-template-columns: minmax(0, 1fr) 36px 46px !important; }
}


/* v44: Header/menu overlap fix while preserving large logo */
.site-header {
  overflow: visible !important;
}
.site-header .container.nav-wrap {
  max-width: min(1840px, calc(100vw - 20px)) !important;
  padding-left: 10px !important;
  padding-right: 10px !important;
}
.nav-wrap {
  display: grid !important;
  grid-template-columns: minmax(520px, auto) minmax(0, 1fr) auto !important;
  column-gap: 12px !important;
  align-items: center !important;
}
.brand-logo {
  min-width: 520px !important;
}
.brand-logo-img {
  width: 520px !important;
  max-height: 190px !important;
}
.site-nav {
  justify-self: start !important;
  margin-left: -42px !important;
  max-width: 100% !important;
  min-width: 0 !important;
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 3px !important;
}
.site-nav > a,
.nav-parent {
  padding: 8px 8px !important;
  font-size: 14px !important;
  white-space: nowrap !important;
  letter-spacing: -0.01em !important;
}
.nav-actions {
  justify-self: end !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: max-content !important;
  position: relative !important;
  z-index: 10 !important;
}
.nav-cta {
  padding: 10px 12px !important;
  font-size: 13px !important;
  white-space: nowrap !important;
}
.theme-toggle,
.menu-toggle {
  flex: 0 0 auto !important;
  position: relative !important;
  z-index: 11 !important;
}

/* Slightly smaller giant-logo header for normal laptop widths so the menu never crashes right. */
@media (max-width: 1500px) {
  .site-header .container.nav-wrap {
    max-width: min(1500px, calc(100vw - 18px)) !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(430px, auto) minmax(0, 1fr) auto !important;
    column-gap: 8px !important;
  }
  .brand-logo { min-width: 430px !important; }
  .brand-logo-img { width: 430px !important; max-height: 158px !important; }
  .site-nav { margin-left: -26px !important; gap: 1px !important; }
  .site-nav > a, .nav-parent { padding: 8px 6px !important; font-size: 13px !important; }
  .nav-cta { padding: 9px 10px !important; font-size: 12.5px !important; }
}
@media (max-width: 1280px) {
  .nav-wrap {
    grid-template-columns: minmax(360px, auto) minmax(0, 1fr) auto !important;
  }
  .brand-logo { min-width: 360px !important; }
  .brand-logo-img { width: 360px !important; max-height: 132px !important; }
  .site-nav { margin-left: -18px !important; }
  .site-nav > a, .nav-parent { padding: 7px 5px !important; font-size: 12.5px !important; }
  .nav-actions { gap: 6px !important; }
}
@media (max-width: 1120px) {
  .nav-cta {
    display: none !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(330px, auto) minmax(0, 1fr) auto !important;
  }
  .brand-logo { min-width: 330px !important; }
  .brand-logo-img { width: 330px !important; max-height: 122px !important; }
  .site-nav > a, .nav-parent { font-size: 12.5px !important; padding: 7px 5px !important; }
}
@media (max-width: 980px) {
  .nav-wrap {
    grid-template-columns: minmax(390px, 1fr) 44px 60px !important;
  }
  .site-nav {
    margin-left: 0 !important;
    flex-wrap: wrap !important;
  }
  .nav-actions {
    min-width: 0 !important;
  }
  .theme-toggle {
    display: inline-flex !important;
  }
  .nav-cta {
    display: none !important;
  }
}
@media (max-width: 760px) {
  .nav-wrap {
    grid-template-columns: minmax(0, 1fr) 42px 58px !important;
  }
  .brand-logo { min-width: 376px !important; }
  .brand-logo-img { width: 376px !important; max-height: 140px !important; }
}
@media (max-width: 520px) {
  .brand-logo { min-width: 320px !important; }
  .brand-logo-img { width: 320px !important; max-height: 118px !important; }
}
@media (max-width: 430px) {
  .brand-logo { min-width: 276px !important; }
  .brand-logo-img { width: 276px !important; max-height: 102px !important; }
}
@media (max-width: 370px) {
  .brand-logo { min-width: 244px !important; }
  .brand-logo-img { width: 244px !important; max-height: 92px !important; }
}


/* v45: Desktop-only header refinement, mobile reverted to the previously stable behavior */

/* Desktop/Web: a bit bigger than v44, but menu still fits */
@media (min-width: 981px) {
  .site-header .container.nav-wrap {
    max-width: min(1880px, calc(100vw - 18px)) !important;
    padding-left: 9px !important;
    padding-right: 9px !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(560px, auto) minmax(0, 1fr) auto !important;
    column-gap: 10px !important;
    min-height: 176px !important;
  }
  .brand-logo {
    min-width: 560px !important;
  }
  .brand-logo-img {
    width: 558px !important;
    max-height: 204px !important;
  }
  .site-nav {
    margin-left: -36px !important;
    gap: 2px !important;
  }
  .site-nav > a,
  .nav-parent {
    padding: 8px 7px !important;
    font-size: 13.5px !important;
  }
  .nav-actions {
    gap: 7px !important;
  }
  .nav-cta {
    padding: 9px 11px !important;
    font-size: 12.5px !important;
  }
}

/* Desktop/laptop fitting: keep slightly bigger, but prevent right overlap */
@media (min-width: 981px) and (max-width: 1500px) {
  .nav-wrap {
    grid-template-columns: minmax(455px, auto) minmax(0, 1fr) auto !important;
    min-height: 166px !important;
  }
  .brand-logo { min-width: 455px !important; }
  .brand-logo-img { width: 452px !important; max-height: 166px !important; }
  .site-nav { margin-left: -28px !important; gap: 1px !important; }
  .site-nav > a, .nav-parent { padding: 8px 6px !important; font-size: 13px !important; }
}

@media (min-width: 981px) and (max-width: 1280px) {
  .nav-wrap {
    grid-template-columns: minmax(378px, auto) minmax(0, 1fr) auto !important;
    min-height: 142px !important;
  }
  .brand-logo { min-width: 378px !important; }
  .brand-logo-img { width: 376px !important; max-height: 140px !important; }
  .site-nav { margin-left: -16px !important; }
  .site-nav > a, .nav-parent { padding: 7px 5px !important; font-size: 12.5px !important; }
}

/* Mobile/tablet: revert the v44 layout changes and restore the stable v43-like header */
@media (max-width: 980px) {
  .site-header .container.nav-wrap {
    max-width: min(1540px, calc(100vw - 32px)) !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .nav-wrap {
    grid-template-columns: minmax(390px, 1fr) 44px 60px !important;
    min-height: 138px !important;
    gap: 8px !important;
    padding-top: 14px !important;
    padding-bottom: 14px !important;
  }
  .brand-logo {
    min-width: 390px !important;
    overflow: visible !important;
  }
  .brand-logo-img {
    width: 388px !important;
    max-height: 142px !important;
  }
  .site-nav {
    margin-left: 0 !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
  .nav-actions {
    min-width: 0 !important;
    gap: 8px !important;
  }
  .theme-toggle {
    display: inline-flex !important;
    width: 44px !important;
    height: 44px !important;
  }
  .nav-cta {
    display: none !important;
  }
}

@media (max-width: 760px) {
  .nav-wrap {
    grid-template-columns: minmax(0, 1fr) 42px 58px !important;
    min-height: 132px !important;
    gap: 7px !important;
  }
  .brand-logo {
    min-width: 376px !important;
    overflow: visible !important;
  }
  .brand-logo-img {
    width: 376px !important;
    max-height: 140px !important;
  }
  .theme-toggle { width: 42px !important; height: 42px !important; }
  .menu-toggle { min-width: 58px !important; padding: 10px 9px !important; }
}

@media (max-width: 520px) {
  .brand-logo { min-width: 320px !important; }
  .brand-logo-img { width: 320px !important; max-height: 118px !important; }
  .nav-wrap {
    min-height: 116px !important;
    grid-template-columns: minmax(0, 1fr) 40px 54px !important;
  }
}

@media (max-width: 430px) {
  .brand-logo { min-width: 276px !important; }
  .brand-logo-img { width: 276px !important; max-height: 102px !important; }
  .nav-wrap {
    min-height: 104px !important;
    grid-template-columns: minmax(0, 1fr) 38px 50px !important;
  }
  .theme-toggle { width: 38px !important; height: 38px !important; }
  .menu-toggle { min-width: 50px !important; font-size: 12px !important; }
}

@media (max-width: 370px) {
  .brand-logo { min-width: 244px !important; }
  .brand-logo-img { width: 244px !important; max-height: 92px !important; }
  .nav-wrap {
    min-height: 98px !important;
    grid-template-columns: minmax(0, 1fr) 36px 46px !important;
  }
}


/* v46: Mobile menu fix
   Problem in v45: later desktop/header rules forced .site-nav to display on mobile.
   Fix: below 981px the nav is hidden by default and only appears when JS adds .open. */
@media (max-width: 980px) {
  .site-header .site-nav {
    display: none !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    top: calc(100% + 8px) !important;
    width: 100% !important;
    margin-left: 0 !important;
    padding: 14px !important;
    border-radius: 22px !important;
    background: color-mix(in srgb, var(--surface) 98%, transparent) !important;
    border: 1px solid var(--line) !important;
    box-shadow: var(--shadow-soft) !important;
    z-index: 1200 !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
    max-height: calc(100vh - 150px) !important;
    overflow-y: auto !important;
  }
  .site-header .site-nav.open {
    display: flex !important;
  }
  .site-header .site-nav > a,
  .site-header .nav-parent {
    width: 100% !important;
    justify-content: flex-start !important;
    padding: 12px 14px !important;
    font-size: 15px !important;
    border-radius: 14px !important;
    background: var(--surface-2) !important;
  }
  .site-header .nav-group {
    width: 100% !important;
    display: block !important;
  }
  .site-header .nav-dropdown {
    display: none !important;
  }
  .site-header .nav-parent::after {
    content: none !important;
  }
  .site-header .nav-wrap {
    position: relative !important;
  }
  .site-header .nav-actions {
    justify-self: end !important;
    display: flex !important;
  }
  .site-header .nav-cta {
    display: none !important;
  }
  .site-header .theme-toggle,
  .site-header .menu-toggle {
    display: inline-flex !important;
    position: relative !important;
    z-index: 1300 !important;
  }
}

/* Keep desktop overlap fix only on real desktop */
@media (min-width: 981px) {
  .site-header .site-nav {
    position: static !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    overflow: visible !important;
  }
}
