/* WTW CMS - Public CSS - Bergmann Dienste - 2026 */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@700;900&family=Barlow:wght@400;500;600;700&display=swap');

:root {
  --acc:   #F97316; --acc-d: #e56b0f;
  --dark:  #111111; --dark2: #1a1a1a; --dark3: #222222;
  --bg:    #ffffff; --bg2:   #f5f5f5;
  --bdr:   #e5e5e5; --text:  #111111; --muted: #666666;
  --w: 1160px; --r: 4px;
  --sans: 'Barlow', -apple-system, sans-serif;
  --disp: 'Barlow Condensed', 'Barlow', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--text);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:var(--acc)}
main{min-height:60vh}
.wrap,.container{max-width:var(--w);margin:0 auto;padding:0 1.5rem}

/* HEADER */
.site-header{background:var(--dark2);border-bottom:3px solid var(--acc);position:relative;z-index:200}
.site-header.sticky{position:sticky;top:0}
.site-header.has-bg{background-size:cover;background-position:center}
.hdr-inner{max-width:var(--w);margin:0 auto;padding:0 1.5rem;height:72px;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.hdr-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;flex-shrink:0}
.hdr-logo{height:46px;width:auto;max-width:200px}
.hdr-name{font-family:var(--disp);font-size:1.45rem;font-weight:900;color:#fff;line-height:1;letter-spacing:.02em}
.hdr-tag{font-size:.62rem;color:rgba(255,255,255,.45);letter-spacing:.12em;text-transform:uppercase;margin-top:.15rem}
.hdr-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.hdr-burger span{display:block;width:24px;height:2px;background:#fff;border-radius:2px;transition:transform .3s}
.hdr-social{display:flex;align-items:center;gap:.35rem}
.hdr-social a{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .2s,transform .15s}
.hdr-social a:hover{background:var(--acc);color:#fff}

/* NAV STIL 1: classic (eigene Leiste) */
.nav-classic{background:var(--dark3);border-bottom:1px solid rgba(255,255,255,.07)}
.nav-classic .nav-inner{max-width:var(--w);margin:0 auto;padding:0 1.5rem;display:flex;gap:0}
.nav-classic .nav-inner a{display:flex;align-items:center;gap:.3rem;padding:.72rem 1.1rem;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6);text-decoration:none;border-bottom:3px solid transparent;transition:color .15s,border-color .15s}
.nav-classic .nav-inner a:hover,.nav-classic .nav-inner a.active{color:#fff;border-bottom-color:var(--acc)}

/* NAV STIL 2: bar (im Header integriert) */
.nav-bar{display:flex;align-items:center;gap:.15rem}
.nav-bar a{display:flex;align-items:center;gap:.3rem;padding:.45rem .9rem;border-radius:var(--r);font-size:.82rem;font-weight:600;color:rgba(255,255,255,.65);text-decoration:none;transition:background .15s,color .15s}
.nav-bar a:hover{background:rgba(255,255,255,.1);color:#fff}
.nav-bar a.active{background:rgba(249,115,22,.2);color:var(--acc)}

/* NAV STIL 3: minimal */
.nav-minimal{display:flex;align-items:center;gap:0}
.nav-minimal a{display:flex;align-items:center;gap:.3rem;padding:.5rem 1.25rem;font-size:.88rem;font-weight:500;color:rgba(255,255,255,.55);text-decoration:none;position:relative;transition:color .15s}
.nav-minimal a::after{content:'';position:absolute;bottom:-.5rem;left:50%;right:50%;height:2px;background:var(--acc);transition:left .2s,right .2s}
.nav-minimal a:hover,.nav-minimal a.active{color:#fff}
.nav-minimal a.active::after,.nav-minimal a:hover::after{left:1.25rem;right:1.25rem}

/* Mobile */
@media(max-width:768px){
  .hdr-burger{display:flex} .hdr-social{display:none}
  .nav-bar,.nav-minimal{display:none}
  .nav-bar.open,.nav-minimal.open{display:flex;flex-direction:column;align-items:stretch;background:var(--dark3);width:100%;position:absolute;top:72px;left:0;z-index:100}
  .nav-classic{display:none}
  .nav-classic.open{display:block}
  .nav-classic .nav-inner{flex-direction:column}
}

/* HERO */
.hero{background:var(--dark);position:relative;overflow:hidden;min-height:520px;display:flex;align-items:center}
.hero.has-bg{background-size:cover;background-position:center}
.hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55)}
.hero-inner{position:relative;z-index:1;max-width:var(--w);margin:0 auto;padding:5rem 1.5rem;width:100%}
.hero-eye{font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--acc);margin-bottom:.75rem}
.hero-h1{font-family:var(--disp);font-size:clamp(2.8rem,6vw,5rem);font-weight:900;color:#fff;line-height:1;letter-spacing:-.01em;margin-bottom:1.25rem}
.hero-sub{font-size:1.05rem;color:rgba(255,255,255,.75);line-height:1.7;max-width:560px;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:.75rem;flex-wrap:wrap}

/* SECTIONS */
.section{padding:5rem 0}
.section.bg2{background:var(--bg2)}
.section.dark{background:var(--dark2)}
.sec-head{text-align:center;margin-bottom:3.5rem}
.sec-eye{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--acc);margin-bottom:.5rem}
.sec-head h2{font-family:var(--disp);font-size:2.5rem;font-weight:900;line-height:1.1;margin-bottom:.75rem}
.section.dark .sec-head h2{color:#fff}
.sec-rule{width:48px;height:4px;background:var(--acc);margin:0 auto .75rem}
.sec-sub{font-size:.95rem;color:var(--muted);max-width:520px;margin:0 auto}
.section.dark .sec-sub{color:rgba(255,255,255,.55)}

/* BUTTONS */
.btn-p{display:inline-flex;align-items:center;background:var(--acc);color:#fff;padding:.8rem 1.85rem;border-radius:var(--r);font-weight:700;font-size:.88rem;text-decoration:none;border:2px solid var(--acc);transition:all .2s;text-transform:uppercase;letter-spacing:.06em}
.btn-p:hover{background:var(--acc-d);border-color:var(--acc-d);color:#fff}
.btn-ghost{display:inline-flex;align-items:center;background:transparent;color:#fff;padding:.8rem 1.85rem;border-radius:var(--r);font-weight:700;font-size:.88rem;text-decoration:none;border:2px solid rgba(255,255,255,.45);transition:all .2s;text-transform:uppercase;letter-spacing:.06em}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);color:#fff}
.btn-o{display:inline-flex;align-items:center;background:transparent;color:var(--text);padding:.8rem 1.85rem;border-radius:var(--r);font-weight:700;font-size:.88rem;text-decoration:none;border:2px solid var(--bdr);transition:all .2s;text-transform:uppercase;letter-spacing:.06em}
.btn-o:hover{border-color:var(--acc);color:var(--acc)}
/* Aliases for old class names */
.btn-primary{display:inline-flex;align-items:center;background:var(--acc);color:#fff;padding:.8rem 1.85rem;border-radius:var(--r);font-weight:700;font-size:.88rem;text-decoration:none;border:2px solid var(--acc);transition:all .2s;text-transform:uppercase;letter-spacing:.06em}
.btn-primary:hover{background:var(--acc-d);color:#fff}
.btn-outline{display:inline-flex;align-items:center;background:transparent;color:var(--text);padding:.8rem 1.85rem;border-radius:var(--r);font-weight:700;font-size:.88rem;text-decoration:none;border:2px solid var(--bdr);transition:all .2s;text-transform:uppercase;letter-spacing:.06em}
.btn-outline:hover{border-color:var(--acc);color:var(--acc)}

/* LEISTUNGEN */
.leistungen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch}
.leistung-card{text-decoration:none;display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.08);height:100%}
.leistung-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.18)}
.leistung-icon{font-size:2rem;line-height:1}
.leistung-titel{font-family:var(--disp);font-size:1.1rem;font-weight:700;line-height:1.2;margin-bottom:.25rem}
.leistung-text{font-size:.84rem;line-height:1.6;opacity:.85;flex:1}

/* STATS */
.stats-section{padding:4rem 0;background:var(--bg2)}
.stats-grid{display:flex;justify-content:space-around;flex-wrap:wrap;gap:2.5rem}
.stat-item{text-align:center;min-width:120px}
.stat-zahl{font-family:var(--disp);font-size:3.5rem;font-weight:900;color:var(--acc);line-height:1}
.stat-text{font-size:.8rem;color:var(--muted);margin-top:.5rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600}

/* TEAM */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.team-card{padding:2rem 1.5rem;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.07);transition:box-shadow .2s,transform .2s}
.team-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.12);transform:translateY(-2px)}
.team-av{width:80px;height:80px;border-radius:50%;background:var(--acc);color:#fff;font-family:var(--disp);font-size:2rem;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;overflow:hidden}
.team-avatar{width:90px;height:90px;border-radius:50%;background:var(--acc);color:#fff;font-family:var(--disp);font-size:2.2rem;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem}
.team-foto-wrap{width:110px;height:110px;overflow:hidden;margin:0 auto 1.25rem;border:3px solid rgba(0,0,0,.1)}
.team-foto{width:100%;height:100%;object-fit:cover;display:block}
.team-av img{width:100%;height:100%;object-fit:cover}
.team-name{font-family:var(--disp);font-size:1.15rem;font-weight:700;margin-bottom:.25rem}
.team-rolle{font-size:.72rem;color:var(--acc);font-weight:600;text-transform:uppercase;letter-spacing:.1em}

/* REFERENZEN */
.refs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.ref-card{background:#222;aspect-ratio:4/3;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:1.25rem;text-decoration:none;color:#fff;position:relative;overflow:hidden;transition:transform .25s}
.ref-card:hover{transform:scale(1.02)}
.ref-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .4s}
.ref-card:hover img{transform:scale(1.06)}
.ref-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 60%);opacity:0;transition:opacity .25s}
.ref-card:hover::after{opacity:1}
.ref-label{position:relative;z-index:1;background:#fff;color:var(--text);padding:.35rem .75rem;font-family:var(--disp);font-size:.82rem;font-weight:700;letter-spacing:.04em;transform:translateY(8px);opacity:0;transition:transform .25s,opacity .25s}
.ref-card:hover .ref-label{transform:translateY(0);opacity:1}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.blog-card{background:var(--bg);border:1px solid var(--bdr);padding:1.75rem;text-decoration:none;color:var(--text);border-top:3px solid var(--acc);transition:box-shadow .2s;display:flex;flex-direction:column;gap:.5rem}
.blog-card:hover{box-shadow:0 4px 20px rgba(0,0,0,.1);color:var(--text)}
.blog-titel{font-family:var(--disp);font-size:1.1rem;font-weight:700;line-height:1.25}
.blog-meta{font-size:.73rem;color:var(--muted)}
.blog-auszug{font-size:.84rem;color:var(--muted);line-height:1.6;margin-top:.25rem}

/* PAGE HERO */
.page-hero{background:var(--dark2);padding:4rem 1.5rem 3rem;position:relative;overflow:hidden}
.page-hero.has-bg{background-size:cover;background-position:center}
.page-hero::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-family:var(--disp);font-size:2.8rem;font-weight:900;color:#fff;letter-spacing:.01em}
.page-hero .sub{color:rgba(255,255,255,.55);font-size:.95rem;margin-top:.4rem}
.breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.73rem;color:rgba(255,255,255,.4);margin-bottom:.75rem}
.breadcrumb a{color:rgba(255,255,255,.4);text-decoration:none}
.breadcrumb a:hover{color:var(--acc)}

/* CMS CONTENT */
.cms-content p{margin-bottom:1em;line-height:1.8}
.cms-content h2{font-family:var(--disp);font-size:1.7rem;font-weight:700;margin:2rem 0 .75rem}
.cms-content h3{font-family:var(--disp);font-size:1.3rem;font-weight:700;margin:1.5rem 0 .5rem}
.cms-content ul,.cms-content ol{padding-left:1.4em;margin-bottom:1em}
.cms-content li{margin-bottom:.35em}
.cms-content img{border-radius:var(--r);margin:1rem 0}
.aside-box{background:var(--bg2);border:1px solid var(--bdr);padding:1.5rem;margin-bottom:1.5rem}
.aside-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--acc);margin-bottom:1rem}
.aside-link{display:block;padding:.45rem .6rem;text-decoration:none;font-size:.83rem;border-left:3px solid transparent;color:var(--text);transition:all .15s}
.aside-link:hover{border-left-color:var(--bdr);color:var(--acc)}
.aside-link.active{border-left-color:var(--acc);color:var(--acc);font-weight:600}
.aside-cta{background:var(--acc);padding:1.5rem;border-radius:var(--r)}

/* FOOTER */
.site-footer{background:var(--dark);border-top:3px solid var(--acc);position:relative}
.site-footer.has-bg{background-size:cover;background-position:center}
.site-footer.has-bg::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.75)}
.footer-inner{position:relative;z-index:1;max-width:var(--w);margin:0 auto;padding:3.5rem 1.5rem 2rem;display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem}
.footer-logo{height:40px;width:auto;margin-bottom:.75rem}
.footer-name{font-family:var(--disp);font-size:1.35rem;font-weight:900;color:#fff;margin-bottom:.25rem}
.footer-text{font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.7;max-width:300px;margin-top:.5rem}
.footer-contact a{display:block;font-size:.83rem;color:rgba(255,255,255,.5);text-decoration:none;margin-top:.35rem;transition:color .15s}
.footer-contact a:hover{color:var(--acc)}
.footer-col-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.3);margin-bottom:1rem}
.footer-nav a{display:block;font-size:.83rem;color:rgba(255,255,255,.45);text-decoration:none;margin-bottom:.45rem;transition:color .15s}
.footer-nav a:hover{color:var(--acc)}
.footer-socials{display:flex;flex-direction:row;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}
.footer-socials .social-link{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.1);color:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .2s,transform .15s}
.footer-socials .social-link:hover{background:var(--acc);color:#fff;transform:translateY(-2px)}
.footer-socials .social-link svg{width:16px;height:16px;display:block}
.footer-copy{position:relative;z-index:1;max-width:var(--w);margin:0 auto;padding:1.25rem 1.5rem;border-top:1px solid rgba(255,255,255,.08);font-size:.73rem;color:rgba(255,255,255,.25);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.footer-copy a{color:rgba(255,255,255,.35);text-decoration:none}
.footer-copy a:hover{color:var(--acc)}

/* RESPONSIVE */
@media(max-width:960px){
  .leistungen-grid,.team-grid,.refs-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .leistungen-grid,.team-grid,.refs-grid,.blog-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .hero-h1{font-size:2.5rem}
}

/* -- Nav zentriert -- */
.nav-classic .nav-inner.centered { justify-content: center; }
.nav-classic.nav-centered .nav-inner { justify-content: center; }
.nav-bar.centered { justify-content: center; }

/* -- Hero-H-he aus config -- */
.hero { min-height: var(--hero-h, 520px); }

/* -- Hero align -- */
.hero.align-center .hero-inner { text-align: center; }
.hero.align-center .hero-btns  { justify-content: center; }
.hero.align-center .hero-sub   { margin-left: auto; margin-right: auto; }
.hero.align-right  .hero-inner { text-align: right; }
.hero.align-right  .hero-btns  { justify-content: flex-end; }

.leistung-card-img { width:100%; height:160px; object-fit:cover; display:block; }
.leistung-badge {
  display: inline-block;
  background: var(--acc);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .2rem .5rem;
  border-radius: 20px;
  margin-bottom: .4rem;
}
.leistung-preis {
  font-size: .78rem;
  color: var(--acc);
  font-weight: 700;
  margin-top: .4rem;
}
.leistung-btn {
  display: inline-block;
  margin-top: .75rem;
  padding: .4rem .9rem;
  background: var(--acc);
  color: #fff;
  border-radius: 6px;
  font-size: .75rem;
  font-weight: 600;
  text-decoration: none;
}

/* -- Hero Slider -- */
.hero-slider { position: relative; overflow: hidden; }
.hero-slide { display: none; }
.hero-slide.active { display: block; }
.hero-dots {
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: .5rem;
  z-index: 10;
}
.hero-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.4);
  cursor: pointer;
  border: none;
  transition: background .2s, transform .2s;
}
.hero-dot.active { background: #fff; transform: scale(1.3); }
.hero-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,.15);
  border: none;
  color: #fff;
  width: 44px; height: 44px;
  border-radius: 50%;
  font-size: 1.2rem;
  cursor: pointer;
  z-index: 10;
  transition: background .2s;
  display: flex; align-items: center; justify-content: center;
}
.hero-arrow:hover { background: rgba(255,255,255,.3); }
.hero-arrow.prev { left: 1.5rem; }
.hero-arrow.next { right: 1.5rem; }

/* -- Referenzen Seite ----------------------- */
.ref-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 2rem;
}
.ref-filter-btn {
  padding: .4rem 1.1rem;
  border-radius: 20px;
  border: 1.5px solid #ddd;
  background: #fff;
  color: #555;
  font-size: .78rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .15s;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
.ref-filter-btn:hover,
.ref-filter-btn.active {
  background: var(--acc);
  border-color: var(--acc);
  color: #fff;
}
.ref-filter-cnt {
  background: rgba(255,255,255,.3);
  border-radius: 10px;
  padding: .05rem .4rem;
  font-size: .68rem;
}
.ref-filter-btn:not(.active) .ref-filter-cnt {
  background: #f0f0f0;
  color: #888;
}
.refs-page-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.25rem;
}
.refs-page-item {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: #111;
  aspect-ratio: 4/3;
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
  transition: transform .2s, box-shadow .2s;
}
.refs-page-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
}
.refs-page-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.refs-page-item:hover img { transform: scale(1.04); }
.refs-page-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.8));
  padding: 1.5rem .85rem .85rem;
  transform: translateY(100%);
  transition: transform .2s;
}
.refs-page-item:hover .refs-page-overlay { transform: translateY(0); }
.refs-page-kat {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--acc);
  background: rgba(249,115,22,.15);
  padding: .15rem .45rem;
  border-radius: 3px;
}
.refs-page-titel {
  font-weight: 700;
  font-size: .88rem;
  color: #fff;
  margin-top: .3rem;
}
.refs-page-desc {
  font-size: .72rem;
  color: rgba(255,255,255,.7);
  margin-top: .2rem;
}

/* -- Referenzen Startseiten-Sektion -------- */
.refs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1rem;
}
.ref-card {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: #222;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
  transition: transform .2s, box-shadow .2s;
}
.ref-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0,0,0,.22);
}
.ref-card img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform .3s;
}
.ref-card:hover img { transform: scale(1.05); }
.ref-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.75));
  padding: 1.2rem .75rem .75rem;
  transform: translateY(100%);
  transition: transform .2s;
}
.ref-card:hover .ref-overlay { transform: translateY(0); }
.ref-label {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--acc);
}

/* Social Icons */
.social-links{display:flex;gap:.75rem;align-items:center}
.social-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--acc);color:#fff;text-decoration:none;transition:background .15s,transform .15s,box-shadow .15s;font-size:1rem}
.social-link:hover{background:var(--acc-dark,#d95e00);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.18)}
.social-link svg{width:15px;height:15px;fill:currentColor}

/* -- Responsive: 3-Spalten Block -- */
@media (max-width: 768px) {
  .section [style*="grid-template-columns:1fr 1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  .section [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

.footer-address { font-size:.82rem; color:rgba(255,255,255,.6); line-height:1.6; margin-bottom:.5rem; }

/* -- Icon-Grid Block --------------------------- */
.icon-grid-item {
  transition: transform .18s ease, box-shadow .18s ease;
}
.icon-grid-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
}
.icon-grid-icon svg {
  width: 100%;
  height: 100%;
}
.icon-grid-titel {
  font-family: var(--disp, sans-serif);
}

/* Responsive: Grid kollabiert auf Mobil */
@media (max-width: 640px) {
  .icon-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 400px) {
  .icon-grid {
    grid-template-columns: 1fr !important;
  }
}

/* == Kontaktseite ================================================= */
.kontakt-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}
.kontakt-h2 {
  font-size: 1.3rem;
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid var(--acc);
  display: inline-block;
}
.kontakt-details { display: flex; flex-direction: column; gap: 1rem; margin-bottom: 2rem; }
.kontakt-item {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  font-size: .9rem;
  line-height: 1.6;
}
.kontakt-icon {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--acc);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: #fff;
}
.kontakt-icon svg { width: 18px; height: 18px; }
.kontakt-item a { color: inherit; text-decoration: none; }
.kontakt-item a:hover { color: var(--acc); }

.kontakt-social { margin-bottom: 2rem; }
.kontakt-social-title { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--muted); margin-bottom: .6rem; }
.kontakt-social-icons { display: flex; gap: .5rem; }

.kontakt-map { border-radius: 10px; overflow: hidden; margin-top: .5rem; box-shadow: 0 4px 20px rgba(0,0,0,.1); }

/* Formular */
.kontakt-form-wrap {
  background: var(--bg2, #f9f9f9);
  border-radius: 14px;
  padding: 2.5rem;
  box-shadow: 0 4px 24px rgba(0,0,0,.07);
}
.kontakt-form { display: flex; flex-direction: column; gap: 1rem; margin-top: .5rem; }
.kf-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.kontakt-form .fg { display: flex; flex-direction: column; gap: .3rem; }
.kontakt-form label { font-size: .78rem; font-weight: 600; color: var(--muted); }
.kontakt-form .req { color: var(--acc); }
.kontakt-form input,
.kontakt-form textarea,
.kontakt-form select {
  padding: .65rem .85rem;
  border: 1.5px solid var(--border, #e5e5e5);
  border-radius: 7px;
  font-family: inherit;
  font-size: .9rem;
  background: #fff;
  transition: border-color .15s;
  width: 100%;
}
.kontakt-form input:focus,
.kontakt-form textarea:focus { outline: none; border-color: var(--acc); }
.kontakt-form textarea { resize: vertical; min-height: 130px; }
.kontakt-form .btn-primary { align-self: flex-start; margin-top: .25rem; }

.kontakt-success {
  display: flex; align-items: center; gap: .6rem;
  background: #ecfdf5; color: #065f46;
  border: 1px solid #6ee7b7;
  border-radius: 8px; padding: .85rem 1rem;
  font-size: .88rem; margin-bottom: 1.25rem;
}
.kontakt-error {
  background: #fef2f2; color: #991b1b;
  border: 1px solid #fca5a5;
  border-radius: 8px; padding: .85rem 1rem;
  font-size: .88rem; margin-bottom: 1.25rem;
}

@media (max-width: 768px) {
  .kontakt-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .kf-row2 { grid-template-columns: 1fr; }
  .kontakt-form-wrap { padding: 1.5rem; }
}

/* == Kontaktseite Karte full-width ============================== */
.kontaktseite-karte { margin-top:2.5rem; border-radius:0; overflow:hidden; }
.kontaktseite-karte iframe { display:block; border:0; width:100%; }

/* == Impressum-Block ============================================= */
.imp-block h2 { font-size:1.4rem; margin:0 0 1.5rem; }
.imp-block h2:not(:first-child) { margin-top:2.5rem; font-size:1.1rem; padding-top:1rem; border-top:1px solid var(--border); }
.imp-card {
  display:flex; align-items:flex-start; gap:1rem;
  background:var(--bg2,#f8f8f8); border-radius:10px;
  padding:1rem 1.25rem; margin-bottom:.75rem;
  border:1px solid var(--border,#eee);
  font-size:.9rem; line-height:1.7;
}
.imp-card-icon {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  background:var(--acc); color:#fff;
  display:flex; align-items:center; justify-content:center;
  margin-top:.1rem;
}
.imp-card-label {
  font-size:.7rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; color:var(--muted); margin-bottom:.2rem;
}
.imp-card a { color:inherit; }
.imp-card a:hover { color:var(--acc); }
.imp-extra { margin-top:2rem; }
.imp-extra h2 { font-size:1.15rem !important; margin-top:2rem !important; border-top:1px solid var(--border); padding-top:1rem; }
.imp-extra p { font-size:.9rem; line-height:1.75; color:var(--muted); }
