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

/* === Variablen (Fallbacks; werden per PHP aus DB überschrieben) === */
:root {
  --primary:      #1a3a5c;
  --primary-dark: #0f2438;
  --accent:       #e8820c;
  --accent-dark:  #c96e08;
  --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:60px; width:auto; object-fit:contain; background:transparent; }
.footer-logo-img { height:80px; width:auto; object-fit:contain; mix-blend-mode:screen; }
.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:#0f2035; }
.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-template-rows:220px 220px;
  gap:10px;
}
.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:#0f2035; 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; }
}
