/* ============================================================
   EHLERS ELEKTROTECHNIK — Mockup 01
   Cinematic dark industrial w/ electric orange accent
   ============================================================ */

/* --- TOKENS --- */
:root {
  /* colors (OKLCH) — warm-tinted dark scheme, minimal heller (anthrazit statt near-black) */
  --ink-0:    oklch(0.15 0.014 45);      /* warm dark, anthrazit */
  --ink-1:    oklch(0.18 0.015 45);
  --ink-2:    oklch(0.22 0.016 45);
  --ink-3:    oklch(0.27 0.018 45);
  --ink-4:    oklch(0.34 0.020 45);
  --line:     oklch(0.40 0.020 45 / .55);
  --line-soft:oklch(0.40 0.020 45 / .22);

  --paper:    oklch(0.96 0.008 55);
  --paper-d:  oklch(0.88 0.012 55);
  --muted:    oklch(0.72 0.025 50);
  --muted-2:  oklch(0.55 0.030 50);

  /* brand orange — derived from Ehlers logo */
  --amp-5:    oklch(0.78 0.185 60);       /* highlight */
  --amp:      oklch(0.72 0.200 55);       /* main accent */
  --amp-d:    oklch(0.62 0.205 50);       /* pressed */
  --amp-glow: oklch(0.80 0.160 65 / .35);

  /* typography */
  --font-display: "Big Shoulders Display", "Impact", sans-serif;
  --font-body:    "Manrope", ui-sans-serif, system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  /* spatial — 4pt scale */
  --s-2:  .25rem;  --s-3:  .5rem;   --s-4:  .75rem;
  --s-5:  1rem;    --s-6:  1.5rem;  --s-7:  2rem;
  --s-8:  3rem;    --s-9:  4.5rem;  --s-10: 6rem;
  --s-11: 9rem;    --s-12: 12rem;

  --radius-s: 4px;
  --radius:   10px;
  --radius-l: 22px;

  --ease-out: cubic-bezier(.22,.8,.28,1);
  --ease-in:  cubic-bezier(.6,.05,.3,.95);
  --ease-smooth: cubic-bezier(.76,0,.24,1);

  --shell: 1440px;
  --pad-x: clamp(1.25rem, 4vw, 3.5rem);

  color-scheme: dark;
}

/* --- RESET --- */
*,*::before,*::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
img, svg, video { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, textarea, select { font: inherit; color: inherit; }
:focus-visible { outline: 2px solid var(--amp); outline-offset: 3px; border-radius: 2px; }

/* --- BODY --- */
body {
  font-family: var(--font-body);
  font-weight: 400;
  line-height: 1.55;
  color: var(--paper);
  background: var(--ink-0);
  overflow-x: hidden;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  cursor: none;
}

@media (hover: none), (max-width: 900px) {
  body { cursor: auto; }
  .cursor { display: none; }
}

::selection { background: var(--amp); color: var(--ink-0); }

/* --- GRAIN OVERLAY --- */
.grain {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 200;
  opacity: .05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.9 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* --- CUSTOM CURSOR --- */
.cursor {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
}
.cursor__ring {
  position: absolute;
  transform: translate(-50%,-50%);
  width: 36px; height: 36px;
  border: 1px solid var(--paper);
  border-radius: 999px;
  transition: width .3s var(--ease-out), height .3s var(--ease-out), background .2s;
}
.cursor__dot {
  position: absolute;
  transform: translate(-50%,-50%);
  width: 4px; height: 4px;
  background: var(--amp);
  border-radius: 999px;
}
.cursor.is-active .cursor__ring {
  width: 64px; height: 64px;
  background: oklch(0.72 0.200 55 / .08);
  border-color: var(--amp);
}

/* --- SCROLL PROGRESS --- */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  width: var(--p, 0%);
  height: 2px;
  background: var(--amp);
  z-index: 300;
  transition: width .1s linear;
  box-shadow: 0 0 12px var(--amp-glow);
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 150;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-6);
  align-items: center;
  padding: var(--s-5) var(--pad-x);
  transition: background .4s var(--ease-out), backdrop-filter .4s;
}
.nav.is-scrolled {
  background: color-mix(in oklch, var(--ink-0) 70%, transparent);
  backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid var(--line-soft);
}

.nav__brand {
  display: flex;
  align-items: center;
  gap: var(--s-4);
}
.nav__logo-img {
  height: 40px;
  width: auto;
  display: block;
  transition: height .3s var(--ease-out);
}
.nav.is-scrolled .nav__logo-img { height: 34px; }
@media (max-width: 600px) {
  .nav__logo-img { height: 34px; }
}

.nav__menu {
  display: flex;
  justify-content: center;
  gap: clamp(1.2rem, 2.5vw, 2.2rem);
  font-family: var(--font-mono);
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .02em;
}
.nav__menu a {
  position: relative;
  padding: 6px 0;
  color: var(--paper-d);
  transition: color .3s;
  display: inline-flex;
  gap: .4em;
  align-items: baseline;
}
.nav__menu a span {
  color: var(--amp);
  font-size: .62rem;
  opacity: .8;
}
.nav__menu a::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: 0;
  height: 1px;
  background: var(--amp);
  transition: right .4s var(--ease-out);
}
.nav__menu a:hover { color: var(--paper); }
.nav__menu a:hover::after { right: 0; }

@media (max-width: 900px) {
  .nav__menu { display: none; }
  .nav { grid-template-columns: 1fr auto; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-4);
  padding: 14px 22px;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .01em;
  transition: transform .3s var(--ease-out), background .3s, color .3s, border-color .3s;
  will-change: transform;
  position: relative;
  overflow: hidden;
  cursor: none;
  white-space: nowrap;
}
.btn__arrow,
.btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: transform .4s var(--ease-out);
}
.btn:hover .btn__arrow { transform: translateX(4px); }

.btn--primary {
  background: var(--amp);
  color: var(--ink-0);
  box-shadow: 0 8px 28px -10px var(--amp), inset 0 0 0 1px oklch(0.60 0.15 50 / .4);
}
.btn--primary:hover {
  background: var(--amp-5);
}

.btn--quiet {
  color: var(--paper-d);
  padding: 14px 18px;
}
.btn--quiet:hover { color: var(--paper); }
.btn--quiet .btn__icon { color: var(--amp); }

.btn--ghost {
  color: var(--paper);
  border: 1px solid var(--line);
  padding: 12px 20px;
}
.btn--ghost:hover {
  background: var(--ink-2);
  border-color: var(--amp);
}

.btn--block { width: 100%; justify-content: center; padding: 18px; }
.btn--inline { padding: 10px 18px; font-size: .82rem; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: 100svh;
  padding: calc(var(--s-10) + 60px) var(--pad-x) var(--s-8);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  isolation: isolate;
}

.hero__canvas {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  z-index: -2;
}
.hero__vignette {
  position: absolute; inset: 0;
  z-index: -1;
  background:
    radial-gradient(ellipse at 20% 20%, oklch(0.72 0.2 55 / .12), transparent 50%),
    radial-gradient(ellipse at 80% 90%, oklch(0.15 0.02 280 / .3), transparent 60%),
    linear-gradient(to right, color-mix(in oklch, var(--ink-0) 70%, transparent) 0%, transparent 50%),
    linear-gradient(to bottom, transparent 30%, color-mix(in oklch, var(--ink-0) 80%, transparent) 70%, var(--ink-0) 100%);
  pointer-events: none;
}
.hero__vignette::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 30% 60%, color-mix(in oklch, var(--ink-0) 55%, transparent), transparent 80%);
}

.hero__meta {
  position: absolute;
  top: calc(60px + var(--s-7));
  left: var(--pad-x);
  right: var(--pad-x);
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  z-index: 2;
}
.hero__meta-item { display: flex; align-items: center; gap: .6em; }
.hero__meta-dot {
  width: 6px; height: 6px;
  background: var(--amp);
  border-radius: 999px;
  box-shadow: 0 0 8px var(--amp);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: .4; transform: scale(.7); }
}

.hero__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--s-6);
  max-width: var(--shell);
  margin: 0 auto;
  width: 100%;
  padding-bottom: var(--s-8);
}
.hero__bottom-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-8);
  align-items: end;
  margin-top: var(--s-7);
}

.hero__eyebrow {
  display: flex;
  align-items: center;
  gap: var(--s-4);
  font-family: var(--font-mono);
  font-size: .75rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--paper-d);
  margin: 0 0 var(--s-5);
  opacity: .85;
}
.hero__eyebrow-bar {
  width: 40px;
  height: 1px;
  background: var(--amp);
}

.hero__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(4.5rem, 13.5vw, 16rem);
  line-height: .82;
  letter-spacing: -.02em;
  margin: 0;
  color: var(--paper);
  text-transform: uppercase;
}
.hero__title .line {
  display: block;
  overflow: hidden;
}
.hero__title .word {
  display: inline-block;
}
.word--accent {
  color: var(--amp);
  position: relative;
}

.hero__below {
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  max-width: 460px;
}
.hero__lede {
  font-size: 1.06rem;
  line-height: 1.6;
  color: var(--paper-d);
  margin: 0;
  max-width: 44ch;
}
.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4);
  align-items: center;
}

.hero__badges {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-soft);
  max-width: var(--shell);
  margin: 0 auto;
  width: 100%;
  padding-top: var(--s-6);
  margin-top: var(--s-7);
}
.hero__badge {
  display: flex;
  gap: var(--s-4);
  align-items: baseline;
  padding-right: var(--s-5);
  border-right: 1px solid var(--line-soft);
}
.hero__badge:last-child { border-right: 0; }
.hero__badge:last-child { border-right: 0; }
.hero__badge-num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.8rem, 2.4vw, 2.6rem);
  color: var(--amp);
  letter-spacing: -.01em;
  line-height: 1;
}
.hero__badge-lbl {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.4;
}

.hero__scroll {
  position: absolute;
  right: var(--pad-x);
  bottom: var(--s-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s-4);
  font-family: var(--font-mono);
  font-size: .64rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--muted);
  z-index: 3;
}
.hero__scroll-line {
  width: 1px;
  height: 60px;
  background: linear-gradient(to bottom, var(--amp), transparent);
  position: relative;
}
.hero__scroll-line::after {
  content: "";
  position: absolute;
  top: 0; left: -2px;
  width: 5px; height: 15px;
  background: var(--amp);
  animation: scroll-line 2.5s infinite var(--ease-smooth);
}
@keyframes scroll-line {
  0%   { transform: translateY(0); opacity: 1; }
  80%  { transform: translateY(45px); opacity: 0; }
  100% { transform: translateY(45px); opacity: 0; }
}

@media (max-width: 900px) {
  .hero__content { grid-template-columns: 1fr; gap: var(--s-6); text-align: center; }
  .hero__meta { position: static; margin-bottom: var(--s-6); }
  .hero__eyebrow { justify-content: center; }

  /* Volle Breite statt 2-Spalten-Quetschung */
  .hero__bottom-row { grid-template-columns: 1fr; }
  .hero__below { max-width: 100%; align-items: center; }
  .hero__lede { max-width: 38ch; margin: 0 auto; }

  /* CTAs mittig, untereinander, gleiche Breite */
  .hero__ctas {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: 340px;
    margin: 0 auto;
  }
  .hero__ctas .btn { justify-content: center; }

  /* Badges: Abstand zur Trennlinie + saubere Borders im 2er-Grid */
  .hero__badges { grid-template-columns: repeat(2,1fr); row-gap: var(--s-6); }
  .hero__badge { flex-direction: column; gap: var(--s-3); align-items: flex-start; }
  .hero__badge:nth-child(even) { border-right: 0; padding-left: var(--s-6); }
  .hero__badge:nth-child(odd) { padding-right: var(--s-6); }
  .hero__scroll { display: none; }
}

/* ============================================================
   TICKER
   ============================================================ */
.ticker {
  background: var(--ink-1);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  overflow: hidden;
  padding: var(--s-6) 0;
}
.ticker__track {
  display: flex;
  animation: ticker 38s linear infinite;
  width: max-content;
  will-change: transform;
}
.ticker__row {
  display: flex;
  align-items: center;
  gap: var(--s-6);
  padding-right: var(--s-6);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3.5rem);
  text-transform: uppercase;
  letter-spacing: -.01em;
  color: var(--paper);
  white-space: nowrap;
}
.ticker__row span:not(.ticker__dot):nth-child(odd) { color: var(--amp); }
.ticker__dot {
  width: 10px; height: 10px;
  background: var(--amp);
  border-radius: 999px;
  flex-shrink: 0;
}
@keyframes ticker {
  to { transform: translateX(-50%); }
}

/* ============================================================
   SECTION HEAD
   ============================================================ */
.section-head {
  max-width: var(--shell);
  margin: 0 auto var(--s-9);
  padding: 0 var(--pad-x);
}
.section-head--split {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--s-9);
  align-items: end;
}
.section-head__kicker {
  font-family: var(--font-mono);
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--amp);
  margin: 0 0 var(--s-5);
}
.section-head__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.5rem, 7vw, 6.5rem);
  line-height: .9;
  letter-spacing: -.02em;
  margin: 0 0 var(--s-6);
  text-transform: uppercase;
  color: var(--paper);
}
.section-head__title .line { display: block; overflow: hidden; }
.section-head__lede {
  font-size: 1.1rem;
  color: var(--paper-d);
  line-height: 1.55;
  max-width: 48ch;
  margin: 0;
}
.accent-dot {
  color: var(--amp);
  font-style: italic;
  font-family: var(--font-display);
}

@media (max-width: 900px) {
  .section-head--split { grid-template-columns: 1fr; gap: var(--s-5); }
}

/* ============================================================
   SERVICES
   ============================================================ */
.services {
  padding: var(--s-11) 0 var(--s-10);
  background: var(--ink-0);
  position: relative;
}
.services__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 1px;
  background: var(--line-soft);
  border-top: 1px solid var(--line-soft);
  border-bottom: 1px solid var(--line-soft);
  max-width: var(--shell);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.service {
  grid-column: span 4;
  background: var(--ink-0);
  padding: var(--s-7) var(--s-6);
  position: relative;
  transition: background .5s var(--ease-out);
  transform-style: preserve-3d;
  cursor: none;
  min-height: 340px;
  display: flex;
  flex-direction: column;
}
.service--feature {
  grid-column: span 4;
  background: var(--ink-1);
}
.service:hover {
  background: var(--ink-1);
}
.service:hover .service__go::before { transform: translateX(6px); }

.service__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: var(--s-6);
  padding-right: 44px;
}
.service__num {
  font-family: var(--font-mono);
  font-size: .74rem;
  letter-spacing: .18em;
  color: var(--amp);
}
.service__tag {
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  white-space: nowrap;
}
.service__head {
  gap: var(--s-3);
}
.service__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 3vw, 2.7rem);
  line-height: .92;
  letter-spacing: -.01em;
  margin: 0 0 var(--s-5);
  text-transform: uppercase;
  color: var(--paper);
}
.service__desc {
  font-size: .95rem;
  color: var(--paper-d);
  margin: 0 0 var(--s-5);
  line-height: 1.55;
  max-width: 36ch;
}
.service__list {
  list-style: none;
  padding: 0;
  margin: auto 0 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: .74rem;
  letter-spacing: .04em;
  color: var(--muted);
  border-top: 1px solid var(--line-soft);
  padding-top: var(--s-5);
}
.service__list li {
  display: flex;
  gap: var(--s-3);
  align-items: center;
}
.service__list li::before {
  content: "";
  width: 6px; height: 1px;
  background: var(--amp);
  flex-shrink: 0;
}
.service__go {
  position: absolute;
  top: var(--s-6); right: var(--s-6);
  width: 32px; height: 32px;
  border-radius: 999px;
  background: var(--ink-3);
  overflow: hidden;
}
.service__go::before {
  content: "→";
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  color: var(--amp);
  transition: transform .4s var(--ease-out);
}

@media (max-width: 900px) {
  .services__grid { grid-template-columns: 1fr; }
  .service, .service--feature { grid-column: span 1; }
}

/* ============================================================
   STATS
   ============================================================ */
.stats {
  padding: var(--s-10) 0;
  background: var(--ink-1);
  position: relative;
  overflow: hidden;
}
.stats::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, var(--line-soft) 1px, transparent 1px);
  background-size: 80px 100%;
  opacity: .4;
  pointer-events: none;
}
.stats__row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
  max-width: var(--shell);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  position: relative;
}
.stat {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.stat__num {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(3.5rem, 7vw, 6rem);
  line-height: .9;
  letter-spacing: -.02em;
  color: var(--paper);
  display: flex;
  align-items: baseline;
}
.stat__suffix {
  color: var(--amp);
  font-size: .6em;
  margin-left: 4px;
}
.stat__lbl {
  font-family: var(--font-mono);
  font-size: .74rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}
@media (max-width: 900px) {
  .stats__row { grid-template-columns: repeat(2, 1fr); row-gap: var(--s-7); }
}

/* ============================================================
   PROCESS / STEPS
   ============================================================ */
.process {
  padding: var(--s-11) 0 var(--s-10);
  position: relative;
}
.steps {
  list-style: none;
  margin: 0;
  padding: 0 var(--pad-x);
  max-width: var(--shell);
  margin-left: auto; margin-right: auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.step {
  padding: var(--s-7) var(--s-5) var(--s-6);
  border-right: 1px solid var(--line-soft);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  transition: background .5s;
}
.step:last-child { border-right: 0; }
.step:hover { background: var(--ink-1); }
.step::before {
  content: "";
  position: absolute;
  top: -1px; left: 0;
  width: 0;
  height: 3px;
  background: var(--amp);
  transition: width .8s var(--ease-smooth);
}
.step.is-in::before { width: 100%; }
.step__index {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.step__index-num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 3rem;
  color: var(--amp);
  line-height: 1;
}
.step__index-label {
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.step__body {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.step__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.7rem;
  line-height: 1;
  letter-spacing: -.01em;
  text-transform: uppercase;
  margin: 0;
  color: var(--paper);
}
.step__desc {
  font-size: .9rem;
  line-height: 1.55;
  color: var(--paper-d);
  margin: 0;
}
.step__time {
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .1em;
  color: var(--amp);
  margin-top: auto;
  border: 1px solid var(--amp);
  padding: 4px 10px;
  border-radius: 999px;
  align-self: flex-start;
}

@media (max-width: 900px) {
  .steps { grid-template-columns: 1fr; }
  .step { border-right: 0; border-bottom: 1px solid var(--line-soft); }
}

/* ============================================================
   MEISTER
   ============================================================ */
.meister {
  padding: var(--s-11) 0;
  background: var(--ink-1);
  position: relative;
  overflow: hidden;
}
.meister__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: var(--s-9);
  max-width: var(--shell);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  align-items: center;
}
.meister__visual {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: var(--radius-l);
  background: var(--ink-2);
}
.meister__portrait {
  position: absolute; inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-image:
    radial-gradient(ellipse at 30% 30%, oklch(0.72 0.2 55 / .25), transparent 60%),
    radial-gradient(circle at 70% 80%, oklch(0.35 0.05 280 / .4), transparent 70%);
}
.meister__portrait-bg {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 20px, var(--line-soft) 20px 21px);
  opacity: .5;
}
.meister__portrait-icon {
  width: 55%;
  color: var(--amp);
  filter: drop-shadow(0 0 20px var(--amp-glow));
  position: relative;
}
.meister__portrait-label {
  position: absolute;
  bottom: var(--s-6);
  left: var(--s-6); right: var(--s-6);
  font-family: var(--font-mono);
  font-size: .64rem;
  letter-spacing: .2em;
  color: var(--muted);
  border-top: 1px solid var(--line-soft);
  padding-top: var(--s-4);
}
.meister__spark {
  position: absolute;
  top: -20%; right: -20%;
  width: 300px; height: 300px;
  border-radius: 999px;
  background: radial-gradient(circle, var(--amp-glow), transparent 70%);
  filter: blur(40px);
  animation: float 12s ease-in-out infinite;
}
@keyframes float {
  0%,100% { transform: translate(0,0) scale(1); }
  50%     { transform: translate(-20px,20px) scale(1.1); }
}

.meister__copy {
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.meister__headline {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.2rem, 4.6vw, 4.4rem);
  line-height: .92;
  letter-spacing: -.015em;
  margin: 0;
  text-transform: uppercase;
  color: var(--paper);
}
.meister__headline .line { display: block; overflow: hidden; }
.meister__lede {
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--paper-d);
  margin: 0;
  max-width: 54ch;
}
.meister__facts {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
  margin: var(--s-4) 0 0;
  padding: var(--s-6) 0 0;
  border-top: 1px solid var(--line-soft);
}
.meister__fact { display: flex; flex-direction: column; gap: 4px; }
.meister__fact dt {
  font-family: var(--font-mono);
  font-size: .66rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.meister__fact dd {
  font-size: .95rem;
  margin: 0;
  color: var(--paper);
}

@media (max-width: 900px) {
  .meister__grid { grid-template-columns: 1fr; }
  .meister__visual { max-width: 360px; }
}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi {
  padding: var(--s-11) 0 var(--s-10);
}
.testi__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: var(--s-5);
  max-width: var(--shell);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.testi__card {
  grid-column: span 4;
  background: var(--ink-1);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: var(--s-7);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
  cursor: none;
  transition: background .4s, transform .4s;
}
.testi__card:hover { background: var(--ink-2); }
.testi__card--wide { grid-column: span 4; }
.testi__card blockquote {
  margin: 0;
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--paper);
  position: relative;
  padding-top: var(--s-6);
}
.testi__card blockquote::before {
  content: "„";
  position: absolute;
  top: -10px; left: 0;
  font-family: var(--font-display);
  font-size: 4rem;
  color: var(--amp);
  line-height: 1;
}
.testi__card figcaption {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding-top: var(--s-5);
  border-top: 1px solid var(--line-soft);
}
.testi__name {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1rem;
  letter-spacing: .02em;
  color: var(--paper);
  text-transform: uppercase;
}
.testi__role {
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .14em;
  color: var(--muted);
  text-transform: uppercase;
}
@media (max-width: 900px) {
  .testi__card { grid-column: span 12; }
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact {
  padding: var(--s-11) 0 var(--s-10);
  background: var(--ink-0);
  position: relative;
}
.contact__inner {
  max-width: var(--shell);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-9);
  align-items: start;
}
.contact__headline {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.4rem, 6.5vw, 6rem);
  line-height: .9;
  letter-spacing: -.02em;
  margin: 0 0 var(--s-5);
  text-transform: uppercase;
  color: var(--paper);
}
.contact__headline .line { display: block; overflow: hidden; }
.contact__lede {
  font-size: 1.05rem;
  color: var(--paper-d);
  line-height: 1.6;
  margin: 0 0 var(--s-7);
  max-width: 46ch;
}
.contact__direct {
  list-style: none;
  margin: 0;
  padding: var(--s-6) 0 0;
  border-top: 1px solid var(--line-soft);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6);
}
.contact__direct li {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.contact__label {
  font-family: var(--font-mono);
  font-size: .66rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.contact__direct a,
.contact__direct span {
  font-size: 1rem;
  color: var(--paper);
  line-height: 1.4;
  transition: color .3s;
}
.contact__direct a:hover { color: var(--amp); }

/* form */
.form {
  background: var(--ink-1);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-l);
  padding: var(--s-7);
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
}
.form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}

/* Kontaktformular-Felder (modern, Box-Style) */
.form__field {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.form__field span {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
}
.form__field input,
.form__field textarea {
  width: 100%;
  box-sizing: border-box;
  background: var(--ink-0);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: 13px 15px;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--paper);
  transition: border-color .2s, background .2s, box-shadow .2s;
}
.form__field input::placeholder,
.form__field textarea::placeholder {
  color: var(--muted-2);
}
.form__field input:focus,
.form__field textarea:focus {
  outline: 0;
  border-color: var(--amp);
  background: var(--ink-1);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--amp) 18%, transparent);
}
.form__field textarea {
  resize: vertical;
  min-height: 130px;
  line-height: 1.5;
}
.field {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.field__label {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
}
.field input,
.field textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--line);
  padding: 10px 0;
  font-size: 1rem;
  color: var(--paper);
  transition: border-color .3s, color .3s;
  border-radius: 0;
}
.field input::placeholder,
.field textarea::placeholder {
  color: var(--muted-2);
}
.field input:focus,
.field textarea:focus {
  outline: 0;
  border-bottom-color: var(--amp);
}
.field textarea {
  resize: vertical;
  min-height: 80px;
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding-top: 4px;
}
.chip {
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: .82rem;
  color: var(--paper-d);
  cursor: none;
  transition: all .3s;
  font-family: var(--font-body);
}
.chip:hover { border-color: var(--paper); color: var(--paper); }
.chip.is-active {
  background: var(--amp);
  border-color: var(--amp);
  color: var(--ink-0);
}

.form__submit {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin-top: var(--s-3);
}
.form__status {
  font-family: var(--font-mono);
  font-size: .78rem;
  color: var(--amp);
  margin: 0;
  text-align: center;
  min-height: 1em;
}

@media (max-width: 900px) {
  .contact__inner { grid-template-columns: 1fr; }
  .contact__direct, .form__row { grid-template-columns: 1fr; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot {
  background: var(--ink-0);
  padding: var(--s-9) var(--pad-x) var(--s-6);
  border-top: 1px solid var(--line-soft);
  max-width: var(--shell);
  margin: 0 auto;
}
.foot__huge {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(3.5rem, 13.8vw, 14rem);
  line-height: .82;
  letter-spacing: -.03em;
  text-transform: uppercase;
  color: var(--paper);
  margin-bottom: var(--s-8);
  padding-bottom: var(--s-7);
  border-bottom: 1px solid var(--line-soft);
}
.foot__huge .line {
  display: block;
  overflow: hidden;
}
.foot__huge .line:nth-child(2) {
  color: var(--amp);
}

.foot__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-6);
  margin-bottom: var(--s-8);
}
.foot__col {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
}
.foot__kicker {
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .2em;
  color: var(--amp);
  text-transform: uppercase;
}
.foot__col p {
  margin: 0;
  font-size: .92rem;
  color: var(--paper-d);
  line-height: 1.55;
}
.foot__col a { transition: color .3s; }
.foot__col a:hover { color: var(--amp); }

.foot__base {
  display: flex;
  justify-content: space-between;
  padding-top: var(--s-5);
  border-top: 1px solid var(--line-soft);
  font-family: var(--font-mono);
  font-size: .7rem;
  letter-spacing: .12em;
  color: var(--muted);
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .foot__grid { grid-template-columns: repeat(2, 1fr); }
  .foot__base { flex-direction: column; gap: var(--s-3); text-align: left; }
}

/* ============================================================
   REVEAL ANIMATIONS — defaults are visible; GSAP animates FROM hidden
   ============================================================ */
.line-inner {
  display: inline-block;
  will-change: transform;
}
/* keep paint clean for text with long descenders */
[data-reveal-chars] .line { padding-bottom: .05em; margin-bottom: -.05em; }

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .ticker__track { animation: none; }
  .hero__meta-dot { animation: none; }
}


/* ============================================================
   NORMAL CURSOR (Custom-Cursor deaktiviert)
   ============================================================ */
body { cursor: auto !important; }
.btn, .service, .testi__card, .step,
a, button, input, textarea, select {
  cursor: auto !important;
}
.btn, a {
  cursor: pointer !important;
}
.service, .testi__card {
  cursor: pointer !important;
}
.cursor {
  display: none !important;
}
/* ============================================================
   EHLERS ELEKTROTECHNIK — Site-Erweiterungen
   Zusätzliche Styles für Sub-Pages (Prose, Listings, CTA-Band)
   ============================================================ */

/* Skip-Link für a11y */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--amp);
  color: var(--ink-0);
  padding: 8px 16px;
  z-index: 9999;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  text-decoration: none;
}
.skip-link:focus { top: 0; }

/* Nav-CTA (Telefon-Button in Nav) */
.nav__cta {
  font-size: 0.78rem;
  letter-spacing: 0.04em;
}
.nav__cta span:first-child { font-family: var(--font-mono); }

/* ============================================================
   PAGE HERO (für alle Sub-Pages außer Startseite)
   ============================================================ */
.page-hero {
  padding: calc(var(--s-9) + 80px) var(--pad-x) var(--s-8);
  background: linear-gradient(180deg, var(--ink-1), var(--ink-0));
  border-bottom: 1px solid var(--line-soft);
  position: relative;
  isolation: isolate;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 20%, var(--amp-glow), transparent 50%);
  opacity: .4;
  z-index: -1;
}
.page-hero__inner {
  max-width: var(--shell);
  margin: 0 auto;
}
.page-hero__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2.5rem, 7vw, 5.5rem);
  line-height: 0.95;
  letter-spacing: -0.015em;
  margin: var(--s-5) 0 var(--s-5);
  text-transform: uppercase;
  color: var(--paper);
}
.page-hero__lede {
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: var(--paper-d);
  max-width: 60ch;
  line-height: 1.55;
  margin: 0 0 var(--s-6);
}
.page-hero__ctas {
  display: flex;
  gap: var(--s-4);
  flex-wrap: wrap;
}
.page-hero--article { background: linear-gradient(180deg, var(--ink-2), var(--ink-0)); }
.page-hero--standort { background: linear-gradient(180deg, var(--ink-1), var(--ink-0)); }

/* ============================================================
   PROSE (Markdown-Content)
   ============================================================ */
.prose {
  padding: var(--s-9) var(--pad-x);
  background: var(--ink-0);
}
.prose__inner {
  max-width: 740px;
  margin: 0 auto;
  color: var(--paper-d);
  font-size: 1.06rem;
  line-height: 1.7;
}
.prose__inner h1 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
  letter-spacing: -0.01em;
  margin: var(--s-7) 0 var(--s-5);
  color: var(--paper);
  text-transform: uppercase;
}
.prose__inner h2 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  line-height: 1.1;
  letter-spacing: -0.005em;
  margin: var(--s-8) 0 var(--s-5);
  color: var(--paper);
  text-transform: uppercase;
  padding-top: var(--s-6);
  border-top: 1px solid var(--line-soft);
}
.prose__inner h2:first-child { padding-top: 0; border-top: 0; margin-top: 0; }
.prose__inner h3 {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 1.2rem;
  margin: var(--s-6) 0 var(--s-4);
  color: var(--paper);
}
.prose__inner p {
  margin: 0 0 var(--s-5);
}
.prose__inner p strong, .prose__inner li strong {
  color: var(--paper);
  font-weight: 600;
}
.prose__inner em { font-style: italic; color: var(--paper); }
.prose__inner a {
  color: var(--amp);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.prose__inner a:hover { color: var(--amp-5); }
.prose__inner ul, .prose__inner ol {
  margin: 0 0 var(--s-5);
  padding-left: 1.5em;
}
.prose__inner li { margin-bottom: var(--s-3); }
.prose__inner blockquote {
  margin: var(--s-6) 0;
  padding: var(--s-5) var(--s-6);
  border-left: 3px solid var(--amp);
  background: var(--ink-1);
  font-style: italic;
  color: var(--paper);
}
.prose__inner code {
  background: var(--ink-2);
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: 0.92em;
}
.prose__inner pre {
  background: var(--ink-2);
  padding: var(--s-5);
  border-radius: var(--radius);
  overflow-x: auto;
  margin: var(--s-5) 0;
}
.prose__inner table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-6) 0;
  font-size: 0.96em;
}
.prose__inner th, .prose__inner td {
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--line-soft);
  text-align: left;
  vertical-align: top;
}
.prose__inner th {
  background: var(--ink-1);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 0.85em;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.prose__inner img {
  display: block;
  width: 100%;
  height: auto;
  margin: var(--s-5) 0;
  border-radius: var(--radius);
}
.prose__inner hr {
  border: 0;
  border-top: 1px solid var(--line-soft);
  margin: var(--s-7) 0;
}

/* ============================================================
   RELATED / LISTING GRID
   ============================================================ */
.related, .listing {
  padding: var(--s-10) var(--pad-x);
  background: var(--ink-1);
  border-top: 1px solid var(--line-soft);
}
.related__inner, .listing__inner {
  max-width: var(--shell);
  margin: 0 auto;
}
.related__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  margin: var(--s-5) 0 var(--s-7);
  color: var(--paper);
}
.related__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--s-5);
}
.related__card {
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  padding: var(--s-6);
  background: var(--ink-2);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--paper);
  transition: border-color 0.25s, transform 0.25s, background 0.25s;
  position: relative;
}
.related__card:hover {
  border-color: var(--amp);
  transform: translateY(-2px);
  background: var(--ink-3);
}
.related__card .related__tag {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--amp);
}
.related__card h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.3rem;
  line-height: 1.1;
  margin: 0;
  text-transform: uppercase;
  letter-spacing: -0.005em;
}
.related__card p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--muted);
  line-height: 1.5;
}

/* ============================================================
   CTA-BAND (am Ende jeder Sub-Page)
   ============================================================ */
.cta-band {
  padding: var(--s-10) var(--pad-x);
  background: linear-gradient(135deg, var(--amp-d), var(--amp));
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,0,0,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.06) 1px, transparent 1px);
  background-size: 60px 60px;
  opacity: 0.6;
}
.cta-band__inner {
  position: relative;
  max-width: var(--shell);
  margin: 0 auto;
  text-align: center;
}
.cta-band__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 5vw, 3.5rem);
  line-height: 1;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-4);
  color: var(--ink-0);
  text-transform: uppercase;
}
.cta-band__lede {
  font-size: 1.1rem;
  color: rgba(28,24,18,0.85);
  margin: 0 0 var(--s-6);
}
.cta-band__btns {
  display: flex;
  gap: var(--s-4);
  justify-content: center;
  flex-wrap: wrap;
}
.cta-band .btn--primary {
  background: var(--ink-0);
  color: var(--paper);
}
.cta-band .btn--primary:hover { background: var(--ink-1); }
.cta-band .btn--ghost {
  border-color: rgba(28,24,18,0.4);
  color: var(--ink-0);
}
.cta-band .btn--ghost:hover {
  background: rgba(0,0,0,0.1);
  border-color: var(--ink-0);
}

/* ============================================================
   MOBILE BURGER-MENU
   ============================================================ */
.nav__burger {
  display: none;
  background: transparent;
  border: 0;
  padding: 10px;
  cursor: pointer;
  flex-direction: column;
  gap: 5px;
  width: 44px; height: 44px;
  justify-content: center;
  align-items: center;
  z-index: 200;
}
.nav__burger span {
  display: block;
  width: 22px; height: 2px;
  background: var(--paper);
  border-radius: 2px;
  transition: transform 0.3s var(--ease-out), opacity 0.2s;
}
.nav__burger.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 900px) {
  .nav { grid-template-columns: auto 1fr auto; }
  .nav__menu { display: none; }
  .nav__cta { display: none; }
  .nav__burger { display: flex; position: relative; z-index: 200; grid-column: 3; justify-self: end; }

  /* backdrop-filter macht das fixed-Menue sonst zum Nav-Gefangenen
     (Containing Block) -> bei offenem Menue deaktivieren */
  .nav.menu-open {
    transition: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background: var(--ink-0) !important;
  }

  @keyframes menuFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
  }
  .nav__menu.is-open {
    display: flex !important;
    animation: menuFadeIn .22s ease-out;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--ink-0);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: var(--s-6);
    font-size: 1.4rem;
    z-index: 150;
    padding: var(--s-9) var(--pad-x);
    overflow-y: auto;
  }
  .nav__menu.is-open a {
    padding: var(--s-3) 0;
    color: var(--paper);
  }
  .nav__menu.is-open a span {
    color: var(--amp);
    margin-right: var(--s-4);
  }
  body.nav-locked { overflow: hidden; }
}

/* ============================================================
   FLOATING WHATSAPP BUTTON
   ============================================================ */
.floating-whatsapp {
  position: fixed;
  bottom: 20px; right: 20px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px 12px 14px;
  background: oklch(0.68 0.18 145);
  color: white;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 0 6px 24px -8px oklch(0.50 0.18 145 / .6);
  z-index: 100;
  transition: transform .25s, box-shadow .25s;
}
.floating-whatsapp:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px -8px oklch(0.50 0.18 145 / .75);
}
.floating-whatsapp svg { flex-shrink: 0; }
@media (max-width: 600px) {
  .floating-whatsapp span { display: none; }
  .floating-whatsapp { padding: 14px; }
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumbs {
  max-width: var(--shell);
  margin: 0 auto;
  padding: var(--s-5) var(--pad-x) 0;
}
.breadcrumbs__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--muted);
}
.breadcrumbs__item { display: inline-flex; align-items: center; gap: var(--s-3); }
.breadcrumbs__item a {
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.breadcrumbs__item a:hover {
  color: var(--paper);
  border-color: var(--amp);
}
.breadcrumbs__item [aria-current] {
  color: var(--paper);
}
.breadcrumbs__sep { color: var(--ink-4); }

/* ============================================================
   FILTER-BAR (Wissenswertes)
   ============================================================ */
.filter-bar {
  display: grid;
  gap: var(--s-5);
  margin-bottom: var(--s-7);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--line-soft);
}
.filter-search {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.filter-search span {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--amp);
}
.filter-search input {
  background: var(--ink-1);
  border: 1px solid var(--line-soft);
  color: var(--paper);
  padding: 14px 18px;
  border-radius: var(--radius);
  font-family: var(--font-body);
  font-size: 1rem;
  width: 100%;
  transition: border-color .2s, background .2s;
}
.filter-search input:focus {
  outline: 0;
  border-color: var(--amp);
  background: var(--ink-2);
}
.filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
}
.filter-chip {
  background: var(--ink-1);
  border: 1px solid var(--line-soft);
  color: var(--paper-d);
  padding: 8px 16px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s;
}
.filter-chip:hover {
  background: var(--ink-2);
  color: var(--paper);
  border-color: var(--amp);
}
.filter-chip.is-active {
  background: var(--amp);
  border-color: var(--amp);
  color: var(--ink-0);
}
.filter-empty {
  text-align: center;
  padding: var(--s-7);
  color: var(--muted);
  font-size: 0.95rem;
}
.filter-empty a { color: var(--amp); text-decoration: underline; }

.article-card__meta {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  color: var(--muted);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: auto;
}

/* ============================================================
   WISSENSWERTES LISTING — luftiger, Kategorie-Farben, line-clamp
   ============================================================ */
.listing--wissen { padding: var(--s-9) var(--pad-x) var(--s-10); }

.page-hero--wissen .page-hero__inner { max-width: 880px; }
.page-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3) var(--s-4);
  align-items: center;
  margin-top: var(--s-5);
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.page-hero__count {
  color: var(--amp);
  font-weight: 700;
}
.page-hero__dot { color: var(--ink-4); }

/* Chip-Pille mit Kategorie-Dot + Count */
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
}
.filter-chip__dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--cat-fg, var(--amp));
  flex: 0 0 auto;
}
.filter-chip__count {
  font-size: 0.65rem;
  opacity: 0.7;
  letter-spacing: 0.08em;
  margin-left: 2px;
}
.filter-chip.is-active .filter-chip__count { opacity: 0.85; }
.filter-chips__toggle {
  margin-top: var(--s-4);
  background: transparent;
  border: 1px dashed var(--line-soft);
  color: var(--paper-d);
  padding: 10px 18px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
}
.filter-chips__toggle:hover {
  border-color: var(--amp);
  color: var(--amp);
  background: var(--ink-2);
}

/* Eigenes Grid: weniger Spalten, mehr Atemraum */
.article-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: var(--s-6);
}
@media (min-width: 1280px) {
  .article-grid { grid-template-columns: repeat(3, 1fr); }
}

.article-card {
  --cat-fg: var(--amp);
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  padding: var(--s-7) var(--s-6) var(--s-6);
  background: linear-gradient(180deg, var(--ink-2) 0%, var(--ink-1) 100%);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-l);
  text-decoration: none;
  color: var(--paper);
  overflow: hidden;
  transition: border-color .25s, transform .25s, background .25s, box-shadow .25s;
  min-height: 240px;
}
/* Farbiger Akzent-Balken oben */
.article-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--cat-fg);
  opacity: 0.85;
  transition: height .25s, opacity .25s;
}
.article-card:hover {
  border-color: var(--cat-fg);
  transform: translateY(-3px);
  background: linear-gradient(180deg, var(--ink-3) 0%, var(--ink-2) 100%);
  box-shadow: 0 18px 40px -20px rgba(0,0,0,0.5);
}
.article-card:hover::before {
  height: 5px;
  opacity: 1;
}

.article-card__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--cat-fg);
  align-self: flex-start;
  padding: 5px 12px 5px 10px;
  border-radius: 999px;
  background: color-mix(in oklch, var(--cat-fg) 14%, transparent);
  border: 1px solid color-mix(in oklch, var(--cat-fg) 35%, transparent);
}
.article-card__dot {
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--cat-fg);
  box-shadow: 0 0 8px var(--cat-fg);
}

.article-card__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.2rem;
  line-height: 1.22;
  margin: 0;
  letter-spacing: -0.005em;
  color: var(--paper);
  /* max 3 Zeilen */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.article-card__lede {
  margin: 0;
  font-size: 0.95rem;
  color: var(--muted);
  line-height: 1.55;
  /* max 3 Zeilen für gleichmäßige Karten */
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.article-card__footer {
  margin-top: auto;
  padding-top: var(--s-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
  border-top: 1px solid var(--line-soft);
}
.article-card .article-card__meta {
  margin-top: 0;
}
.article-card__cta {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cat-fg);
  transition: transform .2s;
}
.article-card:hover .article-card__cta {
  transform: translateX(3px);
}

@media (max-width: 720px) {
  .article-grid { gap: var(--s-5); }
  .article-card { padding: var(--s-6) var(--s-5); min-height: 200px; }
  .article-card__title { font-size: 1.1rem; }
}

/* Touch-Target für neue Karten */
.article-card { min-height: 220px; }

/* ============================================================
   404 PAGE
   ============================================================ */
.page-hero--404 {
  text-align: center;
  background: radial-gradient(ellipse at 50% 30%, var(--amp-glow), transparent 60%), var(--ink-0);
  min-height: 60vh;
  display: flex;
  align-items: center;
}
.page-hero--404 .page-hero__inner {
  width: 100%;
  text-align: center;
}
.page-hero--404 .page-hero__ctas { justify-content: center; }

/* Service-Hero Variation */
.page-hero--service {
  background: linear-gradient(180deg, var(--ink-2), var(--ink-0));
}

/* ============================================================
   PROSE Polish (Bilder, FAQ-Headlines, Tabellen mobile)
   ============================================================ */
.prose__inner img {
  loading: lazy;
}
@media (max-width: 600px) {
  .prose__inner table { font-size: 0.85em; }
  .prose__inner th, .prose__inner td { padding: 8px 10px; }
}

/* Touch-Target-Größen */
.related__card, .filter-chip, .nav__menu a, .btn {
  min-height: 44px;
}

/* Print */
@media print {
  .nav, .floating-whatsapp, .scroll-progress, .cta-band, .related, .ticker { display: none; }
  body { color: black; background: white; }
  .prose__inner { max-width: 100%; }
}


/* === Inhaber-Sektion ohne Visual (Single-Column) === */
.meister--solo .meister__grid {
  grid-template-columns: 1fr;
  max-width: 920px;
}
.meister--solo .meister__copy {
  max-width: 820px;
}
.meister--solo .meister__headline {
  font-size: clamp(2.4rem, 5.4vw, 5rem);
}
.meister--solo .meister__lede {
  font-size: 1.15rem;
  max-width: 64ch;
}
.meister--solo .meister__facts {
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 900px) {
  .meister--solo .meister__facts { grid-template-columns: repeat(2, 1fr); }
}


/* Form-Status-Hint */
.form__hint {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  margin: var(--s-4) 0 0;
  color: var(--muted);
  min-height: 1.2em;
}
.form__hint--success { color: oklch(0.72 0.18 145); }
.form__hint--error { color: oklch(0.68 0.18 25); }

/* ============================================================
   SERVICE-HUB HERO mit BILD
   ============================================================ */
.page-hero--with-image {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--s-7);
  align-items: center;
  max-width: var(--shell);
  margin: 0 auto;
  padding-left: var(--pad-x);
  padding-right: 0;
}
.page-hero--with-image .page-hero__inner {
  padding: 0;
}
.page-hero__visual {
  position: relative;
  align-self: stretch;
  overflow: hidden;
  border-radius: var(--radius-l) 0 0 var(--radius-l);
  min-height: 420px;
}
.page-hero__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.page-hero__visual-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--ink-0) 0%, transparent 30%, transparent 70%, oklch(0.20 0.04 45 / .25) 100%);
  pointer-events: none;
}
@media (max-width: 900px) {
  .page-hero--with-image {
    grid-template-columns: 1fr;
    padding-right: var(--pad-x);
  }
  .page-hero__visual {
    border-radius: var(--radius-l);
    min-height: 260px;
    order: -1;
    margin-bottom: var(--s-5);
  }
}

/* ============================================================
   ARTICLE-HERO mit KATEGORIE-FARBEN
   ============================================================ */
.page-hero--article {
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.page-hero--article::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(circle at 15% 25%, var(--cat-fg, var(--amp-glow)), transparent 35%),
    radial-gradient(circle at 85% 90%, var(--cat-bg, var(--ink-2)), transparent 50%),
    linear-gradient(180deg, var(--ink-1), var(--ink-0));
  opacity: 0.85;
}
.cat-pill {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 999px;
  background: var(--cat-fg, var(--amp));
  color: var(--ink-0);
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 600;
  margin-right: var(--s-3);
}
.reading-time {
  font-family: var(--font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ============================================================
   FAQ-AKKORDEON
   ============================================================ */
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin: var(--s-5) 0;
  border-top: 1px solid var(--line-soft);
}
.faq-item {
  border-bottom: 1px solid var(--line-soft);
  background: transparent;
}
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--s-5) 0;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.15rem;
  color: var(--paper);
  text-transform: uppercase;
  letter-spacing: -0.005em;
  position: relative;
  padding-right: 48px;
  transition: color 0.2s;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 1.8rem;
  color: var(--amp);
  line-height: 1;
  transition: transform 0.3s;
}
.faq-item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.faq-item summary:hover { color: var(--amp); }
.faq-body {
  padding: 0 0 var(--s-5);
  color: var(--paper-d);
  line-height: 1.65;
}
.faq-body p { margin: 0 0 var(--s-3); }

