/* ============================================================
   Autohaus Wenzlaff — zentrales Stylesheet (V2)
   Identität: Anthrazit + Markenrot (aus dem Logo) + warme
   Grautöne. Schrift: Barlow / Barlow Condensed, lokal gehostet
   (DSGVO-sicher, keine externen Server). Mobile-first.
   ============================================================ */

/* ---------- Schriften (lokal, kein CDN) ---------- */

@font-face {
  font-family: "Barlow";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../schriften/barlow-400.woff2") format("woff2");
}
@font-face {
  font-family: "Barlow";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../schriften/barlow-600.woff2") format("woff2");
}
@font-face {
  font-family: "Barlow Condensed";
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../schriften/barlowcondensed-600.woff2") format("woff2");
}
@font-face {
  font-family: "Barlow Condensed";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../schriften/barlowcondensed-700.woff2") format("woff2");
}

/* ---------- Design-Token ---------- */

:root {
  --rot-marke: #ff0000;      /* exaktes Logo-Rot, nur für den Logoblock */
  --rot: #d40000;            /* Buttons, Akzentflächen */
  --rot-dunkel: #a80000;     /* Hover */
  --rot-text: #b00000;       /* Textlinks auf hellem Grund (Kontrast AA) */
  --anthrazit: #2e2d2a;      /* Header, Hero, Footer — leicht warm, eine Stufe heller als reines Schwarz-Anthrazit */
  --anthrazit-hell: #403e3a; /* Flächen auf Dunkel */
  --text: #2c2b27;           /* Fließtext, warmes Fast-Schwarz */
  --grau: #6b6862;           /* Sekundärtext, warm */
  --flaeche: #f6f5f2;        /* helle Wechselfläche, warm */
  --linie: #e5e3de;          /* Rahmen/Linien */
  --weiss: #ffffff;
  --hell-auf-dunkel: #cfcdc8;

  --schrift: "Barlow", -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --schrift-display: "Barlow Condensed", "Arial Narrow", Arial, sans-serif;
}

/* ---------- Basis ---------- */

* { box-sizing: border-box; margin: 0; padding: 0; }

@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}

body {
  font-family: var(--schrift);
  font-size: 1.0625rem;            /* 17 px Grundgröße */
  line-height: 1.65;
  color: var(--text);
  background: var(--weiss);
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--rot-text); text-decoration-thickness: 1px; text-underline-offset: 2px; }
a:hover { color: var(--rot-dunkel); }

a:focus-visible,
button:focus-visible,
input:focus-visible {
  outline: 3px solid var(--rot);
  outline-offset: 2px;
}

.container {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 1.25rem;
}

main > section { padding: 3.5rem 0; }
section.grau { background: var(--flaeche); }

/* ---------- Typografie ---------- */

h1, h2 {
  font-family: var(--schrift-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.015em;
  line-height: 1.1;
  text-wrap: balance;
}

h2 {
  font-size: 1.75rem;
  color: var(--anthrazit);
  margin-bottom: 1.25rem;
}
h2::after {
  content: "";
  display: block;
  width: 3rem;
  height: 4px;
  background: var(--rot);
  margin-top: 0.5rem;
}

h3 {
  font-size: 1.15rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
  color: var(--anthrazit);
}

p { max-width: 46rem; }
p + p { margin-top: 0.85rem; }

.einleitung { font-size: 1.15rem; }

ul.liste { margin: 1rem 0 1rem 1.35rem; max-width: 44rem; }
ul.liste li { margin-bottom: 0.5rem; }

.sekundaer { color: var(--grau); }
.abstand-oben { margin-top: 1.5rem; }
.abstand-klein { margin-top: 0.8rem; }

/* ---------- Icons (inline SVG) ---------- */

.icon {
  width: 1.15em;
  height: 1.15em;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
  vertical-align: -0.2em;
  flex-shrink: 0;
}

.icon-gross {
  width: 2.4rem;
  height: 2.4rem;
  stroke-width: 1.7;
  color: var(--rot);
  margin-bottom: 0.9rem;
}

/* ---------- Skip-Link ---------- */

.skip-link {
  position: absolute;
  left: -9999px;
  background: var(--rot);
  color: var(--weiss);
  padding: 0.6rem 1rem;
  z-index: 200;
}
.skip-link:focus { left: 0; top: 0; color: var(--weiss); }

/* ---------- Buttons ---------- */

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--rot);
  color: var(--weiss);
  padding: 0.7rem 1.4rem;
  border: 2px solid var(--rot);
  border-radius: 4px;
  font-family: var(--schrift);
  font-weight: 600;
  font-size: 1rem;
  text-decoration: none;
  cursor: pointer;
}
.btn:hover { background: var(--rot-dunkel); border-color: var(--rot-dunkel); color: var(--weiss); }

/* heller Kontur-Button für dunkle Flächen */
.btn-kontur {
  background: transparent;
  color: var(--weiss);
  border-color: rgba(255, 255, 255, 0.7);
}
.btn-kontur:hover { background: rgba(255, 255, 255, 0.12); border-color: var(--weiss); color: var(--weiss); }

/* Kontur-Button für helle Flächen */
.btn-rand {
  background: transparent;
  color: var(--rot-text);
  border-color: var(--rot);
}
.btn-rand:hover { background: var(--rot); color: var(--weiss); }

.btn-gross { font-size: 1.1rem; padding: 0.85rem 1.7rem; }

.button-zeile {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

/* ---------- Header ---------- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--anthrazit);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-top: 0.7rem;
  padding-bottom: 0.7rem;
}

.logo-link { flex-shrink: 0; display: block; }
.logo { height: 52px; width: auto; }

.btn-telefon {
  white-space: nowrap;
  padding: 0.5rem 0.9rem;
  font-size: 0.95rem;
  font-variant-numeric: tabular-nums;
}
.btn-telefon .telefon-text { display: none; }
@media (min-width: 480px) {
  .btn-telefon .telefon-text { display: inline; }
}

.nav-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  background: transparent;
  color: var(--weiss);
  border: 2px solid rgba(255, 255, 255, 0.4);
  border-radius: 4px;
  padding: 0.45rem 0.8rem;
  font-family: var(--schrift);
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
}
.nav-toggle:hover { border-color: var(--weiss); }

/* Navigation: mobil als dunkles Ausklapp-Panel, ab 920 px horizontal */

.main-nav {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--anthrazit);
  border-top: 1px solid var(--anthrazit-hell);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.35);
}
.main-nav.offen { display: block; }

.main-nav ul { list-style: none; }

.main-nav a {
  display: block;
  padding: 0.9rem 1.25rem;
  color: var(--hell-auf-dunkel);
  text-decoration: none;
  font-weight: 600;
  font-size: 1.05rem;
  white-space: nowrap;
  border-bottom: 1px solid var(--anthrazit-hell);
}
.main-nav a:hover { color: var(--weiss); background: var(--anthrazit-hell); }
.main-nav a[aria-current="page"] {
  color: var(--weiss);
  box-shadow: inset 4px 0 0 var(--rot);
}

@media (min-width: 920px) {
  .nav-toggle { display: none; }
  .main-nav {
    display: block;
    position: static;
    border: 0;
    box-shadow: none;
    background: transparent;
    margin-left: auto;   /* Navigation rechtsbündig neben dem Telefon-Button */
  }
  .main-nav ul { display: flex; gap: 0.35rem; align-items: center; }
  .main-nav a {
    padding: 0.5rem 0.7rem;
    font-size: 1rem;
    border-bottom: 3px solid transparent;
  }
  .main-nav a:hover { background: transparent; }
  .main-nav a[aria-current="page"] {
    box-shadow: none;
    border-bottom-color: var(--rot);
  }
}

/* ---------- Ankündigungsbanner ---------- */

.ankuendigung {
  background: #fcebe8;
  color: #7a1207;
  border-left: 5px solid var(--rot);
  padding: 0.9rem 1.25rem;
  font-weight: 600;
  text-align: center;
}

/* ---------- Hero (Startseite) ---------- */

.hero {
  background: var(--anthrazit);
  color: var(--weiss);
  padding: 4.5rem 0 5rem;
}

.hero .dachzeile {
  font-family: var(--schrift-display);
  font-weight: 600;
  font-size: 1.05rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--hell-auf-dunkel);
  margin-bottom: 1rem;
}

.hero h1 {
  font-size: clamp(2.6rem, 7vw, 4.2rem);
  max-width: 18ch;
}
.hero h1 .betont { color: #ff4b3a; }

.hero h1::after {
  content: "";
  display: block;
  width: 4.5rem;
  height: 5px;
  background: var(--rot);
  margin-top: 1.1rem;
}

.hero p.unterzeile {
  font-size: 1.2rem;
  max-width: 34rem;
  margin-top: 1.4rem;
  color: var(--hell-auf-dunkel);
}

.hero .button-zeile { margin-top: 2.2rem; }

@media (min-width: 700px) {
  .hero { padding: 6rem 0 6.5rem; }
}

/* ---------- Seitenkopf (Unterseiten) ---------- */

.seitenkopf {
  background: var(--anthrazit);
  color: var(--weiss);
  padding: 2.75rem 0 3rem;
}

.seitenkopf h1 { font-size: clamp(2.1rem, 5vw, 3rem); }

.seitenkopf h1::after {
  content: "";
  display: block;
  width: 3.5rem;
  height: 4px;
  background: var(--rot);
  margin-top: 0.8rem;
}

.seitenkopf p {
  margin-top: 1rem;
  max-width: 40rem;
  font-size: 1.1rem;
  color: var(--hell-auf-dunkel);
}

/* ---------- Kacheln / Karten ---------- */

.kacheln {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  margin-top: 1.75rem;
}
@media (min-width: 700px) { .kacheln { grid-template-columns: repeat(3, 1fr); } }

.kachel {
  background: var(--weiss);
  border: 1px solid var(--linie);
  border-radius: 6px;
  padding: 1.75rem 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.kachel p { flex-grow: 1; margin-bottom: 0; }
.kachel .kachel-link {
  margin-top: 1.1rem;
  font-weight: 600;
  text-decoration: none;
}
.kachel .kachel-link:hover { text-decoration: underline; }

/* ---------- Leistungsliste ---------- */

.leistungen {
  display: grid;
  gap: 1.1rem;
  grid-template-columns: 1fr;
  margin-top: 1.75rem;
}
@media (min-width: 700px) { .leistungen { grid-template-columns: repeat(2, 1fr); } }

.leistung {
  background: var(--weiss);
  border: 1px solid var(--linie);
  border-radius: 6px;
  padding: 1.25rem 1.4rem;
}
.leistung h3 {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.leistung h3 .icon { color: var(--rot); }
.leistung p { margin-bottom: 0; }

/* ---------- Preistabelle (Extras) ---------- */

.tabelle-wrap { overflow-x: auto; margin-top: 1.75rem; }

table.preise {
  width: 100%;
  border-collapse: collapse;
  background: var(--weiss);
  border: 1px solid var(--linie);
}
table.preise caption {
  text-align: left;
  font-size: 0.9rem;
  color: var(--grau);
  padding: 0.6rem 0.25rem;
  caption-side: bottom;
}
table.preise th,
table.preise td {
  padding: 0.85rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--linie);
  vertical-align: top;
}
table.preise thead th {
  font-family: var(--schrift-display);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: 0.95rem;
  border-bottom: 2px solid var(--anthrazit);
}
table.preise td.preis,
table.preise th.preis {
  text-align: right;
  white-space: nowrap;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* ---------- Zwei-Klick-Einwilligung (mobile.de / Karte) ---------- */

.consent-box {
  background: var(--flaeche);
  border: 1px solid var(--linie);
  border-radius: 6px;
  padding: 2.25rem 1.5rem;
  text-align: center;
  margin-top: 1.75rem;
}
.consent-box h3 { font-family: var(--schrift-display); font-weight: 700; text-transform: uppercase; font-size: 1.3rem; }
.consent-box p { max-width: 38rem; margin-left: auto; margin-right: auto; margin-top: 0.6rem; }
.consent-box .btn { margin-top: 1.25rem; }
.consent-box label {
  display: block;
  margin-top: 1rem;
  font-size: 0.9rem;
  color: var(--grau);
  cursor: pointer;
}

.iframe-wrap { margin-top: 1.75rem; }
.iframe-wrap iframe {
  width: 100%;
  border: 1px solid var(--linie);
  border-radius: 6px;
}
.iframe-hoch { height: 2600px; }   /* mobile.de Bestandsliste — bei Bedarf an Bestandsgröße anpassen (alte Seite: 3150px) */
.iframe-karte { height: 420px; }   /* OpenStreetMap */

/* ---------- Kontakt ---------- */

.kontakt-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  margin-top: 1.75rem;
}
@media (min-width: 700px) { .kontakt-grid { grid-template-columns: repeat(2, 1fr); } }

.kontakt-block {
  background: var(--weiss);
  border: 1px solid var(--linie);
  border-radius: 6px;
  padding: 1.6rem 1.5rem;
}
.kontakt-block h2 { font-size: 1.4rem; }
.kontakt-block h3 {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.kontakt-block h3 .icon { color: var(--rot); }

table.zeiten {
  border-collapse: collapse;
  margin-top: 0.5rem;
  font-variant-numeric: tabular-nums;
}
table.zeiten td { padding: 0.3rem 1.4rem 0.3rem 0; }
table.zeiten td:last-child { padding-right: 0; }

/* ---------- Bild + Text ---------- */

.bild-text {
  display: grid;
  gap: 1.75rem;
  grid-template-columns: 1fr;
  align-items: start;
  margin-top: 1.75rem;
}
@media (min-width: 700px) { .bild-text { grid-template-columns: 1.2fr 1fr; } }

.bild-rahmen {
  border: 1px solid var(--linie);
  border-radius: 6px;
  overflow: hidden;
}
.bild-rahmen img { width: 100%; }
.bild-rahmen figcaption {
  font-size: 0.85rem;
  color: var(--grau);
  padding: 0.55rem 0.9rem;
  background: var(--flaeche);
}

/* ---------- Werte (Über uns) ---------- */

.werte {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  margin-top: 1.75rem;
}
@media (min-width: 700px) { .werte { grid-template-columns: repeat(3, 1fr); } }

.wert { border-top: 1px solid var(--linie); padding-top: 1.25rem; }
.wert h3 {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.wert h3 .icon { color: var(--rot); }
.wert p { margin-bottom: 0; }

/* ---------- Hinweiskasten ---------- */

.hinweis {
  background: var(--flaeche);
  border-left: 4px solid var(--grau);
  padding: 1rem 1.25rem;
  margin-top: 1.75rem;
  border-radius: 0 6px 6px 0;
}
.hinweis p { margin-bottom: 0; }

/* ---------- Rechtstexte ---------- */

.rechtstext h1 {
  font-size: clamp(2.1rem, 5vw, 3rem);
}
.rechtstext h2 { margin-top: 2.25rem; font-size: 1.45rem; }
.rechtstext h2::after { display: none; }
.rechtstext h3 { margin-top: 1.25rem; }
.rechtstext ul { margin: 0.6rem 0 0.6rem 1.35rem; max-width: 44rem; }
.rechtstext ul li { margin-bottom: 0.3rem; }

/* ---------- Footer ---------- */

.site-footer {
  background: var(--anthrazit);
  color: var(--hell-auf-dunkel);
  padding: 3rem 0 0;
}

.footer-grid {
  display: grid;
  gap: 2rem;
  grid-template-columns: 1fr;
  padding-bottom: 2.25rem;
}
@media (min-width: 700px) { .footer-grid { grid-template-columns: repeat(3, 1fr); } }

.footer-logo {
  height: 42px;
  width: auto;
  margin-bottom: 1rem;
}

.site-footer h2 {
  font-family: var(--schrift-display);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--weiss);
  margin-bottom: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.site-footer h2::after { display: none; }

.site-footer p { font-variant-numeric: tabular-nums; }

.site-footer a { color: var(--weiss); text-decoration-color: rgba(255, 255, 255, 0.4); }
.site-footer a:hover { color: var(--weiss); text-decoration-color: var(--weiss); }

.site-footer ul { list-style: none; }
.site-footer ul li { margin-bottom: 0.45rem; }
.site-footer ul a { color: var(--hell-auf-dunkel); text-decoration: none; }
.site-footer ul a:hover { color: var(--weiss); text-decoration: underline; }

.footer-unten {
  border-top: 1px solid var(--anthrazit-hell);
  padding: 1.1rem 0;
  font-size: 0.85rem;
  text-align: center;
  color: #979590;
}

/* ---------- Druck ---------- */

@media print {
  .site-header, .site-footer, .nav-toggle, .button-zeile, .consent-box { display: none; }
}
