@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;0,700;1,400&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap');
:root{--green:#1a5e3a;--green-mid:#2a7d50;--green-light:#e8f5ee;--gold:#c9950e;--gold-light:#fef3d6;--dark:#1c2b1e;--mid:#4a6352;--soft:#8aab96;--bg:#fafaf7;--cream:#f3f0e8;--white:#ffffff;--border:#dde8e2;--r:12px;--r-lg:20px;--shadow:0 2px 12px rgba(26,94,58,0.08);--shadow-lg:0 8px 32px rgba(26,94,58,0.12)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--dark);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.topbar{background:var(--dark);color:rgba(255,255,255,.55);font-size:.75rem;padding:7px 0;letter-spacing:.02em}
.topbar-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.topbar a{color:rgba(255,255,255,.55);transition:color .2s}.topbar a:hover{color:var(--gold)}
.topbar-links{display:flex;gap:20px}
header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.logo{display:flex;align-items:center;gap:13px;text-decoration:none;flex-shrink:0}
.logo-text{line-height:1.25}
.logo-name{font-family:'Lora',serif;font-weight:700;font-size:1.15rem;color:var(--dark);display:block}
.logo-sub{font-size:.68rem;color:var(--soft);font-weight:400;text-transform:uppercase;letter-spacing:.09em}
nav{display:flex;gap:2px;align-items:center}
nav a{color:var(--mid);font-size:.875rem;font-weight:500;padding:8px 13px;border-radius:8px;transition:all .2s;white-space:nowrap}
nav a:hover,nav a.active{background:var(--green-light);color:var(--green)}
.nav-cta{background:var(--green)!important;color:white!important;margin-left:8px;padding:8px 16px!important;border-radius:8px!important}
.nav-cta:hover{background:var(--green-mid)!important}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px;color:var(--dark)}
.page-hero{background:var(--green);background-image:radial-gradient(ellipse 80% 70% at 80% 50%,rgba(42,125,80,.6),transparent 65%);color:white;padding:56px 28px 68px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.04) 1px,transparent 0);background-size:28px 28px;pointer-events:none}
.page-hero-inner{max-width:1200px;margin:0 auto;position:relative}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;color:rgba(255,255,255,.5);margin-bottom:14px}
.breadcrumb a{color:rgba(255,255,255,.5)}.breadcrumb a:hover{color:white}
.page-hero h1{font-family:'Lora',serif;font-size:clamp(1.9rem,4vw,2.9rem);font-weight:700;line-height:1.15;letter-spacing:-.01em;margin-bottom:12px}
.page-hero p{font-size:1rem;color:rgba(255,255,255,.72);max-width:580px;line-height:1.7}
.quicklinks{background:white;border-bottom:1px solid var(--border);padding:0 28px}
.quicklinks-inner{max-width:1200px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none}
.quicklinks-inner::-webkit-scrollbar{display:none}
.quick-link{display:flex;align-items:center;gap:8px;padding:15px 20px;color:var(--mid);font-size:.84rem;font-weight:500;white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s}
.quick-link:hover{color:var(--green);border-color:var(--green);background:var(--green-light)}
.content-wrap{max-width:1200px;margin:0 auto;padding:52px 28px;display:grid;grid-template-columns:1fr 310px;gap:40px;align-items:start}
.content-wrap.full{grid-template-columns:1fr}
.sidebar{display:flex;flex-direction:column;gap:20px}
.section-tag{display:inline-flex;align-items:center;gap:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--green);margin-bottom:10px}
.section-tag::before{content:'';display:block;width:20px;height:2px;background:var(--gold)}
.section-title{font-family:'Lora',serif;font-size:1.85rem;font-weight:700;color:var(--dark);margin-bottom:26px;line-height:1.2;letter-spacing:-.01em}
.prose h2{font-family:'Lora',serif;font-size:1.35rem;font-weight:700;color:var(--dark);margin:32px 0 12px}
.prose h3{font-size:1rem;font-weight:700;color:var(--green);margin:22px 0 8px}
.prose p{color:var(--mid);line-height:1.8;margin-bottom:14px}
.prose ul{margin:10px 0 18px 18px}
.prose ul li{color:var(--mid);line-height:1.7;margin-bottom:5px}
.prose a{color:var(--green)}
.card{background:white;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.card-head{padding:13px 17px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-head-title{font-family:'Lora',serif;font-weight:700;font-size:.92rem;color:var(--dark)}
.card-head a{font-size:.74rem;color:var(--green);font-weight:600}
.card-body{padding:17px}
.news-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px;display:flex;gap:14px;align-items:flex-start;transition:all .22s;box-shadow:var(--shadow)}
.news-card:hover{border-color:var(--green);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.news-icon{width:38px;height:38px;background:var(--green-light);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.92rem;flex-shrink:0}
.news-meta{font-size:.7rem;color:var(--soft);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-bottom:5px}
.news-title{font-size:.91rem;font-weight:600;color:var(--dark);line-height:1.4}
.news-arr{color:var(--green);margin-top:3px;flex-shrink:0;opacity:0;transition:opacity .2s}
.news-card:hover .news-arr{opacity:1}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:18px}
.grid-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;gap:9px;transition:all .22s;box-shadow:var(--shadow)}
.grid-card:hover{border-color:var(--green);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.grid-card-icon{font-size:1.5rem}
.grid-card h3{font-family:'Lora',serif;font-size:1rem;font-weight:700;color:var(--dark)}
.grid-card p{font-size:.84rem;color:var(--mid);line-height:1.55}
.grid-card .card-link{font-size:.79rem;color:var(--green);font-weight:600;margin-top:auto}
.item-list{list-style:none}
.item-list li{border-bottom:1px solid var(--border)}
.item-list li:last-child{border-bottom:none}
.item-list li a{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 13px;color:var(--mid);font-size:.875rem;font-weight:500;transition:all .18s;background:white}
.item-list li a:hover{background:var(--green-light);color:var(--green);padding-left:17px}
.info-box{background:var(--green-light);border:1px solid rgba(26,94,58,.18);border-radius:var(--r);padding:16px 18px;margin-bottom:22px}
.info-box-title{font-weight:700;color:var(--green);margin-bottom:6px;font-size:.87rem}
.info-box p{color:var(--mid);font-size:.86rem;margin:0;line-height:1.6}
.sidebar-nav{background:white;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.sidebar-nav-title{padding:11px 15px;border-bottom:1px solid var(--border);font-weight:700;font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--soft);background:var(--bg)}
.sidebar-nav ul{list-style:none}
.sidebar-nav ul li a{display:block;padding:9px 15px;color:var(--mid);font-size:.875rem;font-weight:500;transition:all .18s;border-left:2px solid transparent}
.sidebar-nav ul li a:hover,.sidebar-nav ul li a.active{color:var(--green);background:var(--green-light);border-left-color:var(--green)}
.iserv-mini{background:linear-gradient(135deg,var(--green),var(--green-mid));border-radius:var(--r);padding:20px;color:white;box-shadow:var(--shadow)}
.iserv-mini h4{font-family:'Lora',serif;font-size:.95rem;font-weight:700;margin-bottom:5px}
.iserv-mini p{font-size:.81rem;color:rgba(255,255,255,.7);margin-bottom:13px;line-height:1.5}
.iserv-mini a{display:inline-block;background:white;color:var(--green);font-weight:700;font-size:.81rem;padding:8px 16px;border-radius:7px;transition:all .2s}
.iserv-mini a:hover{background:var(--gold-light)}
.contact-box{background:white;border:1px solid var(--border);border-radius:var(--r);padding:17px;box-shadow:var(--shadow)}
.contact-box h4{font-family:'Lora',serif;font-size:.93rem;font-weight:700;color:var(--dark);margin-bottom:12px}
.contact-row{display:flex;gap:9px;margin-bottom:9px;font-size:.86rem;color:var(--mid);align-items:flex-start}
.contact-row .ci{flex-shrink:0;margin-top:1px}
.contact-row a{color:var(--green)}.contact-row a:hover{text-decoration:underline}
.tbl{width:100%;border-collapse:collapse;font-size:.87rem}
.tbl th{background:var(--green);color:white;padding:9px 13px;text-align:left;font-size:.79rem;font-weight:600}
.tbl td{padding:9px 13px;border-bottom:1px solid var(--border);color:var(--mid)}
.tbl tr:last-child td{border-bottom:none}
.tbl .pause-row td{background:var(--cream)!important;color:var(--soft);font-style:italic}
.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:9px;font-size:.88rem;font-weight:600;text-decoration:none;transition:all .2s;cursor:pointer;border:none;font-family:inherit}
.btn-green{background:var(--green);color:white}.btn-green:hover{background:var(--green-mid);transform:translateY(-1px)}
.btn-outline{background:white;color:var(--green);border:1.5px solid var(--green)}.btn-outline:hover{background:var(--green-light)}
.btn-gold{background:var(--gold);color:white}.btn-gold:hover{background:#b8840c;transform:translateY(-1px)}
footer{background:var(--dark);color:rgba(255,255,255,.5);padding:56px 28px 24px}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:22px}
.footer-brand .logo-name{color:white}
.footer-brand .logo-sub{color:rgba(255,255,255,.35)}
.footer-brand p{font-size:.82rem;line-height:1.75;margin-top:14px;max-width:250px}
.footer-col h4{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.75);margin-bottom:13px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul a{color:rgba(255,255,255,.44);font-size:.83rem;transition:color .2s}
.footer-col ul a:hover{color:rgba(255,255,255,.9)}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.75rem}
.footer-bottom a{color:rgba(255,255,255,.33)}.footer-bottom a:hover{color:rgba(255,255,255,.7)}
.footer-legal{display:flex;gap:18px}
.footer-credit{color:rgba(255,255,255,.22);font-size:.7rem}
@media(max-width:980px){
  .hero-inner,.content-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .jg-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  nav{display:none}.menu-toggle{display:block}
  .footer-grid{grid-template-columns:1fr}
  .topbar-info{display:none}
}

/* ── FOCUS STYLES (Barrierefreiheit) ── */
:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 3px;
  border-radius: 4px;
}
a:focus-visible, button:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 3px;
}
nav a:focus-visible {
  background: var(--green-light);
  color: var(--green);
  outline: 3px solid var(--gold);
}
.nav-cta:focus-visible {
  background: var(--green-mid) !important;
  outline: 3px solid var(--gold);
}
.btn:focus-visible {
  outline: 3px solid var(--gold);
  outline-offset: 3px;
  transform: translateY(-1px);
}
/* Smooth scrolling */
html { scroll-behavior: smooth; }

/* Skip link for keyboard users */
.skip-link {
  position: absolute;
  top: -100px;
  left: 16px;
  background: var(--gold);
  color: var(--dark);
  font-weight: 700;
  font-size: .9rem;
  padding: 10px 18px;
  border-radius: 0 0 8px 8px;
  z-index: 999;
  transition: top .2s;
}
.skip-link:focus { top: 0; }

/* Print styles */
@media print {
  header, footer, .topbar, .quicklinks, .sidebar, .menu-toggle, nav { display: none !important; }
  .content-wrap { grid-template-columns: 1fr !important; }
  .page-hero { background: none !important; color: var(--dark) !important; padding: 16px 0 !important; }
  .page-hero h1, .page-hero p { color: var(--dark) !important; }
  body { font-size: 11pt; }
  a::after { content: " (" attr(href) ")"; font-size: .8em; color: #666; }
  .btn { border: 1px solid #999 !important; }
}
