/* ====== Gemeinsam Erleben — Theme CSS ====== */
:root {
  --ge-green-900: #1a2110;
  --ge-green-800: #2c3a18;
  --ge-green-700: #3f5520;
  --ge-green-600: #4a6b1f;
  --ge-green-500: #637f36;
  --ge-green-400: #8aa247;
  --ge-green-300: #b9be56;
  --ge-green-200: #d5dc8d;
  --ge-green-100: #ebefd2;
  --ge-green-50:  #f3f6e4;
  --ge-paper:       #ffffff;
  --ge-cream:       #faf6ee;
  --ge-cream-warm:  #f5efde;
  --ge-cream-deep:  #ecdfb9;
  --ge-ink:         #1a1f12;
  --ge-ink-soft:    #3d4533;
  --ge-ink-mute:    #6b7259;
  --ge-line:        #e7e3d3;
  --ge-primary:     var(--ge-green-600);
  --ge-primary-dark:var(--ge-green-700);
  --ge-accent:      var(--ge-green-300);
  --ge-radius-sm:   8px;
  --ge-radius:      14px;
  --ge-radius-lg:   22px;
  --ge-radius-xl:   32px;
  --ge-radius-pill: 999px;
  --ge-shadow-card: 0 1px 0 rgba(26,33,18,.04), 0 8px 28px -16px rgba(26,33,18,.18);
  --ge-shadow-lift: 0 2px 0 rgba(26,33,18,.04), 0 30px 60px -30px rgba(26,33,18,.35);
  --ge-font: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --ge-header-h: 96px;
}

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

body {
  font-family: var(--ge-font);
  color: var(--ge-ink);
  background: var(--ge-cream);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  margin: 0;
  padding-top: var(--ge-header-h);
}

button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }

textarea, select { font-family: inherit; }

/* ====== Skip Link ====== */
.ge-skip-link {
  position: absolute; top: -100%; left: 50%; transform: translateX(-50%);
  background: var(--ge-primary); color: #fff;
  padding: 12px 24px; border-radius: 0 0 var(--ge-radius) var(--ge-radius);
  font-size: 14px; font-weight: 600; z-index: 9999;
  transition: top .15s;
}
.ge-skip-link:focus { top: 0; outline: 3px solid var(--ge-accent); outline-offset: 2px; }

/* ====== Focus visible ====== */
:focus-visible {
  outline: 2px solid var(--ge-primary);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ====== Container ====== */
.ge-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 64px;
}

/* ====== Buttons ====== */
.ge-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  border-radius: var(--ge-radius-pill);
  font-size: 15px; font-weight: 600; letter-spacing: -0.01em;
  border: 1px solid transparent;
  transition: transform .15s, background .2s, border-color .2s;
  white-space: nowrap;
  cursor: pointer;
  text-decoration: none;
}
.ge-btn:hover { transform: translateY(-1px); }
.ge-btn:focus-visible { outline-offset: 3px; }
.ge-btn-primary { background: var(--ge-primary); color: #fff; }
.ge-btn-primary:hover { background: var(--ge-primary-dark); }
.ge-btn-accent  { background: var(--ge-accent); color: var(--ge-green-900); }
.ge-btn-dark    { background: var(--ge-green-900); color: #fff; }
.ge-btn-ghost   { background: transparent; color: var(--ge-ink); border-color: var(--ge-line); }
.ge-btn-ghost:hover { border-color: var(--ge-ink); }
.ge-btn-white   { background: #fff; color: var(--ge-green-900); }
.ge-btn-outline-white { border-color: rgba(255,255,255,.4); color: #fff; }
.ge-btn-lg { padding: 18px 28px; font-size: 16px; }
.ge-btn-sm { padding: 10px 16px; font-size: 13px; }
.ge-btn .arrow { display: inline-block; transition: transform .2s; }
.ge-btn:hover .arrow { transform: translateX(3px); }

/* ====== Pills & Labels ====== */
.ge-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ge-primary);
}
.ge-eyebrow::before {
  content: ""; width: 28px; height: 1px; background: currentColor; opacity: .6;
}

.ge-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: var(--ge-radius-pill);
  font-size: 13px; font-weight: 600;
  background: var(--ge-green-100); color: var(--ge-green-700);
  border: 1px solid color-mix(in oklab, var(--ge-primary) 18%, transparent);
}

/* ====== Typography ====== */
.ge-display {
  font-size: clamp(48px, 7vw, 96px);
  line-height: 0.96; letter-spacing: -0.035em;
  font-weight: 800; color: var(--ge-green-900);
  text-wrap: balance; margin: 0;
}
.ge-display .accent { color: var(--ge-primary); }
.ge-display .swash  { font-style: italic; font-weight: 500; }

.ge-h1 { font-size: clamp(44px, 6.5vw, 64px); line-height: 1.02; letter-spacing: -0.03em; font-weight: 800; color: var(--ge-green-900); text-wrap: balance; margin: 0; }
.ge-h2 { font-size: clamp(32px, 4.5vw, 48px); line-height: 1.05; letter-spacing: -0.025em; font-weight: 800; color: var(--ge-green-900); text-wrap: balance; margin: 0; }
.ge-h3 { font-size: clamp(22px, 2.5vw, 28px); line-height: 1.15; letter-spacing: -0.015em; font-weight: 700; color: var(--ge-green-900); margin: 0; }
.ge-h4 { font-size: 20px; line-height: 1.25; letter-spacing: -0.01em; font-weight: 700; color: var(--ge-green-900); margin: 0; }
.ge-lead { font-size: 20px; line-height: 1.5; color: var(--ge-ink-soft); font-weight: 400; text-wrap: pretty; }
.ge-body { font-size: 16px; line-height: 1.65; color: var(--ge-ink-soft); }

/* ====== Header ====== */
.ge-header {
  position: fixed; top: 0; left: 0; right: 0;
  width: 100%; z-index: 50;
}
.admin-bar .ge-header { top: 32px; }
.ge-header.is-scrolled { box-shadow: 0 1px 16px rgba(0,0,0,.07); }
.ge-header.is-transparent.is-scrolled {
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--ge-line);
}
.ge-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 64px;
  max-width: 1440px; margin: 0 auto;
}
.ge-header-logo { display: flex; align-items: center; gap: 14px; }
.ge-header-logo img { height: 52px; width: auto; display: block; }

.ge-nav { display: flex; align-items: center; gap: 4px; }
.ge-nav a {
  padding: 10px 16px; border-radius: var(--ge-radius-pill);
  font-size: 14px; font-weight: 500; color: var(--ge-ink-soft);
  position: relative; text-decoration: none;
  transition: color .15s, background .15s;
}
.ge-nav a:hover { color: var(--ge-green-900); background: rgba(26,33,18,.04); }
.ge-nav a[aria-current="page"],
.ge-nav a.active { color: var(--ge-green-900); font-weight: 600; }
.ge-nav a.intern,
.ge-mobile-nav-links a.intern { display: none; }

.logged-in .ge-nav a.intern,
.logged-in .ge-mobile-nav-links a.intern { display: flex; }

.ge-nav a.intern::after {
  content: ""; display: inline-block; width: 5px; height: 5px;
  border-radius: 50%; background: var(--ge-accent);
  margin-left: 6px; vertical-align: middle;
}

.ge-header-actions { display: flex; align-items: center; gap: 10px; }
.ge-login-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 500; color: var(--ge-ink-soft);
  padding: 8px 12px; border-radius: var(--ge-radius-pill);
  transition: color .15s;
}
.ge-login-link:hover { color: var(--ge-green-900); }

/* Header variants */
.ge-header.is-white {
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--ge-line);
}
.ge-header.is-transparent { background: transparent; border-bottom: 0; }
.ge-header.is-colored { background: var(--ge-green-900); border-bottom: 0; }
.ge-header.is-colored .ge-nav a { color: rgba(255,255,255,.7); }
.ge-header.is-colored .ge-nav a:hover,
.ge-header.is-colored .ge-nav a.active { color: #fff; background: rgba(255,255,255,.08); }
.ge-header.is-colored .ge-login-link { color: rgba(255,255,255,.7); }
.ge-header.is-colored .ge-login-link:hover { color: #fff; }
.ge-header.is-colored .ge-btn-primary { background: var(--ge-accent); color: var(--ge-green-900); }

/* Logo visibility by header variant */
.ge-header-logo .logo-light { display: none; }
.ge-header.is-colored .ge-header-logo .logo-dark  { display: none; }
.ge-header.is-colored .ge-header-logo .logo-light { display: block; }

/* Customizer variant: primary-green header */
body.ge-header-primary .ge-header { background: var(--ge-primary); border-bottom: 0; opacity:93% }
body.ge-header-primary .ge-header .ge-nav a { color: rgba(255,255,255,.75); }
body.ge-header-primary .ge-header .ge-nav a:hover,
body.ge-header-primary .ge-header .ge-nav a.active { color: #fff; background: rgba(255,255,255,.1); }
body.ge-header-primary .ge-header .ge-nav a.intern::after { background: rgba(255,255,255,.8); }
body.ge-header-primary .ge-header .ge-login-link { color: rgba(255,255,255,.75); }
body.ge-header-primary .ge-header .ge-login-link:hover { color: #fff; }
body.ge-header-primary .ge-header .ge-btn-primary { background: #fff; color: var(--ge-primary-dark); }
body.ge-header-primary .ge-header .ge-btn-primary:hover { background: rgba(255,255,255,.9); }
body.ge-header-primary .ge-header-logo .logo-dark  { display: none; }
body.ge-header-primary .ge-header-logo .logo-light { display: block; }
body.ge-header-primary .ge-burger { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.25); }
body.ge-header-primary .ge-burger span { background: #fff; }

/* Mobile burger */
.ge-burger {
  display: none; width: 44px; height: 44px;
  border-radius: 50%; border: 1px solid var(--ge-line); background: #fff;
  align-items: center; justify-content: center; flex-direction: column; gap: 5px;
  cursor: pointer;
}
.ge-burger span {
  display: block; width: 16px; height: 1.6px; background: var(--ge-ink);
  border-radius: 1px; transition: transform .2s, opacity .2s;
}

/* ====== Hero ====== */
.ge-hero {
  position: relative; padding: 56px 0 120px; overflow: hidden;
}
.ge-hero-grid {
  display: grid; grid-template-columns: 1.35fr 1fr; gap: 64px; align-items: end;
}
.ge-hero-meta { display: flex; gap: 32px; margin-top: 40px; }
.ge-hero-meta-item { font-size: 14px; color: var(--ge-ink-mute); }
.ge-hero-meta-item strong {
  display: block; font-size: 32px; font-weight: 800;
  color: var(--ge-green-900); margin-bottom: 4px; letter-spacing: -0.02em;
}
.ge-hero-actions { display: flex; gap: 12px; margin-top: 36px; flex-wrap: wrap; }
.ge-hero-decor {
  position: absolute; right: -60px; top: 40px;
  width: 480px; height: 480px;
  background: url('../logo-color.png') center / contain no-repeat;
  opacity: 0.22;
  pointer-events: none; z-index: 0;
}

/* ====== Section ====== */
.ge-section { padding: 120px 0; position: relative; }
.ge-section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 56px; gap: 32px;
}
.ge-section-head h2 { max-width: 720px; }

/* ====== Next Event Card ====== */
.ge-next {
  background: var(--ge-green-900); color: #fff;
  border-radius: var(--ge-radius-xl); padding: 56px 64px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 56px; align-items: center;
  position: relative; overflow: hidden;
}
.ge-next::before {
  content: ""; position: absolute; right: -120px; bottom: -180px;
  width: 480px; height: 480px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklab, var(--ge-accent) 30%, transparent), transparent 60%);
  pointer-events: none;
}
.ge-next-date {
  display: flex; flex-direction: column; align-items: center;
  background: var(--ge-accent); color: var(--ge-green-900);
  border-radius: var(--ge-radius); padding: 22px 28px; min-width: 140px; z-index: 1;
}
.ge-next-date .dow { font-size: 13px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; }
.ge-next-date .day { font-size: 72px; font-weight: 800; line-height: 1; margin: 2px 0; letter-spacing: -0.04em; }
.ge-next-date .mon { font-size: 14px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; }

.ge-next-body { z-index: 1; }
.ge-next-body .eyebrow {
  font-size: 12px; font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ge-green-200);
}
.ge-next-body h2 { font-size: clamp(32px, 4vw, 56px); line-height: 1.05; font-weight: 800; margin: 10px 0 14px; letter-spacing: -0.03em; color: #fff; }
.ge-next-meta { display: flex; gap: 24px; color: rgba(255,255,255,.75); font-size: 15px; flex-wrap: wrap; }
.ge-next-meta span { display: inline-flex; align-items: center; gap: 8px; }

.ge-next-fallback {
  display: flex; align-items: center; gap: 24px;
  background: var(--ge-green-900); border-radius: var(--ge-radius-xl);
  padding: 32px 48px; color: rgba(255,255,255,.8); font-size: 16px;
}
.ge-next-fallback a { color: var(--ge-accent); font-weight: 600; margin-left: 8px; }

/* ====== Pillars ====== */
.ge-pillars { display: grid; grid-template-columns: repeat(var(--ge-pillar-cols, 4), 1fr); gap: 20px; }
.ge-pillar {
  background: var(--ge-paper); border-radius: var(--ge-radius-lg);
  padding: 32px; border: 1px solid var(--ge-line);
  transition: transform .2s, border-color .2s;
}
.ge-pillar:hover { transform: translateY(-3px); border-color: var(--ge-primary); }
.ge-pillar-num {
  font-size: 13px; font-weight: 700; letter-spacing: 0.12em;
  color: var(--ge-primary); margin-bottom: 56px;
}
.ge-pillar h3 { font-size: 24px; margin-bottom: 12px; }
.ge-pillar p  { font-size: 15px; color: var(--ge-ink-soft); margin: 0; line-height: 1.6; }
.ge-pillar.is-accent { background: var(--ge-green-900); color: #fff; border-color: var(--ge-green-900); }
.ge-pillar.is-accent h3 { color: #fff; }
.ge-pillar.is-accent p  { color: rgba(255,255,255,.7); }
.ge-pillar.is-accent .ge-pillar-num { color: var(--ge-accent); }

/* ====== Event Cards ====== */
.ge-events { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.ge-event-card {
  background: var(--ge-paper); border-radius: var(--ge-radius-lg);
  border: 1px solid var(--ge-line); padding: 28px;
  display: flex; flex-direction: column; gap: 20px;
  transition: transform .2s, border-color .2s, box-shadow .2s;
  text-decoration: none; color: inherit;
}
.ge-event-card:hover { transform: translateY(-3px); border-color: var(--ge-primary); box-shadow: var(--ge-shadow-card); }
.ge-event-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.ge-event-date-block {
  text-align: center; padding: 10px 14px; border-radius: var(--ge-radius);
  background: var(--ge-green-50); color: var(--ge-green-700); min-width: 64px;
}
.ge-event-date-block .d { font-size: 28px; font-weight: 800; line-height: 1; letter-spacing: -0.02em; }
.ge-event-date-block .m { font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; margin-top: 4px; }
.ge-event-card .tag { font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ge-ink-mute); }
.ge-event-card h3  { font-size: 26px; line-height: 1.15; margin: 4px 0 0; }
.ge-event-card .meta { display: flex; flex-direction: column; gap: 6px; font-size: 14px; color: var(--ge-ink-mute); }
.ge-event-card .meta span { display: inline-flex; align-items: center; gap: 8px; }
.ge-event-card .foot {
  display: flex; justify-content: space-between; align-items: center;
  border-top: 1px solid var(--ge-line); padding-top: 18px; margin-top: auto;
}
.ge-event-card .foot .price { font-size: 14px; font-weight: 600; color: var(--ge-green-700); }
.ge-event-card .foot .more {
  font-size: 14px; font-weight: 600; color: var(--ge-green-900);
  display: inline-flex; align-items: center; gap: 6px;
}

/* ====== Status Pills ====== */
.ge-status-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: var(--ge-radius-pill); font-size: 12px; font-weight: 600; }
.ge-status-pill .dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 8px; }
.ge-status-free    { background: var(--ge-green-100); color: var(--ge-green-700); }
.ge-status-free .dot { background: var(--ge-primary); }
.ge-status-fill    { background: #fff7e2; color: #8b6a14; border: 1px solid #f2dfa5; }
.ge-status-fill .dot { background: #d8a02a; }
.ge-status-soldout { background: #ffeded; color: #8d2727; border: 1px solid #f6cccc; }
.ge-status-soldout .dot { background: #c93c3c; }
.ge-status-cancel  { background: var(--ge-ink-mute); color: #fff; }
.ge-status-cancel .dot { background: #fff; }

/* ====== Membership CTA ====== */
.ge-member {
  background: var(--ge-primary); color: #fff;
  border-radius: var(--ge-radius-xl); padding: 80px 64px;
  position: relative; overflow: hidden;
}
.ge-member-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; position: relative; z-index: 1; }
.ge-member h2 { color: #fff; font-size: clamp(36px, 5vw, 64px); line-height: 1; letter-spacing: -0.03em; }
.ge-member h2 em { font-style: italic; font-weight: 500; color: var(--ge-accent); }
.ge-member-bullets { list-style: none; padding: 0; margin: 28px 0; display: flex; flex-direction: column; gap: 12px; }
.ge-member-bullets li {
  display: flex; align-items: flex-start; gap: 12px; font-size: 16px; color: rgba(255,255,255,.9);
}
.ge-member-bullets li::before {
  content: ""; flex: 0 0 22px; width: 22px; height: 22px; margin-top: 2px;
  border-radius: 50%; background: var(--ge-accent);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path fill='none' stroke='%231a2110' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round' d='M2.5 7.2 5.7 10.4 11.5 3.6'/></svg>");
  background-repeat: no-repeat; background-position: center;
}
.ge-member-card {
  background: #fff; color: var(--ge-ink);
  border-radius: var(--ge-radius-lg); padding: 36px;
  box-shadow: var(--ge-shadow-lift);
}
.ge-member-card .price-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 24px; }
.ge-member-card .price { font-size: 56px; font-weight: 800; color: var(--ge-green-900); letter-spacing: -0.03em; line-height: 1; }
.ge-member-card .price-sub { font-size: 15px; color: var(--ge-ink-mute); }
.ge-member-decor {
  position: absolute; right: -180px; top: -120px;
  width: 520px; height: 520px; border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, color-mix(in oklab, var(--ge-accent) 40%, transparent), transparent 60%);
  pointer-events: none;
}

/* Membership CTA variants */
.ge-member.variant-banner {
  padding: 48px 64px; border-radius: var(--ge-radius-xl);
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.ge-member.variant-card { padding: 36px; border-radius: var(--ge-radius-lg); }
.ge-member.variant-inline {
  display: flex; align-items: center; gap: 24px;
  padding: 24px 32px; border-radius: var(--ge-radius-lg);
}

/* ====== Board Teaser ====== */
.ge-board {
  background: var(--ge-cream-warm); border-radius: var(--ge-radius-lg);
  padding: 56px; display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center;
  border: 1px solid var(--ge-cream-deep);
}
.ge-board-locked {
  display: inline-flex; align-items: center; gap: 10px; padding: 8px 14px;
  border-radius: var(--ge-radius-pill); background: var(--ge-green-100); color: var(--ge-green-700);
  font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
}
.ge-board h2 { font-size: clamp(32px, 4vw, 44px); margin: 18px 0; }
.ge-board-list { display: flex; flex-direction: column; gap: 10px; }
.ge-board-row {
  display: flex; align-items: center; gap: 16px;
  background: rgba(255,255,255,.65); border: 1px solid var(--ge-cream-deep);
  border-radius: 12px; padding: 14px 18px;
}
.ge-board-row.locked { color: var(--ge-ink-mute); }
.ge-board-row.locked .ge-board-content { filter: blur(4px); user-select: none; }
.ge-board-content { flex: 1; }
.ge-board-content .title { font-weight: 600; color: var(--ge-green-900); font-size: 15px; }
.ge-board-content .meta  { font-size: 12px; color: var(--ge-ink-mute); }
.ge-board-tag {
  font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ge-primary); padding: 4px 8px; background: var(--ge-green-50); border-radius: 6px;
}

/* ====== Social CTA ====== */
.ge-social-cta {
  background: var(--ge-green-900); color: #fff;
  border-radius: var(--ge-radius-xl); padding: 64px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
.ge-social-cta h2 { color: #fff; font-size: clamp(28px, 3.5vw, 44px); line-height: 1.05; letter-spacing: -0.025em; }
.ge-social-cta p  { color: rgba(255,255,255,.7); }
.ge-social-cards  { display: flex; flex-direction: column; gap: 14px; }
.ge-social-card {
  display: flex; align-items: center; gap: 18px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px; padding: 22px 26px; text-decoration: none;
  transition: background .2s, border-color .2s, transform .15s;
}
.ge-social-card:hover { background: rgba(255,255,255,.1); border-color: var(--ge-accent); transform: translateY(-2px); }
.ge-social-icn {
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--ge-accent); color: var(--ge-green-900);
  display: inline-flex; align-items: center; justify-content: center; flex: 0 0 52px;
}
.ge-social-body { flex: 1; }
.ge-social-name { color: #fff; font-size: 18px; font-weight: 700; letter-spacing: -0.01em; }
.ge-social-meta { color: rgba(255,255,255,.6); font-size: 13px; margin-top: 4px; line-height: 1.4; }
.ge-social-arrow { color: rgba(255,255,255,.7); font-size: 18px; }

/* Social CTA compact variant — passt neben das Spendenformular */
.ge-social-cta--compact {
  max-width: 560px;
  grid-template-columns: 1fr;
  gap: 28px;
  padding: 40px;
}

/* Social CTA + Donate side-by-side row */
.ge-cta-row {
  display: grid;
  grid-template-columns: minmax(0, 560px) 460px;
  gap: 48px;
  align-items: start;
  padding-bottom: 120px;
}
.ge-cta-row .ge-social-cta {
  grid-template-columns: 1fr;
  gap: 32px;
  padding: 48px;
}
.ge-cta-row .ge-social-cta--compact {
  padding: 40px;
  gap: 28px;
}

/* ====== Contact person widgets ====== */
.ge-contact-portrait-svg {
  width: 100%; height: 100%; display: block;
}

/* --- Variante A: dark hero --- */
.ge-contact-hero {
  position: relative;
  background: var(--ge-green-900); color: #fff;
  border-radius: 32px;
  padding: 48px 56px;
  overflow: hidden;
}
.ge-contact-hero-decor {
  position: absolute; right: -160px; bottom: -200px;
  width: 520px; height: 520px; border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, color-mix(in oklab, var(--ge-accent) 38%, transparent), transparent 65%);
  pointer-events: none;
}
.ge-contact-hero-inner {
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: 200px 1fr 320px;
  gap: 48px; align-items: center;
}
.ge-contact-hero-portrait {
  width: 200px; height: 200px; border-radius: 50%;
  position: relative;
  box-shadow: 0 24px 40px -24px rgba(0,0,0,.5), 0 0 0 6px rgba(255,255,255,.05);
}
.ge-contact-hero-badge {
  position: absolute; bottom: 6px; right: 6px;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--ge-accent); color: var(--ge-green-900);
  display: inline-flex; align-items: center; justify-content: center;
  border: 4px solid var(--ge-green-900);
}
.ge-contact-hero-badge svg { width: 18px; height: 18px; }

.ge-contact-hero-body { min-width: 0; }
.ge-contact-hero-eyebrow {
  font-size: 12px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ge-accent);
}
.ge-contact-hero-name {
  font-size: 56px; line-height: 1; letter-spacing: -0.03em;
  font-weight: 800; color: #fff; margin: 12px 0 8px;
}
.ge-contact-hero-role {
  font-size: 17px; color: rgba(255,255,255,.78); margin: 0 0 16px;
  font-weight: 500;
}
.ge-contact-hero-text {
  font-size: 16px; line-height: 1.6; color: rgba(255,255,255,.78); margin: 0 0 20px;
  max-width: 560px; text-wrap: pretty;
}
.ge-contact-hero-meta {
  display: flex; flex-wrap: wrap; gap: 18px 24px;
  font-size: 13px; color: rgba(255,255,255,.65);
}
.ge-contact-hero-meta span {
  display: inline-flex; align-items: center; gap: 8px;
}
.ge-contact-hero-meta .icn { color: var(--ge-accent); }

.ge-contact-hero-actions { display: flex; flex-direction: column; gap: 10px; }
.ge-contact-hero-actions .ge-btn { justify-content: center; }
.ge-contact-hero-action {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  color: #fff;
  text-decoration: none;
  transition: background .15s, border-color .15s, transform .12s;
}
.ge-contact-hero-action:hover {
  background: rgba(255,255,255,.1);
  border-color: var(--ge-accent);
  transform: translateY(-1px);
}
.ge-contact-hero-action .ic {
  width: 40px; height: 40px; border-radius: 12px;
  background: var(--ge-accent); color: var(--ge-green-900);
  display: inline-flex; align-items: center; justify-content: center;
  flex: 0 0 40px;
}
.ge-contact-hero-action .ic svg { width: 18px; height: 18px; }
.ge-contact-hero-action .tx { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.ge-contact-hero-action .tx .k {
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.ge-contact-hero-action .tx .v {
  font-size: 15px; font-weight: 600; color: #fff; margin-top: 2px;
}

/* --- Variante B: light inline card --- */
.ge-contact-card {
  display: grid;
  grid-template-columns: 200px 1fr 320px;
  gap: 40px; align-items: center;
  background: var(--ge-paper);
  border: 1px solid var(--ge-line);
  border-radius: 28px;
  padding: 36px 40px;
  box-shadow: var(--ge-shadow-card);
  position: relative; overflow: hidden;
}
.ge-contact-card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 6px; background: var(--ge-accent);
}
.ge-contact-card-portrait {
  width: 200px; height: 200px; border-radius: 50%;
  position: relative;
  box-shadow: 0 1px 0 rgba(26,33,18,.04), 0 18px 36px -18px rgba(26,33,18,.25);
}
.ge-contact-card-body { min-width: 0; }
.ge-contact-card-head h3 { font-size: 32px; margin: 8px 0 6px; letter-spacing: -0.02em; }
.ge-contact-card-role {
  font-size: 15px; color: var(--ge-ink-soft); margin: 0 0 12px;
  font-weight: 500;
}
.ge-contact-card-text {
  font-size: 15px; line-height: 1.6; color: var(--ge-ink-soft); margin: 0 0 18px;
  text-wrap: pretty; max-width: 540px;
}
.ge-contact-card-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.ge-contact-card-chips .ge-pill { padding: 5px 11px; font-size: 12px; }

.ge-contact-card-side {
  display: flex; flex-direction: column; gap: 6px;
  background: var(--ge-cream); border: 1px solid var(--ge-line);
  border-radius: 16px; padding: 12px;
}
.ge-contact-side-row {
  display: grid; grid-template-columns: 40px 1fr auto; align-items: center; gap: 12px;
  padding: 10px 12px; border-radius: 12px;
  color: var(--ge-ink);
  text-decoration: none;
  transition: background .15s;
}
.ge-contact-side-row:hover { background: var(--ge-paper); }
.ge-contact-side-row .ic {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--ge-green-50); color: var(--ge-primary);
  display: inline-flex; align-items: center; justify-content: center;
}
.ge-contact-side-row .ic svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.ge-contact-side-row .tx { display: flex; flex-direction: column; line-height: 1.3; min-width: 0; }
.ge-contact-side-row .tx .k {
  font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ge-ink-mute);
}
.ge-contact-side-row .tx .v {
  font-size: 14px; font-weight: 600; color: var(--ge-green-900);
  margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ge-contact-side-arrow {
  color: var(--ge-ink-mute); font-size: 16px; transition: transform .15s, color .15s;
}
.ge-contact-side-row:hover .ge-contact-side-arrow {
  color: var(--ge-primary); transform: translateX(2px);
}

/* --- Variante C: team row --- */
.ge-contact-row { padding: 0; }
.ge-contact-row-head { margin-bottom: 32px; }
.ge-contact-row-head h2 { margin-top: 12px; font-size: 40px; }
.ge-contact-row-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
}
.ge-contact-row-card {
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: 22px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 16px;
  transition: transform .15s, border-color .15s, box-shadow .15s;
}
.ge-contact-row-card:hover {
  transform: translateY(-3px);
  border-color: var(--ge-primary);
  box-shadow: var(--ge-shadow-card);
}
.ge-contact-row-portrait {
  width: 88px; height: 88px; border-radius: 50%;
  position: relative;
}
.ge-contact-row-body { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.ge-contact-row-role {
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ge-primary);
}
.ge-contact-row-name {
  font-size: 22px; font-weight: 800; color: var(--ge-green-900);
  letter-spacing: -0.015em; margin: 4px 0 0;
}
.ge-contact-row-area {
  font-size: 13px; color: var(--ge-ink-mute); font-weight: 500;
}
.ge-contact-row-text {
  font-size: 14px; line-height: 1.55; color: var(--ge-ink-soft); margin: 8px 0 0;
  text-wrap: pretty;
}
.ge-contact-row-links {
  display: flex; gap: 8px; margin-top: auto; padding-top: 14px;
  border-top: 1px solid var(--ge-line);
}
.ge-contact-row-links a {
  width: 40px; height: 40px; border-radius: 10px;
  background: var(--ge-green-50); color: var(--ge-primary);
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s, transform .12s;
}
.ge-contact-row-links a:hover {
  background: var(--ge-primary); color: #fff; transform: translateY(-1px);
}
.ge-contact-row-links svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }

/* ====== Footer ====== */
.ge-footer {
  background: var(--ge-green-900); color: rgba(255,255,255,.7);
  padding: 80px 0 32px; position: relative; overflow: hidden;
}
.ge-footer-top {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 56px;
  padding-bottom: 56px; border-bottom: 1px solid rgba(255,255,255,.1);
}
.ge-footer .col-title { color: #fff; font-size: 13px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 18px; }
.ge-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px; }
.ge-footer ul a { color: rgba(255,255,255,.7); text-decoration: none; }
.ge-footer ul a:hover { color: #fff; }
.ge-footer-brand p { margin: 16px 0 24px; font-size: 14px; max-width: 320px; }
.ge-footer-brand .motto { font-style: italic; color: var(--ge-accent); }
.ge-footer img.logo { height: 60px; }
.ge-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 32px; font-size: 13px; color: rgba(255,255,255,.5);
  flex-wrap: wrap; gap: 16px;
}
.ge-footer-bottom a { margin-left: 20px; color: rgba(255,255,255,.5); }
.ge-footer-bottom a:hover { color: #fff; }
.ge-footer-decor {
  position: absolute; left: -100px; bottom: -200px;
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklab, var(--ge-primary) 50%, transparent), transparent 60%);
  pointer-events: none;
}

/* ====== Breadcrumbs ====== */
.ge-breadcrumbs {
  padding: 32px 0 0; display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--ge-ink-mute); flex-wrap: wrap;
}
.ge-breadcrumbs a { text-decoration: none; }
.ge-breadcrumbs a:hover { color: var(--ge-green-900); }
.ge-breadcrumbs .sep { opacity: .4; }
.ge-breadcrumbs .here { color: var(--ge-green-900); font-weight: 600; }

/* ====== Event Detail ====== */
.ge-event-hero {
  padding: 56px 0 80px;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: stretch;
}
.ge-event-hero-text .ge-pill { margin-bottom: 24px; }
.ge-event-hero-text h1 { font-size: clamp(48px, 7vw, 88px); line-height: 0.95; letter-spacing: -0.035em; margin: 0; }
.ge-event-hero-text .subtitle { font-size: 22px; color: var(--ge-ink-soft); margin: 24px 0 0; max-width: 540px; text-wrap: pretty; }

.ge-event-datecard {
  background: var(--ge-green-900); color: #fff;
  border-radius: 28px; padding: 36px;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative; overflow: hidden; min-height: 360px;
}
.ge-event-datecard::after {
  content: ""; position: absolute; right: -90px; top: -90px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklab, var(--ge-accent) 35%, transparent), transparent 65%);
  pointer-events: none;
}
.ge-event-datecard .label  { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,.6); font-weight: 600; }
.ge-event-datecard .big-day { font-size: clamp(80px, 12vw, 168px); font-weight: 800; line-height: 0.85; letter-spacing: -0.05em; margin: 16px 0 4px; color: var(--ge-accent); }
.ge-event-datecard .big-mon { font-size: 24px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; }
.ge-event-datecard .badge {
  display: inline-flex; align-items: center; gap: 8px; align-self: flex-start;
  padding: 10px 14px; border-radius: var(--ge-radius-pill);
  background: rgba(255,255,255,.08); color: #fff;
  font-size: 13px; font-weight: 600; border: 1px solid rgba(255,255,255,.15);
  z-index: 1;
}
.ge-event-datecard .badge .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ge-accent); }

.ge-event-quick { display: grid; grid-template-columns: repeat(var(--ge-quick-cols, 4), 1fr); gap: 12px; margin-bottom: 80px; }
.ge-event-quick-card {
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius); padding: 22px 24px;
}
.ge-event-quick-card .lbl { font-size: 12px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ge-ink-mute); margin-bottom: 8px; }
.ge-event-quick-card .val { font-size: 20px; font-weight: 700; color: var(--ge-green-900); letter-spacing: -0.01em; line-height: 1.2; }
.ge-event-quick-card a.val:hover { text-decoration: underline; text-underline-offset: 3px; }
.ge-event-quick-card .sub { font-size: 13px; color: var(--ge-ink-mute); margin-top: 2px; }

.ge-event-body { display: grid; grid-template-columns: 1.5fr 1fr; gap: 80px; }
.ge-event-content h2 { font-size: clamp(28px, 3.5vw, 40px); line-height: 1.05; letter-spacing: -0.025em; margin: 0 0 24px; }
.ge-event-content p  { font-size: 18px; line-height: 1.7; color: var(--ge-ink-soft); margin: 0 0 20px; }
.ge-event-content strong { color: var(--ge-green-900); font-weight: 700; }

.ge-event-bullets { list-style: none; padding: 0; margin: 32px 0; display: flex; flex-direction: column; gap: 14px; }
.ge-event-bullets li {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 20px; background: var(--ge-paper);
  border: 1px solid var(--ge-line); border-radius: var(--ge-radius);
  font-size: 16px; color: var(--ge-green-900); font-weight: 500;
}
.ge-event-bullets li::before {
  content: ""; flex: 0 0 28px; width: 28px; height: 28px;
  border-radius: 50%; background: var(--ge-primary);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 14 14'><path fill='none' stroke='white' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' d='M2.5 7.2 5.7 10.4 11.5 3.6'/></svg>");
  background-repeat: no-repeat; background-position: center;
}

.ge-event-aside { display: flex; flex-direction: column; gap: 16px; }
.ge-aside-card {
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-lg); padding: 32px;
}
.ge-aside-card.is-primary { background: var(--ge-green-50); border-color: var(--ge-green-200); }
.ge-aside-card.is-accent  { background: var(--ge-accent); border-color: transparent; }
.ge-aside-card h3 { font-size: 22px; margin-bottom: 12px; }
.ge-aside-card p  { font-size: 15px; color: var(--ge-ink-soft); margin: 0 0 18px; line-height: 1.6; }
.ge-aside-card .row { display: flex; justify-content: space-between; padding: 12px 0; border-top: 1px solid var(--ge-line); font-size: 14px; }
.ge-aside-card .row:first-of-type { border-top: 0; }
.ge-aside-card .row .k { color: var(--ge-ink-mute); }
.ge-aside-card .row .v { color: var(--ge-green-900); font-weight: 600; }

/* Share buttons */
.ge-share { display: flex; gap: 8px; margin-top: 16px; }
.ge-share button, .ge-share a {
  width: 40px; height: 40px; border-radius: 50%;
  border: 1px solid var(--ge-line); background: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ge-ink-soft); cursor: pointer;
  transition: border-color .15s, color .15s;
}
.ge-share button:hover, .ge-share a:hover { border-color: var(--ge-primary); color: var(--ge-primary); }

/* Registration progress bar */
.ge-reg-bar { background: var(--ge-cream-warm); height: 8px; border-radius: 99px; overflow: hidden; margin-bottom: 10px; }
.ge-reg-bar-fill { height: 100%; background: var(--ge-primary); border-radius: 99px; transition: width .4s; }
.ge-reg-bar-fill.is-soldout { background: #c93c3c; }

/* ====== Calendar / Archive ====== */
.ge-calendar-hero { padding: 56px 0; }
.ge-calendar-hero h1 { font-size: clamp(48px, 7vw, 88px); line-height: 0.95; letter-spacing: -0.035em; margin: 16px 0 0; max-width: 920px; }
.ge-calendar-hero .ge-lead { margin-top: 24px; max-width: 620px; }

.ge-filterbar {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 24px; background: var(--ge-paper);
  border: 1px solid var(--ge-line); border-radius: var(--ge-radius-lg);
  flex-wrap: wrap; margin: 24px 0 48px;
}
.ge-filterbar .lbl { font-size: 13px; font-weight: 600; color: var(--ge-ink-mute); letter-spacing: 0.06em; text-transform: uppercase; }

.ge-filter-pills { display: flex; gap: 6px; flex-wrap: wrap; }
.ge-filter-pill {
  padding: 8px 14px; border-radius: var(--ge-radius-pill);
  font-size: 13px; font-weight: 500; color: var(--ge-ink-soft);
  border: 1px solid var(--ge-line); background: var(--ge-cream);
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  transition: all .15s;
}
.ge-filter-pill.active { background: var(--ge-green-900); color: #fff; border-color: var(--ge-green-900); }
.ge-filter-pill:hover:not(.active) { border-color: var(--ge-primary); color: var(--ge-green-900); }
.ge-filter-pill .count { font-size: 11px; padding: 2px 7px; background: var(--ge-green-100); color: var(--ge-green-700); border-radius: 99px; }
.ge-filter-pill.active .count { background: rgba(255,255,255,.18); color: #fff; }

.ge-search {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--ge-cream); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-pill); padding: 8px 16px; flex: 1; min-width: 220px;
}
.ge-search input { flex: 1; border: 0; background: transparent; font: inherit; outline: none; font-size: 14px; color: var(--ge-ink); }

.ge-cal-section  { margin-bottom: 64px; }
.ge-cal-month {
  font-size: 13px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ge-primary); margin-bottom: 20px;
  display: flex; align-items: center; gap: 14px;
}
.ge-cal-month::after { content: ""; flex: 1; height: 1px; background: var(--ge-line); }

.ge-cal-row {
  display: grid; grid-template-columns: 120px 1fr 220px 200px 160px; gap: 24px;
  align-items: center; padding: 28px 24px;
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-lg); margin-bottom: 10px;
  transition: border-color .15s, transform .15s, box-shadow .15s;
  text-decoration: none; color: inherit; display: grid;
}
.ge-cal-row:hover { border-color: var(--ge-primary); transform: translateY(-2px); box-shadow: var(--ge-shadow-card); }
.ge-cal-date { text-align: center; }
.ge-cal-date .d { font-size: 44px; font-weight: 800; line-height: 1; color: var(--ge-green-900); letter-spacing: -0.03em; }
.ge-cal-date .dow { font-size: 12px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ge-ink-mute); margin-top: 6px; }
.ge-cal-title { display: flex; flex-direction: column; gap: 6px; }
.ge-cal-title .tag { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ge-primary); }
.ge-cal-title h3 { font-size: 22px; margin: 0; line-height: 1.2; }
.ge-cal-meta { display: flex; flex-direction: column; gap: 6px; font-size: 13px; color: var(--ge-ink-mute); }
.ge-cal-meta span { display: inline-flex; align-items: center; gap: 8px; }
.ge-cal-cta { display: flex; justify-content: flex-end; }

/* ====== Forms ====== */
.ge-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }

.ge-input {
  width: 100%; padding: 14px 16px;
  border: 1px solid var(--ge-line); border-radius: 12px;
  background: var(--ge-cream); font: inherit; font-size: 15px; color: var(--ge-ink);
  transition: border-color .15s, background .15s;
  appearance: auto;
}
.ge-input:focus { outline: none; border-color: var(--ge-primary); background: #fff; }
.ge-input::placeholder { color: var(--ge-ink-mute); }
.ge-input.error { border-color: #c93c3c; }

textarea.ge-input { resize: vertical; min-height: 140px; }

.ge-checkbox {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--ge-ink-mute); margin: 14px 0 18px; line-height: 1.45;
}
.ge-checkbox input { margin-top: 2px; accent-color: var(--ge-primary); width: 16px; height: 16px; flex: 0 0 16px; }
.ge-form-submit { width: 100%; }

/* Form page layout */
.ge-formpage-hero { padding: 56px 0 0; }
.ge-formpage-hero h1 { font-size: clamp(48px, 7vw, 88px); line-height: 0.95; letter-spacing: -0.035em; margin: 16px 0 24px; }

.ge-formpage-grid {
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 80px;
  padding: 56px 0 120px; align-items: start;
}
.ge-formpage-grid.no-sidebar { grid-template-columns: 1fr; max-width: 680px; }
.ge-formpage-info p { margin: 16px 0; line-height: 1.65; }
.ge-formpage-info .ge-info-card {
  background: var(--ge-cream-warm); border: 1px solid var(--ge-cream-deep);
  border-radius: var(--ge-radius-lg); padding: 28px; margin-top: 24px;
}
.ge-formpage-info .ge-info-card h4 { font-size: 16px; margin-bottom: 10px; }
.ge-formpage-info .ge-info-card p  { font-size: 14px; color: var(--ge-ink-soft); margin: 0; }

/* Contact page wp:columns layout */
.ge-kontakt-body { padding: 56px 0 120px; }
.ge-kontakt-columns.wp-block-columns {
  gap: 80px !important;
  align-items: flex-start !important;
  flex-wrap: nowrap !important;
}

.ge-form-card {
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: 28px; padding: 48px; box-shadow: var(--ge-shadow-card);
}
.ge-form-section { margin-bottom: 36px; }
.ge-form-section:last-child { margin-bottom: 0; }
.ge-form-section-head {
  font-size: 12px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ge-primary); padding-bottom: 10px; margin-bottom: 18px;
  border-bottom: 1px solid var(--ge-line);
  display: flex; align-items: center; justify-content: space-between;
}
.ge-form-section-head .step { font-size: 11px; color: var(--ge-ink-mute); letter-spacing: 0.1em; }

.ge-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.ge-field label { font-size: 13px; font-weight: 600; color: var(--ge-green-900); }
.ge-field label .req { color: #c93c3c; margin-left: 4px; }
.ge-field .hint { font-size: 12px; color: var(--ge-ink-mute); }
.ge-field .error-msg { font-size: 12px; color: #c93c3c; }
.ge-field-2   { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.ge-field-3-1 { display: grid; grid-template-columns: 2fr 1fr; gap: 12px; }
.ge-field-1-2 { display: grid; grid-template-columns: 1fr 2fr; gap: 12px; }

.ge-fieldset-row { display: flex; gap: 10px; flex-wrap: wrap; }
.ge-radio-card {
  flex: 1; min-width: 110px;
  border: 1.5px solid var(--ge-line); background: var(--ge-cream);
  border-radius: 12px; padding: 16px 20px;
  display: flex; flex-direction: column; gap: 4px;
  cursor: pointer; transition: all .15s; position: relative;
}
.ge-radio-card.active { border-color: var(--ge-primary); background: var(--ge-green-50); }
.ge-radio-card.active::after {
  content: ""; position: absolute; top: 10px; right: 10px;
  width: 18px; height: 18px; border-radius: 50%; background: var(--ge-primary);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 14 14'><path fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round' d='M2.5 7.2 5.7 10.4 11.5 3.6'/></svg>");
  background-repeat: no-repeat; background-position: center;
}
.ge-radio-card .amt { font-size: 24px; font-weight: 800; color: var(--ge-green-900); letter-spacing: -0.02em; }
.ge-radio-card .sub { font-size: 12px; color: var(--ge-ink-mute); }

.ge-segment {
  display: inline-flex; padding: 4px; background: var(--ge-cream);
  border-radius: var(--ge-radius-pill); border: 1px solid var(--ge-line);
}
.ge-segment button {
  padding: 8px 16px; border: 0; background: transparent;
  border-radius: var(--ge-radius-pill); font-size: 13px; font-weight: 600; color: var(--ge-ink-soft); cursor: pointer;
}
.ge-segment button.active { background: var(--ge-green-900); color: #fff; }

.ge-sepa-box {
  background: var(--ge-cream); border: 1px solid var(--ge-line);
  border-radius: 14px; padding: 18px 20px;
  font-size: 12px; color: var(--ge-ink-mute); line-height: 1.55; margin-top: 16px;
}
.ge-sepa-box strong { color: var(--ge-green-900); }
.ge-form-checkboxes { display: flex; flex-direction: column; gap: 12px; }

/* ====== Login Page ====== */
.ge-login-page {
  min-height: 70vh; padding: 80px 0;
  display: flex; align-items: center; justify-content: center;
}
.ge-login-card {
  width: min(480px, 100%); padding: 56px;
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: 28px; box-shadow: var(--ge-shadow-lift);
}
.ge-login-card .ge-pill { margin-bottom: 24px; }
.ge-login-card h1 { font-size: 44px; line-height: 1.05; letter-spacing: -0.025em; margin: 0 0 12px; }
.ge-login-card p  { color: var(--ge-ink-soft); margin: 0 0 32px; }
.ge-login-card .forgot { font-size: 13px; color: var(--ge-primary); font-weight: 600; text-decoration: none; }
.ge-login-card .foot {
  text-align: center; margin-top: 28px; padding-top: 28px;
  border-top: 1px solid var(--ge-line); font-size: 14px; color: var(--ge-ink-mute);
}
.ge-login-card .foot a { color: var(--ge-green-900); font-weight: 600; }

/* ====== Board (Schwarzes Brett) ====== */
.ge-board-header { padding: 56px 0 32px; }
.ge-board-header h1 { font-size: clamp(48px, 6vw, 72px); line-height: 1; letter-spacing: -0.03em; margin: 16px 0; }

.ge-board-toolbar {
  display: flex; align-items: center; gap: 16px;
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-lg); padding: 16px 20px; flex-wrap: wrap;
}
.ge-board-cats { display: flex; gap: 6px; flex-wrap: wrap; }

.ge-board-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ge-board-grid--compact { grid-template-columns: repeat(2, 1fr); gap: 12px; }
.ge-board-card {
  background: var(--ge-paper); border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-lg); padding: 28px;
  transition: border-color .15s, transform .15s, box-shadow .15s;
  display: flex; flex-direction: column; gap: 14px;
  text-decoration: none; color: inherit;
}
.ge-board-card:hover { border-color: var(--ge-primary); transform: translateY(-2px); box-shadow: var(--ge-shadow-card); }
.ge-board-card .top { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.ge-board-card h3   { font-size: 22px; line-height: 1.2; margin: 0; }
.ge-board-card .body { color: var(--ge-ink-soft); font-size: 15px; line-height: 1.55; margin: 0; }
.ge-board-card .meta {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px; border-top: 1px solid var(--ge-line); font-size: 13px; color: var(--ge-ink-mute);
}
.ge-board-card .meta .by { display: inline-flex; align-items: center; gap: 8px; }

.ge-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ge-green-300); color: var(--ge-green-900);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700; flex: 0 0 28px;
}

.ge-board-pending { background: #fff7e2; border-color: #f2dfa5; }

/* Locked card — shown to non-logged-in visitors for sichtbarkeit=intern posts.
   Only category and a decorative placeholder are sent to the browser — no real content. */
.ge-board-card.is-locked {
  background: var(--ge-green-50); border-color: var(--ge-line);
  cursor: default;
}
.ge-board-card.is-locked:hover { transform: none; box-shadow: none; border-color: var(--ge-line); }
.ge-board-lock-icon { color: var(--ge-ink-mute); flex: 0 0 auto; }
.ge-board-locked-body { display: flex; flex-direction: column; gap: 10px; padding: 4px 0; }
.ge-board-placeholder-line {
  height: 14px; border-radius: 4px;
  background: linear-gradient(90deg, var(--ge-green-100) 25%, var(--ge-green-200) 50%, var(--ge-green-100) 75%);
  background-size: 200% 100%;
  animation: ge-shimmer 1.6s infinite;
}
@keyframes ge-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.ge-board-locked-hint {
  font-size: 13px; color: var(--ge-ink-mute); margin: 0;
}
@media (prefers-reduced-motion: reduce) {
  .ge-board-placeholder-line { animation: none; }
}

.ge-pending-bar {
  display: inline-flex; align-items: center; gap: 8px;
  background: #f2dfa5; color: #8b6a14; padding: 4px 10px;
  border-radius: var(--ge-radius-pill);
  font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
}

.ge-board-detail-hero { padding: 32px 0 48px; }
.ge-board-detail-hero h1 { font-size: clamp(36px, 5vw, 56px); line-height: 1.02; letter-spacing: -0.025em; margin: 16px 0 24px; max-width: 900px; }

/* Attachments */
.ge-attach { display: flex; flex-direction: column; gap: 8px; }
.ge-attach-item {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 18px; background: var(--ge-cream);
  border: 1px solid var(--ge-line); border-radius: 12px;
  font-size: 14px; color: var(--ge-green-900); font-weight: 500;
}
.ge-attach-item .file-icn {
  width: 38px; height: 38px; border-radius: 8px; background: var(--ge-paper);
  border: 1px solid var(--ge-line); display: inline-flex; align-items: center;
  justify-content: center; flex: 0 0 38px;
  font-size: 10px; font-weight: 800; color: var(--ge-primary); letter-spacing: 0.05em;
}
.ge-attach-item .size { color: var(--ge-ink-mute); font-size: 12px; font-weight: 400; margin-left: auto; }

.ge-upload {
  border: 1.5px dashed var(--ge-line); border-radius: 14px;
  padding: 32px; text-align: center; background: var(--ge-cream); color: var(--ge-ink-mute);
}
.ge-upload strong { color: var(--ge-green-900); display: block; margin-bottom: 6px; font-size: 15px; }
.ge-upload .sub { font-size: 13px; }

/* ====== Icons ====== */
.icn { width: 16px; height: 16px; flex: 0 0 16px; stroke: currentColor; fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; vertical-align: -2px; }
.icn-lg { width: 22px; height: 22px; flex: 0 0 22px; }
.icn-xl { width: 28px; height: 28px; flex: 0 0 28px; }

/* ====== Alerts ====== */
.ge-alert {
  padding: 16px 20px; border-radius: var(--ge-radius); font-size: 14px;
  display: flex; align-items: flex-start; gap: 12px; margin-bottom: 20px;
}
.ge-alert-success { background: var(--ge-green-50); border: 1px solid var(--ge-green-200); color: var(--ge-green-700); }
.ge-alert-error   { background: #ffeded; border: 1px solid #f6cccc; color: #8d2727; }
.ge-alert-warning { background: #fff7e2; border: 1px solid #f2dfa5; color: #8b6a14; }

/* ====== Pagination ====== */
.ge-pagination {
  display: flex; justify-content: center; gap: 8px; margin-top: 48px;
}

/* ====== Membership Form mini card ====== */
.ge-mini-join { background: var(--ge-cream); border-radius: var(--ge-radius); padding: 24px; margin-top: 20px; }

/* ====== Wave divider ====== */
.ge-wave { display: block; width: 100%; height: 80px; }
.ge-wave path { fill: currentColor; }

/* ====== Mobile Nav Drawer ====== */
.ge-mobile-nav {
  position: fixed; inset: 0; z-index: 200;
  display: flex; visibility: hidden; pointer-events: none;
}
.ge-mobile-nav.open { visibility: visible; pointer-events: all; }
.ge-mobile-nav-overlay {
  position: absolute; inset: 0; background: rgba(26,33,18,.5);
  opacity: 0; transition: opacity .25s;
}
.ge-mobile-nav.open .ge-mobile-nav-overlay { opacity: 1; }
.ge-mobile-nav-drawer {
  position: relative; margin-left: auto; width: min(360px, 90vw);
  background: #fff; height: 100%; overflow-y: auto;
  transform: translateX(100%); transition: transform .3s cubic-bezier(.2,.7,.3,1);
  display: flex; flex-direction: column;
}
.ge-mobile-nav.open .ge-mobile-nav-drawer { transform: translateX(0); }
.ge-mobile-nav-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 24px; border-bottom: 1px solid var(--ge-line);
}
.ge-mobile-nav-links { padding: 16px; display: flex; flex-direction: column; gap: 4px; }
.ge-mobile-nav-links a {
  display: block; padding: 14px 16px; border-radius: var(--ge-radius-pill);
  font-size: 16px; font-weight: 500; color: var(--ge-ink); text-decoration: none;
  transition: background .15s, color .15s;
}
.ge-mobile-nav-links a:hover { background: var(--ge-cream); color: var(--ge-green-900); }
.ge-mobile-nav-links a[aria-current="page"] { color: var(--ge-green-900); font-weight: 700; }
.ge-mobile-nav-footer { padding: 24px; border-top: 1px solid var(--ge-line); margin-top: auto; display: flex; flex-direction: column; gap: 10px; }

/* ====== 404 ====== */
.ge-404 { padding: 120px 0; text-align: center; }
.ge-404 .num { font-size: clamp(80px, 15vw, 160px); font-weight: 800; color: var(--ge-green-100); line-height: 1; letter-spacing: -0.05em; }
.ge-404 h1 { font-size: clamp(28px, 4vw, 48px); margin: 0 0 16px; }
.ge-404 p  { font-size: 18px; color: var(--ge-ink-soft); max-width: 480px; margin: 0 auto 40px; }

/* ====== Reduced Motion ====== */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  .ge-btn:hover, .ge-event-card:hover, .ge-board-card:hover,
  .ge-pillar:hover, .ge-social-card:hover, .ge-cal-row:hover {
    transform: none;
  }
}

/* ====== Tablet (≤ 1024px) ====== */
@media (max-width: 1024px) {
  :root { --ge-header-h: 88px; }
  .ge-container { padding: 0 40px; }
  .ge-header-inner { padding: 18px 40px; }
  .ge-pillars { grid-template-columns: repeat(2, 1fr); }
  .ge-events  { grid-template-columns: repeat(2, 1fr); }
  .ge-cal-row { grid-template-columns: 90px 1fr 160px auto; }
  .ge-cal-row .ge-cal-status { display: none; }
  .ge-event-body { grid-template-columns: 1fr; gap: 48px; }
  .ge-formpage-grid { grid-template-columns: 1fr; }
  .ge-formpage-info { display: none; }
  .ge-kontakt-columns.wp-block-columns { flex-wrap: wrap !important; gap: 40px !important; }
  .ge-kontakt-columns.wp-block-columns > .wp-block-column { flex-basis: 100% !important; min-width: 0 !important; }
  .ge-footer-top { grid-template-columns: 1fr 1fr; }
  .ge-next { grid-template-columns: auto 1fr; gap: 32px; padding: 40px 40px; }
  .ge-next > .ge-btn { grid-column: 1 / -1; justify-content: center; }
  .ge-member-grid { grid-template-columns: 1fr; }
  .ge-social-cta { grid-template-columns: 1fr; }
  .ge-cta-row { grid-template-columns: 1fr; }
  .ge-contact-hero-inner { grid-template-columns: 200px 1fr; }
  .ge-contact-hero-actions { grid-column: 1 / -1; flex-direction: row; flex-wrap: wrap; }
  .ge-contact-card { grid-template-columns: 160px 1fr; }
  .ge-contact-card-side { grid-column: 1 / -1; }
  .ge-contact-row-grid { grid-template-columns: repeat(2, 1fr); }
  .ge-board { grid-template-columns: 1fr; }
  .ge-event-quick { grid-template-columns: repeat(2, 1fr); }
  .ge-board-grid { grid-template-columns: 1fr; }
  .ge-board-grid--compact { grid-template-columns: 1fr; }
}

@media screen and (max-width: 782px) {
  .admin-bar .ge-header { top: 46px; }
}

/* ====== Mobile (≤ 768px) ====== */
@media (max-width: 768px) {
  :root { --ge-header-h: 84px; }
  .ge-container { padding: 0 20px; }
  .ge-header-inner { padding: 16px 20px; }
  .ge-nav { display: none; }
  .ge-header-actions .ge-btn-member { display: none; }
  .ge-burger { display: inline-flex; }
  .ge-hero { padding: 40px 0 80px; }
  .ge-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .ge-hero-decor { width: 220px; height: 220px; right: 0; top: 16px; opacity: 0.09; }
  .ge-hero-meta { flex-wrap: wrap; gap: 16px; }
  .ge-hero-actions { flex-direction: column; }
  .ge-hero-actions .ge-btn { justify-content: center; }
  .ge-section { padding: 80px 0; }
  .ge-pillars { grid-template-columns: 1fr; }
  .ge-events  { grid-template-columns: 1fr; }
  .ge-next    { grid-template-columns: 1fr; padding: 32px 24px; gap: 24px; }
  .ge-next-body h2 { font-size: 32px; }
  .ge-next-meta { flex-direction: column; gap: 8px; }
  .ge-member { padding: 48px 24px; }
  .ge-social-cta { padding: 48px 24px; }
  .ge-cta-row .ge-social-cta { padding: 48px 24px; }
  .ge-contact-hero { padding: 32px 24px; border-radius: 24px; }
  .ge-contact-hero-inner { grid-template-columns: 1fr; gap: 24px; }
  .ge-contact-hero-name { font-size: 36px; }
  .ge-contact-hero-actions { flex-direction: column; }
  .ge-contact-card { grid-template-columns: 1fr; gap: 24px; padding: 28px 20px; border-radius: 20px; }
  .ge-contact-card-portrait { width: 80px; height: 80px; }
  .ge-contact-card-side { grid-column: unset; }
  .ge-contact-row-grid { grid-template-columns: 1fr; }
  .ge-board { padding: 32px 24px; }
  .ge-footer-top { grid-template-columns: 1fr; }
  .ge-footer { padding: 56px 0 24px; }
  .ge-event-hero { grid-template-columns: 1fr; padding: 32px 0 48px; }
  .ge-event-quick { grid-template-columns: repeat(2, 1fr); margin-bottom: 48px; }
  .ge-formpage-hero h1 { font-size: clamp(36px, 10vw, 64px); }
  .ge-kontakt-body { padding: 40px 0 80px; }
  .ge-form-card { padding: 28px 20px; }
  .ge-login-card { padding: 36px 24px; }
  .ge-cal-row { grid-template-columns: 72px 1fr; }
  .ge-cal-row .ge-cal-meta, .ge-cal-row .ge-cal-cta, .ge-cal-row .ge-cal-status { display: none; }
  .ge-field-2, .ge-field-3-1, .ge-field-1-2 { grid-template-columns: 1fr; }
  .ge-board-grid { grid-template-columns: 1fr; }
  .ge-board-grid--compact { grid-template-columns: 1fr; }
}

/* ==========================================================================
   Donation widget (gemeinsam/donate block)
   ========================================================================== */

.ge-donate {
  background: var(--ge-paper);
  border: 1px solid var(--ge-line);
  border-radius: 24px;
  padding: 32px;
  box-shadow: var(--ge-shadow-card);
  width: 100%;
  position: relative;
  overflow: hidden;
}
.ge-donate::before {
  content: ""; position: absolute; right: -110px; top: -110px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, color-mix(in oklab, var(--ge-accent) 38%, transparent), transparent 65%);
  pointer-events: none;
}
.ge-donate--card    { max-width: 560px; }
.ge-donate--compact { max-width: 340px; padding: 26px; border-radius: 22px; }

.ge-donate-head { position: relative; z-index: 1; margin-bottom: 22px; }
.ge-donate-title {
  font-size: 28px; line-height: 1.05; letter-spacing: -0.02em;
  font-weight: 800; color: var(--ge-green-900);
  margin: 10px 0 8px; text-wrap: balance;
}
.ge-donate--compact .ge-donate-title { font-size: 24px; }
.ge-donate-sub {
  font-size: 14px; line-height: 1.55; color: var(--ge-ink-soft); margin: 0;
  text-wrap: pretty;
}
.ge-donate--compact .ge-donate-sub { font-size: 13px; }

/* Tabs */
.ge-donate-tabs {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px;
  padding: 4px;
  background: var(--ge-cream);
  border: 1px solid var(--ge-line);
  border-radius: var(--ge-radius-pill);
  margin-bottom: 22px;
  position: relative; z-index: 1;
}
.ge-donate-tab {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 14px;
  border: 0; background: transparent;
  border-radius: var(--ge-radius-pill);
  font: inherit; font-size: 13px; font-weight: 600;
  color: var(--ge-ink-soft); cursor: pointer;
  transition: background .15s, color .15s, box-shadow .15s;
}
.ge-donate-tab .icn { width: 14px; height: 14px; flex: 0 0 14px; }
.ge-donate-tab:hover { color: var(--ge-green-900); }
.ge-donate-tab.is-active {
  background: var(--ge-green-900); color: #fff;
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 6px 14px -6px rgba(26,33,18,.4);
}

.ge-donate-body {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; gap: 18px;
}
.ge-donate-field { display: flex; flex-direction: column; gap: 8px; }
.ge-donate-label {
  font-size: 13px; font-weight: 600; color: var(--ge-green-900);
  letter-spacing: -0.005em;
}
.ge-donate-label .req { color: #c93c3c; margin-left: 4px; }
.ge-donate-hint { font-size: 12px; color: var(--ge-ink-mute); }

/* Amount picker */
.ge-donate-amounts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.ge-donate-amt {
  display: flex; flex-direction: column; align-items: flex-start; gap: 2px;
  padding: 12px 14px;
  border: 1.5px solid var(--ge-line);
  background: var(--ge-cream);
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  transition: border-color .15s, background .15s, transform .12s;
  position: relative;
}
.ge-donate-amt:hover { border-color: color-mix(in oklab, var(--ge-primary) 50%, var(--ge-line)); }
.ge-donate-amt.is-active {
  border-color: var(--ge-primary);
  background: var(--ge-green-50);
}
.ge-donate-amt.is-active::after {
  content: ""; position: absolute; top: 8px; right: 8px;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--ge-primary)
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 14 14'><path fill='none' stroke='white' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round' d='M2.5 7.2 5.7 10.4 11.5 3.6'/></svg>")
    no-repeat center;
}
.ge-donate-amt .val {
  font-size: 22px; font-weight: 800; color: var(--ge-green-900); letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.ge-donate-amt .sub {
  font-size: 11px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ge-ink-mute);
}
.ge-donate-amt.is-active .sub { color: var(--ge-primary); }

.ge-donate-amt--custom {
  grid-column: 1 / -1;
  flex-direction: column;
}
.ge-donate-amt--custom .custom-row {
  display: flex; align-items: baseline; gap: 6px; width: 100%;
}
.ge-donate-amt--custom input {
  flex: 1; border: 0; background: transparent; padding: 0;
  font: inherit;
  font-size: 22px; font-weight: 800;
  color: var(--ge-green-900); letter-spacing: -0.02em;
  outline: none;
  font-variant-numeric: tabular-nums;
  -moz-appearance: textfield;
}
.ge-donate-amt--custom input::-webkit-outer-spin-button,
.ge-donate-amt--custom input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.ge-donate-amt--custom .cur {
  font-size: 18px; font-weight: 700; color: var(--ge-green-900);
}

.ge-donate--compact .ge-donate-amt { padding: 10px 12px; }
.ge-donate--compact .ge-donate-amt .val { font-size: 18px; }
.ge-donate--compact .ge-donate-amt--custom input { font-size: 18px; }

/* IBAN input */
.ge-input--iban {
  font-family: ui-monospace, "SF Mono", Menlo, monospace;
  letter-spacing: 0.06em;
  font-size: 14px;
}

/* Consent */
.ge-donate-consent {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 14px 16px;
  background: var(--ge-cream);
  border: 1px solid var(--ge-line);
  border-radius: 12px;
  font-size: 12px; line-height: 1.5; color: var(--ge-ink-soft);
  cursor: pointer;
}
.ge-donate-consent input {
  margin-top: 2px;
  width: 16px; height: 16px;
  accent-color: var(--ge-primary);
  flex: 0 0 16px;
}
.ge-donate-consent strong { color: var(--ge-green-900); font-weight: 600; }
.ge-donate-consent .req { color: #c93c3c; margin-left: 2px; }

/* Submit button */
.ge-donate-submit {
  width: 100%; justify-content: center;
  margin-top: 2px;
  font-size: 15px;
}
.ge-donate-submit:disabled {
  background: var(--ge-green-100); color: var(--ge-ink-mute);
  cursor: not-allowed; transform: none;
}
.ge-donate-submit:disabled:hover { background: var(--ge-green-100); transform: none; }

/* Status */
.ge-donate-status:empty { display: none; }
.ge-donate-status { font-size: 13px; padding: 10px 14px; border-radius: 10px; }

/* Footer note */
.ge-donate-foot {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 0; padding-top: 4px;
  font-size: 11px; color: var(--ge-ink-mute);
  line-height: 1.4;
}
.ge-donate-foot .icn { width: 13px; height: 13px; flex: 0 0 13px; color: var(--ge-primary); }

/* Panels */
.ge-donate-panel { display: flex; flex-direction: column; gap: 18px; }
.ge-donate-panel.is-hidden { display: none; }

/* PayPal panel */
.ge-donate-paypal { display: flex; flex-direction: column; gap: 16px; }
.ge-donate-paypal-card {
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px;
  background: var(--ge-cream);
  border: 1px solid var(--ge-line);
  border-radius: 14px;
}
.ge-donate-paypal-mark {
  width: 44px; height: 44px; border-radius: 10px;
  background: #fff; border: 1px solid var(--ge-line);
  display: inline-flex; align-items: center; justify-content: center;
  flex: 0 0 44px;
}
.ge-donate-paypal-text { display: flex; flex-direction: column; gap: 2px; }
.ge-donate-paypal-text strong {
  font-size: 14px; color: var(--ge-green-900); font-weight: 700;
}
.ge-donate-paypal-text span {
  font-size: 12px; color: var(--ge-ink-soft); line-height: 1.5;
}

@media (prefers-reduced-motion: reduce) {
  .ge-donate-amt { transition: none; }
  .ge-donate-tab { transition: none; }
}

@media (prefers-reduced-motion: reduce) {
  .ge-contact-hero-action,
  .ge-contact-side-row,
  .ge-contact-row-card,
  .ge-contact-row-links a { transition: none; transform: none !important; }
}

/* Event detail — contact person */
.ge-event-contact {
  margin-top: 32px;
  padding: 16px 20px;
  background: var(--ge-cream);
  border: 1px solid var(--ge-line);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ge-event-contact-label {
  font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ge-ink-mute);
}
.ge-event-contact-name {
  font-size: 15px; font-weight: 600; color: var(--ge-green-900);
}

/* Blog category filter */
.ge-blog-filter {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 32px;
}
.ge-blog-filter__link {
  display: inline-block;
  padding: 6px 16px;
  border-radius: var(--ge-radius-pill);
  border: 1.5px solid var(--ge-line);
  background: var(--ge-paper);
  font-size: 13px;
  font-weight: 500;
  color: var(--ge-ink-soft);
  transition: border-color .15s, background .15s, color .15s;
}
.ge-blog-filter__link:hover {
  border-color: var(--ge-primary);
  color: var(--ge-primary);
}
.ge-blog-filter__link.is-active {
  background: var(--ge-primary);
  border-color: var(--ge-primary);
  color: var(--ge-paper);
}
@media (prefers-reduced-motion: reduce) {
  .ge-blog-filter__link { transition: none; }
}
@media (max-width: 600px) {
  .ge-blog-filter {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }
  .ge-blog-filter__link {
    white-space: nowrap;
    flex-shrink: 0;
  }
}
