/* ========================================================================
   Harix Transport — Custom WordPress Theme
   Modern, fast, SEO-friendly. Mobile-first.
   ======================================================================== */

:root{
  --primary:#1565FF;
  --primary-dark:#0D4BCC;
  --primary-light:#E8F0FF;
  --dark:#0A0E27;
  --dark-2:#1A1F3A;
  --gray-900:#1F2937;
  --gray-700:#374151;
  --gray-500:#6B7280;
  --gray-300:#D1D5DB;
  --gray-100:#F3F4F6;
  --gray-50:#F8FAFC;
  --white:#ffffff;
  --success:#10B981;
  --shadow-sm:0 1px 2px rgba(10,14,39,.06);
  --shadow:0 4px 12px rgba(10,14,39,.08);
  --shadow-lg:0 20px 50px rgba(10,14,39,.15);
  --radius:12px;
  --radius-lg:20px;
  --container:1200px;
  --header-h:84px;
  --transition:all .25s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  margin:0;
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  font-size:16px;
  line-height:1.65;
  color:var(--gray-900);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--primary-dark)}
h1,h2,h3,h4,h5,h6{
  font-family:'Inter',sans-serif;
  color:var(--dark);
  line-height:1.2;
  margin:0 0 .6em;
  font-weight:800;
  letter-spacing:-.02em;
}
h1{font-size:clamp(2rem,5vw,3.5rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}
h3{font-size:clamp(1.25rem,2.5vw,1.6rem)}
p{margin:0 0 1em}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
section{padding:80px 0}
@media (max-width:768px){section{padding:56px 0}}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:14px 28px;
  border-radius:10px;
  font-weight:600;
  font-size:15px;
  border:2px solid transparent;
  cursor:pointer;
  transition:var(--transition);
  text-decoration:none;
  white-space:nowrap;
}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(21,101,255,.35)}
.btn-primary:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px rgba(21,101,255,.45)}
.btn-outline{background:transparent;color:var(--dark);border-color:var(--gray-300)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-white{background:#fff;color:var(--dark)}
.btn-white:hover{background:var(--primary-light);color:var(--primary-dark)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--gray-100);
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:var(--header-h);
  gap:24px;
}
.site-logo img{height:46px;width:auto}
.site-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:4px;align-items:center}
.site-nav a{
  display:block;
  padding:8px 12px;
  color:var(--gray-900);
  font-weight:500;
  font-size:14px;
  border-radius:8px;
  white-space:nowrap;
}
.site-nav a:hover,.site-nav .current-menu-item>a{color:var(--primary);background:var(--primary-light)}
.header-cta{display:flex;align-items:center;gap:12px}
.header-phone{
  display:flex;align-items:center;gap:8px;
  color:var(--dark);font-weight:600;font-size:14px;
  white-space:nowrap;
}
.header-phone svg{color:var(--primary)}

.menu-toggle{
  display:none;
  background:none;border:none;cursor:pointer;padding:8px;
}
.menu-toggle span{
  display:block;width:26px;height:2px;background:var(--dark);
  margin:6px 0;transition:var(--transition);border-radius:2px;
}

@media (max-width:960px){
  .site-nav,.header-phone{display:none}
  .menu-toggle{display:block}
  .site-nav.is-open{
    display:block;
    position:absolute;top:var(--header-h);left:0;right:0;
    background:#fff;border-top:1px solid var(--gray-100);
    box-shadow:var(--shadow);padding:16px 24px;
  }
  .site-nav.is-open ul{flex-direction:column;align-items:stretch;gap:4px}
  .menu-toggle.is-active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .menu-toggle.is-active span:nth-child(2){opacity:0}
  .menu-toggle.is-active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .header-cta .btn{padding:10px 18px;font-size:13px}
}
@media (max-width:480px){
  .header-cta .btn{padding:8px 14px;font-size:12px}
  .site-header .container{gap:12px}
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:120px 0 100px;
  background:linear-gradient(135deg,rgba(10,14,39,.95) 0%,rgba(21,101,255,.85) 100%);
  color:#fff;
  overflow:hidden;
}
.hero .hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.2s ease;z-index:0}
.hero .hero-slide.active{opacity:1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,14,39,.82) 0%,rgba(21,101,255,.7) 100%);z-index:1;pointer-events:none}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(21,101,255,.35),transparent 60%);
  pointer-events:none;
}
.hero>.container{position:relative;z-index:2}
.hero-inner{position:relative;max-width:780px}
.hero .eyebrow{
  display:inline-block;
  padding:8px 16px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  border-radius:999px;
  font-size:13px;
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  margin-bottom:24px;
  backdrop-filter:blur(8px);
}
.hero h1{color:#fff;margin-bottom:20px}
.hero .lead{font-size:20px;opacity:.95;max-width:640px;margin-bottom:36px}
@media (max-width:768px){.hero .lead{font-size:17px}.hero{padding:80px 0 64px}}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:480px){.hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}}

.hero-stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  margin-top:60px;
  padding-top:40px;
  border-top:1px solid rgba(255,255,255,.15);
  position:relative;
}
.hero-stats .stat{text-align:center}
.hero-stats .stat strong{display:block;font-size:2rem;font-weight:800;color:#fff;margin-bottom:4px}
.hero-stats .stat span{font-size:14px;opacity:.85;display:block;line-height:1.3}
@media (max-width:768px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:20px}}
@media (max-width:480px){.hero-stats{grid-template-columns:repeat(2,1fr);gap:16px}.hero-stats .stat strong{font-size:1.6rem}}

/* ---------- Sections ---------- */
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-head .eyebrow{
  display:inline-block;
  color:var(--primary);
  font-weight:700;
  font-size:13px;
  letter-spacing:.1em;
  text-transform:uppercase;
  margin-bottom:12px;
}
.section-head p{color:var(--gray-500);font-size:18px;margin:0}

/* ---------- Services grid ---------- */
.services{background:var(--gray-50)}
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
}
@media (max-width:768px){.services-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}}
@media (max-width:480px){.services-grid{grid-template-columns:1fr}}
.service-card{
  background:#fff;
  padding:36px 32px;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  border:1px solid var(--gray-100);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.service-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--primary),var(--primary-dark));
  transform:scaleX(0);transform-origin:left;transition:var(--transition);
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}
.service-card:hover::before{transform:scaleX(1)}
.service-icon{
  width:56px;height:56px;border-radius:14px;
  background:var(--primary-light);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:20px;
}
.service-card h3{margin-bottom:12px}
.service-card p{color:var(--gray-500);margin-bottom:20px}
.service-card .link{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:600;font-size:14px;color:var(--primary);
}
.service-card .link:hover{gap:10px}

/* ---------- Features (Why Us) ---------- */
.features-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:32px;
}
.feature{display:flex;gap:16px;align-items:flex-start}
.feature-icon{
  flex-shrink:0;width:48px;height:48px;border-radius:12px;
  background:var(--primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
}
.feature h3{font-size:1.1rem;margin-bottom:6px}
.feature p{color:var(--gray-500);font-size:15px;margin:0}

/* ---------- Fleet ---------- */
.fleet{background:var(--dark);color:#fff;position:relative;overflow:hidden}
.fleet::before{
  content:"";position:absolute;top:-50%;right:-20%;width:80%;height:200%;
  background:radial-gradient(circle,rgba(21,101,255,.2),transparent 60%);
  pointer-events:none;
}
.fleet h2,.fleet .section-head p{color:#fff;position:relative}
.fleet .section-head p{opacity:.8}
.fleet-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:20px;
  position:relative;
}
@media (max-width:768px){.fleet-grid{grid-template-columns:repeat(2,1fr);gap:16px}}
@media (max-width:480px){.fleet-grid{grid-template-columns:1fr}}
.fleet-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.1);
  padding:28px;
  border-radius:var(--radius);
  backdrop-filter:blur(6px);
  transition:var(--transition);
}
.fleet-card:hover{background:rgba(255,255,255,.08);border-color:rgba(21,101,255,.4);transform:translateY(-4px)}
.fleet-card .count{
  display:inline-block;font-size:2.5rem;font-weight:800;
  color:var(--primary);line-height:1;margin-bottom:8px;
}
.fleet-card h3,.fleet-card .fleet-name{color:#fff;font-size:1.1rem;margin-bottom:6px;font-weight:800;line-height:1.2}
.fleet-card p{color:rgba(255,255,255,.7);font-size:14px;margin:0}
.fleet-card .fleet-name{margin-top:0}
.standort-name{font-size:1.15rem;font-weight:800;margin-bottom:8px;color:var(--dark);position:relative;z-index:2;line-height:1.2}
.karriere-name{font-size:1.1rem;font-weight:800;margin-bottom:8px;color:var(--dark);line-height:1.2}

/* ---------- Fleet with Images ---------- */
.fleet-card-img{
  display:flex;flex-direction:column;
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid var(--gray-100);
  transition:var(--transition);
}
.fleet-card-img:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.fleet-card-img .img-wrapper{
  position:relative;
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--gray-100);
}
.fleet-card-img .img-wrapper img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition);
}
.fleet-card-img:hover .img-wrapper img{transform:scale(1.05)}
.fleet-card-img .card-content{
  padding:24px;
}
.fleet-card-img h3{
  font-size:1.1rem;
  margin-bottom:8px;
  color:var(--dark);
}
.fleet-card-img p{
  color:var(--gray-500);
  font-size:14px;
  margin:0;
  line-height:1.5;
}

/* ---------- Standorte Grid ---------- */
.standorte-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
}
@media (max-width:768px){
  .standorte-grid{
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:20px;
  }
}
@media (max-width:480px){
  .standorte-grid{
    grid-template-columns:1fr;
  }
}
.standorte-card{
  background:#fff;
  border:2px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.standorte-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--primary-light) 0%,transparent 100%);
  opacity:0;transition:var(--transition);
  pointer-events:none;
}
.standorte-card:hover{
  border-color:var(--primary);
  box-shadow:var(--shadow-lg);
  transform:translateY(-4px);
}
.standorte-card:hover::before{opacity:.5}
.standorte-card.hauptstandort{
  border-color:var(--primary);
  background:linear-gradient(135deg,var(--primary-light),.5%, #fff 50%);
}
.standorte-card .icon-box{
  width:48px;
  height:48px;
  border-radius:12px;
  background:var(--primary-light);
  color:var(--primary);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:16px;
  font-size:24px;
  position:relative;
  z-index:2;
}
.standorte-card h3{
  font-size:1.15rem;
  margin-bottom:8px;
  color:var(--dark);
  position:relative;
  z-index:2;
}
.standorte-card p{
  color:var(--gray-500);
  font-size:14px;
  margin:0;
  position:relative;
  z-index:2;
  line-height:1.6;
}

/* ---------- Inhaber Section ---------- */
.inhaber-photo{
  width:100%;
  max-width:320px;
}
.inhaber-photo img{
  width:100%;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  display:block;
}
.inhaber-content h2{
  margin-bottom:24px;
  color:var(--dark);
}
.inhaber-content p{
  color:var(--gray-700);
  font-size:16px;
  line-height:1.75;
  margin-bottom:20px;
}
.inhaber-content p:last-child{
  margin-bottom:0;
}
.inhaber-content strong{
  color:var(--dark);
  font-weight:700;
}

/* ---------- Fuhrpark Gallery ---------- */
.fuhrpark-gallery{
  padding:80px 0;
}
.vehicle-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid var(--gray-100);
  transition:var(--transition);
}
.vehicle-card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-6px);
}
.vehicle-card-img{
  position:relative;
  width:100%;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--gray-100);
}
.vehicle-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:var(--transition);
}
.vehicle-card:hover .vehicle-card-img img{
  transform:scale(1.08);
}
.vehicle-card-content{
  padding:24px;
}
.vehicle-card h3{
  font-size:1.15rem;
  margin-bottom:8px;
  color:var(--dark);
}
.vehicle-card p{
  color:var(--gray-500);
  font-size:14px;
  margin:0;
  line-height:1.6;
}

/* ---------- Fahrzeug-Masse Grid ---------- */
.masse-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:32px;
}
@media (max-width:768px){
  .masse-grid{
    grid-template-columns:1fr;
  }
}
.masse-card{
  background:#fff;
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.masse-card:hover{
  box-shadow:var(--shadow-lg);
  transform:translateY(-4px);
  border-color:var(--primary-light);
}
.masse-card-img{
  width:100%;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--gray-100);
}
.masse-card-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.masse-card-content{
  padding:28px 24px;
}
.masse-card h3{
  font-size:1.2rem;
  margin-bottom:24px;
  color:var(--dark);
}
.masse-specs{
  display:flex;
  flex-direction:column;
  gap:12px;
}
.spec-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  padding-bottom:12px;
  border-bottom:1px solid var(--gray-100);
}
.spec-row:last-child{
  border-bottom:none;
  padding-bottom:0;
}
.spec-label{
  font-size:13px;
  font-weight:600;
  color:var(--gray-500);
  text-transform:uppercase;
  letter-spacing:.05em;
}
.spec-value{
  font-size:16px;
  font-weight:700;
  color:var(--dark);
}

/* ---------- Downloads Grid ---------- */
.downloads-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:24px;
}
@media (max-width:768px){
  .downloads-grid{
    grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
    gap:20px;
  }
}
@media (max-width:480px){
  .downloads-grid{
    grid-template-columns:1fr;
  }
}
.download-card{
  background:#fff;
  border:1px solid var(--gray-100);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  text-align:center;
  transition:var(--transition);
  box-shadow:var(--shadow-sm);
}
.download-card:hover{
  box-shadow:var(--shadow-lg);
  border-color:var(--primary);
  transform:translateY(-4px);
}
.download-card .pdf-icon{
  width:56px;
  height:56px;
  border-radius:12px;
  background:var(--primary-light);
  color:var(--primary);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 16px;
  font-size:28px;
}
.download-card h3{
  font-size:1.1rem;
  margin-bottom:8px;
  color:var(--dark);
}
.download-card p{
  color:var(--gray-500);
  font-size:14px;
  margin-bottom:20px;
}
.download-card .btn{
  width:100%;
  justify-content:center;
}

/* ---------- Services Page Detail ---------- */
.service-detail-section{
  padding:80px 0;
}
@media (max-width:768px){
  .service-detail-section{
    padding:56px 0;
  }
}
.service-detail{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
  margin-bottom:80px;
}
@media (max-width:900px){
  .service-detail{
    grid-template-columns:1fr;
    gap:36px;
    margin-bottom:56px;
  }
}
.service-detail.reverse{
  grid-template-columns:1fr 1fr;
}
.service-detail.reverse .service-detail-img{
  order:2;
}
@media (max-width:900px){
  .service-detail.reverse{
    grid-template-columns:1fr;
  }
  .service-detail.reverse .service-detail-img{
    order:0;
  }
}
.service-detail-img{
  position:relative;
  width:100%;
}
.service-detail-img img{
  width:100%;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  display:block;
}
.service-detail-content h2{
  margin-bottom:20px;
  color:var(--dark);
}
.service-detail-content p{
  color:var(--gray-700);
  font-size:16px;
  line-height:1.75;
  margin-bottom:20px;
}
.service-detail-content ul{
  list-style:none;
  padding:0;
  margin:24px 0;
}
.service-detail-content li{
  padding-left:28px;
  margin-bottom:12px;
  position:relative;
  color:var(--gray-700);
  font-size:15px;
  line-height:1.6;
}
.service-detail-content li::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  width:16px;
  height:16px;
  background:var(--primary);
  border-radius:50%;
  flex-shrink:0;
}

/* ---------- Team Grid ---------- */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:36px;
}
@media (max-width:768px){
  .team-grid{
    grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
    gap:28px;
  }
}
@media (max-width:480px){
  .team-grid{
    grid-template-columns:1fr;
  }
}
.team-member{
  text-align:center;
}
.team-member-photo{
  position:relative;
  margin-bottom:20px;
  overflow:hidden;
}
.team-member-photo img{
  width:200px;
  height:200px;
  border-radius:50%;
  object-fit:cover;
  display:block;
  margin:0 auto;
  box-shadow:var(--shadow);
  transition:var(--transition);
}
.team-member:hover .team-member-photo img{
  box-shadow:var(--shadow-lg);
  transform:scale(1.05);
}
.team-member h3{
  font-size:1.1rem;
  margin-bottom:4px;
  color:var(--dark);
}
.team-member p{
  color:var(--gray-500);
  font-size:14px;
  margin:0;
  font-weight:500;
}

/* ---------- CTA Banner ---------- */
.cta-banner{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  color:#fff;
  border-radius:var(--radius-lg);
  padding:60px 48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:32px;
  flex-wrap:wrap;
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}
.cta-banner::after{
  content:"";position:absolute;top:-50%;right:-10%;width:400px;height:400px;
  background:radial-gradient(circle,rgba(255,255,255,.1),transparent 70%);
}
.cta-banner h2{color:#fff;margin-bottom:8px;position:relative}
.cta-banner p{color:rgba(255,255,255,.9);margin:0;font-size:17px;position:relative}
.cta-banner .btn-white{position:relative}
@media (max-width:768px){.cta-banner{padding:40px 24px;flex-direction:column;text-align:center;align-items:center}}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 100%);
  color:#fff;
  padding:100px 0 80px;
  position:relative;
  overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(21,101,255,.25),transparent 50%);
}
.page-hero .container{position:relative}
.page-hero h1{color:#fff;margin-bottom:12px}
.page-hero p{font-size:19px;opacity:.85;max-width:640px;margin:0}
.breadcrumbs{font-size:14px;opacity:.7;margin-bottom:20px}
.breadcrumbs a{color:#fff}

/* ---------- Content pages ---------- */
.content{padding:80px 0}
.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:48px}
@media (max-width:900px){.content-grid{grid-template-columns:1fr}}
.content article h2{margin-top:40px}
.content article h2:first-child{margin-top:0}
.content article ul{padding-left:20px}
.content article li{margin-bottom:8px}
.content-sidebar{
  background:var(--gray-50);
  padding:32px;
  border-radius:var(--radius);
  border:1px solid var(--gray-100);
  height:fit-content;
  position:sticky;top:calc(var(--header-h) + 20px);
}
.content-sidebar h3{font-size:1.1rem;margin-bottom:16px}
.content-sidebar .contact-item{
  display:flex;gap:12px;align-items:flex-start;
  margin-bottom:16px;font-size:14px;color:var(--gray-700);
}
.content-sidebar .contact-item svg{flex-shrink:0;color:var(--primary);margin-top:2px}
.content-sidebar .btn{width:100%;justify-content:center;margin-top:12px}

/* ---------- Process steps ---------- */
.process-steps{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:24px;
  margin:40px 0;
}
.step{
  background:#fff;border:1px solid var(--gray-100);
  border-radius:var(--radius);padding:28px;text-align:center;
  position:relative;transition:var(--transition);
}
.step:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow)}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;
  background:var(--primary);color:#fff;font-weight:800;font-size:18px;
  margin-bottom:16px;
}
.step h3{font-size:1.05rem;margin-bottom:6px}
.step p{color:var(--gray-500);font-size:14px;margin:0}

.check-list{list-style:none;padding:0;margin:24px 0}
.check-list li{
  padding:12px 0 12px 32px;
  position:relative;
  border-bottom:1px solid var(--gray-100);
}
.check-list li::before{
  content:"";
  position:absolute;left:0;top:16px;
  width:20px;height:20px;border-radius:50%;
  background:var(--primary);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat:no-repeat;background-position:center;
}

/* ---------- Contact / Form ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info .info-item{
  display:flex;gap:16px;align-items:flex-start;margin-bottom:28px;
}
.contact-info .info-item .icon-box{
  flex-shrink:0;width:48px;height:48px;border-radius:12px;
  background:var(--primary-light);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
}
.contact-info h3{font-size:1rem;margin-bottom:4px}
.contact-info p{margin:0;color:var(--gray-700)}
.contact-info a{color:var(--gray-700)}
.contact-info a:hover{color:var(--primary)}

.form-card{
  background:#fff;padding:40px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow);border:1px solid var(--gray-100);
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{margin-bottom:18px}
.form-group label{
  display:block;font-size:14px;font-weight:600;
  color:var(--gray-700);margin-bottom:6px;
}
.form-group label .req{color:#DC2626}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:12px 14px;
  border:1.5px solid var(--gray-300);border-radius:8px;
  font-size:15px;font-family:inherit;color:var(--dark);
  background:#fff;transition:var(--transition);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(21,101,255,.12);
}
.form-group textarea{resize:vertical;min-height:120px}
.form-check{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--gray-500);margin-bottom:20px}
.form-check input{margin-top:3px;width:16px;height:16px;flex-shrink:0}
.form-message{
  padding:14px 18px;border-radius:8px;margin-bottom:16px;font-size:14px;
}
.form-message.success{background:#D1FAE5;color:#065F46;border:1px solid #6EE7B7}
.form-message.error{background:#FEE2E2;color:#991B1B;border:1px solid #FCA5A5}

/* ---------- Footer ---------- */
.site-footer{background:var(--dark);color:rgba(255,255,255,.7);padding:64px 0 24px}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;margin-bottom:48px;
}
@media (max-width:800px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media (max-width:500px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:1rem;margin-bottom:18px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin-bottom:10px;font-size:14px}
.site-footer a{color:rgba(255,255,255,.7)}
.site-footer a:hover{color:var(--primary)}
.footer-about img{height:44px;width:auto;margin-bottom:16px}
.footer-about p{font-size:14px;line-height:1.7}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;
  display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:12px;font-size:13px;
}

/* ---------- Leistungen Page ---------- */
.main-content.full-width{padding:0}
.service-detail{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:40px;
  align-items:flex-start;
  padding:56px 0;
  border-bottom:1px solid var(--gray-100);
}
.service-detail:last-child{border-bottom:none}
.service-detail--reverse{direction:ltr}
.service-detail--reverse .service-icon{order:0}
.service-detail--reverse .service-content{order:1}
@media (max-width:900px){
  .service-detail{grid-template-columns:1fr;gap:24px;padding:40px 0}
}
.service-detail .service-icon{
  width:100px;height:100px;border-radius:var(--radius-lg);
  background:var(--primary-light);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.service-detail .icon-svg{width:64px;height:64px}
.service-detail .service-content h2{
  font-size:clamp(1.4rem,2.5vw,1.8rem);
  margin-bottom:16px;color:var(--dark);
}
.service-detail .service-content p{
  color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:16px;
}
.service-detail .service-content .service-link{
  color:var(--primary);font-weight:600;text-decoration:underline;
}
.service-detail .service-content .service-link:hover{color:var(--primary-dark)}

/* ---------- Fuhrpark Page ---------- */
.fuhrpark-page .hero-section{
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 100%);
  color:#fff;padding:100px 0 80px;position:relative;overflow:hidden;
}
.fuhrpark-page .hero-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(21,101,255,.25),transparent 50%);
}
.fuhrpark-page .hero-overlay{display:none}
.fuhrpark-page .hero-content{position:relative}
.fuhrpark-page .hero-title{color:#fff;margin-bottom:12px}
.fuhrpark-page .hero-description{font-size:19px;opacity:.85;max-width:640px;margin:0}
.fuhrpark-page .breadcrumbs{position:relative}
.fuhrpark-page .breadcrumbs ol{
  list-style:none;margin:0;padding:0;display:flex;gap:8px;
  font-size:14px;opacity:.7;margin-bottom:20px;
}
.fuhrpark-page .breadcrumbs a{color:#fff}
.section-padding{padding:80px 0}
@media (max-width:768px){.section-padding{padding:56px 0}}
.section-header{text-align:center;max-width:720px;margin:0 auto 56px}
.section-title{font-size:clamp(1.6rem,3.5vw,2.5rem);margin-bottom:12px}
.section-subtitle{color:var(--gray-500);font-size:18px;margin:0}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
@media (max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:20px}}
@media (max-width:480px){.gallery-grid{grid-template-columns:1fr}}
.vehicle-image{
  position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:var(--gray-100);
}
.vehicle-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.vehicle-card:hover .vehicle-image img{transform:scale(1.08)}
.vehicle-info{padding:24px}
.vehicle-name{font-size:1.15rem;margin-bottom:8px;color:var(--dark)}
.vehicle-description{color:var(--gray-500);font-size:14px;margin:0;line-height:1.6}

/* Masse section improvements */
.masse-section{background:var(--gray-50)}
.masse-section .section-header h2{color:var(--dark)}
.masse-image{
  width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--gray-100);
}
.masse-image img{width:100%;height:100%;object-fit:contain;display:block;padding:16px;background:#fff}
.masse-content{padding:28px 24px}
.masse-title{font-size:1.2rem;margin-bottom:24px;color:var(--dark)}
.specs-grid{display:flex;flex-direction:column;gap:12px}
.spec-item{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
  padding-bottom:12px;border-bottom:1px solid var(--gray-100);
}
.spec-item:last-child{border-bottom:none;padding-bottom:0}
.specs-note{
  margin-top:16px;font-size:13px;color:var(--gray-500);
  font-style:italic;padding-top:12px;border-top:1px solid var(--gray-100);
}
.fuhrpark-page .cta-banner{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  color:#fff;text-align:center;border-radius:var(--radius-lg);
}
.fuhrpark-page .cta-content{max-width:600px;margin:0 auto}
.fuhrpark-page .cta-title{color:#fff;margin-bottom:12px}
.fuhrpark-page .cta-description{color:rgba(255,255,255,.9);font-size:17px;margin-bottom:32px}
.fuhrpark-page .cta-button{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 32px;border-radius:10px;font-weight:600;font-size:15px;
  background:#fff;color:var(--primary-dark);transition:var(--transition);
  text-decoration:none;
}
.fuhrpark-page .cta-button:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.2)}

/* ---------- Downloads Page ---------- */
.page-wrapper{min-height:100vh}
.downloads-hero{
  background:linear-gradient(135deg,var(--dark) 0%,var(--dark-2) 100%);
  color:#fff;padding:100px 0 80px;position:relative;overflow:hidden;
}
.downloads-hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(21,101,255,.25),transparent 50%);
}
.downloads-hero .container{position:relative}
.downloads-hero .breadcrumbs{font-size:14px;opacity:.7;margin-bottom:20px}
.downloads-hero .breadcrumbs a{color:#fff}
.downloads-hero .separator{margin:0 8px;opacity:.5}
.downloads-hero .hero-title{color:#fff;margin-bottom:12px}
.downloads-hero .hero-description{font-size:19px;opacity:.85;max-width:640px;margin:0}
.downloads-section{padding:80px 0}
.downloads-section .downloads-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;
}
@media (max-width:768px){.downloads-section .downloads-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}}
@media (max-width:480px){.downloads-section .downloads-grid{grid-template-columns:1fr}}
.download-card{
  background:#fff;border:1px solid var(--gray-100);border-radius:var(--radius-lg);
  padding:32px 28px;display:flex;flex-direction:column;align-items:center;
  text-align:center;transition:var(--transition);box-shadow:var(--shadow-sm);
}
.download-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);transform:translateY(-4px)}
.download-card .card-icon{
  width:56px;height:56px;border-radius:12px;
  background:var(--primary-light);color:var(--primary);
  display:flex;align-items:center;justify-content:center;margin-bottom:16px;
}
.download-card .card-icon svg{width:28px;height:28px}
.download-card .card-content{flex:1;margin-bottom:20px}
.download-card .card-title{font-size:1.1rem;margin-bottom:8px;color:var(--dark)}
.download-card .card-description{color:var(--gray-500);font-size:14px;margin:0}
.download-button{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:10px;font-weight:600;font-size:14px;
  background:var(--primary);color:#fff;transition:var(--transition);
  text-decoration:none;width:100%;justify-content:center;
}
.download-button:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 4px 14px rgba(21,101,255,.35)}
.download-button svg{width:16px;height:16px}
.downloads-info-section{padding:60px 0;background:var(--gray-50)}
.downloads-info-section .info-content{text-align:center;max-width:600px;margin:0 auto}
.downloads-info-section .info-text{color:var(--gray-700);font-size:16px;margin-bottom:24px}
.downloads-info-section .cta-button{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:10px;font-weight:600;font-size:15px;
  background:var(--primary);color:#fff;transition:var(--transition);
  text-decoration:none;
}
.downloads-info-section .cta-button:hover{background:var(--primary-dark);transform:translateY(-2px)}

/* ---------- Über uns Page ---------- */
.inhaber-section{padding:80px 0}
.inhaber-grid{
  display:grid;grid-template-columns:380px 1fr;gap:48px;align-items:flex-start;
}
@media (max-width:900px){.inhaber-grid{grid-template-columns:1fr;gap:36px}}
.inhaber-section .inhaber-image img{
  width:100%;max-width:380px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);display:block;
}
.inhaber-section .inhaber-content .eyebrow{
  display:inline-block;color:var(--primary);font-weight:700;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;
}
.inhaber-section .inhaber-content h2{
  font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:8px;color:var(--dark);
}
.inhaber-section .inhaber-content h3{
  font-size:1.3rem;color:var(--primary);margin-bottom:4px;
}
.inhaber-section .inhaber-title{
  color:var(--gray-500);font-weight:600;font-size:15px;margin-bottom:24px;
}
.inhaber-section .inhaber-content p{
  color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:20px;
}
.company-section{padding:80px 0;background:var(--gray-50)}
.company-section h2{margin-bottom:24px}
.company-content{max-width:900px}
.company-content p{color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:20px}
.company-content h3{margin-top:40px;margin-bottom:20px}
.services-list{list-style:none;padding:0;margin:24px 0}
.services-list li{
  padding:12px 0 12px 32px;position:relative;
  border-bottom:1px solid var(--gray-100);color:var(--gray-700);font-size:15px;
}
.services-list li::before{
  content:"";position:absolute;left:0;top:16px;
  width:20px;height:20px;border-radius:50%;background:var(--primary);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat:no-repeat;background-position:center;
}
.values-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:32px;
}
@media (max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.values-grid{grid-template-columns:1fr}}
.value-item{
  background:#fff;padding:32px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);
}
.value-item:hover{box-shadow:var(--shadow);border-color:var(--primary-light);transform:translateY(-4px)}
.value-item h4{font-size:1.1rem;margin-bottom:8px;color:var(--dark)}
.value-item p{color:var(--gray-500);font-size:14px;margin:0;line-height:1.6}

.standorte-section{padding:80px 0}
.standorte-section h2{margin-bottom:16px}
.standorte-section .section-intro{
  color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:40px;max-width:900px;
}
.standorte-section .standorte-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;
  margin-bottom:32px;
}
.standorte-section .standort-card{
  background:#fff;border:2px solid var(--gray-100);border-radius:var(--radius-lg);
  padding:32px 28px;transition:var(--transition);
}
.standorte-section .standort-card:hover{
  border-color:var(--primary);box-shadow:var(--shadow-lg);transform:translateY(-4px);
}
.standorte-section .standort-card h3{font-size:1.15rem;margin-bottom:8px;color:var(--dark)}
.standorte-section .standort-card .address{
  color:var(--primary);font-weight:600;font-size:14px;margin-bottom:12px;
}
.standorte-section .standort-card .description{color:var(--gray-500);font-size:14px;margin:0;line-height:1.6}
.standorte-conclusion{
  color:var(--gray-700);font-size:16px;line-height:1.75;
  padding:24px;background:var(--primary-light);border-radius:var(--radius);
  border-left:4px solid var(--primary);
}

.team-section{padding:80px 0;background:var(--gray-50)}
.team-section h2{margin-bottom:16px}
.team-section .section-intro{
  color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:40px;max-width:900px;
}
.team-section .team-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px;
}
.team-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--gray-100);transition:var(--transition);
}
.team-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}
.team-card .team-image{
  width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--gray-100);
}
.team-card .team-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}
.team-card:hover .team-image img{transform:scale(1.05)}
.team-card h3,.team-card p,.team-card .team-role{padding:0 24px}
.team-card h3{font-size:1.15rem;margin-top:20px;margin-bottom:4px;color:var(--dark)}
.team-card .team-role{color:var(--primary);font-weight:600;font-size:13px;margin-bottom:12px}
.team-card p:last-child{color:var(--gray-500);font-size:14px;line-height:1.6;padding-bottom:24px;margin:0}

.zertifikationen-section{padding:80px 0}
.zertifikationen-section h2{margin-bottom:16px}
.zertifikationen-section .section-intro{
  color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:32px;max-width:900px;
}
.zertifikationen-content{max-width:900px}
.zertifikationen-cta{
  margin-top:32px;padding:28px;background:var(--primary-light);
  border-radius:var(--radius);border-left:4px solid var(--primary);
}
.zertifikationen-cta p{margin-bottom:16px;color:var(--gray-700)}
.zertifikationen-cta .btn-secondary{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border-radius:10px;font-weight:600;font-size:14px;
  background:var(--primary);color:#fff;transition:var(--transition);text-decoration:none;
}
.zertifikationen-cta .btn-secondary:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px)}

.promise-section{padding:80px 0;background:var(--gray-50)}
.promise-section h2{margin-bottom:24px}
.promise-grid{
  display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:center;
}
@media (max-width:900px){.promise-grid{grid-template-columns:1fr;gap:32px}}
.promise-text p{color:var(--gray-700);font-size:16px;line-height:1.75;margin-bottom:20px}
.promise-image img{
  width:100%;max-width:380px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:block;
}

/* CTA banner primary (class-based, no inline styles) */
.cta-banner-primary{
  background:linear-gradient(135deg,#1a4d7a 0%,#2a6fa6 100%);
  color:#fff;padding:80px 0;text-align:center;
}
.cta-banner-primary .container{position:relative}
.cta-banner-title{color:#fff;margin-bottom:20px}
.cta-banner-text{font-size:1.1rem;margin-bottom:30px;max-width:600px;margin-left:auto;margin-right:auto;color:rgba(255,255,255,.9)}
.cta-banner-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}

/* CTA variants for inner pages */
.btn-light{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:10px;font-weight:600;font-size:15px;
  background:#fff;color:var(--primary-dark);transition:var(--transition);text-decoration:none;
}
.btn-light:hover{background:var(--primary-light);color:var(--primary-dark);transform:translateY(-2px)}
.btn-outline-light{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:10px;font-weight:600;font-size:15px;
  background:transparent;color:#fff;border:2px solid rgba(255,255,255,.4);
  transition:var(--transition);text-decoration:none;
}
.btn-outline-light:hover{background:rgba(255,255,255,.1);border-color:#fff;color:#fff}

/* ---------- Karriere Section ---------- */
.karriere-section{padding:80px 0;background:var(--dark);color:#fff;position:relative;overflow:hidden}
.karriere-section::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 50%,rgba(21,101,255,.3),transparent 60%);
  pointer-events:none;
}
.karriere-section .container{position:relative}
.karriere-section h2{color:#fff;margin-bottom:16px}
.karriere-section .section-intro{color:rgba(255,255,255,.8);font-size:17px;margin-bottom:40px;max-width:700px}
.karriere-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;
  margin-bottom:32px;
}
@media (max-width:480px){.karriere-grid{grid-template-columns:1fr}}
.karriere-card{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-lg);padding:32px;transition:var(--transition);
  backdrop-filter:blur(6px);
}
.karriere-card:hover{background:rgba(255,255,255,.1);border-color:rgba(21,101,255,.4);transform:translateY(-4px)}
.karriere-card h3{color:#fff;font-size:1.15rem;margin-bottom:8px}
.karriere-card p{color:rgba(255,255,255,.7);font-size:14px;margin:0;line-height:1.6}
.karriere-cta{text-align:center;margin-top:24px}
.karriere-cta p{color:rgba(255,255,255,.8);font-size:16px;margin-bottom:16px}
.karriere-cta a{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:10px;font-weight:700;font-size:16px;
  background:var(--primary);color:#fff;transition:var(--transition);text-decoration:none;
  box-shadow:0 4px 14px rgba(21,101,255,.35);
}
.karriere-cta a:hover{background:var(--primary-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px rgba(21,101,255,.45)}

/* ---------- Leistungen visual improvements ---------- */
.leistungen-hero-desc{font-size:19px;opacity:.85;max-width:640px;margin:0}
.leistungen-cta-section{padding:0 0 80px}
.leistungen-cta-section .cta-banner{
  margin-top:40px;
}

/* ---------- Über uns CTA section ---------- */
.cta-section{padding:0 0 80px}
.cta-section .cta-banner{margin-top:0}

/* ---------- Standort badge ---------- */
.standort-badge{
  display:inline-block;padding:4px 12px;border-radius:999px;
  background:var(--primary);color:#fff;
  font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;
  margin-bottom:12px;
}

/* ---------- Inhaber on front page ---------- */
.inhaber{background:var(--gray-50)}
.inhaber-content{
  display:grid;grid-template-columns:320px 1fr;gap:48px;align-items:center;
}
@media (max-width:768px){.inhaber-content{grid-template-columns:1fr;gap:32px;text-align:center}.inhaber-image{display:flex;justify-content:center}}
.inhaber-image img{
  width:100%;max-width:320px;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.inhaber-text .eyebrow{
  display:inline-block;color:var(--primary);font-weight:700;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px;
}
.inhaber-text h2{margin-bottom:6px}
.inhaber-title{color:var(--primary);font-weight:600;font-size:15px;margin-bottom:20px}
.inhaber-text p{color:var(--gray-700);font-size:16px;line-height:1.75}

/* ---------- Utilities ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.badge{
  display:inline-block;padding:4px 10px;border-radius:999px;
  background:var(--primary-light);color:var(--primary-dark);
  font-size:12px;font-weight:600;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:all .8s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ---------- Print ---------- */
@media print{
  .site-header,.site-footer,.cta-banner,.hero-actions{display:none}
  body{color:#000}
}

/* ---------- WhatsApp floating button ---------- */
.whatsapp-float{position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(37,211,102,.4);z-index:9999;transition:transform .3s,box-shadow .3s}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 20px rgba(37,211,102,.5)}
@media (max-width:480px){.whatsapp-float{bottom:16px;right:16px;width:48px;height:48px}.whatsapp-float svg{width:24px;height:24px}}

/* ---------- Mobile logo fix ---------- */
@media(max-width:768px){.site-logo img{height:56px;width:auto}}

/* ---------- Features grid ---------- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:32px}
@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.features-grid{grid-template-columns:1fr}}

/* ---------- Footer logo fix ---------- */
.footer-about img{height:48px;width:auto;margin-bottom:16px}

/* ---------- Karriere Page ---------- */

/* Hero — nutzt .page-hero Basis-Stil, nur ergänzende Karriere-Overrides */
.karriere-hero .page-hero-desc{font-size:18px;max-width:640px;margin:0}

/* Vorteile Grid */
.karriere-vorteile-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
@media(max-width:900px){.karriere-vorteile-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.karriere-vorteile-grid{grid-template-columns:1fr}}

.karriere-vorteil-card{
  background:#fff;padding:32px 28px;border-radius:var(--radius-lg);
  border:1px solid var(--gray-100);transition:var(--transition);
  text-align:center;position:relative;overflow:hidden;
}
.karriere-vorteil-card::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:3px;
  background:var(--primary);transform:scaleX(0);transition:transform .3s ease;
}
.karriere-vorteil-card:hover{
  box-shadow:var(--shadow-lg);transform:translateY(-6px);border-color:transparent;
}
.karriere-vorteil-card:hover::after{transform:scaleX(1)}
.karriere-vorteil-icon{
  width:56px;height:56px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;
}
.karriere-vorteil-card h3{font-size:1.1rem;margin-bottom:8px;color:var(--dark)}
.karriere-vorteil-card p{color:var(--gray-500);font-size:14px;line-height:1.6;margin:0}

/* Jobs Grid */
.karriere-jobs-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
}
@media(max-width:768px){.karriere-jobs-grid{grid-template-columns:1fr}}

.karriere-job-card{
  background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--gray-100);transition:var(--transition);
  display:flex;flex-direction:column;position:relative;
}
.karriere-job-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:var(--primary-light)}
.karriere-job-badge{
  position:absolute;top:16px;right:16px;
  background:var(--primary);color:#fff;font-size:11px;font-weight:700;
  padding:4px 12px;border-radius:999px;letter-spacing:.03em;text-transform:uppercase;
}
.karriere-job-header{
  display:flex;align-items:flex-start;gap:16px;padding:28px 28px 20px;
}
.karriere-job-icon{
  width:48px;height:48px;min-width:48px;border-radius:12px;
  background:var(--primary-light);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
}
.karriere-job-header h3{font-size:1.1rem;margin-bottom:8px;color:var(--dark)}
.karriere-job-tags{display:flex;flex-wrap:wrap;gap:6px}
.karriere-job-tags span{
  display:inline-block;padding:3px 10px;border-radius:6px;
  background:var(--gray-50);color:var(--gray-500);font-size:12px;font-weight:600;
  border:1px solid var(--gray-100);
}
.karriere-job-body{padding:0 28px 24px;flex:1}
.karriere-job-body p{color:var(--gray-700);font-size:15px;margin-bottom:16px;line-height:1.6}
.karriere-job-details{display:flex;flex-direction:column;gap:8px}
.karriere-job-detail{
  font-size:13px;color:var(--gray-500);line-height:1.5;
  padding:10px 14px;background:var(--gray-50);border-radius:8px;
}
.karriere-job-detail strong{color:var(--dark);font-weight:700}
.karriere-job-apply{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:16px 28px;background:var(--primary);color:#fff;
  font-weight:600;font-size:15px;text-decoration:none;
  transition:var(--transition);margin-top:auto;
}
.karriere-job-apply:hover{background:var(--primary-dark);color:#fff;gap:12px}

/* CTA Section */
.karriere-cta{padding-bottom:80px}
.karriere-cta-box{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  border-radius:var(--radius-lg);padding:64px 48px;text-align:center;
  position:relative;overflow:hidden;box-shadow:var(--shadow-lg);
}
.karriere-cta-box::after{
  content:"";position:absolute;top:-50%;right:-10%;width:400px;height:400px;
  background:radial-gradient(circle,rgba(255,255,255,.08),transparent 70%);pointer-events:none;
}
.karriere-cta-content{position:relative;max-width:600px;margin:0 auto}
.karriere-cta-content h2{color:#fff;margin-bottom:12px}
.karriere-cta-content p{color:rgba(255,255,255,.85);font-size:17px;margin-bottom:32px}
.karriere-cta-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:480px){
  .karriere-cta-box{padding:40px 24px}
  .karriere-cta-buttons{flex-direction:column}
  .karriere-cta-buttons .btn{width:100%;justify-content:center}
}
