/* ============================================================
   SL RENTALS – Klassisch Design
   Alle Farben via PHP CSS-Variablen aus DB überschreibbar
   ============================================================ */

/* === Variablen (Fallbacks; werden per PHP aus DB überschrieben) === */
:root {
  --primary:      #1c1c1e;
  --primary-dark: #111113;
  --accent:       #c0392b;
  --accent-dark:  #a93226;
  --light:        #f4f6f8;
  --light-2:      #eceff3;
  --gray:         #6b7280;
  --gray-d:       #374151;
  --border:       #d1d5db;
  --white:        #ffffff;
  --text:         #1f2937;
  --shadow:       0 4px 20px rgba(0,0,0,0.10);
  --shadow-lg:    0 12px 48px rgba(0,0,0,0.16);
  --radius:       3px;
  --tr:           0.18s ease;
}

/* === Reset === */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Source Sans 3',sans-serif; color:var(--text); background:var(--white); line-height:1.65; overflow-x:hidden; font-size:16px; }
img  { display:block; max-width:100%; height:auto; }
a    { color:inherit; text-decoration:none; }

/* === Layout === */
.container      { max-width:1200px; margin:0 auto; padding:0 24px; }
.container-wide { max-width:1400px; margin:0 auto; padding:0 24px; }

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.consent-notice {
  position:fixed; bottom:0; left:0; right:0; z-index:9999;
  background:var(--primary-dark);
  border-top:3px solid var(--accent);
  box-shadow:0 -4px 32px rgba(0,0,0,0.35);
  padding:16px 0;
  transform:translateY(100%);
  transition:transform .45s cubic-bezier(.16,1,.3,1), opacity .45s ease;
  opacity:0;
  pointer-events:none;
}
.consent-notice.visible {
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}
.consent-notice.hiding {
  transform:translateY(100%);
  opacity:0;
  pointer-events:none;
}
.consent-inner {
  display:flex; align-items:center; gap:20px;
  flex-wrap:wrap; justify-content:space-between;
}
.consent-text { font-size:14px; color:rgba(255,255,255,0.82); line-height:1.6; flex:1; min-width:180px; }
.consent-text a { color:var(--accent); }
.consent-btns { display:flex; gap:10px; flex-shrink:0; flex-wrap:wrap; }
.consent-ok {
  display:inline-block; text-decoration:none;
  background:var(--accent); color:#fff; border:none;
  padding:9px 22px; font-family:inherit; font-weight:700;
  font-size:14px; cursor:pointer; border-radius:var(--radius);
  transition:background var(--tr);
}
.consent-ok:hover { background:var(--accent-dark); color:#fff; }
.consent-skip {
  display:inline-block; text-decoration:none;
  background:transparent; color:rgba(255,255,255,0.65);
  border:1px solid rgba(255,255,255,0.3);
  padding:9px 22px; font-family:inherit; font-size:14px;
  cursor:pointer; border-radius:var(--radius); transition:all var(--tr);
}
.consent-skip:hover { border-color:rgba(255,255,255,0.6); color:#fff; }

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar {
  background:var(--primary-dark);
  border-bottom:1px solid rgba(255,255,255,0.04);
  padding:7px 0; font-size:13px;
  color:rgba(255,255,255,0.7);
}
.topbar-inner {
  display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:4px 14px;
}
.topbar-left  { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.topbar-sep   { width:1px; height:12px; background:rgba(255,255,255,0.18); flex-shrink:0; }
.tb-company   { font-weight:700; color:rgba(255,255,255,0.95); white-space:nowrap; }
.tb-address   { color:rgba(255,255,255,0.55); white-space:nowrap; font-size:12px; }
.tb-hours     { color:rgba(255,255,255,0.5); font-size:12px; white-space:nowrap; }
.topbar-right { display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.topbar-right a { color:rgba(255,255,255,0.8); font-size:13px; transition:color var(--tr); white-space:nowrap; }
.topbar-right a:hover { color:var(--accent); }

/* ============================================================
   NAVIGATION
   ============================================================ */
.main-nav {
  background:var(--white);
  border-bottom:3px solid var(--accent);
  position:sticky; top:0; z-index:600;
  box-shadow:0 2px 12px rgba(0,0,0,0.08);
  transition:box-shadow var(--tr);
}
.nav-inner {
  display:flex; align-items:center;
  justify-content:space-between; height:72px; gap:16px;
}
.nav-logo { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.logo-mark {
  background:var(--primary); color:#fff;
  font-family:'Oswald',sans-serif; font-size:22px;
  font-weight:700; padding:9px 14px;
  letter-spacing:1.5px; line-height:1; white-space:nowrap;
}
.logo-mark span { color:var(--accent); }
.logo-img { height:44px; width:auto; object-fit:contain; }
.logo-info { line-height:1.3; }
.logo-info strong { display:block; font-size:14px; color:var(--primary); font-weight:700; white-space:nowrap; }
.logo-info small  { font-size:12px; color:var(--gray); white-space:nowrap; }

.nav-links { display:flex; list-style:none; gap:2px; align-items:center; }
.nav-links a {
  display:block; padding:8px 15px;
  color:var(--primary); font-weight:600; font-size:14px;
  border-radius:var(--radius); white-space:nowrap;
  transition:background var(--tr), color var(--tr);
}
.nav-links a:hover,
.nav-links a.active { background:var(--primary); color:#fff; }
.nav-cta {
  background:var(--accent) !important;
  color:#fff !important; padding:9px 20px !important;
  font-weight:700 !important; margin-left:6px;
}
.nav-cta:hover { background:var(--accent-dark) !important; }

.nav-burger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:6px;
}
.nav-burger span {
  display:block; width:24px; height:2px;
  background:var(--primary); border-radius:2px; transition:all .3s;
}
.nav-burger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity:0; }
.nav-burger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* Mobile Drawer */
.mobile-drawer {
  display:none; position:fixed; top:0; right:0; bottom:0;
  width:min(340px,90vw);
  background:var(--primary); z-index:700;
  flex-direction:column; padding:80px 32px 32px;
  overflow-y:auto; transform:translateX(100%);
  transition:transform .3s ease;
}
.mobile-drawer.open { display:flex; transform:translateX(0); }
.drawer-close {
  position:absolute; top:20px; right:20px;
  background:none; border:none; color:rgba(255,255,255,0.6);
  font-size:22px; cursor:pointer; padding:6px;
  transition:color var(--tr);
}
.drawer-close:hover { color:#fff; }
.mobile-drawer nav { display:flex; flex-direction:column; gap:0; }
.mobile-drawer nav a {
  display:block; padding:15px 0;
  color:rgba(255,255,255,0.82); font-size:20px;
  font-family:'Oswald',sans-serif; font-weight:600;
  letter-spacing:1px; border-bottom:1px solid rgba(255,255,255,0.08);
  transition:color var(--tr);
}
.mobile-drawer nav a:hover { color:var(--accent); }
.mob-cta {
  margin-top:20px; background:var(--accent);
  color:#fff !important; text-align:center;
  border-radius:var(--radius); padding:14px 0 !important;
}
.drawer-contact {
  margin-top:auto; padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.08);
  display:flex; flex-direction:column; gap:10px;
}
.drawer-contact a { color:rgba(255,255,255,0.6); font-size:14px; transition:color var(--tr); }
.drawer-contact a:hover { color:var(--accent); }
.drawer-backdrop {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.5); z-index:699;
}
.drawer-backdrop.open { display:block; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-block; padding:13px 30px;
  font-family:'Source Sans 3',sans-serif; font-size:15px;
  font-weight:700; border-radius:var(--radius);
  border:2px solid transparent; cursor:pointer;
  transition:all var(--tr); white-space:nowrap;
  line-height:1.4; text-align:center;
}
.btn-primary      { background:var(--accent);   color:#fff; border-color:var(--accent); }
.btn-primary:hover { background:var(--accent-dark); border-color:var(--accent-dark); }
.btn-secondary    { background:var(--primary);  color:#fff; border-color:var(--primary); }
.btn-secondary:hover { background:var(--primary-dark); border-color:var(--primary-dark); }
.btn-outline      { background:transparent; color:#fff; border-color:rgba(255,255,255,0.55); }
.btn-outline:hover { background:rgba(255,255,255,0.1); border-color:#fff; }
.btn-outline-dark { background:transparent; color:var(--primary); border-color:var(--primary); }
.btn-outline-dark:hover { background:var(--primary); color:#fff; }
.btn-lg { padding:16px 40px; font-size:17px; }
.btn-sm { padding:9px 20px; font-size:14px; }

/* ============================================================
   SECTION BASE
   ============================================================ */
.section    { padding:80px 0; }
.section-sm { padding:52px 0; }
.bg-light   { background:var(--light); }
.bg-light-2 { background:var(--light-2); }
.bg-primary { background:var(--primary); }
.bg-dark    { background:#111113; }
.text-center { text-align:center; }

.section-label {
  display:inline-block; background:var(--accent); color:#fff;
  font-size:11px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; padding:4px 14px; margin-bottom:14px;
}
.section-title {
  font-family:'Oswald',sans-serif; font-size:40px; font-weight:700;
  color:var(--primary); line-height:1.1; margin-bottom:16px;
}
.section-title span, .section-title em { font-style:normal; color:var(--accent); }
.on-dark .section-title { color:#fff; }
.section-intro { font-size:17px; color:var(--gray); max-width:640px; margin-bottom:48px; line-height:1.7; }
.on-dark .section-intro { color:rgba(255,255,255,0.7); margin-bottom:32px; }
.text-center .section-intro { margin-left:auto; margin-right:auto; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position:relative; min-height:640px;
  display:flex; align-items:center;
  overflow:hidden; background:var(--primary);
}
.hero-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  background-repeat:no-repeat;
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(
    105deg,
    rgba(26,58,92,0.93) 0%,
    rgba(26,58,92,0.78) 45%,
    rgba(26,58,92,0.42) 100%
  );
}
.hero-content { position:relative; z-index:2; padding:80px 0; max-width:700px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--accent); color:#fff; font-size:12px;
  font-weight:700; letter-spacing:2.5px; text-transform:uppercase;
  padding:5px 16px; margin-bottom:22px;
}
.hero h1 {
  font-family:'Oswald',sans-serif;
  font-size:clamp(34px, 4.5vw, 60px);
  font-weight:700; color:#fff; line-height:1.05;
  margin-bottom:20px; text-shadow:0 2px 16px rgba(0,0,0,0.25);
}
.hero h1 span { color:var(--accent); }
.hero-text { font-size:18px; color:rgba(255,255,255,0.87); margin-bottom:36px; max-width:540px; line-height:1.7; }
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:52px; }
.hero-stats {
  display:flex; flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,0.15);
  padding-top:32px; gap:0;
}
.hero-stat {
  padding-right:32px; margin-right:32px;
  border-right:1px solid rgba(255,255,255,0.15);
  text-align:center;
}
.hero-stat:last-child { border:none; padding:0; margin:0; }
.hero-stat .num { font-family:'Oswald',sans-serif; font-size:42px; font-weight:700; color:var(--accent); line-height:1; }
.hero-stat .lbl { font-size:13px; color:rgba(255,255,255,0.6); margin-top:4px; }

/* ============================================================
   USP STRIP
   ============================================================ */
.usp-strip { background:var(--primary-dark); }
.usp-grid  {
  display:grid; grid-template-columns:repeat(4,1fr);
  border-left:1px solid rgba(255,255,255,0.06);
}
.usp-item {
  display:flex; gap:14px; align-items:center;
  padding:20px 22px;
  border-right:1px solid rgba(255,255,255,0.06);
}
.usp-icon { font-size:24px; flex-shrink:0; }
.usp-lbl  { font-size:11px; color:rgba(255,255,255,0.4); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:2px; }
.usp-val  { font-size:14px; font-weight:600; color:rgba(255,255,255,0.88); }

/* ============================================================
   KATEGORIEN
   ============================================================ */
.cats-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.cat-card {
  background:var(--white); border:1px solid var(--border);
  border-top:4px solid var(--accent);
  overflow:hidden; color:inherit; display:flex; flex-direction:column;
  transition:box-shadow var(--tr), transform var(--tr);
}
.cat-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.cat-img { height:210px; overflow:hidden; background:var(--light); flex-shrink:0; }
.cat-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.cat-card:hover .cat-img img { transform:scale(1.05); }
.cat-body { padding:24px; flex:1; display:flex; flex-direction:column; }
.cat-icon-wrap {
  width:48px; height:48px; background:var(--primary);
  display:flex; align-items:center; justify-content:center;
  font-size:22px; margin-bottom:14px; flex-shrink:0;
}
.cat-body h3 { font-family:'Oswald',sans-serif; font-size:21px; color:var(--primary); margin-bottom:10px; }
.cat-body p  { color:var(--gray); font-size:14px; line-height:1.65; flex:1; margin-bottom:16px; }
.cat-link { color:var(--accent); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:0.5px; margin-top:auto; }

/* ============================================================
   PRODUKTE
   ============================================================ */
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.product-card {
  background:var(--white); border:1px solid var(--border);
  overflow:hidden; display:flex; flex-direction:column;
  transition:box-shadow var(--tr);
}
.product-card:hover { box-shadow:var(--shadow); }
.product-img-wrap { height:220px; background:var(--light); overflow:hidden; position:relative; flex-shrink:0; }
.product-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.product-card:hover .product-img-wrap img { transform:scale(1.04); }
.prod-badge {
  position:absolute; top:12px; left:12px;
  font-size:10px; font-weight:700; padding:3px 10px;
  letter-spacing:1px; text-transform:uppercase;
}
.prod-badge.avail   { background:#16a34a; color:#fff; }
.prod-badge.unavail { background:#dc2626; color:#fff; }
.prod-badge.request { background:#d97706; color:#fff; }
.prod-cat-tag {
  position:absolute; top:12px; right:12px;
  background:rgba(26,58,92,0.82); color:#fff; font-size:10px; padding:3px 10px;
}
.product-body { padding:22px; flex:1; display:flex; flex-direction:column; }
.product-body h3 { font-family:'Oswald',sans-serif; font-size:21px; color:var(--primary); margin-bottom:8px; }
.product-body p  { color:var(--gray); font-size:14px; margin-bottom:16px; line-height:1.6; flex:1; }
.product-specs {
  display:grid; grid-template-columns:repeat(3,1fr); gap:8px;
  padding:14px 0; border-top:1px solid var(--border);
  border-bottom:1px solid var(--border); margin-bottom:16px;
}
.spec-box { text-align:center; }
.spec-box .sk { font-size:10px; color:var(--gray); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:3px; }
.spec-box .sv { font-size:14px; font-weight:700; color:var(--primary); }
.product-body .btn { margin-top:auto; }

/* ============================================================
   WHY
   ============================================================ */
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.why-images { position:relative; padding-bottom:28px; padding-right:28px; }
.why-img-main { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.why-img-small {
  position:absolute; bottom:0; right:0;
  width:47%; aspect-ratio:1; object-fit:cover;
  border:5px solid var(--white); box-shadow:var(--shadow-lg);
}
.why-badge-box {
  position:absolute; bottom:72px; left:-20px;
  background:var(--accent); color:#fff; padding:18px 22px;
  text-align:center; box-shadow:var(--shadow);
}
.why-badge-box .big   { font-family:'Oswald',sans-serif; font-size:46px; font-weight:700; line-height:1; }
.why-badge-box .small { font-size:12px; opacity:.9; margin-top:2px; }
.why-list { list-style:none; margin:20px 0 32px; }
.why-list li {
  display:flex; gap:14px; align-items:flex-start;
  padding:12px 0; border-bottom:1px solid var(--border);
  font-size:15px; color:var(--gray-d); line-height:1.6;
}
.why-check {
  width:24px; height:24px; background:var(--accent); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:700; flex-shrink:0; margin-top:1px;
}

/* ============================================================
   PROCESS
   ============================================================ */
.process-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0; position:relative;
}
.process-row::before {
  content:''; position:absolute; top:35px; left:12.5%; right:12.5%;
  height:2px; background:var(--border); z-index:0;
}
.process-step { text-align:center; padding:0 16px; position:relative; z-index:1; }
.step-circle {
  width:70px; height:70px; background:var(--white);
  border:3px solid var(--accent); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'Oswald',sans-serif; font-size:28px; font-weight:700;
  color:var(--accent); margin:0 auto 20px; box-shadow:var(--shadow);
}
.bg-light   .step-circle,
.bg-light-2 .step-circle { background:var(--light); }
.process-step h4 { font-family:'Oswald',sans-serif; font-size:18px; color:var(--primary); margin-bottom:10px; }
.process-step p  { font-size:14px; color:var(--gray); line-height:1.65; }

/* ============================================================
   GALERIE
   ============================================================ */
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:220px;
  gap:10px;
  overflow:visible;
}
.gallery-item { overflow:hidden; position:relative; background:var(--light); }
.gallery-item.wide { grid-column:span 2; }
.gallery-item.tall { grid-row:span 2; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.gallery-item:hover img { transform:scale(1.06); }
.gallery-overlay {
  position:absolute; inset:0; background:rgba(26,58,92,0);
  transition:background .3s;
  display:flex; align-items:flex-end; padding:16px;
}
.gallery-item:hover .gallery-overlay { background:rgba(26,58,92,0.55); }
.gallery-caption { color:#fff; font-weight:600; font-size:14px; opacity:0; transform:translateY(8px); transition:all .3s; }
.gallery-item:hover .gallery-caption { opacity:1; transform:translateY(0); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial {
  background:var(--white); border:1px solid var(--border);
  padding:28px; position:relative;
}
.testimonial::before {
  content:'"'; font-family:Georgia,serif; font-size:80px;
  color:var(--accent); opacity:.18; position:absolute;
  top:8px; left:18px; line-height:1;
}
.t-stars { color:var(--accent); font-size:16px; margin-bottom:10px; }
.t-text  { font-size:15px; color:var(--gray-d); line-height:1.7; margin-bottom:20px; font-style:italic; }
.t-author { display:flex; gap:12px; align-items:center; border-top:1px solid var(--border); padding-top:14px; }
.t-avatar { width:44px; height:44px; border-radius:50%; object-fit:cover; background:var(--light); flex-shrink:0; }
.t-name    { font-weight:700; font-size:14px; color:var(--primary); }
.t-company { font-size:12px; color:var(--gray); }

/* ============================================================
   PARALLAX BANNER
   ============================================================ */
.parallax-banner {
  position:relative; padding:80px 0;
  background-size:cover; background-position:center;
  background-attachment:fixed;
  overflow:hidden;
}
.parallax-banner::before { content:''; position:absolute; inset:0; background:rgba(26,58,92,0.82); }
.parallax-banner > .container { position:relative; z-index:1; }
.banner-content { text-align:center; color:#fff; }
.banner-content h2 { font-family:'Oswald',sans-serif; font-size:40px; color:#fff; margin-bottom:14px; }
.banner-content h2 span { color:var(--accent); }
.banner-content p { font-size:17px; color:rgba(255,255,255,0.75); margin-bottom:32px; max-width:560px; margin-left:auto; margin-right:auto; }

/* ============================================================
   KONTAKT
   ============================================================ */
.contact-wrap { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.contact-info { color:#fff; }
.contact-detail { display:flex; gap:14px; align-items:flex-start; margin-bottom:16px; }
.contact-ic {
  width:38px; height:38px; background:rgba(255,255,255,0.1);
  display:flex; align-items:center; justify-content:center;
  font-size:17px; flex-shrink:0; border-radius:var(--radius); margin-top:2px;
}
.cd-lbl { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.45); margin-bottom:3px; }
.cd-val { font-size:15px; color:rgba(255,255,255,0.9); font-weight:500; }
.cd-val a { color:rgba(255,255,255,0.9); transition:color var(--tr); }
.cd-val a:hover { color:var(--accent); }
.map-wrap { margin-top:28px; height:220px; border-radius:var(--radius); overflow:hidden; }
.map-wrap iframe { width:100%; height:100%; border:none; display:block; }
.map-placeholder {
  width:100%; height:100%; background:rgba(255,255,255,0.08);
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:8px; border-radius:var(--radius);
  color:rgba(255,255,255,0.4); font-size:14px; text-align:center; padding:20px;
}
.map-placeholder .map-pin { font-size:32px; }

.contact-form-box { background:var(--white); padding:36px; box-shadow:var(--shadow-lg); }
.contact-form-box h3 {
  font-family:'Oswald',sans-serif; font-size:24px; color:var(--primary);
  margin-bottom:24px; padding-bottom:14px; border-bottom:2px solid var(--border);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fg { margin-bottom:14px; }
.fg label {
  display:block; font-size:12px; font-weight:700;
  color:var(--gray-d); margin-bottom:6px;
  text-transform:uppercase; letter-spacing:0.5px;
}
.fg input, .fg select, .fg textarea {
  width:100%; padding:11px 14px;
  border:1.5px solid var(--border); border-radius:var(--radius);
  font-family:'Source Sans 3',sans-serif; font-size:15px;
  color:var(--text); background:var(--light); outline:none;
  transition:border-color var(--tr), background var(--tr);
  box-sizing:border-box;
}
.fg input[type="date"] { padding:8px 10px; font-size:14px; cursor:pointer; min-width:0; }
.fg input:focus, .fg select:focus, .fg textarea:focus {
  border-color:var(--accent); background:var(--white);
}
.fg textarea { min-height:100px; resize:vertical; }
.fg.checkbox { display:flex; align-items:flex-start; gap:10px; }
.fg.checkbox input { width:auto; margin-top:4px; flex-shrink:0; }
.fg.checkbox label { font-size:13px; text-transform:none; letter-spacing:0; font-weight:400; color:var(--gray); }
.form-submit {
  width:100%; background:var(--accent); color:#fff; border:none;
  border-radius:var(--radius); padding:14px;
  font-family:'Source Sans 3',sans-serif; font-size:16px;
  font-weight:700; cursor:pointer; margin-top:6px;
  transition:background var(--tr);
}
.form-submit:hover { background:var(--accent-dark); }
.form-msg { padding:12px 16px; border-radius:var(--radius); margin-bottom:14px; font-size:14px; font-weight:600; display:none; }
.form-msg.success { background:#dcfce7; color:#15803d; display:block; }
.form-msg.error   { background:#fee2e2; color:#dc2626; display:block; }

/* ============================================================
   PAGE HERO (Unterseiten)
   ============================================================ */
.page-hero { background:var(--primary); padding:52px 0; position:relative; overflow:hidden; }
.page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:.18; }
.page-hero > .container { position:relative; z-index:1; }
.breadcrumb { display:flex; gap:8px; align-items:center; font-size:13px; color:rgba(255,255,255,0.5); margin-bottom:12px; }
.breadcrumb a { color:rgba(255,255,255,0.6); transition:color var(--tr); }
.breadcrumb a:hover { color:var(--accent); }
.breadcrumb .sep { color:rgba(255,255,255,0.35); }
.page-hero h1 { font-family:'Oswald',sans-serif; font-size:42px; color:#fff; font-weight:700; margin-bottom:8px; }
.page-hero p  { color:rgba(255,255,255,0.72); font-size:17px; max-width:560px; }

/* ============================================================
   FOOTER
   ============================================================ */
footer { background:#111113; color:rgba(255,255,255,0.55); }
.footer-top { padding:60px 0 48px; }
.footer-grid { display:grid; grid-template-columns:2.2fr 1fr 1fr 1.3fr; gap:48px; }
.footer-logo-link { display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.footer-brand-txt { font-size:13px; line-height:1.85; color:rgba(255,255,255,0.45); margin-bottom:20px; }
.footer-brand-txt a { color:rgba(255,255,255,0.45); transition:color var(--tr); }
.footer-brand-txt a:hover { color:var(--accent); }
.footer-social { display:flex; gap:10px; }
.footer-social a {
  width:36px; height:36px; background:rgba(255,255,255,0.07);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.55); transition:background var(--tr), color var(--tr);
}
.footer-social a:hover { background:var(--accent); color:#fff; }
.footer-col h4 {
  color:rgba(255,255,255,0.9); font-family:'Oswald',sans-serif;
  font-size:15px; letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:18px; padding-bottom:10px;
  border-bottom:2px solid var(--accent); display:inline-block;
}
.footer-col ul  { list-style:none; }
.footer-col li  { margin-bottom:10px; }
.footer-col li a { color:rgba(255,255,255,0.45); font-size:14px; transition:color var(--tr); }
.footer-col li a:hover { color:var(--accent); }
.footer-contact-list li { display:flex; gap:10px; align-items:flex-start; margin-bottom:12px; font-size:14px; color:rgba(255,255,255,0.45); }
.fc-ic { flex-shrink:0; font-size:15px; margin-top:1px; }
.footer-contact-list li a { color:rgba(255,255,255,0.6); transition:color var(--tr); }
.footer-contact-list li a:hover { color:var(--accent); }
.footer-bottom-bar { border-top:1px solid rgba(255,255,255,0.07); }
.footer-bottom {
  padding:18px 0; display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:10px;
  font-size:12px; color:rgba(255,255,255,0.28);
}
.footer-links { display:flex; flex-wrap:wrap; }
.footer-links a { color:rgba(255,255,255,0.38); margin-left:16px; transition:color var(--tr); }
.footer-links a:hover { color:var(--accent); }

/* ============================================================
   HILFEKLASSEN
   ============================================================ */
.mt-32 { margin-top:32px; }
.mt-40 { margin-top:40px; }
.mb-0  { margin-bottom:0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1100px) {
  .why-grid    { gap:52px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:36px; }
  .why-images  { padding-bottom:18px; padding-right:18px; }
  .why-img-small { right:-8px; bottom:-8px; }
}

@media (max-width:900px) {
  /* Nav */
  .nav-links  { display:none; }
  .nav-burger { display:flex; }
  .logo-info  { display:none; }

  /* Sections */
  section { padding:56px 0; }
  .section-title { font-size:34px; }

  /* Hero */
  .hero { min-height:auto; }
  .hero-content { padding:60px 0; }
  .hero-stat .num { font-size:34px; }

  /* 2-spaltig */
  .usp-grid          { grid-template-columns:repeat(2,1fr); }
  .cats-grid         { grid-template-columns:repeat(2,1fr); }
  .products-grid     { grid-template-columns:repeat(2,1fr); }
  .testimonials-grid { grid-template-columns:repeat(2,1fr); }
  .process-row       { grid-template-columns:repeat(2,1fr); gap:32px; }
  .process-row::before { display:none; }
  .gallery-grid      { grid-template-columns:repeat(2,1fr); grid-template-rows:auto; }
  .gallery-item.wide,
  .gallery-item.tall { grid-column:span 1; grid-row:span 1; }
  .gallery-item      { height:200px; }

  /* Why */
  .why-grid    { grid-template-columns:1fr; gap:0; }
  .why-images  { display:none; }

  /* Kontakt */
  .contact-wrap { grid-template-columns:1fr; gap:36px; }
}

@media (max-width:640px) {
  /* Topbar: auf Mobil nur Telefon + Mail sichtbar */
  .tb-company, .tb-address, .tb-hours { display:none; }
  .topbar-sep { display:none; }
  .topbar-inner { justify-content:flex-end; }

  /* 1-spaltig */
  .usp-grid          { grid-template-columns:repeat(2,1fr); }
  .cats-grid         { grid-template-columns:1fr; }
  .products-grid     { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .process-row       { grid-template-columns:1fr; }
  .gallery-grid      { grid-template-columns:1fr 1fr; }

  /* Hero */
  .hero h1    { font-size:30px; }
  .hero-text  { font-size:16px; }
  .hero-btns  { flex-direction:column; }
  .hero-btns .btn { text-align:center; }
  .hero-stats { flex-wrap:wrap; gap:16px; border:none; padding:0; }
  .hero-stat  { border:none; padding:0; margin:0; }

  /* Form */
  .form-row { grid-template-columns:1fr; }
  .contact-form-box { padding:22px 18px; }

  /* Footer */
  .footer-grid   { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .footer-links  { justify-content:center; }
  .footer-links a { margin:0 8px; }

  .section-title { font-size:28px; }
  .section-intro { font-size:15px; margin-bottom:36px; }

  .why-badge-box { display:none; }
}

@media (max-width:400px) {
  .container { padding:0 14px; }
  .usp-grid  { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; }
}

/* ============================================================
   SL DOORSYSTEMS – Zusätzliche Styles
   ============================================================ */

/* Leistungs-Kacheln (Service-Seiten) */
.service-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:28px; margin-bottom:60px;
}
.service-card {
  background:var(--white); border:1px solid var(--border);
  border-top:4px solid var(--accent);
  padding:32px 28px; transition:box-shadow var(--tr), transform var(--tr);
}
.service-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.service-card-icon { font-size:2.8rem; margin-bottom:18px; }
.service-card h3 { font-family:'Oswald',sans-serif; font-size:22px; color:var(--primary); margin-bottom:12px; }
.service-card p { color:var(--gray); font-size:15px; line-height:1.7; }
.service-card ul { padding-left:18px; color:var(--gray); font-size:14px; line-height:2; margin-top:12px; }

/* Team-Karten */
.team-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.team-card {
  background:var(--white); border:1px solid var(--border);
  overflow:hidden; text-align:center;
}
.team-card-avatar {
  width:100%; height:200px; background:var(--light);
  display:flex; align-items:center; justify-content:center;
  font-size:4rem;
}
.team-card-body { padding:24px; }
.team-card-body h3 { font-family:'Oswald',sans-serif; font-size:22px; color:var(--primary); margin-bottom:6px; }
.team-card-body .role { color:var(--accent); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:1px; margin-bottom:14px; }
.team-card-body ul { list-style:none; padding:0; text-align:left; font-size:14px; color:var(--gray); line-height:2; }
.team-card-body ul li::before { content:"✓ "; color:var(--accent); font-weight:700; }

/* Partner-Logos */
.partner-grid {
  display:grid; grid-template-columns:repeat(5,1fr); gap:18px; align-items:center;
}
.partner-card {
  border:1px solid var(--border); padding:18px 16px;
  display:flex; align-items:center; justify-content:center;
  transition:border-color var(--tr), box-shadow var(--tr);
  background:var(--white);
}
.partner-card:hover { border-color:var(--accent); box-shadow:0 2px 12px rgba(192,57,43,0.1); }
.partner-card span { font-weight:700; font-size:14px; color:var(--primary); text-align:center; }

/* Leistungsübersicht Liste */
.leistung-list { display:grid; grid-template-columns:1fr 1fr; gap:12px 40px; margin:24px 0; }
.leistung-list li {
  list-style:none; padding:8px 0; border-bottom:1px solid var(--border);
  color:var(--gray-d); font-size:15px; display:flex; align-items:center; gap:10px;
}
.leistung-list li::before { content:"→"; color:var(--accent); font-weight:700; flex-shrink:0; }

/* Info-Box */
.info-box {
  background:var(--light); border-left:4px solid var(--accent);
  padding:20px 24px; margin:24px 0;
}
.info-box p { color:var(--gray-d); font-size:15px; line-height:1.7; margin:0; }

/* Jobs */
.jobs-grid { display:grid; gap:20px; }
.job-card {
  background:var(--white); border:1px solid var(--border);
  padding:28px 32px; display:flex; justify-content:space-between;
  align-items:center; gap:24px; flex-wrap:wrap;
  transition:box-shadow var(--tr); border-left:4px solid var(--accent);
}
.job-card:hover { box-shadow:var(--shadow); }
.job-card h3 { font-family:'Oswald',sans-serif; font-size:22px; color:var(--primary); margin-bottom:6px; }
.job-card p { color:var(--gray); font-size:14px; }
.job-tag { display:inline-block; background:var(--accent); color:#fff; font-size:11px; font-weight:700; padding:3px 12px; letter-spacing:1px; text-transform:uppercase; margin-right:8px; margin-bottom:8px; }

/* Referenzen / Galerie */
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.gallery-item { overflow:hidden; aspect-ratio:4/3; background:var(--light); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.gallery-item:hover img { transform:scale(1.06); }

/* Kontakt-Seite */
.kontakt-grid { display:grid; grid-template-columns:1fr 420px; gap:52px; align-items:start; }
.kontakt-info-box { background:var(--primary); color:#fff; padding:36px; }
.kontakt-info-box h3 { font-family:'Oswald',sans-serif; font-size:26px; margin-bottom:24px; }
.kontakt-info-item { display:flex; gap:14px; align-items:flex-start; margin-bottom:20px; }
.kontakt-info-icon { font-size:1.3rem; flex-shrink:0; margin-top:2px; }
.kontakt-info-label { font-size:11px; text-transform:uppercase; letter-spacing:1px; color:rgba(255,255,255,0.5); margin-bottom:4px; }
.kontakt-info-val { font-size:15px; color:#fff; font-weight:600; }
.kontakt-info-val a { color:var(--accent); }

/* Formular Styles */
.form-styled .form-row { margin-bottom:18px; }
.form-styled label { display:block; font-weight:700; font-size:13px; color:var(--primary); text-transform:uppercase; letter-spacing:0.5px; margin-bottom:7px; }
.form-styled input, .form-styled select, .form-styled textarea {
  width:100%; padding:12px 16px; border:1.5px solid var(--border);
  font-family:inherit; font-size:15px; color:var(--text); background:#fff;
  outline:none; transition:border-color var(--tr); border-radius:0;
}
.form-styled input:focus, .form-styled select:focus, .form-styled textarea:focus { border-color:var(--accent); }
.form-styled textarea { min-height:130px; resize:vertical; }
.form-styled .form-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-styled .checkbox-row { display:flex; align-items:flex-start; gap:12px; font-size:14px; color:var(--gray); }
.form-styled .checkbox-row input { width:auto; margin-top:3px; }
.form-styled .checkbox-row a { color:var(--accent); }
.form-alert { padding:14px 18px; border-radius:0; margin-bottom:20px; border-left:4px solid; font-size:15px; }
.form-alert-success { background:#f0fdf4; border-color:#16a34a; color:#15803d; }
.form-alert-error   { background:#fef2f2; border-color:#dc2626; color:#dc2626; }

/* Page Hero (Unterseiten) */
.page-hero {
  background:var(--primary); padding:60px 0; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; right:-100px; top:-100px;
  width:400px; height:400px; background:var(--accent); opacity:.06;
  border-radius:50%;
}
.page-hero-content { position:relative; z-index:2; }
.page-hero-breadcrumb { font-size:13px; color:rgba(255,255,255,0.5); margin-bottom:12px; }
.page-hero-breadcrumb a { color:rgba(255,255,255,0.6); }
.page-hero-breadcrumb a:hover { color:var(--accent); }
.page-hero h1 { font-family:'Oswald',sans-serif; font-size:clamp(30px,3.5vw,52px); color:#fff; font-weight:700; line-height:1.1; margin-bottom:16px; }
.page-hero p { font-size:17px; color:rgba(255,255,255,0.75); max-width:580px; line-height:1.7; }
.page-hero-label { display:inline-block; background:var(--accent); color:#fff; font-size:11px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; padding:4px 14px; margin-bottom:14px; }

/* Breadcrumb */
.breadcrumb-bar { background:var(--light); border-bottom:1px solid var(--border); padding:10px 0; }
.breadcrumb-bar nav { font-size:13px; color:var(--gray); display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.breadcrumb-bar a { color:var(--accent); }
.breadcrumb-sep { color:var(--border); }

/* Subnavigation (Service-Seiten) */
.subnav { background:var(--light-2); border-bottom:1px solid var(--border); }
.subnav-inner { display:flex; gap:0; overflow-x:auto; }
.subnav-inner a { 
  padding:14px 22px; font-size:14px; font-weight:600; color:var(--gray-d);
  border-bottom:3px solid transparent; white-space:nowrap;
  transition:color var(--tr), border-color var(--tr);
}
.subnav-inner a:hover, .subnav-inner a.active { color:var(--accent); border-bottom-color:var(--accent); }

/* Impressum / Datenschutz */
.legal-content { max-width:800px; }
.legal-content h2 { font-family:'Oswald',sans-serif; font-size:24px; color:var(--primary); margin:36px 0 12px; }
.legal-content h3 { font-size:17px; font-weight:700; color:var(--primary); margin:24px 0 8px; }
.legal-content p { color:var(--gray-d); line-height:1.8; margin-bottom:14px; }
.legal-content dl { margin-bottom:16px; }
.legal-content dt { font-weight:700; color:var(--primary); }
.legal-content dd { color:var(--gray-d); margin-left:20px; margin-bottom:6px; }
.legal-content a { color:var(--accent); }

/* Responsive */
@media(max-width:1024px) {
  .service-grid { grid-template-columns:repeat(2,1fr); }
  .partner-grid { grid-template-columns:repeat(3,1fr); }
  .kontakt-grid { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .service-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:repeat(2,1fr); }
  .leistung-list { grid-template-columns:1fr; }
  .partner-grid { grid-template-columns:repeat(2,1fr); }
  .job-card { flex-direction:column; align-items:flex-start; }
  .form-styled .form-grid-2 { grid-template-columns:1fr; }
}

/* ============================================================
   MOBILE RESPONSIVE – Vollständiger Fix für alle Seiten
   ============================================================ */

/* Hilfsklassen für responsive Layouts */
.grid-2col    { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:start; }
.grid-2col-sm { display:grid; grid-template-columns:1fr 340px; gap:52px; align-items:start; }
.grid-2col-md { display:grid; grid-template-columns:1fr 360px; gap:52px; align-items:start; }
.grid-2col-img { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.grid-3col    { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.grid-list-2  { display:grid; grid-template-columns:1fr 1fr; gap:8px 30px; list-style:none; padding:0; }
.grid-img-2   { display:grid; grid-template-columns:1fr 1fr; gap:16px; }

/* Topbar – auf sehr kleinen Screens stärker kürzen */
@media (max-width:480px) {
  .topbar { display:none; }
  .navbar  { top:0; }
}

/* Navigation Mobile */
@media (max-width:900px) {
  .mobile-menu {
    padding:20px 0;
  }
  .mobile-menu a {
    padding:14px 24px;
    font-size:17px;
  }
  .mobile-submenu a {
    padding:10px 24px 10px 40px;
    font-size:15px;
  }
}

/* Hero Mobile */
@media (max-width:640px) {
  .hero { min-height:auto; }
  .hero-content { padding:48px 0 40px; }
  .hero h1 { font-size:clamp(26px, 7vw, 36px); line-height:1.15; }
  .hero-text { font-size:15px; }
  .hero-btns { flex-direction:column; gap:12px; }
  .hero-btns .btn { text-align:center; width:100%; }
  .hero-stats { display:grid; grid-template-columns:1fr 1fr; gap:12px; border:none; padding:0; margin-top:28px; }
  .hero-stat { border:none; padding:12px; background:rgba(255,255,255,.06); border-radius:6px; text-align:center; }
  .hero-stat .num { font-size:28px; }
}

/* Section Titles */
@media (max-width:640px) {
  .section-title { font-size:clamp(22px, 6vw, 30px); }
  .page-hero h1  { font-size:clamp(22px, 6vw, 38px); }
  .page-hero p   { font-size:15px; }
  .page-hero     { padding:40px 0; }
}

/* Index – 2-spaltige Bereiche */
@media (max-width:768px) {
  .grid-2col,
  .grid-2col-sm,
  .grid-2col-md,
  .grid-2col-img { grid-template-columns:1fr !important; gap:32px !important; }

  .grid-img-2 { grid-template-columns:1fr 1fr !important; }

  .grid-3col { grid-template-columns:1fr 1fr !important; }

  .grid-list-2 { grid-template-columns:1fr !important; }
}

@media (max-width:480px) {
  .grid-3col  { grid-template-columns:1fr !important; }
  .grid-img-2 { grid-template-columns:1fr 1fr !important; }
}

/* Index – Inline-Grid-Fixes über Klassen */
@media (max-width:768px) {
  /* "Warum wir" Bild+Text Bereich */
  .idx-why-grid { grid-template-columns:1fr !important; }
  /* Galerie Vorschau 3-spaltig */
  .idx-gallery  { grid-template-columns:1fr 1fr !important; }
  /* Leistungsliste 2-spaltig */
  .idx-leistung { grid-template-columns:1fr !important; }
}

@media (max-width:480px) {
  .idx-gallery { grid-template-columns:1fr 1fr !important; }
}

/* Jobs Seite */
@media (max-width:900px) {
  .jobs-layout { grid-template-columns:1fr !important; }
  .jobs-sidebar { display:none; }
}
@media (max-width:640px) {
  .job-card { padding:20px 18px; }
  .job-card h3 { font-size:18px; }
}

/* Kontakt Seite */
@media (max-width:768px) {
  .kontakt-grid { grid-template-columns:1fr !important; }
}

/* Anfahrt Seite */
@media (max-width:768px) {
  .anfahrt-grid { grid-template-columns:1fr !important; gap:32px !important; }
}

/* Service Unterseiten – Sidebar-Layout */
@media (max-width:900px) {
  .service-layout   { grid-template-columns:1fr !important; gap:32px !important; }
  .service-sidebar  { display:none; }
}
@media (max-width:640px) {
  .service-list-2 { grid-template-columns:1fr !important; gap:6px !important; }
}

/* Referenzen Galerie */
@media (max-width:768px) {
  .referenzen-grid { grid-template-columns:repeat(2,1fr) !important; min-width:auto !important; }
}
@media (max-width:480px) {
  .referenzen-grid { grid-template-columns:1fr 1fr !important; }
}

/* Partner Seite */
@media (max-width:640px) {
  .partner-grid { grid-template-columns:repeat(2,1fr) !important; gap:10px !important; }
  .partner-card { padding:18px 12px; min-height:90px; }
  .partner-info-inner { flex-direction:column !important; gap:20px !important; }
  .partner-info-box { padding:24px 18px !important; }
}
@media (max-width:360px) {
  .partner-grid { grid-template-columns:1fr 1fr !important; gap:8px !important; }
}

/* Footer Mobile */
@media (max-width:640px) {
  .footer-grid { grid-template-columns:1fr !important; gap:28px; }
  .footer-bottom { flex-direction:column; text-align:center; gap:10px; }
  .footer-links { justify-content:center; flex-wrap:wrap; }
  .footer-col h4 { margin-bottom:12px; }
}

/* Buttons Mobile */
@media (max-width:480px) {
  .btn { padding:12px 20px; font-size:14px; }
  .btn-lg { padding:14px 24px; font-size:15px; }
}

/* Termine / Kontaktformular Mobile */
@media (max-width:640px) {
  .form-styled .form-grid-2 { grid-template-columns:1fr !important; }
  .contact-wrap { grid-template-columns:1fr !important; }
}

/* Team / Ansprechpartner */
@media (max-width:640px) {
  .team-grid { grid-template-columns:1fr !important; }
  .team-card-avatar { height:160px; font-size:3rem; }
}

/* Tabellen scrollbar auf Mobile */
@media (max-width:640px) {
  table { display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; }
}

/* Breadcrumb kürzen */
@media (max-width:480px) {
  .page-hero-breadcrumb { font-size:12px; }
}

/* Subnav scrollbar */
.subnav-inner { -webkit-overflow-scrolling:touch; scrollbar-width:none; }
.subnav-inner::-webkit-scrollbar { display:none; }

/* USP Grid auf Mobile */
@media (max-width:400px) {
  .usp-grid { grid-template-columns:1fr !important; }
}

/* Container padding auf sehr kleinen Screens */
@media (max-width:360px) {
  .container { padding:0 12px; }
}

/* ============================================================
   LAYOUT-KLASSEN (Inline-Style-Ersatz – Mobile-ready)
   ============================================================ */

/* Service-Seiten: Haupt + Sidebar */
.service-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 52px;
  align-items: start;
}

/* Jobs-Seite: Haupt + Sidebar */
.jobs-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 52px;
  align-items: start;
}

/* Service-Liste 2-spaltig */
.service-list-2 {
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 30px;
}

/* ============================================================
   MOBILE OVERRIDES – greifen jetzt ohne !important-Konflikt
   ============================================================ */

/* USP-Strip unter Hero auf Mobile verstecken */
@media (max-width: 768px) {
  .usp-strip { display: none; }
}

/* Service + Jobs Layout: 1 Spalte auf Mobile */
@media (max-width: 900px) {
  .service-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .jobs-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .service-sidebar,
  .jobs-sidebar {
    display: none;
  }
  .service-list-2 {
    grid-template-columns: 1fr;
    gap: 4px 0;
  }
}

@media (max-width: 640px) {
  .service-list-2 {
    grid-template-columns: 1fr;
  }
}
