/* ═══════════════════════════════════════════════════════════
   NAVBAR – VOLLSTÄNDIG KORREKTE IMPLEMENTIERUNG
   ═══════════════════════════════════════════════════════════ */

/* Reset */
* { box-sizing: border-box; }

/* Navbar wrapper */
#navbar {
  background: #fff;
  border-bottom: 1px solid #e5e7eb;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

/* Inner row */
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 68px;
  padding: 0 24px;
}

/* Logo */
.nav-logo img {
  height: 52px;
  width: auto;
  border-radius: 10px;
  object-fit: contain;
  display: block;
}

/* ── Desktop Nav Links ─────────────────────────────────── */
.nav-links {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.nav-links > li { position: relative; }
.nav-links > li > a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  border-radius: 8px;
  font-size: .9rem;
  font-weight: 600;
  color: #1a2332;
  text-decoration: none;
  transition: background .2s, color .2s;
}
.nav-links > li > a:hover { background: #f3f4f6; color: #F59E0B; }
.nav-links > li > a svg { transition: transform .2s; }


/* Dropdown */
.dropdown {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  box-shadow: 0 4px 24px rgba(0,0,0,.12);
  min-width: 220px;
  padding: 8px;
  z-index: 100;
}

.dropdown a {
  display: block;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: .875rem;
  font-weight: 500;
  color: #1a2332;
  text-decoration: none;
  transition: background .15s, color .15s;
}
.dropdown a:hover { background: #FEF3C7; color: #D97706; }

/* Call button */
.nav-inner > div > .btn {
  white-space: nowrap;
}

/* ── Hamburger Button ──────────────────────────────────── */
.hamburger {
  display: none;          /* hidden on desktop */
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  z-index: 200;
}
.hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: #1a2332;
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}
/* Hamburger → X animation */
.hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu {
  display: flex;
  flex-direction: column;
  gap: 4px;
  background: #fff;
  border-top: 1px solid #e5e7eb;
  padding: 0 16px;
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease, padding .3s ease;
}
.mobile-menu.open {
  max-height: 1000px;
  padding: 12px 16px 20px;
}
.mobile-menu a {
  display: block;
  padding: 11px 16px;
  border-radius: 8px;
  font-weight: 600;
  font-size: .95rem;
  color: #1a2332;
  text-decoration: none;
  transition: background .15s;
}
.mobile-menu a:hover { background: #f3f4f6; }
.mobile-menu .btn {
  margin-top: 8px;
  justify-content: center;
  display: flex;
}


/* ── Mobile Menu ───────────────────────────────────────── */

/* ── Responsive Breakpoints ────────────────────────────── */
@media (max-width: 1023px) {
  .nav-inner { padding: 0 16px; }
}

@media (max-width: 767px) {
  /* Show hamburger, hide desktop nav */
  .hamburger         { display: flex !important; }
  .nav-links         { display: none !important; }
  .nav-inner > div > .btn { display: none; }   /* hide call button on mobile (shown in menu) */
  .nav-inner         { height: 60px; }
  .nav-logo img      { height: 44px; }
}


/* ═══ Page Styles ═══ */
/* Base mobile improvements */
html { -webkit-text-size-adjust: 100%; }
* { -webkit-tap-highlight-color: transparent; }
a, button { touch-action: manipulation; }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:#1a2332;background:#fff;line-height:1.6;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
h1,h2,h3,h4{line-height:1.2}

/* VARS */
:root{
  --orange:#F59E0B;
  --orange-dark:#D97706;
  --orange-light:#FEF3C7;
  --navy:#1a2332;
  --navy2:#243044;
  --gray:#6b7280;
  --gray-light:#f3f4f6;
  --gray-bg:#f8fafc;
  --white:#fff;
  --border:#e5e7eb;
  --radius:12px;
  --radius-lg:16px;
  --shadow:0 2px 12px rgba(0,0,0,.08);
  --shadow-md:0 4px 24px rgba(0,0,0,.12);
}

/* UTILITY */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.section-sm{padding:56px 0}
.tag{display:inline-block;background:var(--orange-light);color:#92400e;font-size:.8rem;font-weight:600;padding:6px 16px;border-radius:50px;margin-bottom:16px}
.section-title{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:var(--navy);margin-bottom:12px}
.section-title span{color:var(--orange)}
.section-sub{font-size:1rem;color:var(--gray);max-width:580px}
.check{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--navy)}
.check svg{color:var(--orange);flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 24px;border-radius:50px;font-weight:700;font-size:.95rem;cursor:pointer;border:none;transition:all .2s;font-family:inherit}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 6px 20px rgba(245,158,11,.4)}
.btn-white{background:#fff;color:var(--navy);border:2px solid #fff}
.btn-white:hover{background:var(--gray-light)}
.btn-outline-dark{background:#25D366;color:#fff;border:1.5px solid #25D366}
.btn-outline-dark:hover{background:#128C4A;border-color:#128C4A;transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,211,102,.4)}
.btn-ghost{background:rgba(26,35,50,.08);color:var(--navy)}
.btn-ghost:hover{background:rgba(26,35,50,.15)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{background:#1da851}

/* TOP BAR */







/* NAVBAR */

#navbar.scrolled{box-shadow:var(--shadow-md)}












/* Dropdown */




.nav-cta{display:flex;align-items:center;gap:8px}







/* Mobile Accordion */











/* HERO */
#hero{background:var(--navy);position:relative;overflow:hidden;min-height:88vh;display:flex;align-items:center}
/* HERO: Split layout - Text Left / Image Right */
#hero{min-height:100vh;display:flex;align-items:stretch;padding-top:72px;background:var(--navy);overflow:hidden}
.hero-split{display:grid;grid-template-columns:1fr 1fr;width:100%;min-height:calc(100vh - 72px)}
/* LEFT: Text column */
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:60px 56px 60px 24px;max-width:720px;margin-left:auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;font-size:.82rem;font-weight:700;padding:8px 18px;border-radius:50px;margin-bottom:28px;width:fit-content}
.hero-badge svg{flex-shrink:0}
.hero-title{font-size:clamp(1.9rem,3.5vw,3.2rem);font-weight:800;color:#fff;margin-bottom:20px;line-height:1.1}
.hero-title span{color:var(--orange)}
.hero-desc{font-size:clamp(.88rem,1.4vw,1rem);color:rgba(255,255,255,.8);margin-bottom:32px;line-height:1.75}
.hero-desc strong{color:#fff}
.hero-desc a{color:var(--orange);transition:opacity .2s}
.hero-desc a:hover{opacity:.8}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.hero-trust{display:flex;flex-direction:column;gap:9px;align-items:flex-start;padding-top:24px;border-top:1px solid rgba(255,255,255,.12)}
.hero-trust-label{font-size:1rem;font-weight:700;color:var(--orange);letter-spacing:.02em;margin-bottom:6px}
.hero-trust-item{display:flex;align-items:center;gap:8px;font-size:.88rem;color:rgba(255,255,255,.85)}
.hero-trust-item svg{color:var(--orange);flex-shrink:0}
/* RIGHT: Image column */
.hero-right{position:relative;overflow:hidden;min-height:500px}
.hero-right img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero-right::before{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--navy) 0%,transparent 20%);z-index:1}
/* Responsive */
@media(max-width:900px){
  #hero{padding-top:56px}
  .hero-split{grid-template-columns:1fr;min-height:auto}
  .hero-right{height:320px;order:-1}
  .hero-right::before{background:linear-gradient(to top,var(--navy) 0%,transparent 40%)}
  .hero-left{padding:40px 24px 48px;max-width:100%;margin:0;align-items:center;text-align:center}
  .hero-badge{margin-left:auto;margin-right:auto}
  .hero-btns{justify-content:center}
  .hero-trust{align-items:center}
  .hero-trust-item{justify-content:center}
}
@media(max-width:480px){
  .hero-left{padding:32px 16px 40px;align-items:center;text-align:center}
  .hero-title{font-size:1.75rem}
  .hero-btns{flex-direction:column;align-items:center}
  .hero-btns .btn{justify-content:center;width:100%;max-width:320px}
  .hero-right{height:260px}
}

/* STATS BAR */
.stats-bar{background:var(--orange);padding:36px 24px}
.stats-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-item{text-align:center;color:#fff}
.stat-icon{margin-bottom:8px;opacity:.9}
.stat-number{font-size:2.4rem;font-weight:800;display:block;line-height:1}
.stat-label{font-size:.85rem;opacity:.85;margin-top:4px}

/* SERVICES */
#services{background:var(--gray-bg)}
.services-header{text-align:center;margin-bottom:48px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service-card{background:#fff;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.service-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.service-card-img{position:relative;height:200px;overflow:hidden}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.service-card:hover .service-card-img img{transform:scale(1.05)}
.service-card-icon{position:absolute;bottom:16px;left:16px;width:44px;height:44px;background:var(--orange);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem}
.service-card-body{padding:24px}
.service-card-body h3{font-size:1.1rem;font-weight:800;color:var(--navy);margin-bottom:10px}
.service-card-body h3 a{color:var(--orange)}
.service-card-body p{font-size:.875rem;color:var(--gray);line-height:1.65;margin-bottom:14px}
.service-list{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.service-list li{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--navy)}
.service-list li svg{color:var(--orange);flex-shrink:0}
.service-link{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:700;color:var(--orange);transition:gap .2s}
.service-link:hover{gap:10px}
/* Wide cards (2-col) */
.services-grid-wide{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}
.service-card-wide{background:#fff;border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow);display:flex;gap:20px;align-items:flex-start;transition:transform .25s,box-shadow .25s}
.service-card-wide:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.service-wide-icon{width:52px;height:52px;background:var(--orange-light);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:1.4rem;flex-shrink:0}
.service-wide-body h3{font-size:1rem;font-weight:800;color:var(--navy);margin-bottom:6px}
.service-wide-body p{font-size:.855rem;color:var(--gray);line-height:1.6;margin-bottom:12px}
.service-wide-list{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;list-style:none}
.service-wide-list li{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--navy)}
.service-wide-list li svg{color:var(--orange);flex-shrink:0}

/* PROCESS */
#process{background:#fff}
.process-header{text-align:center;margin-bottom:56px}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-steps::before{content:'';position:absolute;top:36px;left:calc(12.5% + 16px);right:calc(12.5% + 16px);height:2px;background:repeating-linear-gradient(90deg,var(--border) 0,var(--border) 8px,transparent 8px,transparent 16px)}
.process-step{text-align:center;padding:0 8px}
.process-num{font-size:2rem;font-weight:800;color:var(--orange-light);margin-bottom:4px}
.process-icon-wrap{width:64px;height:64px;background:var(--orange);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#fff;font-size:1.4rem;position:relative;z-index:1}
.process-step h4{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.process-step p{font-size:.85rem;color:var(--gray);line-height:1.6}

/* ABOUT */
#about{background:var(--navy);color:#fff}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-tag{background:var(--orange);color:#fff}
.about-title{color:#fff;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:800;margin-bottom:20px}
.about-title span{color:var(--orange)}
.about-text{color:rgba(255,255,255,.75);font-size:.95rem;line-height:1.75;margin-bottom:16px}
.about-text a{color:var(--orange)}
.about-highlights{display:flex;gap:24px;flex-wrap:wrap;margin-top:24px}
.about-hl{display:flex;align-items:center;gap:8px;font-size:.875rem;color:rgba(255,255,255,.8)}
.about-hl svg{color:var(--orange)}
.about-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-stat-card{background:var(--orange);border-radius:var(--radius-lg);padding:28px 24px;color:#fff;text-align:center}
.about-stat-card svg{margin-bottom:8px;opacity:.9}
.about-stat-num{font-size:2.4rem;font-weight:800;display:block}
.about-stat-label{font-size:.85rem;opacity:.85}
.about-img-card{border-radius:var(--radius-lg);overflow:hidden}
.about-img-card img{width:100%;height:100%;object-fit:cover;min-height:160px}
.about-dark-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:28px 24px;text-align:center}
.about-dark-card svg{color:var(--orange);margin-bottom:8px}
.about-dark-card .num{font-size:2.4rem;font-weight:800;color:var(--orange);display:block}
.about-dark-card .lbl{font-size:.85rem;color:rgba(255,255,255,.7)}

/* HANNOVER */
#hannover{background:var(--orange-light)}
.hannover-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.hannover-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.hannover-img img{width:100%;height:400px;object-fit:cover}
.hannover-link{display:inline-flex;align-items:center;gap:6px;font-size:.875rem;font-weight:600;color:#92400e;margin-top:16px;transition:gap .2s}
.hannover-link:hover{gap:10px}

/* SERVICE AREAS */
#areas{background:var(--gray-bg)}
.areas-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}
.area-card{background:#fff;border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow)}
.area-card-head{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.area-card-head svg{color:var(--orange)}
.area-card-head h3{font-size:1.1rem;font-weight:800;color:var(--navy)}
.area-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.area-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--navy)}
.area-item svg{color:var(--orange);flex-shrink:0}
.area-note{font-size:.82rem;color:var(--gray);margin-top:16px;font-style:italic}
.areas-radius{background:var(--orange-light);border-radius:var(--radius-lg);padding:40px;text-align:center}
.radius-circle{width:120px;height:120px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 0 0 16px rgba(245,158,11,.15),0 0 0 32px rgba(245,158,11,.07)}
.radius-circle svg{color:var(--orange);margin-bottom:4px}
.radius-circle strong{font-size:1.1rem;font-weight:800;color:var(--navy)}
.radius-circle span{font-size:.75rem;color:var(--gray)}

/* WHY US */
#why{background:#fff}
.why-header{text-align:center;margin-bottom:48px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{text-align:center;padding:32px 20px;border-radius:var(--radius-lg);background:var(--gray-bg)}
.why-icon{width:60px;height:60px;background:var(--orange-light);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:1.3rem;color:var(--orange)}
.why-card h4{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:8px}
.why-card p{font-size:.855rem;color:var(--gray);line-height:1.65}

/* REVIEWS */
#reviews{background:var(--gray-bg)}
.reviews-header{text-align:center;margin-bottom:48px}
.overall-row{display:inline-flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);padding:14px 24px;border-radius:50px;box-shadow:var(--shadow);margin-bottom:40px}
.overall-score{font-size:2rem;font-weight:800;color:var(--navy)}
.overall-right{text-align:left}
.overall-stars{color:#FBBC04;font-size:1.1rem;display:block}
.google-badge{display:flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:#4285F4;margin-top:3px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}
.review-card{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);transition:transform .2s}
.review-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.review-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.review-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#0077B6,#0EA5E9);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;color:#fff;flex-shrink:0}
.review-name{font-weight:700;font-size:.95rem;color:var(--navy)}
.review-time{font-size:.78rem;color:var(--gray);margin-top:2px}
.review-stars{color:#FBBC04;font-size:.95rem;margin-bottom:8px}
.review-text{font-size:.875rem;color:var(--gray);line-height:1.65}
.reviews-cta{text-align:center}
.reviews-cta a{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#4285F4;border:1.5px solid #4285F4;padding:12px 24px;border-radius:50px;font-weight:700;font-size:.875rem;transition:all .2s}
.reviews-cta a:hover{background:#4285F4;color:#fff}

/* FAQ */
#faq{background:#fff}
.faq-header{text-align:center;margin-bottom:48px}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:#fff}
.faq-q{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 24px;cursor:pointer;transition:background .15s}
.faq-q:hover{background:var(--gray-bg)}
.faq-q-inner{display:flex;flex-direction:column;gap:4px;flex:1}
.faq-tag-small{font-size:.7rem;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.05em}
.faq-q-text{font-weight:700;font-size:.9rem;color:var(--navy);line-height:1.4}
.faq-toggle{width:28px;height:28px;background:var(--orange-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--orange);font-size:1.1rem;flex-shrink:0;margin-top:2px;transition:transform .3s,background .2s}
.faq-item.open .faq-toggle{transform:rotate(45deg);background:var(--orange);color:#fff}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .3s;font-size:.875rem;color:var(--gray);line-height:1.7}
.faq-item.open .faq-a{max-height:300px;padding:0 24px 20px}
.faq-wide{grid-column:span 2}

/* BOOKING */
#booking{background:var(--gray-bg)}
.booking-header{text-align:center;margin-bottom:40px}
.calendar-widget{background:#fff;border-radius:var(--radius-lg);max-width:800px;margin:0 auto;padding:28px;box-shadow:var(--shadow)}
.calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.calendar-head h3{font-size:1rem;font-weight:800;color:var(--navy);display:flex;align-items:center;gap:8px}
.calendar-head h3 svg{color:var(--orange)}
.calendar-nav{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--gray)}
.cal-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.cal-btn:hover{background:var(--gray-light)}
.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:24px}
.cal-day{border-radius:10px;border:1px solid var(--border);padding:12px 8px;text-align:center;cursor:pointer;transition:all .15s}
.cal-day:hover{border-color:var(--orange);background:var(--orange-light)}
.cal-day .day-name{font-size:.72rem;color:var(--gray);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.cal-day .day-num{font-size:1.3rem;font-weight:800;color:var(--navy);margin:4px 0}
.cal-day .day-free{font-size:.72rem;color:#16a34a;font-weight:600}
.cal-day.today .day-num{color:var(--orange)}
.calendar-contact{text-align:center;padding-top:20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.calendar-contact span{font-size:.875rem;color:var(--gray)}

/* CTA BANNER */
#cta{background:linear-gradient(135deg,var(--orange) 0%,var(--orange-dark) 100%);padding:64px 24px;text-align:center}
#cta h2{font-size:clamp(1.8rem,4vw,2.6rem);font-weight:800;color:#fff;margin-bottom:12px}
#cta p{color:rgba(255,255,255,.85);font-size:1rem;margin-bottom:32px;max-width:560px;margin-left:auto;margin-right:auto}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:24px}
.cta-trust{display:flex;gap:28px;justify-content:center;flex-wrap:wrap}
.cta-trust-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:rgba(255,255,255,.85)}
.cta-trust-item svg{opacity:.9}

/* FOOTER */
footer{background:var(--gray-bg);border-top:1px solid var(--border);padding:56px 24px 0}
.footer-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid var(--border)}
.footer-brand-logo{display:flex;align-items:center;gap:0;margin-bottom:16px}
.footer-brand-logo img{width:auto;height:60px;max-width:200px;border-radius:10px;object-fit:contain}
.footer-brand-name{display:none}
.footer-brand-name span{font-size:.7rem;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.06em}
.footer-brand p{font-size:.875rem;color:var(--gray);line-height:1.65;margin-bottom:16px}
.footer-contact{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-contact li{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--gray)}
.footer-contact li svg{color:var(--orange);flex-shrink:0}
.footer-contact li a{color:var(--gray);transition:color .15s}
.footer-contact li a:hover{color:var(--orange)}
.footer-col h4{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--navy);margin-bottom:16px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{font-size:.875rem;color:var(--gray);transition:color .15s}
.footer-col ul li a:hover{color:var(--orange)}
.footer-bottom{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:20px 0;font-size:.82rem;color:var(--gray)}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{color:var(--gray);transition:color .15s}
.footer-bottom-links a:hover{color:var(--navy)}

/* STICKY WA */
.sticky-wa{position:fixed;bottom:24px;right:24px;z-index:999;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,.5);transition:transform .2s}
.sticky-wa:hover{transform:scale(1.1)}

/* RESPONSIVE */
@media(max-width:1024px){
  .services-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  
  
  .services-grid{grid-template-columns:1fr}
  .services-grid-wide{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr 1fr;gap:24px}
  .process-steps::before{display:none}
  .hannover-grid{grid-template-columns:1fr}
  .areas-grid{grid-template-columns:1fr}
  .area-cols{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .reviews-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
  .faq-wide{grid-column:span 1}
  .about-visual{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .calendar-days{grid-template-columns:repeat(4,1fr)}
  .section{padding:56px 0}
  
}
@media(max-width:480px){
  .hero-btns{flex-direction:column;align-items:center}
  .stats-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  .calendar-days{grid-template-columns:repeat(3,1fr)}
  .area-cols{grid-template-columns:1fr}
  .about-visual{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════════════
   VOLLSTÄNDIGES RESPONSIVE DESIGN - ALLE GERÄTE
   ═══════════════════════════════════════════════ */

/* Hover-Effekte für klickbare Links im Topbar */




/* ── DESKTOP GROSSE BILDSCHIRME (1400px+) ── */
@media(min-width:1400px){
  .container{ max-width:1320px }
  .hero-title{ font-size:4.5rem }
  .section-title{ font-size:2.8rem }
  .services-grid{ grid-template-columns:repeat(3,1fr) }
  .reviews-grid{ grid-template-columns:repeat(3,1fr) }
}

/* ── DESKTOP NORMAL (1024px - 1399px) ── */
@media(min-width:1024px) and (max-width:1399px){
  .container{ max-width:1200px }
  .hero-title{ font-size:3.8rem }
  .services-grid{ grid-template-columns:repeat(3,1fr) }
}

/* ── TABLET LANDSCAPE (768px - 1023px) ── */
@media(min-width:768px) and (max-width:1023px){
  .container{ padding:0 32px }
  
  
  
  
  .nav-cta .nav-phone-link{ display:none }
  .hero-title{ font-size:3rem }
  .hero-content{ padding:40px 32px }
  .stats-grid{ grid-template-columns:repeat(4,1fr) }
  .stat-number{ font-size:2rem }
  .services-grid{ grid-template-columns:repeat(2,1fr) }
  .services-grid-wide{ grid-template-columns:repeat(2,1fr) }
  .service-card-img{ height:180px }
  .process-steps{ grid-template-columns:repeat(2,2fr); gap:32px }
  .process-steps::before{ display:none }
  .about-grid{ grid-template-columns:1fr; gap:40px }
  .about-visual{ grid-template-columns:1fr 1fr }
  .hannover-grid{ grid-template-columns:1fr; gap:32px }
  .hannover-img img{ height:300px }
  .areas-grid{ grid-template-columns:1fr 1fr }
  .area-cols{ grid-template-columns:1fr 1fr }
  .why-grid{ grid-template-columns:repeat(2,1fr) }
  .reviews-grid{ grid-template-columns:repeat(2,1fr) }
  .faq-grid{ grid-template-columns:1fr }
  .faq-wide{ grid-column:span 1 }
  .calendar-days{ grid-template-columns:repeat(7,1fr) }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px }
  .footer-bottom{ flex-direction:column; gap:10px; text-align:center }
  
}

/* ── TABLET PORTRAIT / GROSSES HANDY (480px - 767px) ── */
@media(min-width:480px) and (max-width:767px){
  
  
  
  
  
  .section{ padding:48px 0 }
  .section-sm{ padding:36px 0 }
  .container{ padding:0 16px }
  .hero-content{ padding:40px 16px }
  .hero-title{ font-size:2.2rem; letter-spacing:-.01em }
  .hero-desc{ font-size:.95rem }
  .hero-btns{ flex-direction:column; align-items:center; gap:10px }
  .hero-btns .btn{ width:100%; max-width:320px; justify-content:center; padding:14px 20px }
  .hero-trust{ gap:8px; align-items:center }
  .hero-trust-item{ font-size:.82rem }
  .stats-bar{ padding:24px 16px }
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:20px }
  .stat-number{ font-size:1.9rem }
  .stat-label{ font-size:.78rem }
  .services-header{ margin-bottom:32px }
  .section-title{ font-size:1.6rem }
  .section-sub{ font-size:.9rem }
  .services-grid{ grid-template-columns:1fr; gap:16px }
  .service-card-img{ height:200px }
  .services-grid-wide{ grid-template-columns:1fr; gap:16px }
  .service-card-wide{ flex-direction:column; gap:14px }
  .service-wide-list{ grid-template-columns:1fr }
  .process-steps{ grid-template-columns:1fr; gap:20px }
  .process-steps::before{ display:none }
  .about-grid{ grid-template-columns:1fr; gap:36px }
  .about-visual{ grid-template-columns:1fr 1fr }
  .about-stat-num{ font-size:2rem }
  .hannover-grid{ grid-template-columns:1fr; gap:24px }
  .hannover-img img{ height:240px }
  .areas-grid{ grid-template-columns:1fr; gap:16px }
  .area-cols{ grid-template-columns:1fr 1fr }
  .why-grid{ grid-template-columns:1fr; gap:14px }
  .why-card{ padding:24px 16px }
  .reviews-grid{ grid-template-columns:1fr; gap:14px }
  .faq-grid{ grid-template-columns:1fr }
  .faq-wide{ grid-column:span 1 }
  .calendar-widget{ padding:20px 16px }
  .calendar-days{ grid-template-columns:repeat(4,1fr); gap:6px }
  .cal-day{ padding:10px 4px }
  .cal-day .day-num{ font-size:1.1rem }
  .cta-btns{ flex-direction:column; align-items:center; gap:10px }
  .cta-btns .btn{ width:100%; max-width:320px; justify-content:center }
  .cta-trust{ flex-direction:column; align-items:center; gap:8px }
  .footer-grid{ grid-template-columns:1fr; gap:28px }
  .footer-bottom{ flex-direction:column; gap:10px; text-align:center }
  .footer-links{ justify-content:center; flex-wrap:wrap }
  .sticky-wa{ bottom:16px; right:16px; width:50px; height:50px }
  .overall-rating{ flex-direction:column; text-align:center }
  .overall-row{ flex-direction:column; text-align:center; gap:8px }
}

/* ── KLEINES HANDY (max 479px) ── */
@media(max-width:479px){
  
  
  
  
  
  
  .section{ padding:40px 0 }
  .container{ padding:0 14px }
  .hero-content{ padding:32px 14px }
  .hero-title{ font-size:1.85rem; line-height:1.15 }
  .hero-badge{ font-size:.75rem; padding:6px 14px }
  .hero-desc{ font-size:.88rem; line-height:1.65 }
  .hero-btns{ flex-direction:column; align-items:stretch; gap:10px }
  .hero-btns .btn{ justify-content:center; padding:14px 16px; font-size:.9rem }
  .hero-trust{ gap:8px; align-items:center }
  .hero-trust-item{ font-size:.8rem }
  .stats-bar{ padding:20px 14px }
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:16px }
  .stat-number{ font-size:1.7rem }
  .stat-icon svg{ width:22px; height:22px }
  .stat-label{ font-size:.75rem }
  .section-title{ font-size:1.5rem }
  .section-sub{ font-size:.88rem }
  .tag{ font-size:.75rem; padding:5px 12px }
  .services-header{ margin-bottom:24px; text-align:center }
  .services-grid{ grid-template-columns:1fr; gap:14px }
  .service-card-img{ height:180px }
  .service-card-body{ padding:18px }
  .service-card-body h3{ font-size:1rem }
  .services-grid-wide{ grid-template-columns:1fr; gap:14px }
  .service-card-wide{ flex-direction:column; padding:20px }
  .service-wide-list{ grid-template-columns:1fr }
  .process-header{ text-align:center }
  .process-steps{ grid-template-columns:1fr; gap:20px }
  .process-steps::before{ display:none }
  .process-num{ font-size:1.5rem }
  .process-icon-wrap{ width:52px; height:52px; font-size:1.2rem }
  .about-grid{ grid-template-columns:1fr; gap:28px }
  .about-visual{ grid-template-columns:1fr 1fr }
  .about-stat-num{ font-size:1.8rem }
  .about-dark-card .num{ font-size:1.8rem }
  .about-title{ font-size:1.6rem }
  .about-highlights{ flex-direction:column; gap:10px }
  .hannover-grid{ grid-template-columns:1fr; gap:20px }
  .hannover-img img{ height:200px }
  .areas-grid{ grid-template-columns:1fr; gap:14px }
  .area-card{ padding:20px }
  .area-cols{ grid-template-columns:1fr 1fr; gap:6px }
  .area-item{ font-size:.78rem }
  .why-grid{ grid-template-columns:1fr; gap:12px }
  .why-card{ padding:20px 14px }
  .why-icon{ width:50px; height:50px; font-size:1.1rem }
  .reviews-grid{ grid-template-columns:1fr; gap:12px }
  .review-card{ padding:18px }
  .overall-row{ flex-direction:column; text-align:center; padding:12px 16px }
  .faq-grid{ grid-template-columns:1fr }
  .faq-wide{ grid-column:span 1 }
  .faq-q{ padding:16px 18px }
  .faq-item.open .faq-a{ padding:0 18px 18px }
  .calendar-widget{ padding:16px 12px }
  .calendar-days{ grid-template-columns:repeat(3,1fr); gap:5px }
  .cal-day{ padding:8px 4px }
  .cal-day .day-num{ font-size:1rem }
  .cal-day .day-free{ font-size:.65rem }
  .calendar-contact{ flex-direction:column; gap:8px }
  .calendar-contact .btn{ width:100%; justify-content:center }
  #cta{ padding:48px 14px }
  #cta h2{ font-size:1.6rem }
  .cta-btns{ flex-direction:column; align-items:stretch; gap:10px }
  .cta-btns .btn{ justify-content:center; font-size:.9rem }
  .cta-trust{ flex-direction:column; align-items:center; gap:8px; font-size:.8rem }
  footer{ padding:40px 14px 0 }
  .footer-grid{ grid-template-columns:1fr; gap:24px }
  .footer-brand-logo img{ height:44px }
  .footer-bottom{ flex-direction:column; gap:8px; text-align:center; font-size:.78rem }
  .footer-links{ justify-content:center; flex-wrap:wrap; gap:12px }
  .sticky-wa{ bottom:14px; right:14px; width:48px; height:48px }
  .sticky-wa svg{ width:22px; height:22px }
  .btn{ font-size:.88rem }
  
  .service-link{ font-size:.82rem }
  .radius-circle{ width:100px; height:100px }
  .radius-circle strong{ font-size:1rem }
}

/* ── TOUCH-GERÄTE: Hover-Effekte optimieren ── */
@media(hover:none){
  .service-card:hover{ transform:none; box-shadow:var(--shadow) }
  .btn:hover{ transform:none }
  .btn-orange:hover{ box-shadow:none }
}

/* ── BILDER RESPONSIVE ── */
img{ max-width:100%; height:auto }
.service-card-img img{ width:100%; height:100%; object-fit:cover }
.about-img-card img{ width:100%; object-fit:cover; min-height:140px; max-height:200px }
.hannover-img img{ width:100% }

/* ── NAVBAR STICKY MOBILE FIX ── */


/* ── SMOOTH TRANSITIONS ── */
.btn, a, .service-card, .review-card, .why-card, .faq-item, .cal-day{
  transition: all .2s ease;
}


/* ─── INTRO SECTION (Text + Bild) ─────────────────── */
#intro { background: #f8fafc; }


.intro-text-col h2 {
  font-size: clamp(1.4rem, 2.8vw, 2rem);
  font-weight: 800;
  color: var(--navy);
  line-height: 1.2;
  margin-bottom: 20px;
  letter-spacing: -.02em;
}
.intro-text-col h2 span { color: var(--orange); }
.intro-text-col p {
  font-size: .96rem;
  color: var(--gray);
  margin-bottom: 16px;
  line-height: 1.75;
}
.intro-text-col h3 {
  font-size: .88rem;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin: 24px 0 14px;
}

.intro-benefits li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .94rem;
  font-weight: 600;
  color: var(--navy);
}
.intro-benefits li svg { color: var(--orange); flex-shrink: 0; }


.intro-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  transition: transform .4s ease;
}
.intro-img-wrap:hover img { transform: scale(1.02); 
  
  
}








@media(max-width:480px){
  
  .intro-text-col h2 { font-size:1.35rem }
  
}


/* ─── ANFRAGE MODAL ─────────────────────────── */
#anfrage-modal{
  display:none; position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.65); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:16px;
}
.modal-box{
  background:#fff; border-radius:20px; padding:40px 36px;
  width:100%; max-width:520px; position:relative;
  box-shadow:0 24px 64px rgba(0,0,0,.3);
  max-height:90vh; overflow-y:auto;
}
.modal-close{
  position:absolute; top:16px; right:16px;
  width:36px; height:36px; border-radius:50%;
  background:#f3f4f6; border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:#6b7280; transition:background .2s;
}
.modal-close:hover{background:#e5e7eb; color:#111}
.modal-box h3{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1.4rem; font-weight:800; color:#1a2332; margin-bottom:6px;
}
.modal-box p{font-size:.88rem; color:#6b7280; margin-bottom:24px}
.modal-form .form-group{margin-bottom:14px}
.modal-form label{
  display:block; font-size:.82rem; font-weight:600;
  color:#1a2332; margin-bottom:5px;
}
.modal-form input,
.modal-form textarea,
.modal-form select{
  width:100%; padding:12px 14px;
  border:1.5px solid #e5e7eb; border-radius:10px;
  font-family:'Plus Jakarta Sans',sans-serif; font-size:.9rem;
  color:#1a2332; outline:none; transition:border-color .2s;
  background:#f9fafb; -webkit-appearance:none;
}
.modal-form input:focus,
.modal-form textarea:focus,
.modal-form select:focus{border-color:#F59E0B; background:#fff}
.modal-form textarea{resize:vertical; min-height:90px}
.modal-form select option{background:#fff}
.modal-submit{
  width:100%; padding:15px; background:#F59E0B; color:#fff;
  border:none; border-radius:50px; font-family:'Plus Jakarta Sans',sans-serif;
  font-size:1rem; font-weight:700; cursor:pointer;
  transition:background .2s, transform .2s;
  margin-top:8px;
}
.modal-submit:hover{background:#D97706; transform:translateY(-1px)}
.modal-wa-alt{
  display:flex; align-items:center; justify-content:center;
  gap:8px; margin-top:16px; font-size:.85rem; color:#6b7280;
}
.modal-wa-alt a{
  display:inline-flex; align-items:center; gap:6px;
  color:#25D366; font-weight:700; text-decoration:none;
}
@media(max-width:480px){
  .modal-box{padding:28px 20px}
  .modal-box h3{font-size:1.2rem}
}


/* Upload area */
.upload-label{
  display:flex;align-items:center;gap:10px;
  border:2px dashed #e5e7eb;border-radius:10px;
  padding:14px 16px;cursor:pointer;
  font-size:.88rem;color:#6b7280;
  transition:border-color .2s,background .2s;
  background:#f9fafb;
}
.upload-label:hover{border-color:#F59E0B;background:#fffbeb;color:#92400e}
.upload-label svg{flex-shrink:0;color:#F59E0B}
.photo-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.photo-preview img{width:70px;height:70px;object-fit:cover;border-radius:8px;border:2px solid #e5e7eb}

@keyframes spin{to{transform:rotate(360deg)}}

/* Hamburger → X Animation */

/* ── Mobile Accordion ── */
.mob-link{display:block;padding:12px 20px;font-weight:600;color:#1a2332;text-decoration:none;border-bottom:1px solid #f3f4f6}
.mob-link:hover{background:#FEF3C7;color:#D97706}
.mob-accordion{border-bottom:1px solid #f3f4f6}
.mob-accordion-head{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;font-weight:700;color:#1a2332;cursor:pointer;user-select:none;transition:background .15s}
.mob-accordion-head:hover{background:#f3f4f6}
.mob-accordion-head svg{transition:transform .3s;flex-shrink:0;color:#F59E0B}
.mob-accordion.open .mob-accordion-head svg{transform:rotate(180deg)}
.mob-accordion-body{max-height:0;overflow:hidden;transition:max-height .35s ease}
.mob-accordion.open .mob-accordion-body{max-height:500px}
.mob-accordion-body a{display:block;padding:10px 20px 10px 32px;font-size:.9rem;font-weight:500;color:#6b7280;text-decoration:none;transition:color .15s,background .15s;border-bottom:1px solid #f9fafb}
.mob-accordion-body a:hover{color:#D97706;background:#FEF3C7}









@media(max-width:600px){
  
  
  
}

/* ── Topbar ── */
.topbar{background:#1a2332;padding:8px 24px;font-size:.82rem;color:rgba(255,255,255,.8)}
.topbar-inner{max-width:1200px;margin:0 auto;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.topbar-item{display:flex;align-items:center;gap:6px;white-space:nowrap}
.topbar-item a{color:rgba(255,255,255,.8);text-decoration:none;transition:color .15s}
.topbar-item a:hover{color:#F59E0B}
.topbar-item svg{opacity:.7;flex-shrink:0}
@media(max-width:700px){
  .topbar{padding:6px 14px;font-size:.76rem}
  .topbar-inner{justify-content:center;gap:12px}
}
