/* ============================================================
   MAHR + PARTNER Ingenieurbüro GmbH
   Moderne Website – Professionelles Design
   ============================================================ */

/* --- Design-Variablen --------------------------------------- */
:root {
  --navy:       #1a2b4a;
  --navy-mid:   #2d4a7a;
  --navy-light: #3d5f99;
  --red:        #c42929;
  --red-hover:  #a82020;
  --light-bg:   #f4f6f9;
  --text:       #2c3e50;
  --text-light: #6c7a8d;
  --white:      #ffffff;
  --border:     #e0e6ed;
  --shadow-sm:  0 2px 8px rgba(26,43,74,0.08);
  --shadow-md:  0 4px 20px rgba(26,43,74,0.12);
  --radius:     6px;
  --max-width:  1100px;
  --transition: 0.2s ease;
}

/* --- Reset -------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: 'Inter', 'Segoe UI', Arial, sans-serif;
  color: var(--text);
  background: var(--white);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }
a { color: var(--navy-light); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--red); }
ul { list-style: none; }

/* --- Typografie --------------------------------------------- */
h1, h2, h3, h4 {
  font-weight: 700;
  line-height: 1.25;
  color: var(--navy);
}
h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); margin-bottom: 1rem; }
h2 { font-size: clamp(1.3rem, 3vw, 1.75rem); margin-bottom: 0.75rem; }
h3 { font-size: 1.15rem; margin-bottom: 0.5rem; }
h4 { font-size: 1rem; }
p  { margin-bottom: 1rem; color: var(--text); }
p:last-child { margin-bottom: 0; }

/* --- Layout-Helfer ------------------------------------------ */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
}
.section { padding: 4rem 0; }
.section--grey { background: var(--light-bg); }
.section--navy { background: var(--navy); color: var(--white); }
.section--navy h2, .section--navy h3, .section--navy p { color: var(--white); }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-auto { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.5rem; }

/* Kompetenz-Grid: zentriert Waisenelemente in der letzten Reihe */
.kompetenz-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
}
.kompetenz-grid > * {
  flex: 0 1 calc(33.333% - 1rem);
  min-width: 260px;
}

/* --- Navigationbar ------------------------------------------ */
.navbar {
  background: var(--navy);
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: 0 2px 12px rgba(0,0,0,0.15);
}
.navbar__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
}
.navbar__logo img {
  height: 40px;
  width: auto;
  background: white;
  padding: 3px 8px;
  border-radius: 4px;
}
.navbar__logo span {
  color: var(--white);
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.navbar__nav { display: flex; gap: 0; }
.navbar__nav a {
  display: block;
  padding: 0.6rem 1.1rem;
  color: rgba(255,255,255,0.85);
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border-radius: var(--radius);
  transition: background var(--transition), color var(--transition);
}
.navbar__nav a:hover,
.navbar__nav a.aktiv {
  background: rgba(255,255,255,0.12);
  color: var(--white);
}
.navbar__nav a.aktiv {
  border-bottom: 2px solid var(--red);
}

/* Hamburger (Mobile) */
.navbar__toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  flex-direction: column;
  gap: 5px;
}
.navbar__toggle span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--white);
  transition: transform var(--transition), opacity var(--transition);
}
.navbar__toggle.offen span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.navbar__toggle.offen span:nth-child(2) { opacity: 0; }
.navbar__toggle.offen span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }

/* Mobile Nav */
.navbar__mobile {
  display: none;
  background: var(--navy);
  border-top: 1px solid rgba(255,255,255,0.1);
}
.navbar__mobile a {
  display: block;
  padding: 1rem 1.5rem;
  color: rgba(255,255,255,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  font-size: 0.95rem;
  font-weight: 500;
}
.navbar__mobile a:hover,
.navbar__mobile a.aktiv { color: var(--white); background: rgba(255,255,255,0.07); }
.navbar__mobile.offen { display: block; }

/* --- Hero --------------------------------------------------- */
.hero {
  position: relative;
  height: clamp(340px, 55vw, 600px);
  overflow: hidden;
  background: var(--navy);
}
.hero__slider {
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
}

.hero__bild {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  opacity: 0;
  transition: opacity 1.2s ease;
}

.hero__bild.aktiv {
  opacity: 0.70;
}
.hero__inhalt {
  position: relative;
  z-index: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
}
.hero__inhalt h1 {
  color: var(--white);
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 800;
  text-shadow: 0 2px 12px rgba(0,0,0,0.3);
  max-width: 600px;
  margin-bottom: 0.75rem;
}
.hero__inhalt p {
  color: rgba(255,255,255,0.9);
  font-size: clamp(1rem, 2vw, 1.2rem);
  max-width: 500px;
  margin-bottom: 1.5rem;
  text-shadow: 0 1px 4px rgba(0,0,0,0.2);
}

/* Seitenheader (für Unterseiten) */
.seitenheader {
  background: var(--navy);
  padding: 3rem 0 2.5rem;
  position: relative;
  overflow: hidden;
}
.seitenheader::before {
  content: '';
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.2;
}
.seitenheader .container { position: relative; z-index: 1; }
.seitenheader h1 { color: var(--white); margin-bottom: 0.25rem; }
.seitenheader p { color: rgba(255,255,255,0.75); margin: 0; }

/* --- Buttons ------------------------------------------------ */
.btn {
  display: inline-block;
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.95rem;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
  cursor: pointer;
  border: none;
}
.btn--rot {
  background: var(--red);
  color: var(--white);
}
.btn--rot:hover {
  background: var(--red-hover);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(196,41,41,0.35);
}
.btn--outline {
  background: transparent;
  color: var(--white);
  border: 2px solid rgba(255,255,255,0.6);
}
.btn--outline:hover {
  background: rgba(255,255,255,0.12);
  color: var(--white);
}
.btn--navy {
  background: var(--navy);
  color: var(--white);
}
.btn--navy:hover {
  background: var(--navy-mid);
  color: var(--white);
  transform: translateY(-1px);
}

/* --- Karten / Cards ----------------------------------------- */
.card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--transition), transform var(--transition);
  display: flex;
  flex-direction: column;
}
.card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}
.card__bild {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.card__inhalt { padding: 1.25rem; flex: 1; display: flex; flex-direction: column; }
.card__inhalt h3 { margin-bottom: 0.5rem; }
.card__inhalt p { color: var(--text-light); font-size: 0.9rem; flex: 1; margin-bottom: 1rem; }
.card__meta {
  font-size: 0.8rem;
  color: var(--text-light);
  border-top: 1px solid var(--border);
  padding-top: 0.75rem;
  margin-top: auto;
}

/* Kompetenz-Karten (Homepage) */
.kompetenz-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.75rem;
  border-top: 4px solid var(--navy);
  transition: box-shadow var(--transition), transform var(--transition);
}
.kompetenz-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
/* --- Kompetenz-Karten: Animations-Block -------------------- */
.kompetenz-titel-anim {
  background: var(--navy);
  border-radius: var(--radius);
  padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
  overflow: hidden;
  position: relative;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.15rem;
}

/* Leuchtstreifen (nur wenn sichtbar via IntersectionObserver) */
.kompetenz-titel-anim::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,0.07) 50%,
    transparent 100%
  );
}
.kompetenz-card--animiert .kompetenz-titel-anim::after {
  animation: lichtstreifen 3s ease-in-out infinite;
}

@keyframes lichtstreifen {
  0%   { left: -60%; }
  100% { left: 120%; }
}

/* Rote Akzentlinie links */
.kompetenz-titel-anim::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 0;
  background: var(--red);
  border-radius: 0 0 2px 2px;
}
.kompetenz-card--animiert .kompetenz-titel-anim::before {
  animation: linie-wachsen 0.6s ease forwards;
}

@keyframes linie-wachsen {
  from { height: 0; }
  to   { height: 100%; }
}

/* Text-Zeilen im Animations-Block */
.kompetenz-titel-anim span {
  display: block;
  color: var(--white);
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
  opacity: 0;
  transform: translateX(-12px);
}
.kompetenz-titel-anim span:nth-child(2) {
  color: rgba(255,255,255,0.6);
  font-size: 1.1rem;
  font-weight: 600;
}
.kompetenz-card--animiert .kompetenz-titel-anim span {
  animation: text-einblenden 0.5s ease forwards;
}
.kompetenz-card--animiert .kompetenz-titel-anim span:nth-child(1) { animation-delay: 0.15s; }
.kompetenz-card--animiert .kompetenz-titel-anim span:nth-child(2) { animation-delay: 0.3s; }

@keyframes text-einblenden {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* Hover: Akzentfarbe wechselt */
.kompetenz-card:hover .kompetenz-titel-anim {
  background: var(--navy-mid);
}
.kompetenz-card:hover .kompetenz-titel-anim span:nth-child(2) {
  color: rgba(255,255,255,0.8);
}
.kompetenz-card h3 { margin-bottom: 0.5rem; }
.kompetenz-card p { color: var(--text-light); font-size: 0.9rem; }

/* --- Akkordeon (Kompetenzen) -------------------------------- */
.akkordeon { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.akkordeon__item { border-bottom: 1px solid var(--border); }
.akkordeon__item:last-child { border-bottom: none; }
.akkordeon__trigger {
  width: 100%;
  background: none;
  border: none;
  padding: 1.1rem 1.25rem;
  text-align: left;
  font-size: 1rem;
  font-weight: 600;
  color: var(--navy);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: background var(--transition);
}
.akkordeon__trigger:hover { background: var(--light-bg); }
.akkordeon__trigger.aktiv { background: var(--navy); color: var(--white); }
.akkordeon__trigger.aktiv .akkordeon__pfeil { transform: rotate(180deg); color: var(--white); }
.akkordeon__pfeil {
  font-size: 1.2rem;
  transition: transform var(--transition);
  color: var(--text-light);
  flex-shrink: 0;
}
.akkordeon__inhalt {
  display: none;
  padding: 1.25rem;
  background: var(--light-bg);
}
.akkordeon__inhalt.aktiv { display: block; }
.akkordeon__inhalt ul { margin-top: 0.75rem; }
.akkordeon__inhalt li {
  padding: 0.3rem 0 0.3rem 1.25rem;
  position: relative;
  color: var(--text-light);
  font-size: 0.9rem;
}
.akkordeon__inhalt li::before {
  content: '–';
  position: absolute;
  left: 0;
  color: var(--navy-light);
}

/* --- Download-Liste ---------------------------------------- */
.download-liste { margin: 0; }
.download-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius);
  transition: background var(--transition);
  color: var(--text);
  margin-bottom: 0.25rem;
}
.download-item:hover { background: var(--light-bg); color: var(--navy); }
.download-item__icon {
  width: 36px;
  height: 36px;
  background: var(--red);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--white);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
.download-item__name { font-size: 0.95rem; font-weight: 500; }

.download-gruppe { margin-bottom: 2rem; }
.download-gruppe h3 {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-light);
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
  margin-bottom: 0.5rem;
}

/* --- Kontaktformular --------------------------------------- */
.form-gruppe { margin-bottom: 1.25rem; }
.form-gruppe label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 0.4rem;
}
.form-gruppe input,
.form-gruppe textarea,
.form-gruppe select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-family: inherit;
  color: var(--text);
  background: var(--white);
  transition: border-color var(--transition), box-shadow var(--transition);
  outline: none;
}
.form-gruppe input:focus,
.form-gruppe textarea:focus {
  border-color: var(--navy-light);
  box-shadow: 0 0 0 3px rgba(45,74,122,0.12);
}
.form-gruppe textarea { min-height: 140px; resize: vertical; }

/* --- Google Maps ------------------------------------------- */
.karte-container {
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  height: 420px;
}
.karte-container iframe { width: 100%; height: 100%; border: 0; display: block; }

/* --- Kontakt-Box ------------------------------------------- */
.kontakt-box {
  background: var(--navy);
  border-radius: var(--radius);
  padding: 1.75rem;
  color: var(--white);
  margin-bottom: 1.5rem;
}
.kontakt-box h3 { color: var(--white); margin-bottom: 1rem; }
.kontakt-zeile {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  font-size: 0.95rem;
}
.kontakt-zeile span:first-child {
  opacity: 0.6;
  min-width: 20px;
  flex-shrink: 0;
}
.kontakt-zeile a { color: rgba(255,255,255,0.85); }
.kontakt-zeile a:hover { color: var(--white); }

/* --- Unternehmen Highlights -------------------------------- */
.highlight-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.highlight {
  background: var(--navy);
  padding: 2rem 1.5rem;
  text-align: center;
  color: var(--white);
  border-right: 1px solid rgba(255,255,255,0.1);
}
.highlight:last-child { border-right: none; }
.highlight__zahl {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--white);
  line-height: 1;
  margin-bottom: 0.4rem;
}
.highlight__label { color: rgba(255,255,255,0.7); font-size: 0.875rem; }

/* --- Projekte Grid / Detail -------------------------------- */
.projekt-detail__bild {
  width: 100%;
  border-radius: var(--radius);
  margin-bottom: 1.5rem;
  box-shadow: var(--shadow-sm);
}
.projekt-fakten {
  background: var(--light-bg);
  border-radius: var(--radius);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.projekt-fakten dl { display: grid; grid-template-columns: 1fr 2fr; gap: 0.5rem 1rem; }
.projekt-fakten dt { font-weight: 600; color: var(--navy); font-size: 0.9rem; }
.projekt-fakten dd { color: var(--text-light); font-size: 0.9rem; }

/* Zurück-Link */
.zurueck-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--text-light);
  font-size: 0.875rem;
  margin-bottom: 1.5rem;
  transition: color var(--transition);
}
.zurueck-link:hover { color: var(--navy); }

/* --- Sidebar ----------------------------------------------- */
.sidebar { }
.sidebar-box {
  background: var(--light-bg);
  border-radius: var(--radius);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.sidebar-box h3 {
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-light);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--border);
}
.sidebar-link-liste a {
  display: block;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-size: 0.9rem;
  transition: color var(--transition), padding-left var(--transition);
}
.sidebar-link-liste a:hover { color: var(--navy); padding-left: 4px; }
.sidebar-link-liste a:last-child { border-bottom: none; }

/* --- Footer ------------------------------------------------ */
.footer {
  background: var(--navy);
  color: rgba(255,255,255,0.75);
  padding: 3rem 0 1.5rem;
}
.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 2rem;
  margin-bottom: 2rem;
}
.footer__logo { margin-bottom: 0.75rem; }
.footer__logo img {
  height: 36px;
  background: white;
  padding: 4px 8px;
  border-radius: 4px;
}
.footer__logo span {
  display: block;
  color: var(--white);
  font-weight: 700;
  font-size: 1rem;
  margin-top: 0.5rem;
}
.footer p { font-size: 0.875rem; line-height: 1.6; color: rgba(255,255,255,0.65); margin-bottom: 0.5rem; }
.footer h4 { color: var(--white); font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 1rem; }
.footer ul li { margin-bottom: 0.4rem; }
.footer ul li a { color: rgba(255,255,255,0.65); font-size: 0.875rem; transition: color var(--transition); }
.footer ul li a:hover { color: var(--white); }
.footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 1.25rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.45);
  flex-wrap: wrap;
  gap: 0.5rem;
}
.footer__bottom a { color: rgba(255,255,255,0.45); }
.footer__bottom a:hover { color: rgba(255,255,255,0.75); }

/* --- Trennlinie mit Label ---------------------------------- */
.abschnitt-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
.abschnitt-label h2 { white-space: nowrap; }
.abschnitt-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

/* --- Hilfklassen ------------------------------------------- */
.text-center { text-align: center; }
.text-light { color: var(--text-light); }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }
.mt-2 { margin-top: 1rem; }
.mt-4 { margin-top: 2rem; }

/* Breadcrumb */
.breadcrumb {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.6);
  margin-top: 0.4rem;
}
.breadcrumb a { color: rgba(255,255,255,0.6); }
.breadcrumb a:hover { color: var(--white); }
.breadcrumb span { margin: 0 0.4rem; }

/* --- Scroll-to-Top Button ---------------------------------- */
.scroll-top {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 44px;
  height: 44px;
  background: var(--navy);
  color: var(--white);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.3s, transform 0.3s, background var(--transition);
  z-index: 99;
  box-shadow: var(--shadow-md);
  pointer-events: none;
}
.scroll-top.sichtbar {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.scroll-top:hover { background: var(--navy-mid); }

/* --- Responsive -------------------------------------------- */
@media (max-width: 900px) {
  .grid-2  { grid-template-columns: 1fr; }
  .grid-3  { grid-template-columns: 1fr 1fr; }
  .kompetenz-grid > * { flex: 0 1 calc(50% - 0.75rem); }
  .highlight-grid { grid-template-columns: 1fr 1fr; }
  .highlight:nth-child(2) { border-right: none; }
  .highlight:nth-child(3) { border-top: 1px solid rgba(255,255,255,0.1); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .projekt-fakten dl { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
  /* Downloads: 2fr/1fr und 2-spaltige Referenzlisten → 1 Spalte */
  [style*="grid-template-columns: 2fr 1fr"] { grid-template-columns: 1fr !important; }
  [style*="grid-template-columns: 1fr 1fr"] { grid-template-columns: 1fr !important; }

  .navbar__nav  { display: none; }
  .navbar__toggle { display: flex; }
  .section { padding: 2.5rem 0; }
  .grid-3  { grid-template-columns: 1fr; }
  .kompetenz-grid > * { flex: 0 1 100%; }
  .grid-auto { grid-template-columns: 1fr; }
  .highlight-grid { grid-template-columns: 1fr; }
  .highlight { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .hero { height: 300px; }
  h1 { font-size: 1.6rem; }
}

/* --- Barrierefreiheit: Animationen deaktivieren ------------ */
@media (prefers-reduced-motion: reduce) {
  .hero__bild { transition: none; }
  .kompetenz-card--animiert .kompetenz-titel-anim::after { animation: none; }
  .kompetenz-card--animiert .kompetenz-titel-anim::before { animation: none; height: 100%; }
  .kompetenz-card--animiert .kompetenz-titel-anim span { animation: none; opacity: 1; transform: none; }
  .card, .kompetenz-card, .btn { transition: none; }
}
