/*
  © Auto Zentrale Bergheim – Stylesheet
  Entwickelt von: 	Entwickler für Marken & Menschen — Holger Hinkelmann
  Stand: 		November 2025
*/

/* ================== Variablen & Reset ================== */
:root{
  --brand-blue:#000D74;
  --accent-yellow:#FBC705;
  --ticker-h:32px;
  --footer-h:56px;
}

*{margin:0;padding:0;box-sizing:border-box;}
a{color:#000;text-decoration:none;transition:color .2s ease;}
a:hover{color:var(--accent-yellow);text-decoration:underline;}

@font-face{font-family:Futura1;src:url(1futuralt.ttf);}
@font-face{font-family:Futura2;src:url(1futurabk.ttf);}
@font-face{font-family:Script1;src:url(1script.ttf);}

/* ================== Seite & Grundlayout ================== */
html,body{height:100%;}
body{
  font-family:Calibri, Helvetica, Arial, sans-serif;
  color:#fff;
  background:var(--brand-blue);
  font-size:15px;
  line-height:1.5;
  padding-bottom:var(--footer-h);
  overflow-x:auto;  /* Hybrid: horizontales Scrollen erlaubt */
  overflow-y:auto;
}

/* Überschriften */
h1{font-size:27px;font-family:Futura1, sans-serif;}
h2{font-size:19px;font-family:Futura1, sans-serif;}
h3{font-size:17px;font-family:Futura1, sans-serif;}

/* ================== Wrapper / Bühne ================== */
#wrapper,
#wrapper_leistungen,
#wrapper_tuev,
#wrapper_gebrauchtwagen,
#wrapper_kontakt,
#wrapper_impressum{
  width:1276px;
  margin:10px auto;
  position:relative;
}
#wrapper{ min-height:1279px; }

/* Hintergrundbild als <img class="bg"> */
#wrapper .bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;
  background:#000D74;
  display:block;
  z-index:0;
}

/* Inhaltsschicht über Bild */
#wrapper .layer{ position:relative; z-index:5; }

/* ================== Navigation ================== */
#navi{
  position:absolute;
  top:154px; left:290px;
  font-size:22px; line-height:24px;
  font-family:Futura1, sans-serif;
  z-index:6;
}
#navi li{list-style:none;float:left;}
#navi a{display:block;margin:4px 25px 0 5px;color:#000;}

#navi a{
  color:#000;
  text-decoration:none;
  padding:2px 6px;
  border-bottom:2px solid transparent;
}
#navi a:hover{
  color:#FBC705;
  border-bottom-color:#FBC705;
  text-decoration:none;
}
#navi a.active{
  color:#FBC705;
  border-bottom-color:#FBC705;
  font-weight:700;
  text-decoration:none;
}

/* ================== Willkommen-Box ================== */
.welcome-box{
  position:absolute; left:1000px; top:220px;
  width:230px; padding:16px 20px;
  background:rgba(255,255,255,0.82);
  border-radius:8px;
  font-family:Futura1, sans-serif;
  font-size:22px; font-weight:bold; line-height:35px;
  color:#000;
  box-shadow:0 4px 16px rgba(0,0,0,0.15);
  text-align:left;
  z-index:7;
}
.welcome-box .brand{color:var(--brand-blue);}

/* ================== Ticker (zentrierter Kasten) ================== */
#ticker{
  position:fixed;
  top:12px; left:50%; transform:translateX(-50%);
  width:50%; max-width:640px; height:32px;
  background:rgba(0,13,116,.95); color:#fff;
  border:1px solid rgba(255,255,255,.25);
  border-radius:6px;
  display:flex; align-items:center; justify-content:center;
  z-index:50;
  box-shadow:0 4px 16px rgba(0,13,116,.6);
  padding:0 10px; overflow:hidden;
}
#ticker .ticker-link{color:#fff;font-family:Futura1;font-size:18px;text-align:center;}
#ticker .ticker-link:hover{color:var(--accent-yellow);text-decoration:underline;}
#ticker marquee{width:100%;white-space:nowrap;color:inherit;}

/* ================== Kacheln (Desktop absolut) ================== */
/* Desktop-Kacheln absolut auf der Bühne */
.kachel{
  position:absolute;
  top:840px;
  width:200px;
  text-align:center;
  line-height:20px;
  color:#fff;
  font-family:Futura1;
  font-size:16px;
}
.k1{left:30px;} .k2{left:290px;} .k3{left:540px;} .k4{left:790px;} .k5{left:1045px;}

/* Mobile: Kacheln fließen unter dem Bild */
@media (max-width:900px){
  .kachel{
    position:static !important;
    width:auto;
    text-align:left;
    margin:12px 16px 0 16px;
  }
}

/* ================== Kundenstimmen / Slider ================== */
/* Kundenstimmen unter der Bühne – ohne riesigen oberen Abstand */

.reviews-slider{
  position: relative;
  z-index: 4;
  width: 1276px;          /* gleiche Breite wie #wrapper */
  max-width: 1276px;      /* nicht größer werden */
  margin: 30px auto 80px; /* 30px Abstand unterm Hero/Kacheln */
  padding: 0 20px;        /* etwas Innenluft, wirkt ruhiger */
  color: #fff;
}

.reviews-slider h2{
  font-family: Futura1, sans-serif;
  font-size: 20px;
  margin: 0 0 10px 0;
  color: #fff;
}

.slider-viewport{
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 0 6px 14px rgba(0,0,0,.15);
  background: rgba(255,255,255,0.90);
}

.slides{ display: flex; transition: transform .4s ease; }
.review{ min-width: 100%; padding: 16px; color: #222; background: transparent; }
.review .stars{ color:#FBC705; font-size:16px; margin-bottom:8px; }
.review blockquote{ font-size:15px; line-height:1.45; margin:0; }
.review figcaption{ margin-top:10px; font-size:13px; color:#444; }

.slider-nav{ display:flex; gap:8px; justify-content:center; margin-top:10px; }
.slider-nav button{
  width:36px; height:36px; border-radius:50%;
  border:1px solid rgba(255,255,255,.35);
  background: rgba(0,13,116,.85);
  color:#fff; font-size:20px; line-height:1;
  cursor:pointer; 
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.slider-nav button:hover{
  transform: translateY(-1px);
  background: #FBC705; color:#000; border-color:#FBC705;
  box-shadow: 0 0 6px rgba(251,199,5,0.6);
}

/* Mobile: schmal & zentriert */
@media (max-width: 900px){
  .reviews-slider{
    width: 92%;
    max-width: 620px;
    margin: 24px auto 120px; /* unten Luft zum Footer */
    padding: 0;
  }
}



/* ================== Footer ================== */
footer{
  position:relative; z-index:10;
  background:#000D74; color:#fff;
  border-top:1px solid rgba(255,255,255,.2);
  height:56px; display:flex; align-items:center; justify-content:center;
}
footer a{color:var(--accent-yellow);}
footer a:hover{text-decoration:underline;}

/* Mobile — let it FLOW, narrow slider, push it down */
@media (max-width: 900px){

  /* Ensure no rogue absolute positions on small screens */
  #navi, .welcome-box, .kachel, #openhours, #phone{
    position:static !important; left:auto !important; top:auto !important;
    margin:12px 16px !important;
  }

  /* Nav wraps nicely */
  #navi ul{ display:flex !important; flex-wrap:wrap !important; gap:10px 14px !important; }
  #navi a{ margin:0 !important; font-size:16px !important; }

  /* Stage full width; image becomes normal block */
  #wrapper{ width:100vw !important; max-width:100vw !important; margin:0 auto !important; min-height:auto !important; }
  #wrapper .bg{ position:relative !important; inset:auto !important; width:100% !important; height:auto !important; }

  /* Add vertical space so slider starts under hero/kacheln */
  .after-hero{ height: 600px !important; }   /* was zu wenig -> hochsetzen */

  /* Slider narrower & centered */
  .reviews-slider{
    width:92% !important; max-width:620px !important;
    margin:24px auto 120px !important;      /* nicht über den hero schieben */
  }

  /* Ticker small */
  #ticker{ top:8px !important; width:40% !important; min-height:26px !important; padding:4px 6px !important; }
  #ticker .ticker-link, #ticker marquee{ font-size:15px !important; }
}

/* Footer must remain clickable and above background */
footer{ position:relative !important; z-index:10 !important; pointer-events:auto !important; }

/* Farben für Top-Leiste erzwingen */
#openhours, #openhours * { color:#fff !important; }
#phone a { color:#fff !important; }

/* Mobile Positionen für Öffnungszeiten/Telefon */
@media (max-width: 900px){
  #openhours, #phone{
    position:absolute !important;
    left:auto !important;
    right:16px !important;
    margin:0 !important;
    z-index:6;              /* über Bild */
  }
  #openhours{ top:72px !important; }
  #phone{     top:100px !important; }
}

/* === HOTFIX: Reviews-Slider zentrieren & ausrichten (Desktop) === */
@media (min-width: 901px){
  #wrapper + .reviews-slider{
    position: relative !important;
    width: 1276px !important;       /* exakt wie #wrapper */
    max-width: 1276px !important;
    box-sizing: border-box !important;
    margin: 30px auto 80px !important; /* direkt unter den Kacheln */
    left: auto !important;
    right: auto !important;
    float: none !important;
    clear: both !important;          /* falls irgendwo floats wirken */
    transform: none !important;
  }
}



/* Bühne bleibt fix 1276 px */
#wrapper { 
  width: 1276px !important; 
  min-height: 1279px !important;
  margin: 10px auto !important;
  position: relative !important;
}


/* Zusätzliche Sicherungen gegen "Grafik-Flitsch" */
#navi ul { white-space: nowrap; }      /* verhindert Umbruch der Menüpunkte */
.phone-link, #phone a { color:#fff !important; }  /* Telefon bleibt weiß */


/* ========= LEISTUNGEN SEITE ========= */
.leistungen-content {
  position: relative;
  z-index: 5;
  width: 80%;
  max-width: 960px;
  margin: 160px auto 100px;     /* 160px Abstand wegen Navi & Top-Bereich */
  color: #fff;
  font-family: Calibri, Helvetica, sans-serif;
  line-height: 1.6;
}
.leistungen-content h1 {
  font-family: Futura1, sans-serif;
  font-size: 26px;
  margin-bottom: 12px;
  color: #fff;
}
.leistungen-content h2 {
  font-family: Futura1, sans-serif;
  font-size: 20px;
  margin-top: 28px;
  margin-bottom: 8px;
  color: #FBC705;
}
.leistungen-content p {
  margin-bottom: 12px;
  font-size: 15px;
  color: #f2f2f2;
}
.leistungen-content .abschluss {
  margin-top: 28px;
  font-weight: bold;
  color: #fff;
}

/* ========= HU / TÜV SEITE ========= */
.tuev-content {
  position: relative;
  z-index: 5;
  width: 80%;
  max-width: 960px;
  margin: 160px auto 100px;
  color: #fff;
  font-family: Calibri, Helvetica, sans-serif;
  line-height: 1.6;
}
.tuev-content h1 {
  font-family: Futura1, sans-serif;
  font-size: 26px;
  margin-bottom: 12px;
  color: #fff;
}
.tuev-content h2 {
  font-family: Futura1, sans-serif;
  font-size: 20px;
  margin-top: 28px;
  margin-bottom: 8px;
  color: #FBC705;
}
.tuev-content p {
  margin-bottom: 12px;
  font-size: 15px;
  color: #f2f2f2;
}
.tuev-content ul {
  margin: 6px 0 12px 24px;
  padding-left: 10px;
  color: #f2f2f2;
  line-height: 1.55;
}
.tuev-content li {
  margin-bottom: 6px;
}
.tuev-content .abschluss {
  margin-top: 28px;
  font-weight: bold;
  color: #fff;
}

/* Inspektion-Wrapper wie die anderen Bühnen */
#wrapper_inspektion{
  width:1276px;
  margin:10px auto;
  position:relative;
  min-height:1279px;   /* passend zum Bühnenbild */
}

/* ========= Inspektions-Seite ========= */
.inspektion-content{
  position:relative; z-index:5;
  width:80%; max-width:960px;
  margin:160px auto 100px;
  color:#fff; line-height:1.6;
  font-family: Calibri, Helvetica, sans-serif;
}
.inspektion-content h1{
  font-family:Futura1, sans-serif; font-size:26px;
  margin-bottom:12px; color:#fff;
}
.inspektion-content h2{
  font-family:Futura1, sans-serif; font-size:20px;
  margin:28px 0 8px; color:#FBC705;
}
.inspektion-content p{ margin-bottom:12px; font-size:15px; color:#f2f2f2; }
.inspektion-content ul{ margin:6px 0 12px 24px; padding-left:10px; color:#f2f2f2; line-height:1.55; }
.inspektion-content li{ margin-bottom:6px; }
.inspektion-content .abschluss{ margin-top:28px; font-weight:bold; color:#fff; }

/* ========= Gebrauchtwagen SEITE ========= */
.gebraucht-content{
  position: relative;
  z-index: 5;
  width: 80%;
  max-width: 960px;
  margin: 160px auto 90px;     /* gleiche Einrückung/Abstände wie die anderen */
  color: #fff;
  font-family: Calibri, Helvetica, sans-serif;
  line-height: 1.6;
}
.gebraucht-content h1{
  font-family: Futura1, sans-serif;
  font-size: 26px;
  margin-bottom: 12px;
  color: #fff;
}
.gebraucht-content h2{
  font-family: Futura1, sans-serif;
  font-size: 20px;
  margin: 24px 0 8px;
  color: #FBC705;
}
.gebraucht-content p{ margin-bottom: 12px; color:#f2f2f2; }

/* Häkchen-Liste (sauber, ohne gelbe Flächen) */
.gebraucht-content ul{ list-style: none; margin: 8px 0 12px; padding-left: 1.4em; }
.gebraucht-content li{ position: relative; margin: 6px 0; }
.gebraucht-content li::before{
  content: '✔';
  position: absolute; left: -1.4em;
  color: #FBC705; font-weight: 700;
}


/* ===== AutoScout24 Karte ===== */
.as24-card{
  position:relative; z-index:5;
  width:80%; max-width:960px;
  margin:28px auto 90px;
  padding:16px 18px;
  border-radius:12px;
  background:rgba(255,255,255,0.08);
  box-shadow:0 6px 14px rgba(0,0,0,.12);
  color:#fff;
}
.as24-head{ display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.as24-badge{ display:block; }
.as24-card h2{ font-family:Futura1, sans-serif; font-size:20px; margin:0; color:#FBC705; }
.as24-text{ margin:6px 0 12px; color:#ffffff; }
.as24-cta{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin:6px 0 4px; }
.as24-btn{ background:#FBC705; color:#000; font-weight:bold; padding:10px 14px; border-radius:8px; }
.as24-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(0,0,0,0.2); background:inherit; color:inherit;}
.as24-plain{ color:#fff; text-decoration:underline; }
.as24-note{ font-size:13.5px; color:#ddd; margin-top:10px; }

@media (max-width:900px){
  .as24-card{ width:92%; margin:24px auto 120px; }
}

/* ====== Bessere Darstellung Google-Kartenausschnitt @Mobile ===== */
.map-section h2{font-family:Futura1,sans-serif;color:#fff;margin-top:20px;}
.map-section p{color:#fff;line-height:1.5;}
.map-container img{max-width:100%;height:auto;}
@media (max-width:900px){
  .map-container{max-width:95%;margin:16px auto;}
}

/* Kontakt – Map unter dem Formular, wie im Impressum */
.map-section { 
  margin: 24px 0 40px; 
}
.map-section h2{
  font-family: Futura1, sans-serif; 
  color: #fff; 
  margin: 0 0 10px 0;
}
.map-consent{
  max-width: 720px;
  background: rgba(255,255,255,0.08);
  border: 2px solid #000D74;
  border-radius: 10px;
  box-shadow: 0 6px 14px rgba(0,0,0,.15);
  padding: 12px;
}
.map-img{
  display:block; width:100%; height:auto; border-radius: 6px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  margin-bottom: 10px;
}
.map-hint{
  color:#ddd; font-size:13px; margin-top:8px; line-height:1.5;
}
.map-embed-wrap{
  position: relative; 
  padding-bottom: 56.25%;  /* 16:9 */
  height: 0; 
  overflow: hidden; 
  border-radius: 8px;
}
.map-embed-wrap iframe{
  position: absolute; top:0; left:0; width:100%; height:100%;
  border:0;
}

/* Sicherstellen, dass Formular-Inhalte über dem BG liegen */
.contact-wrap, .layer, main { position: relative; z-index: 5; }

/* === NAV überall identisch (Desktop) === */
@media (min-width:901px){
  /* gleiche Layer-Geometrie auf allen Seiten */
  #wrapper .layer,
  #wrapper_leistungen .layer,
  #wrapper_tuev .layer,
  #wrapper_gebrauchtwagen .layer,
  #wrapper_kontakt .layer,
  #wrapper_impressum .layer{
    position: relative !important;
    padding-top: 0 !important;
  }

  /* NAV-Koordinaten wie Startseite */
  #navi{
    position: absolute !important;
    top: 154px !important;
    left: 290px !important;
    z-index: 8 !important;
  }

  /* Öffnungszeiten + Telefon sicher über dem Bild & klickbar */
  #openhours{
    position: absolute !important;
    left: 820px !important;
    top: 100px !important;
    z-index: 9 !important;
    pointer-events: auto !important;
  }
  #phone{
    position: absolute !important;
    left: 1047px !important;
    top: 118px !important;
    z-index: 9 !important;
    pointer-events: auto !important;
  }
}

/* === Kontakt-Seite: Hero-Höhe fixieren, damit nichts "unter" das Bild rutscht === */
#wrapper_kontakt{ min-height:1279px; }
#wrapper_kontakt .layer{ min-height:1279px; }

/* === Kontakt-Reihe (Card links, Map rechts) + Formular darunter === */
.kontakt-top{
  display:flex; flex-wrap:wrap; gap:20px; align-items:stretch;
  margin: 140px 30px 20px;  
}
/* links (Kontaktkarte) schmaler lassen */
.kontakt-card{
  flex:1 1 440px;        /* vorher 420 */
  max-width:520px;
  min-height:460px;      /* gleiche Höhe wie Karte, siehe Punkt 2 */
  display:flex; flex-direction:column; justify-content:space-between;
}

/* rechts (Karte) breiter machen */
.map-section{
  flex:1 1 760px;        /* vorher 420 */
  max-width:820px;       /* vorher 520 */
  min-height:460px;
  display:flex; flex-direction:column; justify-content:space-between;
}

.form-card{
  max-width: 1180px;	/* vorher 900px */
  margin: 20px auto 60px; /* mittig unter Kontakt-Box und Karte platziert */
}


/* ===== FINAL OVERRIDES (autoritative Fixes) ===== */

/* 2.1 Bühne: .bg auch auf Unterseiten absolut positionieren */
#wrapper_leistungen .bg,
#wrapper_tuev .bg,
#wrapper_gebrauchtwagen .bg,
#wrapper_kontakt .bg,
#wrapper_impressum .bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;
  z-index:0;
}

/* 2.2 Layer-Geometrie einheitlich */
#wrapper .layer,
#wrapper_leistungen .layer,
#wrapper_tuev .layer,
#wrapper_gebrauchtwagen .layer,
#wrapper_kontakt .layer,
#wrapper_impressum .layer{
  position:relative !important;
  padding-top:0 !important;
  z-index:5 !important;
}

/* 2.3 NAV + Top-Zeile (Öffnungszeiten/Telefon) – überall gleich (DESKTOP) */
@media (min-width:901px){
  #navi{
    position:absolute !important;
    top:154px !important;
    left:290px !important;
    z-index:8 !important;
  }
  #openhours{
    position:absolute !important;
    left:820px !important;
    top:100px !important;
    margin:0 !important;
    z-index:9 !important;
    color:#fff !important;
    pointer-events:auto !important;
  }
  #phone{
    position:absolute !important;
    left:1047px !important;
    top:118px !important;
    margin:0 !important;
    z-index:9 !important;
    pointer-events:auto !important;
  }
}

/* 2.4 Kontakt-Seite – Reihe unter dem Hero + Formular darunter */
.kontakt-top{
  display:flex; flex-wrap:wrap; gap:20px; align-items:flex-start;
  margin: 140px 30px 16px 30px; /* wenig Luft unter dem Bild */
}
.kontakt-card{ flex:1 1 420px; max-width:520px; }
.kontakt-top .map-section{ flex:1 1 420px; max-width:520px; margin:0 !important; }

.form-card{
  flex:0 0 100% !important;
  max-width:none;              /* schön breit auf 1276er Bühne */
  width:calc(100% - 60px);       /* 30px Seitenrand links/rechts */
  margin:18px 30px 60px !important;
}

/* 2.5 Mobile-Fallback (nur Ordnung – keine Positionssprünge mehr) */
@media (max-width:900px){
  #navi, #openhours, #phone{ position:static !important; margin:0 16px !important; }
  .kontakt-top{ flex-direction:column; margin:16px !important; }
  .kontakt-card, .kontakt-top .map-section{ max-width:none !important; }
  .form-card{ width:92%; max-width:620px; margin:16px auto 60px !important; }
  .form-card form{ grid-template-columns:1fr !important; }
}

/* 2.6 Sicherheit gegen „Grafik-Flitsch“ bei schmalen Desktopfenstern */
html, body{ min-width:1276px; overflow-x:auto; }

/* ===== GLOBAL STAGE LOCK (alle Seiten identisch wie Home) ===== */
#wrapper .bg,
#wrapper_leistungen .bg,
#wrapper_tuev .bg,
#wrapper_inspektion .bg,
#wrapper_gebrauchtwagen .bg,
#wrapper_kontakt .bg,
#wrapper_impressum .bg{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:contain; z-index:0; pointer-events:none;   /* blockiert keine Klicks */
}

#wrapper .layer,
#wrapper_leistungen .layer,
#wrapper_tuev .layer,
#wrapper_inspektion .layer,
#wrapper_gebrauchtwagen .layer,
#wrapper_kontakt .layer,
#wrapper_impressum .layer{
  position:relative; z-index:5; min-height:1279px; padding-top:0;
}

/* NAV / Öffnungszeiten / Telefon – überall exakt wie auf der Startseite */
#wrapper #navi, 
#wrapper_leistungen #navi,
#wrapper_tuev #navi,
#wrapper_inspektion #navi,
#wrapper_gebrauchtwagen #navi,
#wrapper_kontakt #navi,
#wrapper_impressum #navi{
  position:absolute; top:154px; left:290px; z-index:12;
}
#wrapper #openhours, 
#wrapper_leistungen #openhours,
#wrapper_tuev #openhours,
#wrapper_inspektion #openhours,
#wrapper_gebrauchtwagen #openhours,
#wrapper_kontakt #openhours{
  position:absolute; left:820px; top:100px; margin:0; z-index:12; color:#fff !important; pointer-events:auto;
}
#wrapper #phone, 
#wrapper_leistungen #phone,
#wrapper_tuev #phone,
#wrapper_inspektion #phone,
#wrapper_gebrauchtwagen #phone,
#wrapper_kontakt #phone{
  position:absolute; left:1047px; top:118px; margin:0; z-index:12; pointer-events:auto;
}
#phone a{ color:#fff !important; }

/* Inhaltsoffset unter der NAV-Zeile (statt „klebt am Bild“) */
.leistungen-content,
.tuev-content,
.inspektion-content{
  width:80%; max-width:960px;
  margin:260px auto 100px;    /* 260px = sauber unter Hero/NAV */
  color:#fff; line-height:1.6;
}

/* Kontaktseite – Kontaktkarte & Map nebeneinander, Formular darunter */
#wrapper_kontakt .kontakt-top{
  display:flex; flex-wrap:wrap; gap:20px; align-items:flex-start;
  margin:260px 30px 16px;      /* exakt unter dem Hero */
  position:relative; z-index:6;
}
#wrapper_kontakt .kontakt-card{ flex:1 1 420px; max-width:520px; }
#wrapper_kontakt .map-section{  flex:1 1 420px; max-width:520px; }

#wrapper_kontakt .form-card{
  max-width:1190px;
  margin:18px 30px 40px;
  position:relative; z-index:6;
}

/* Map-Consent wie im Impressum (Optik + Sicherheit) */
.map-consent{
  background:rgba(255,255,255,0.08);
  border:2px solid #000D74; border-radius:10px;
  box-shadow:0 6px 14px rgba(0,0,0,.15); padding:12px;
}
.map-embed-wrap{ position:relative; padding-bottom:56.25%; height:0; overflow:hidden; border-radius:8px; }
.map-embed-wrap iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* Sicher: Footer bleibt drüber */
footer{ position:relative; z-index:10; }

/* Optional: schmale Fenster sollen NICHT umbrechen -> Horizontal-Scroll erlaubt */
html, body{ min-width:1276px; overflow-x:auto; }

/* === GLOBAL HEADER OVERRIDE (gilt für alle Unterseiten) === */
/* 1) Einheitliche Bühne + identische Koordinaten wie auf index.php */
.page .layer { position: relative !important; z-index: 5 !important; }
.page #navi  { position: absolute !important; top: 154px !important; left: 290px !important; z-index: 8 !important; }
.page #openhours { position: absolute !important; left: 820px !important; top: 100px !important; margin: 0 !important; z-index: 9 !important; pointer-events: auto !important; }
.page #phone     { position: absolute !important; left: 1047px !important; top: 118px !important; margin: 0 !important; z-index: 9 !important; pointer-events: auto !important; }

/* 2) Content unterhalb des Hero-Bildes starten lassen */
.hero-spacer { height: 360px; }  /* bei Bedarf 340–400 px feinjustieren */

/* 3) Kontakt-Reihe (links Karte/Adresse, rechts Map) */
.kontakt-top{
  display:flex; flex-wrap:wrap; gap:20px; align-items:flex-start;
  margin: 10px 30px 16px;    /* kleiner Abstand unter dem Hero */
}
.kontakt-card{ flex:1 1 420px; max-width:520px; }
.map-section { flex:1 1 420px; max-width:520px; }

/* 4) Formular in den normalen Fluss */
.form-card{
  max-width:1190px;
  margin: 18px 30px 40px;
}


/* Hero-Finetune für alle Unterseiten */
.page .bg{
  object-position: center top;                 /* Bild am oberen Rand ausrichten */
  transform: translateY(var(--hero-y, 0px));   /* feiner vertikaler Nudge */
  transition: transform .2s ease;
}

.page .hero-spacer{
  height: var(--spacer-h, 360px);              /* Startabstand für Texte */
}

@media (max-width: 900px){
  /* kleiner „Hero-Spacing“, falls nötig */
  .hero-spacer { height: 12px !important; }
  /* oder, wenn du keinen hero-spacer nutzt: */
  #wrapper .layer{ margin-top: 8px !important; }
}

/* ========== CLEAN MOBILE LAYOUT (unter 900px) ========== */
@media (max-width: 900px){

  /* Keine Zwangsbreite, kein Horizontal-Scroll */
  html, body{
    min-width: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  /* Bühne im Fluss */
  #wrapper{
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    min-height: auto !important;
    position: relative !important;
  }

  /* Hintergrundbild als normales Block-Image, oben sichtbar */
  #wrapper .bg{
    position: relative !important;   /* nicht absolute */
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: contain !important;
    object-position: center top !important; /* zeigt den oberen Bereich */
    z-index: 0 !important;
  }

  /* Overlays in den Fluss – keine festen Koordinaten */
  #navi, #openhours, #phone, .welcome-box{
    position: static !important;
    margin: 8px 16px !important;
  }

  /* Kacheln im Fluss (kein absolute), volle Breite */
  .kachel{
    position: static !important;
    width: auto !important;
    text-align: left !important;
    margin: 12px 16px !important;
    color: #000 !important;   /* auf weiß lesbar */
  }

  /* Wenn du ein Grid benutzt (empfohlen): */
  .kachel-grid{
    display: grid !important;
    grid-template-columns: 1fr !important; /* Mobile 1 Spalte */
    gap: 12px !important;
    margin: 16px auto 24px !important;
    padding: 0 16px !important;
    max-width: 680px !important;  /* optional, damit es nicht „klebt“ */
  }

  /* Kundenstimmen kompakt */
  .reviews-slider{
    width: 92% !important;
    max-width: 640px !important;
    margin: 16px auto 80px !important;
    padding: 0 !important;
  }

  /* Ticker kleiner */
  #ticker{
    top: 8px !important;
    width: 80% !important;
    max-width: 420px !important;
    min-height: 26px !important;
    padding: 4px 6px !important;
  }
}

/* ======= MOBILE STAGE SCALER (exakte Overlay-Positionen auch mobil) ======= */
@media (max-width: 900px){

  /* 0) Global: Desktop-Zwang deaktivieren */
  html, body{
    min-width: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  /* 1) Basisgröße deiner Bühne (wie am Desktop) */
  :root{
    --stage-w: 1276;   /* Breite der Bühne in px */
    --stage-h: 1279;   /* Höhe der Bühne in px */
    --stage-scale: calc(100vw / var(--stage-w));
  }

  /* 2) Ganze Bühne (#wrapper) wird skaliert – Koordinaten bleiben korrekt */
  #wrapper{
    width: calc(var(--stage-w) * 1px) !important;
    height: calc(var(--stage-h) * var(--stage-scale)) !important; /* reserviert sichtbare Höhe */
    margin: 0 auto !important;
    position: relative !important;

    transform: scale(var(--stage-scale)) !important;
    transform-origin: top center !important;
  }

  /* 3) Hintergrund bleibt absolut und füllt die Bühne vollständig */
  #wrapper .bg{
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center top !important;
    z-index: 0 !important;
  }

  /* 4) Overlays bleiben absolut (wie Desktop), NICHT auf 'static' umstellen */
  #navi, #openhours, #phone, .welcome-box, .kachel{
    position: absolute !important;
  }

  /* 5) Kacheln als transparente Overlays (kein schwarzer Kachelhintergrund) */
  .kachel{
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    color: #fff !important;
    text-align: center !important;
  }

  /* 6) Bereich unter der Bühne – normaler Fluss */
  #wrapper + .reviews-slider{
    width: 92% !important;
    max-width: 640px !important;
    margin: 20px auto 80px !important;
    transform: none !important;
    left: auto !important; right: auto !important; clear: both !important;
  }

  /* 7) Ticker kompakter */
  #ticker{
    top: 8px !important;
    width: 80% !important;
    max-width: 420px !important;
    min-height: 26px !important;
    padding: 4px 6px !important;
  }
}

/* ===== NUKE LEGACY LOCKS (muss GANZ ans Ende!) ===== */
@media (max-width: 900px){
  /* alte Locks aushebeln */
  html, body{
    min-width: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  /* keine Desktop-Geometrie für Mobile erzwingen */
  #wrapper{
    width: auto !important;
    max-width: none !important;
    min-height: 0 !important;
    margin: 0 auto !important;
    position: relative !important;
    transform: none !important;  /* wir setzen gleich das saubere Scaling */
  }

  /* alle „position: absolute !important“ aus alten Blöcken außer Kraft */
  #navi, #openhours, #phone, .welcome-box, .kachel{
    position: absolute; /* Basiswert (Desktop) */
  }
}

/* ===== MOBILE STAGE SCALER (exakte Desktop-Positionen auch mobil) ===== */
@media (max-width: 900px){

  :root{
    --stage-w: 1276;   /* Original-Bühnenbreite */
    --stage-h: 1279;   /* Original-Bühnenhöhe  */
    --stage-scale: calc(100vw / var(--stage-w));
  }

  /* sichtbare Höhe der skalierten Bühne reservieren */
  #wrapper{
    width: calc(var(--stage-w) * 1px) !important;
    height: calc(var(--stage-h) * var(--stage-scale)) !important;
    transform: scale(var(--stage-scale)) !important;
    transform-origin: top center !important;
    margin: 0 auto !important;
  }

  /* Hintergrund füllt die Bühne */
  #wrapper .bg{
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center top !important;
    z-index: 0 !important;
  }

  /* Overlays bleiben bei ihren Desktop-Koordinaten */
  #navi, #openhours, #phone, .welcome-box, .kachel{
    position: absolute !important;
  }

  /* Kachel-Boxen durchsichtig (kein schwarzer Block) */
  .kachel{
    background: transparent !important;
    box-shadow: none !important;
    border: 0 !important;
    color: #fff !important;
    text-align: center !important;
  }

  /* Bereich unter der Bühne normal fließen lassen */
  #wrapper + .reviews-slider{
    width: 92% !important;
    max-width: 640px !important;
    margin: 20px auto 80px !important;
    left: auto !important; right: auto !important; transform: none !important; clear: both !important;
  }

  /* Ticker kompakter */
  #ticker{
    top: 8px !important;
    width: 80% !important;
    max-width: 420px !important;
    min-height: 26px !important;
    padding: 4px 6px !important;
  }
}

/* ===== AZB – AUTHORITATIVE OVERRIDES (GANZ ANS ENDE DER CSS) ===== */

/* 0) Basis: Bühne immer als 1276px Canvas denken */
:root{
  --stage-w: 1276px;
  --stage-h: 1279px;
}

/* 1) Bühne & Hintergrund fixieren (überall gleich) */
#wrapper{
  width: var(--stage-w) !important;
  min-height: var(--stage-h) !important;
  margin: 10px auto !important;
  position: relative !important;
  transform: none !important;        /* kein Skalieren */
}
#wrapper .bg{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center top !important;
  z-index: 0 !important;
  pointer-events: none !important;    /* blockiert keine Klicks */
}

/* 2) Overlays immer absolut – wie am Desktop */
#navi, #openhours, #phone, .welcome-box, .kachel{
  position: absolute !important;
  z-index: 6 !important;
}

/* 3) Kacheln: transparent, kein „schwarzer Block“, exakt positioniert */
.kachel{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
  color: #fff !important;
  text-align: center !important;
  width: 200px !important;
  top: 840px !important;
}
.k1{ left:  30px !important; }
.k2{ left: 290px !important; }
.k3{ left: 540px !important; }
.k4{ left: 790px !important; }
.k5{ left:1045px !important; }

/* 4) Mobile & schmale Desktops: horizontales Scrollen erlauben */
@media (max-width: 1400px){
  html, body{
    min-width: var(--stage-w) !important;
    overflow-x: auto !important;
    overflow-y: auto !important;
  }

  /* keine „Mobile-Autolayouts“ aktivieren */
  #wrapper{
    width: var(--stage-w) !important;
    max-width: var(--stage-w) !important;
    min-height: var(--stage-h) !important;
  }

  /* verhindert, dass frühere Mobile-Blocks Positionen umstellen */
  #navi, #openhours, #phone, .welcome-box, .kachel{
    left: auto; top: auto; /* Basis zurücksetzen */
  }
  /* … und dann gelten unsere absoluten Werte per !important aus 2)+3) */
}

/* 5) Slider unter der Bühne zentriert lassen */
#wrapper + .reviews-slider{
  position: relative !important;
  width: var(--stage-w) !important;
  max-width: var(--stage-w) !important;
  margin: 30px auto 80px !important;
  left: auto !important; right: auto !important; transform: none !important; clear: both !important;
}

/* 6) Sicherheit: nirgends Overflow-X verstecken */
*, *::before, *::after{
  /* falls irgendwo overflow-x:hidden gesetzt wurde */
  overscroll-behavior-x: contain;
}

/* ===== AZB – FINAL AUTHORITATIVE OVERRIDES ===== */

/* Bühne = fixe 1276px-Canvas */
:root{ --stage-w:1276px; --stage-h:1279px; }

html, body{
  min-width: var(--stage-w) !important;
  overflow-x: auto !important;     /* seitlich scrollen erlaubt */
  overflow-y: auto !important;     /* vertikal scrollen erlaubt */
  -webkit-overflow-scrolling: touch !important;
  
}

/* Wrapper + Hintergrund stehen immer korrekt */
#wrapper{
  width: var(--stage-w) !important;
  max-width: var(--stage-w) !important;
  min-height: var(--stage-h) !important;
  margin: 10px auto !important;
  position: relative !important;
  display: block !important;
}
#wrapper .bg{
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: center top !important;
  z-index: 0 !important;
  pointer-events: none !important;
}

/* --- ALLE Overlays absolut fixieren + KOORDINATEN FEST --- */
#navi, #openhours, #phone, .welcome-box, .kachel{
  position: absolute !important;
  z-index: 6 !important;
}

/* NAV exakt wie Desktop */
#navi{ top:154px !important; left:290px !important; }

/* Öffnungszeiten + Telefon exakt */
#openhours{ left:820px !important; top:100px !important; }
#phone{     left:1047px !important; top:118px !important; }
#phone a{ color:#fff !important; }

/* Welcome-Box exakt */
.welcome-box{
  left:1000px !important; top:220px !important;
  background: rgba(255,255,255,0.82) !important;
  color:#000 !important;
}

/* Kacheln: transparent, exakt positioniert */
.kachel{
  background: transparent !important;
  box-shadow: none !important; border: 0 !important;
  color:#fff !important; text-align:center !important;
  width:200px !important; top:840px !important;
}
.k1{ left:  30px !important; }
.k2{ left: 290px !important; }
.k3{ left: 540px !important; }
.k4{ left: 790px !important; }
.k5{ left:1045px !important; }

/* Slider direkt unter der Bühne */
#wrapper + .reviews-slider{
  position: relative !important;
  width: var(--stage-w) !important;
  max-width: var(--stage-w) !important;
  margin: 30px auto 80px !important;
  left:auto !important; right:auto !important; transform:none !important; clear:both !important;
}

/* Sicherheitsnetz gegen verstecktes Scrollen irgendwo */
main, .layer, .contact-wrap, .as24-card, .reviews-slider{
  overflow: visible !important;
}

/* ===== AZB – MOBILE/SMALL VIEW AUTHORITATIVE FIXES ===== */

/* 2.1 Globale Scrolling-/Zoom-Freigabe */
html, body{
  min-width: 1276px !important;     /* volle Bühne als Canvas */
  overflow-x: auto !important;       /* Seitwärts-Scroll erlaubt */
  overflow-y: auto !important;       /* Hoch/Runter-Scroll erlaubt */
  -webkit-overflow-scrolling: touch !important;
}

/* 2.2 Wrapper/Stage – identisch auf allen Seiten */
#wrapper,
#wrapper_leistungen,
#wrapper_tuev,
#wrapper_inspektion,
#wrapper_gebrauchtwagen,
#wrapper_kontakt,
#wrapper_impressum{
  width:1276px !important;
  max-width:1276px !important;
  min-height:1279px !important;
  margin:10px auto !important;
  position:relative !important;
  display:block !important;
  overflow:visible !important;
}

/* 2.3 Hintergrundbilder: immer volle Bühne, nicht scroll-blockend */
#wrapper .bg,
#wrapper_leistungen .bg,
#wrapper_tuev .bg,
#wrapper_inspektion .bg,
#wrapper_gebrauchtwagen .bg,
#wrapper_kontakt .bg,
#wrapper_impressum .bg{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  object-position:center top !important;
  z-index:0 !important;
  pointer-events:none !important;
}

/* 2.4 Overlays (Navi, Welcome, Öffnungszeiten, Telefon, Kacheln) fixieren */
#navi, #openhours, #phone, .welcome-box, .kachel{
  position:absolute !important;
  z-index:6 !important;
}

/* exakte Koordinaten */
#navi{ top:154px !important; left:290px !important; }
#openhours{ left:820px !important; top:100px !important; }
#phone{ left:1047px !important; top:118px !important; }
#phone a{ color:#fff !important; }

.welcome-box{
  left:1000px !important; top:220px !important;
  background:rgba(255,255,255,0.82) !important; color:#000 !important;
}

.kachel{
  width:200px !important; top:840px !important;
  background:transparent !important; box-shadow:none !important;
  color:#fff !important; text-align:center !important; border:0 !important;
}
.k1{ left:  30px !important; }
.k2{ left: 290px !important; }
.k3{ left: 540px !important; }
.k4{ left: 790px !important; }
.k5{ left:1045px !important; }

/* 2.5 Slider direkt unter der Bühne (egal welches Viewport) */
#wrapper + .reviews-slider{
  position:relative !important;
  width:1276px !important; max-width:1276px !important;
  margin:30px auto 80px !important;
  left:auto !important; right:auto !important; transform:none !important; clear:both !important;
  overflow:visible !important;
}

/* 2.6 Unterseiten: Content nicht nach oben rutschen lassen */
.leistungen-content,
.tuev-content,
.inspektion-content,
.gebraucht-content{
  width:80% !important; max-width:960px !important;
  margin:260px auto 100px !important;      /* immer unter Hero/Navi starten */
  position:relative !important; z-index:5 !important;
}

/* 2.7 Safety: nichts darf Scrollen killen */
main, .layer, .contact-wrap, .as24-card, .map-section, .form-card{
  overflow:visible !important;
}

/* 2.8 Bugfix: fehlende Einheit in älterem Block */
.kontakt-top{
  margin:140px 30px 20px !important;   /* statt "140 30px 20px" */
}

/* allow pinch-zoom on all browsers */
html, body {
  touch-action: auto !important;        /* statt pan-x pan-y */
  -ms-touch-action: auto !important;     /* MS/Edge legacy */
  -webkit-text-size-adjust: 100% !important; /* iOS: kein Auto-Zoom auf Text */
}

/* falls irgendwo noch touch-action gesetzt wurde (Buttons/Links/etc.) */
a, button, img, .layer, main {
  touch-action: auto !important;
}

/* ==== FINAL CONTACT OFFSETS (authoritative) ==== */
#wrapper_kontakt .kontakt-top{
  margin: 250px 30px 16px !important;   /* feinjustieren: 280–340px */
  position: relative;
  z-index: 6;
}

#wrapper_kontakt .form-card{
  margin: 40px 30px 60px !important;    /* wenn das Formular noch zu dicht ist */
}

/* Mobile: etwas geringer, aber stabil unter dem Hero */
@media (max-width:900px){
  #wrapper_kontakt .kontakt-top{
    margin: 220px 16px 16px !important;
  }
  #wrapper_kontakt .form-card{
    margin: 24px 16px 48px !important;
  }
}
