/* =========================================================
   Blitzgebäudereinigung Hamburg — Design System v2
   Premium / Agency Level
   Farben: Weiß, Blau, Gelb, Anthrazit/Grau
   Display: Sora · Text: Inter
   ========================================================= */

:root {
  /* Brand */
  --blue-900: #08213f;
  --blue-800: #0c3768;
  --blue-700: #0f4c97;
  --blue-600: #1565d8;
  --blue-500: #2a7df0;
  --blue-100: #cfe1ff;
  --blue-50:  #eaf2ff;
  --yellow:   #ffd200;
  --yellow-600: #f5b800;
  --ink:      #0e1a29;   /* Anthrazit */
  --ink-700:  #2b3a4d;
  --slate:    #5b6b7e;
  --slate-300:#9aa9ba;
  --line:     #e7edf4;
  --bg:       #ffffff;
  --bg-soft:  #f4f8fd;
  --bg-blue:  #eef5ff;
  --white:    #ffffff;

  /* System */
  --radius:   20px;
  --radius-sm:14px;
  --radius-lg:30px;
  --shadow-sm: 0 4px 16px -4px rgba(13,45,95,.08);
  --shadow:    0 22px 55px -18px rgba(13,55,120,.22);
  --shadow-lg: 0 50px 100px -28px rgba(11,50,110,.40);
  --shadow-blue: 0 24px 55px -16px rgba(21,101,216,.5);
  --shadow-yellow: 0 18px 40px -10px rgba(245,184,0,.55);
  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 72px);
  --ease: cubic-bezier(.22,.7,.25,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --ff: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --ff-display: "Sora", "Inter", system-ui, sans-serif;

  --header-h: 96px;
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 120px; overflow-x: clip; }
body {
  font-family: var(--ff);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}
img { display:block; max-width:100%; height:auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; }
::selection { background: var(--yellow); color: var(--ink); }
:focus-visible { outline: 3px solid var(--blue-500); outline-offset: 3px; border-radius: 6px; }

/* ---------- Scroll progress bar ---------- */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 3px; width: 0%; z-index: 200;
  background: linear-gradient(90deg, var(--blue-600), var(--yellow));
  box-shadow: 0 0 12px rgba(21,101,216,.5);
  transition: width .1s linear;
}

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(76px, 10vw, 150px); position: relative; }
.section--soft { background: var(--bg-soft); }
.section--blue { background: var(--bg-blue); }
.section--ink { background: var(--ink); color: #d3e0ef; }
.section--soft::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image: radial-gradient(circle, rgba(21,101,216,.10) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 0%, #000, transparent 75%);
  mask-image: radial-gradient(ellipse 70% 60% at 50% 0%, #000, transparent 75%);
}
.section--ink::before {
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000, transparent 80%);
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, #000, transparent 80%);
}
.section > .container { position: relative; z-index: 1; }
.grid { display: grid; gap: clamp(22px, 3vw, 34px); }

/* ---------- Typography ---------- */
h1,h2,h3,h4 { font-family: var(--ff-display); line-height: 1.07; font-weight: 800; letter-spacing: -.025em; color: var(--ink); }
.section--ink h1,.section--ink h2,.section--ink h3 { color: #fff; }
h1 { font-size: clamp(2.55rem, 5.6vw, 4.6rem); }
h2 { font-size: clamp(2rem, 3.9vw, 3.1rem); }
h3 { font-size: clamp(1.22rem, 1.7vw, 1.45rem); font-weight: 700; }
p  { color: var(--ink-700); }
.lead { font-size: clamp(1.08rem, 1.45vw, 1.32rem); color: var(--ink-700); line-height: 1.6; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: .8rem; font-weight: 700; letter-spacing: .16em; text-transform: uppercase;
  color: var(--blue-700);
  padding: 8px 16px 8px 14px; border-radius: 100px;
  background: linear-gradient(180deg, #fff, var(--blue-50));
  border: 1px solid var(--blue-100);
  box-shadow: var(--shadow-sm);
}
.section--ink .eyebrow { color: var(--ink); background: linear-gradient(180deg, #fff3b0, var(--yellow)); border-color: var(--yellow-600); }
.text-yellow { color: var(--yellow-600); }
.text-blue { color: var(--blue-600); }

.section-head { max-width: 780px; margin-bottom: clamp(42px, 5vw, 68px); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head h2 { margin-top: 18px; }
.section-head p { margin-top: 18px; }

/* ---------- Buttons ---------- */
.btn {
  position: relative; overflow: hidden;
  display: inline-flex; align-items: center; justify-content:center; gap: 10px;
  font-weight: 700; font-size: 1rem; line-height: 1;
  padding: 17px 28px; border-radius: 100px; border: 1.5px solid transparent;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s, border-color .3s;
  white-space: nowrap; isolation: isolate;
}
.btn svg { width: 18px; height: 18px; transition: transform .35s var(--ease); }
.btn:hover svg { transform: translateX(4px); }
.btn::after { /* shine */
  content:""; position:absolute; inset:0; z-index:-1; transform: translateX(-120%);
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,.45) 50%, transparent 70%);
  transition: transform .7s var(--ease);
}
.btn:hover::after { transform: translateX(120%); }
.btn--primary { background: linear-gradient(180deg, #ffdc33, var(--yellow)); color: var(--ink); box-shadow: var(--shadow-yellow); }
.btn--primary:hover { transform: translateY(-3px); box-shadow: 0 24px 50px -10px rgba(245,184,0,.7); }
.btn--blue { background: linear-gradient(180deg, var(--blue-500), var(--blue-600)); color:#fff; box-shadow: var(--shadow-blue); }
.btn--blue:hover { transform: translateY(-3px); box-shadow: 0 28px 60px -12px rgba(21,101,216,.65); }
.btn--ghost { background: rgba(255,255,255,.6); color: var(--ink); border-color: var(--line); backdrop-filter: blur(6px); }
.btn--ghost:hover { border-color: var(--blue-600); color: var(--blue-700); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn--white { background:#fff; color: var(--blue-700); }
.btn--white:hover { transform: translateY(-3px); box-shadow: var(--shadow); }
.btn--lg { padding: 20px 36px; font-size: 1.05rem; }
.btn--block { width: 100%; }

/* =========================================================
   TOP UTILITY BAR
   ========================================================= */
.topbar {
  background: linear-gradient(90deg, var(--ink), #16263b);
  color: #c2d2e4; font-size: .84rem; position: relative; z-index: 101;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; height: 42px; }
.topbar__usp { display: inline-flex; align-items: center; gap: 9px; font-weight: 500; letter-spacing: .01em; }
.topbar__usp .stars { color: var(--yellow); letter-spacing: 1px; }
.topbar__usp b { color: #fff; font-weight: 700; }
.topbar__links { display: flex; align-items: center; gap: 16px; }
.topbar__links a { display: inline-flex; align-items: center; gap: 8px; color: #c2d2e4; font-weight: 500; transition: color .25s; white-space: nowrap; }
.topbar__links a:hover { color: #fff; }
.topbar__links a svg { width: 15px; height: 15px; color: var(--yellow); flex: 0 0 auto; }
.topbar__sep { width: 1px; height: 16px; background: rgba(255,255,255,.18); flex: 0 0 auto; }
/* Telefonnummer prominent & vollständig in der Infoleiste */
.topbar__phone b { color: #fff; font-weight: 700; letter-spacing: .01em; }
.topbar__phone:hover b { color: var(--yellow); }
.topbar__wa svg { color: #25d366; }
.topbar__wa:hover { color: #25d366; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,.66);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid rgba(231,237,244,.7);
  transition: background .45s var(--ease), box-shadow .45s var(--ease), border-color .45s;
}
.site-header.scrolled {
  background: rgba(255,255,255,.94);
  box-shadow: 0 14px 50px -18px rgba(12,40,90,.28);
  border-color: var(--line);
}
.nav { display: flex; align-items: center; flex-wrap: nowrap; gap: clamp(14px, 2vw, 40px); padding-block: 24px; transition: padding .45s var(--ease); }
.site-header.scrolled .nav { padding-block: 13px; }

/* Brand */
.brand { display: flex; align-items: center; gap: 14px; flex: 0 0 auto; }
.brand__mark {
  width: 48px; height: 48px; border-radius: 14px; flex: 0 0 auto;
  display: grid; place-items: center; color: var(--ink); position: relative;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 6px 16px -6px rgba(13,45,95,.18), inset 0 0 0 1px rgba(255,255,255,.6);
  transition: transform .45s var(--ease), width .45s var(--ease), height .45s var(--ease);
}
.brand:hover .brand__mark { transform: rotate(-8deg) scale(1.05); }
.site-header.scrolled .brand__mark { width: 43px; height: 43px; }
.brand__mark svg { width: 26px; height: 26px; }
.brand__mark img { width: 34px; height: auto; display: block; }
.brand__text { display: flex; flex-direction: column; font-family: var(--ff-display); font-weight: 800; font-size: 1.18rem; letter-spacing: -.03em; line-height: 1; color: var(--ink); }
.brand__text b { color: var(--blue-700); font-weight: 800; }
.brand__text small { font-family: var(--ff); margin-top: 6px; font-size: .65rem; font-weight: 600; letter-spacing: .18em; color: var(--slate); text-transform: uppercase; }

/* Nav links — zentriert, immer einzeilig, mehr Luft */
.nav__links { display: flex; align-items: center; gap: clamp(1px, .4vw, 8px); margin-inline: auto; }
.nav__links a {
  position: relative; font-weight: 600; font-size: .96rem; color: var(--ink-700); white-space: nowrap;
  padding: 11px 15px; border-radius: 10px; transition: color .3s var(--ease);
}
.nav__links a::after {
  content:""; position: absolute; left: 15px; right: 15px; bottom: 6px; height: 2px;
  border-radius: 2px; background: linear-gradient(90deg, var(--blue-600), var(--blue-500));
  transform: scaleX(0); transform-origin: center; transition: transform .4s var(--ease);
}
.nav__links a:hover { color: var(--blue-700); }
.nav__links a:hover::after, .nav__links a[aria-current="page"]::after { transform: scaleX(1); }
.nav__links a[aria-current="page"] { color: var(--blue-700); }

/* CTA cluster — Kontakt-Icons + Button, mit feinem Trenner davor */
.nav__cta { display: flex; align-items: center; gap: 14px; flex: 0 0 auto; }
.nav__cta::before { content:""; width: 1px; height: 34px; background: var(--line); flex: 0 0 auto; }
/* CTA-Button: niemals stauchen, niemals abschneiden */
.nav__cta .btn { flex: 0 0 auto; white-space: nowrap; }

/* Kontakt-Icon-Buttons (Telefon + WhatsApp) — gefüllte Premium-Buttons in CTA-Designsprache */
.iconbtn {
  position: relative; width: 46px; height: 46px; border-radius: 50%; flex: 0 0 auto;
  display: grid; place-items: center; color: #fff; border: 0;
  transition: box-shadow .35s var(--ease), transform .35s var(--ease), filter .3s;
}
.iconbtn svg { width: 21px; height: 21px; }
.iconbtn:hover { transform: translateY(-3px); filter: brightness(1.05); }
.iconbtn:active { transform: translateY(-1px); }
.iconbtn::after { /* Tooltip */
  content: attr(data-tip); position: absolute; top: calc(100% + 11px); left: 50%; transform: translateX(-50%) translateY(4px);
  background: var(--ink); color: #fff; font-size: .72rem; font-weight: 600; letter-spacing: .02em;
  padding: 6px 10px; border-radius: 8px; white-space: nowrap; opacity: 0; pointer-events: none; transition: opacity .25s, transform .25s var(--ease);
  box-shadow: var(--shadow); z-index: 5;
}
.iconbtn::before { /* Tooltip-Pfeil */
  content: ""; position: absolute; top: calc(100% + 5px); left: 50%; transform: translateX(-50%);
  border: 6px solid transparent; border-bottom-color: var(--ink); opacity: 0; transition: opacity .25s; z-index: 5;
}
.iconbtn:hover::after { opacity: 1; transform: translateX(-50%); }
.iconbtn:hover::before { opacity: 1; }
.iconbtn--phone { background: linear-gradient(180deg, var(--blue-500), var(--blue-700)); box-shadow: 0 10px 24px -8px rgba(21,101,216,.6); }
.iconbtn--phone:hover { box-shadow: var(--shadow-blue); }
.iconbtn--wa { background: linear-gradient(180deg, #2be370, #1cb854); box-shadow: 0 10px 24px -8px rgba(37,211,102,.6); }
.iconbtn--wa:hover { box-shadow: 0 18px 40px -10px rgba(37,211,102,.7); }

/* Hamburger */
.nav__toggle { display: none; width: 50px; height: 50px; border: 1px solid var(--line); border-radius: 14px; background:#fff; align-items:center; justify-content:center; box-shadow: var(--shadow-sm); transition: border-color .3s, box-shadow .3s; }
.nav__toggle:hover { border-color: var(--blue-300, var(--blue-100)); box-shadow: var(--shadow); }
.nav__toggle span { position: relative; width: 21px; height: 2px; background: var(--ink); border-radius: 2px; transition: .3s; }
.nav__toggle span::before, .nav__toggle span::after { content:""; position:absolute; left:0; width:21px; height:2px; background: var(--ink); border-radius:2px; transition:.3s; }
.nav__toggle span::before { top:-6px; } .nav__toggle span::after { top:6px; }
body.menu-open .nav__toggle span { background: transparent; }
body.menu-open .nav__toggle span::before { top:0; transform: rotate(45deg); }
body.menu-open .nav__toggle span::after { top:0; transform: rotate(-45deg); }

/* legacy phone (falls noch verwendet) */
.nav__phone { display:inline-flex; align-items:center; gap:8px; font-weight:700; color: var(--ink); }
.nav__phone svg { width:18px; height:18px; color: var(--blue-600); }

/* =========================================================
   HERO
   ========================================================= */
.hero { position: relative; overflow: hidden; background: var(--bg-blue); }
.hero::before {
  content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(1000px 560px at 88% -12%, rgba(21,101,216,.20), transparent 58%),
    radial-gradient(760px 540px at -8% 112%, rgba(255,210,0,.22), transparent 60%);
}
.hero::after { /* subtle dot grid */
  content:""; position:absolute; inset:0; z-index:0; opacity:.5;
  background-image: radial-gradient(circle, rgba(15,76,151,.10) 1px, transparent 1px);
  background-size: 30px 30px;
  -webkit-mask-image: radial-gradient(ellipse 60% 70% at 75% 30%, #000, transparent 70%);
  mask-image: radial-gradient(ellipse 60% 70% at 75% 30%, #000, transparent 70%);
}
.hero__grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(36px, 5vw, 80px); align-items: center; padding-block: clamp(56px, 8vw, 116px); }
.hero h1 { margin-bottom: 24px; }
.hero h1 .hl { color: var(--blue-700); position: relative; white-space: nowrap; }
.hero h1 .hl::after { content:""; position:absolute; left:-2px; right:-2px; bottom:.05em; height:.26em; background: linear-gradient(90deg, var(--yellow), var(--yellow-600)); z-index:-1; border-radius: 4px; opacity:.9; }
.hero .lead { max-width: 56ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.hero__trust { display: flex; flex-wrap: wrap; align-items:center; gap: 14px 28px; margin-top: 38px; padding-top: 30px; border-top: 1px solid rgba(15,76,151,.12); }
.hero__trust .tcheck { display:inline-flex; align-items:center; gap:10px; font-weight:600; font-size:.96rem; color: var(--ink-700); }
.hero__trust .tcheck svg { width:22px; height:22px; color: var(--white); background: var(--blue-600); border-radius: 50%; padding: 4px; flex:0 0 auto; box-shadow: var(--shadow-blue); }

/* Hero media — layered & framed */
.hero__media { position: relative; }
.hero__media::before { /* offset accent card */
  content:""; position:absolute; z-index:0; right:-24px; bottom:-24px; width:62%; height:64%;
  border-radius: var(--radius-lg);
  background: linear-gradient(140deg, var(--yellow), var(--yellow-600));
  box-shadow: var(--shadow-yellow);
}
.hero__media::after { /* dotted square top-left */
  content:""; position:absolute; z-index:0; left:-26px; top:-22px; width:120px; height:120px;
  background-image: radial-gradient(circle, var(--blue-500) 1.6px, transparent 1.6px);
  background-size: 16px 16px; opacity:.45; border-radius: 8px;
}
.hero__frame { position: relative; z-index: 1; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); border: 5px solid #fff; }
.hero__frame .ph { aspect-ratio: 4/5; transition: transform 1.2s var(--ease); }
.hero__media:hover .hero__frame .ph { transform: scale(1.06); }
.hero__badge {
  position:absolute; right:-14px; top:30px; z-index:3; background: linear-gradient(160deg, var(--blue-700), var(--blue-900));
  color:#fff; border-radius: 18px; padding: 16px 20px; text-align:center; box-shadow: var(--shadow-blue);
  border: 1px solid rgba(255,255,255,.12); animation: floaty 6s var(--ease) infinite reverse;
}
.hero__badge b { font-size: 2rem; display:block; color: var(--yellow); line-height:1; font-family: var(--ff-display); }
.hero__badge small { font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:#bcd0ea; }
@keyframes floaty { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(-9px); } }

/* ---------- Trust bar ---------- */
.trustbar { border-bottom: 1px solid var(--line); background:#fff; position: relative; z-index: 2; }
.trustbar .container { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap: 18px 34px; padding-block: 26px; }
.trustbar .ti { display:flex; align-items:center; gap: 13px; font-weight:600; color: var(--ink); font-size: .98rem; }
.trustbar .ti svg { width: 24px; height:24px; color: var(--blue-600); flex:0 0 auto; }
.trustbar .ti span { display:grid; place-items:center; width:46px; height:46px; border-radius:13px; background: var(--blue-50); }

/* ---------- Image placeholders ---------- */
.ph {
  position: relative; overflow: hidden; background-size: cover; background-position: center;
  background-color: var(--blue-800);
  background-image: linear-gradient(135deg, var(--blue-700), var(--blue-900));
}
.ph[data-label]::after {
  content: attr(data-label);
  position: absolute; left: 14px; bottom: 12px;
  font-size: .72rem; font-weight: 600; letter-spacing: .03em;
  color: rgba(255,255,255,.9); background: rgba(10,42,82,.5);
  padding: 5px 11px; border-radius: 8px; backdrop-filter: blur(4px);
  opacity: 0; transition: opacity .3s;
}
.ph.is-fallback[data-label]::after { opacity: 1; }
.ph.is-fallback::before {
  content:""; position:absolute; inset:0;
  background-image: radial-gradient(circle at 30% 25%, rgba(255,255,255,.14), transparent 45%);
}

/* ---------- Service overview cards ---------- */
.cards { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.card {
  background:#fff; border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px; transition: transform .4s var(--ease), box-shadow .4s, border-color .4s;
  position: relative; overflow: hidden; height: 100%;
}
.card::before { /* top accent that grows */
  content:""; position:absolute; top:0; left:0; right:0; height:4px; transform: scaleX(0); transform-origin: left;
  background: linear-gradient(90deg, var(--blue-600), var(--yellow)); transition: transform .45s var(--ease);
}
.card:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: transparent; }
.card:hover::before { transform: scaleX(1); }
.card__icon {
  width: 60px; height: 60px; border-radius: 17px; display: grid; place-items: center;
  background: var(--blue-50); color: var(--blue-700); margin-bottom: 20px;
  transition: background .4s var(--ease), color .4s, transform .4s, box-shadow .4s;
}
.card:hover .card__icon { background: linear-gradient(160deg, var(--blue-500), var(--blue-700)); color:#fff; transform: rotate(-6deg) scale(1.06); box-shadow: var(--shadow-blue); }
.card__icon svg { width: 29px; height: 29px; }
.card h3 { margin-bottom: 11px; }
.card p { font-size: .98rem; }
.card__link { margin-top: 18px; display:inline-flex; align-items:center; gap:8px; font-weight:700; color: var(--blue-700); font-size:.95rem; }
.card__link svg { width:16px; height:16px; transition: transform .3s var(--ease); }
.card:hover .card__link svg { transform: translateX(5px); }

/* Service detail cards (with image) */
.service { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; display:flex; flex-direction:column; height:100%; transition: transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.service:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: transparent; }
.service__img { aspect-ratio: 16/10; transition: transform 1s var(--ease); }
.service:hover .service__img { transform: scale(1.07); }
.service__body { padding: 28px; display:flex; flex-direction:column; flex:1; }
.service__body h3 { margin-bottom: 11px; }
.service__body p { font-size:.97rem; flex:1; }
.service__tag { align-self:flex-start; margin-bottom:14px; font-size:.7rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color: var(--blue-700); background: var(--blue-50); padding:6px 13px; border-radius:100px; border:1px solid var(--blue-100); }

/* ---------- Split / Über uns ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(36px,5vw,84px); align-items:center; }
.split--reverse .split__media { order: -1; }
.split__media { position: relative; }
.split__media .ph { aspect-ratio: 5/4; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); border: 5px solid #fff; transition: transform 1.1s var(--ease); }
.split__media:hover .ph { transform: scale(1.04); }
.split__media::after { /* dotted accent */
  content:""; position:absolute; z-index:-1; right:-24px; bottom:-24px; width:130px; height:130px;
  background-image: radial-gradient(circle, var(--blue-500) 1.6px, transparent 1.6px); background-size: 16px 16px; opacity:.4;
}
.split--reverse .split__media::after { right:auto; left:-24px; }
.featurelist { display:grid; gap: 18px; margin-top: 28px; }
.featurelist li { display:flex; gap: 15px; }
.featurelist .ic { width: 44px; height:44px; flex:0 0 auto; border-radius: 13px; background: var(--blue-50); color: var(--blue-700); display:grid; place-items:center; border:1px solid var(--blue-100); transition: transform .3s, background .3s, color .3s; }
.featurelist li:hover .ic { background: var(--blue-600); color:#fff; transform: scale(1.08); }
.featurelist .ic svg { width:21px; height:21px; }
.featurelist b { display:block; font-size:1.04rem; }
.featurelist span { color: var(--slate); font-size:.95rem; }

/* ---------- Stats ---------- */
.stats { grid-template-columns: repeat(4, 1fr); text-align:center; }
.stat { position: relative; }
.stat + .stat::before { content:""; position:absolute; left:-1px; top:14%; height:72%; width:1px; background: rgba(255,255,255,.12); }
.stat b { display:block; font-size: clamp(2.5rem, 4.4vw, 3.7rem); font-weight:800; color: var(--yellow); line-height:1; letter-spacing:-.04em; font-family: var(--ff-display); }
.stat span { display:block; margin-top: 12px; color:#c3d2e3; font-weight:600; font-size:.96rem; }
.stat--light b { color: var(--blue-700); }
.stat--light span { color: var(--slate); }

/* ---------- Why us ---------- */
.why { grid-template-columns: repeat(3, 1fr); }
.why__item { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 32px; transition: transform .4s var(--ease), box-shadow .4s, border-color .4s; position: relative; overflow: hidden; }
.why__item:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.why__item .n { font-weight:800; color: var(--slate-300); font-size: .95rem; letter-spacing:.04em; font-family: var(--ff-display); }
.why__item .ic { width:56px; height:56px; border-radius:16px; display:grid; place-items:center; background: linear-gradient(150deg, var(--blue-600), var(--blue-800)); color:#fff; margin-bottom:20px; box-shadow: var(--shadow-blue); transition: transform .4s var(--ease); }
.why__item:hover .ic { transform: rotate(-6deg) scale(1.05); }
.why__item .ic svg { width:27px; height:27px; }
.why__item h3 { margin-bottom:9px; }
.why__item p { font-size:.97rem; }

/* ---------- Testimonials ---------- */
.testi { grid-template-columns: repeat(3, 1fr); }
.testi__card { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 32px; display:flex; flex-direction:column; gap:16px; position: relative; transition: transform .4s var(--ease), box-shadow .4s; box-shadow: var(--shadow-sm); }
.testi__card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.testi__card::before { content:"“"; position:absolute; top:6px; right:24px; font-family: var(--ff-display); font-size: 5rem; line-height:1; color: var(--blue-50); font-weight:800; }
.testi__card .stars { color: var(--yellow-600); letter-spacing:2px; position: relative; z-index:1; }
.testi__card p { color: var(--ink); flex:1; position: relative; z-index:1; font-size: 1.02rem; }
.testi__who { display:flex; align-items:center; gap:13px; }
.testi__av { width:48px; height:48px; border-radius:50%; background: linear-gradient(140deg, var(--blue-500), var(--blue-800)); color:#fff; display:grid; place-items:center; font-weight:700; font-family: var(--ff-display); box-shadow: var(--shadow-blue); }
.testi__who b { display:block; font-size:.99rem; }
.testi__who small { color: var(--slate); }

/* ---------- Logos / partners ---------- */
.logos { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap: 18px 44px; }
.logos .logo { font-weight:800; color: var(--slate-300); font-size:1.12rem; letter-spacing:-.02em; font-family: var(--ff-display); transition: color .3s; }
.logos .logo:hover { color: var(--blue-600); }

/* ---------- CTA band ---------- */
.cta-band { position: relative; overflow:hidden; background: linear-gradient(125deg, var(--blue-900), var(--blue-700) 55%, var(--blue-600)); color:#fff; border-radius: var(--radius-lg); padding: clamp(40px, 5vw, 72px); box-shadow: var(--shadow-lg); }
.cta-band::before { content:""; position:absolute; right:-70px; top:-70px; width:340px; height:340px; border-radius:50%; background: radial-gradient(circle, rgba(255,210,0,.4), transparent 65%); }
.cta-band::after { content:""; position:absolute; left:-40px; bottom:-90px; width:280px; height:280px; border-radius:50%; background: rgba(255,255,255,.07); }
.cta-band .inner { position:relative; z-index:1; display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:30px; }
.cta-band h2 { color:#fff; max-width: 18ch; }
.cta-band p { color:#d6e4fb; margin-top:12px; }
.cta-band .actions { display:flex; flex-wrap:wrap; gap:14px; }

/* ---------- Career perks ---------- */
.perks { grid-template-columns: repeat(3,1fr); }
.perk { display:flex; gap:17px; align-items:flex-start; background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding:26px; transition: transform .4s var(--ease), box-shadow .4s, border-color .4s; }
.perk:hover { transform: translateY(-5px); box-shadow: var(--shadow); border-color: transparent; }
.perk .ic { width:52px; height:52px; flex:0 0 auto; border-radius:15px; background: linear-gradient(160deg, #ffe066, var(--yellow)); color: var(--ink); display:grid; place-items:center; box-shadow: var(--shadow-yellow); transition: transform .4s var(--ease); }
.perk:hover .ic { transform: rotate(-6deg) scale(1.06); }
.perk .ic svg { width:25px; height:25px; }
.perk b { display:block; margin-bottom:5px; font-size:1.05rem; }
.perk p { font-size:.94rem; }

/* ---------- Jobs ---------- */
.jobs { display:grid; gap:18px; }
.job { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding:26px 30px; transition: box-shadow .4s, transform .4s var(--ease), border-color .4s; position: relative; overflow: hidden; }
.job::before { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background: linear-gradient(180deg, var(--blue-600), var(--yellow)); transform: scaleY(0); transform-origin: top; transition: transform .4s var(--ease); }
.job:hover { box-shadow: var(--shadow); transform: translateY(-4px); border-color:transparent; }
.job:hover::before { transform: scaleY(1); }
.job__main h3 { margin-bottom:6px; }
.job__meta { display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.chip { font-size:.8rem; font-weight:600; color: var(--ink-700); background: var(--bg-soft); border:1px solid var(--line); padding:7px 13px; border-radius:100px; display:inline-flex; align-items:center; gap:6px; }
.chip svg { width:14px; height:14px; color: var(--blue-600); }

/* ---------- Forms ---------- */
.form { background:#fff; border:1px solid var(--line); border-radius: var(--radius-lg); padding: clamp(28px, 4vw, 48px); box-shadow: var(--shadow); position: relative; }
.form__grid { display:grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.field { display:flex; flex-direction:column; gap:8px; }
.field.full { grid-column: 1 / -1; }
.field label { font-weight:600; font-size:.92rem; color: var(--ink); }
.field label .req { color: #e0483d; }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: 1rem; color: var(--ink);
  border: 1.5px solid var(--line); border-radius: 13px; padding: 14px 16px; background: var(--bg-soft);
  transition: border-color .25s, box-shadow .25s, background .25s; width:100%;
}
.field textarea { min-height: 134px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--blue-500); background:#fff; box-shadow: 0 0 0 4px rgba(42,125,240,.14); }
.field .file { border: 1.6px dashed var(--slate-300); border-radius: 13px; padding: 20px; text-align:center; color: var(--slate); transition: border-color .25s, background .25s; cursor: pointer; }
.field .file:hover { border-color: var(--blue-500); background: var(--bg-blue); }
.field input[type="file"] { padding: 0; border:0; }
.form__consent { display:flex; gap:12px; align-items:flex-start; font-size:.88rem; color: var(--slate); }
.form__consent input { width:18px; height:18px; margin-top:3px; flex:0 0 auto; accent-color: var(--blue-600); }
.form__note { font-size:.85rem; color: var(--slate); margin-top:16px; }
.form__success { display:none; align-items:center; gap:12px; background: #e9f8ee; border:1px solid #bce8cb; color:#15703a; padding:16px 18px; border-radius:13px; font-weight:600; margin-bottom:18px; }
.form__success.show { display:flex; }
.form__success svg { width:22px; height:22px; flex:0 0 auto; }
.form__error { display:none; align-items:center; gap:12px; background:#fdecea; border:1px solid #f5c2bd; color:#b3261e; padding:16px 18px; border-radius:13px; font-weight:600; margin-bottom:18px; }
.form__error.show { display:flex; }
.form__error svg { width:22px; height:22px; flex:0 0 auto; }

/* ---------- MyHammer-Bewertungen / Trust-Karte ---------- */
.mh-card { max-width:940px; margin-inline:auto; display:flex; align-items:stretch; gap:clamp(24px,4vw,44px); background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(26px,4vw,44px); box-shadow:var(--shadow); }
.mh-card__rating { display:flex; align-items:center; gap:18px; padding-right:clamp(24px,4vw,44px); border-right:1px solid var(--line); flex:0 0 auto; }
.mh-badge { width:60px; height:60px; flex:0 0 auto; border-radius:16px; display:grid; place-items:center; color:var(--ink); background:linear-gradient(180deg,#ffdc33,var(--yellow)); box-shadow:var(--shadow-yellow); }
.mh-badge svg { width:30px; height:30px; }
.mh-platform { display:block; font-family:var(--ff-display); font-weight:800; font-size:1.5rem; letter-spacing:-.02em; color:var(--ink); line-height:1; }
.mh-stars { display:block; color:var(--yellow-600); letter-spacing:3px; font-size:1.15rem; margin:7px 0 6px; }
.mh-count { display:block; color:var(--slate); font-size:.95rem; }
.mh-count b { color:var(--ink); font-weight:800; }
.mh-card__body { display:flex; flex-direction:column; justify-content:center; gap:18px; flex:1 1 auto; }
.mh-points { list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.mh-points li { display:flex; align-items:flex-start; gap:10px; color:var(--ink-700); font-size:.98rem; line-height:1.5; }
.mh-points svg { width:20px; height:20px; flex:0 0 auto; color:var(--blue-600); margin-top:1px; }
.mh-card__body .btn { align-self:flex-start; }
@media (max-width:760px){
  .mh-card { flex-direction:column; text-align:center; }
  .mh-card__rating { flex-direction:column; padding-right:0; padding-bottom:24px; border-right:0; border-bottom:1px solid var(--line); justify-content:center; }
  .mh-stars { letter-spacing:4px; }
  .mh-points { max-width:420px; margin-inline:auto; }
  .mh-card__body .btn { align-self:stretch; justify-content:center; }
}

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1.1fr; gap: clamp(32px,4vw,60px); align-items:start; }
.infocard { background:#fff; border:1px solid var(--line); border-radius: var(--radius); padding: 30px; display:grid; gap:20px; box-shadow: var(--shadow-sm); }
.infoitem { display:flex; gap:15px; align-items:flex-start; }
.infoitem .ic { width:50px; height:50px; flex:0 0 auto; border-radius:14px; background: var(--blue-50); color: var(--blue-700); display:grid; place-items:center; border:1px solid var(--blue-100); transition: background .3s, color .3s; }
.infoitem:hover .ic { background: var(--blue-600); color:#fff; }
.infoitem .ic svg { width:22px; height:22px; }
.infoitem b { display:block; font-size:.8rem; text-transform:uppercase; letter-spacing:.1em; color: var(--slate); margin-bottom:4px; }
.infoitem a, .infoitem span { font-weight:600; color: var(--ink); font-size:1.05rem; }
.map { border-radius: var(--radius); overflow:hidden; border:5px solid #fff; box-shadow: var(--shadow); }
.map iframe { display:block; width:100%; height:340px; border:0; filter: grayscale(.15) contrast(1.05); }
/* Google-Maps-Einwilligung (2-Klick-Lösung) */
.map-consent { height:340px; display:grid; place-items:center; text-align:center; padding:28px; background: linear-gradient(135deg, var(--blue-50), #fff); }
.map-consent__inner { max-width:430px; }
.map-consent svg { width:42px; height:42px; color: var(--blue-600); margin-bottom:14px; }
.map-consent__title { font-family: var(--ff-display); font-weight:700; font-size:1.18rem; color: var(--ink); margin-bottom:8px; }
.map-consent__text { color: var(--slate); font-size:.95rem; line-height:1.6; margin-bottom:18px; }
.map-consent__text a { color: var(--blue-600); }
.map-consent__text a:hover { color: var(--blue-700); }
.map-consent__btn { cursor:pointer; }
/* Cookie-/Datenschutz-Hinweis */
.cookie-banner { position: fixed; left:16px; bottom:16px; z-index:140; width: calc(100% - 32px); max-width:440px; background:#fff; border:1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); padding:20px 22px; transform: translateY(160%); opacity:0; transition: transform .5s cubic-bezier(.2,.8,.2,1), opacity .5s; }
.cookie-banner.show { transform:none; opacity:1; }
.cookie-banner__text { color: var(--ink-700); font-size:.92rem; line-height:1.6; margin-bottom:16px; }
.cookie-banner__text a { color: var(--blue-600); }
.cookie-banner__text a:hover { color: var(--blue-700); }
.cookie-banner__actions { display:flex; gap:10px; flex-wrap:wrap; }
.cookie-banner__actions .btn { cursor:pointer; }
@media (max-width:520px){ .cookie-banner { left:12px; bottom:12px; width: calc(100% - 24px); padding:18px; } }

/* ---------- Page hero ---------- */
.pagehero { position:relative; background: linear-gradient(135deg, var(--blue-900), var(--ink)); color:#fff; overflow:hidden; }
.pagehero::before { content:""; position:absolute; inset:0; background: radial-gradient(760px 420px at 82% -20%, rgba(21,101,216,.5), transparent 60%), radial-gradient(540px 420px at 0% 120%, rgba(255,210,0,.16), transparent 60%); }
.pagehero::after { content:""; position:absolute; inset:0; opacity:.5; background-image: linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px); background-size: 54px 54px; -webkit-mask-image: radial-gradient(ellipse 70% 80% at 70% 30%, #000, transparent 75%); mask-image: radial-gradient(ellipse 70% 80% at 70% 30%, #000, transparent 75%); }
.pagehero .container { position:relative; z-index:1; padding-block: clamp(64px, 9vw, 116px); }
.pagehero h1 { color:#fff; max-width: 19ch; }
.pagehero p { color:#cddcef; margin-top:20px; max-width: 60ch; font-size: 1.14rem; }
.crumbs { display:flex; gap:8px; align-items:center; font-size:.88rem; color:#9fb4cd; margin-bottom:20px; }
.crumbs a:hover { color:#fff; }
.crumbs svg { width:14px; height:14px; opacity:.6; }

/* ---------- Accordion ---------- */
.acc { background:#fff; border:1px solid var(--line); border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow-sm); }
.acc__item + .acc__item { border-top: 1px solid var(--line); }
.acc__q { width:100%; text-align:left; background:none; border:0; padding: 24px 26px; display:flex; align-items:center; justify-content:space-between; gap:16px; font-weight:700; font-size:1.06rem; color: var(--ink); font-family: var(--ff-display); transition: color .25s; }
.acc__q:hover { color: var(--blue-700); }
.acc__q .pm { width:32px; height:32px; flex:0 0 auto; border-radius:50%; background: var(--blue-50); color: var(--blue-700); display:grid; place-items:center; transition: transform .35s var(--ease), background .3s, color .3s; }
.acc__q .pm svg { width:16px; height:16px; }
.acc__item.open .acc__q .pm { background: var(--blue-600); color:#fff; transform: rotate(135deg); }
.acc__a { max-height:0; overflow:hidden; transition: max-height .4s var(--ease); }
.acc__a p { padding: 0 26px 24px; color: var(--ink-700); }

/* ---------- Footer ---------- */
.footer { background: linear-gradient(180deg, var(--ink), #0a1422); color:#aebfd1; padding-top: clamp(64px,8vw,100px); position: relative; overflow: hidden; }
.footer::before { content:""; position:absolute; top:0; left:0; right:0; height:1px; background: linear-gradient(90deg, transparent, var(--blue-500), var(--yellow), transparent); opacity:.5; }
.footer__top { display:grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 44px; padding-bottom: 52px; border-bottom:1px solid rgba(255,255,255,.1); }
.footer h4 { color:#fff; font-size:1.02rem; margin-bottom:20px; letter-spacing:.01em; }
.footer .brand { margin-bottom:18px; }
.footer .brand__text { color:#fff; }
.footer .brand__text b { color: var(--yellow); }
.footer .brand__text small { color:#8ea2b8; }
.footer p { color:#9fb1c6; font-size:.95rem; }
.footer__links li + li { margin-top:12px; }
.footer__links a { color:#aebfd1; font-size:.96rem; transition: color .25s, padding .25s; display:inline-block; }
.footer__links a:hover { color:#fff; padding-left:6px; }
.footer__contact li { display:flex; gap:12px; margin-bottom:14px; font-size:.96rem; color:#c2d2e4; }
.footer__contact svg { width:18px; height:18px; color: var(--yellow); flex:0 0 auto; margin-top:3px; }
.footer__cta { background: linear-gradient(160deg, rgba(255,255,255,.07), rgba(255,255,255,.03)); border:1px solid rgba(255,255,255,.1); border-radius: var(--radius); padding:26px; }
.footer__cta p { color:#cdddee; margin-bottom:16px; }
.footer__bottom { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:14px; padding-block: 28px; font-size:.88rem; color:#8298b0; }
.footer__bottom .legal { display:flex; flex-wrap:wrap; gap:20px; }
.footer__bottom a:hover { color:#fff; }

/* ---------- Floating CTA (mobil) ---------- */
.float-cta { position: fixed; left:14px; right:14px; bottom:14px; z-index:90; display:none; gap:10px; }
.float-cta .btn { flex:1; box-shadow: var(--shadow-lg); }

/* ---------- Schwebender WhatsApp-Button (unten links) ---------- */
.wa-fab {
  position: fixed; left: 30px; bottom: 30px; z-index: 95;
  display: inline-flex; align-items: center; gap: 0; height: 62px; padding: 0;
  background: linear-gradient(160deg, #2be370, #25d366 55%, #1cb854); color: #fff;
  border-radius: 100px; box-shadow: 0 12px 30px -8px rgba(37,211,102,.45);
  overflow: hidden; max-width: 62px;
  /* Startzustand: ausgeblendet, leicht nach unten versetzt - erscheint per JS nach 25 % Scroll */
  opacity: 0; visibility: hidden; transform: translateY(24px);
  transition: max-width .55s var(--ease), box-shadow .35s,
              transform .5s var(--ease-out), opacity .5s var(--ease-out), visibility .5s;
}
.wa-fab.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.wa-fab__ic { width: 62px; height: 62px; flex: 0 0 auto; display: grid; place-items: center; }
.wa-fab__ic svg { width: 32px; height: 32px; }
.wa-fab__label { white-space: nowrap; font-weight: 700; font-size: .98rem; padding-right: 24px; opacity: 0; transition: opacity .35s; }
.wa-fab::before { /* Puls-Ring */
  content: ""; position: absolute; left: 0; top: 0; width: 62px; height: 62px; border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(37,211,102,.55); animation: waPulse 2.4s var(--ease) infinite;
}
.wa-fab.is-visible:hover { max-width: 360px; box-shadow: 0 20px 44px -12px rgba(37,211,102,.6); transform: translateY(-3px); }
.wa-fab:hover .wa-fab__label { opacity: 1; }
@keyframes waPulse { 0%{ box-shadow: 0 0 0 0 rgba(37,211,102,.5); } 70%{ box-shadow: 0 0 0 18px rgba(37,211,102,0); } 100%{ box-shadow: 0 0 0 0 rgba(37,211,102,0); } }
/* Tablet & kleiner: links, oberhalb der unteren CTA-Leiste (.float-cta ab ≤1240px sichtbar) */
@media (max-width: 1240px) { .wa-fab { left: 20px; bottom: 86px; } }
@media (max-width: 1080px) { .wa-fab { height: 56px; max-width: 56px; } .wa-fab__ic { width: 56px; height: 56px; } .wa-fab::before { width: 56px; height: 56px; } }
/* Mobile / Smartphones: kein schwebender WhatsApp-Button (Header-WhatsApp bleibt) */
@media (max-width: 640px) { .wa-fab { display: none !important; } }

/* ---------- Scroll reveal ---------- */
.reveal { opacity:0; transform: translateY(30px); transition: opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.in { opacity:1; transform:none; }
.reveal.d1 { transition-delay:.09s; } .reveal.d2 { transition-delay:.18s; } .reveal.d3 { transition-delay:.27s; }
.reveal.d4 { transition-delay:.36s; } .reveal.d5 { transition-delay:.45s; } .reveal.d6 { transition-delay:.54s; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
/* Kompakt-Stufe: volle Navigation passt sauber bis ~1240px (1280/1366-Laptops) */
@media (max-width: 1440px) {
  .nav { gap: clamp(12px, 1.6vw, 28px); }
  .brand__mark { width: 44px; height: 44px; }
  .site-header.scrolled .brand__mark { width: 40px; height: 40px; }
  .brand__text { font-size: 1.04rem; }
  .nav__links a { padding: 9px 12px; font-size: .92rem; }
  .nav__links a::after { left: 12px; right: 12px; }
  .nav__cta { gap: 12px; }
  .nav__cta::before { display: none; }
  .iconbtn { width: 44px; height: 44px; }
  .iconbtn svg { width: 20px; height: 20px; }
  .nav__cta .btn { padding: 13px 20px; font-size: .93rem; }
}

/* Hamburger-Modus: Navigation klappt direkt unter den Header */
@media (max-width: 1240px) {
  .nav__toggle { display: flex; }
  .brand__text { font-size: 1.18rem; }
  .brand__mark, .site-header.scrolled .brand__mark { width: 46px; height: 46px; }
  .iconbtn { width: 46px; height: 46px; }
  .iconbtn svg { width: 21px; height: 21px; }
  .nav__cta .btn { padding: 15px 24px; font-size: .98rem; }
  .nav__links {
    position: absolute; top: 100%; left: 0; right: 0; margin: 0;
    flex-direction: column; align-items: stretch; gap: 2px;
    background:#fff; padding: 16px var(--gutter) 28px;
    border-top: 1px solid var(--line); border-bottom:1px solid var(--line);
    box-shadow: var(--shadow); transform: translateY(-12px); opacity:0; pointer-events:none;
    transition: transform .35s var(--ease), opacity .35s;
  }
  body.menu-open .nav__links { display:flex; transform:none; opacity:1; pointer-events:auto; }
  .nav__links a { padding: 15px 16px; font-size:1.08rem; border-radius:12px; }
  .nav__links a::after { display:none; }
  .nav__links a:hover, .nav__links a[aria-current="page"] { background: var(--blue-50); }
  .nav__cta::before { display: none; }
  .float-cta { display:flex; }
}
@media (max-width: 760px) {
  .topbar { display:none; }
}
/* Auf kleinen Phones: Header-CTA weicht den Kontakt-Icons (Conversion läuft über die untere Leiste) */
@media (max-width: 640px) {
  .nav__cta .btn--primary { display: none; }
  .nav__cta { gap: 8px; }
  .iconbtn { width: 44px; height: 44px; }
}
@media (max-width: 880px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__media { max-width: 440px; margin-inline:auto; width:100%; }
  .split, .contact-grid { grid-template-columns: 1fr; }
  .split--reverse .split__media { order: 0; }
  .stats { grid-template-columns: repeat(2,1fr); gap:36px; }
  .stat + .stat::before { display:none; }
  .why, .testi, .perks { grid-template-columns: 1fr; }
  .form__grid { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr 1fr; gap:34px; }
  .cta-band .inner { flex-direction: column; align-items:flex-start; }
}
@media (max-width: 560px) {
  .footer__top { grid-template-columns: 1fr; }
  .hero__actions .btn, .cta-band .actions .btn { width:100%; }
  .job { flex-direction:column; align-items:flex-start; }
  .job .btn { width:100%; }
  .brand__text { font-size: 1.12rem; }
  .hero__badge { right: 4px; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior:auto !important; animation: none !important; }
  .reveal { opacity:1 !important; transform:none !important; transition:none !important; }
}

/* ---------- Referenz-Galerie (Einblicke in unsere Arbeit) ---------- */
.gallery { display:grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 22px; }
.shot {
  position: relative; overflow: hidden; background:#fff;
  border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: transform .4s var(--ease), box-shadow .4s, border-color .4s;
}
.shot:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.shot .ph { aspect-ratio: 4/3; transition: transform 1s var(--ease); }
.shot:hover .ph { transform: scale(1.06); }
.shot figcaption {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
  padding: 26px 16px 13px; color:#fff; font-size: .86rem; font-weight: 600; letter-spacing:.01em;
  background: linear-gradient(to top, rgba(10,32,60,.82), rgba(10,32,60,0));
  opacity: 0; transform: translateY(8px); transition: opacity .3s var(--ease), transform .3s var(--ease);
}
.shot:hover figcaption, .shot:focus-within figcaption { opacity: 1; transform: none; }

/* ====================================================================
   Premium Trust-Sektion (.tp) — Glassmorphism, Gold-Akzente, Glow
   ==================================================================== */
.tp {
  position: relative; overflow: hidden; isolation: isolate;
  padding-block: clamp(66px, 9vw, 118px);
  background: linear-gradient(160deg, #0F172A 0%, #1E293B 100%);
  color: #e2e8f0;
}
/* dezentes Punktmuster, oben weich ausmaskiert */
.tp::before {
  content: ""; position: absolute; inset: 0; z-index: -2;
  background-image: radial-gradient(circle, rgba(255,255,255,.055) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(ellipse 85% 60% at 50% 0%, #000 28%, transparent 78%);
          mask-image: radial-gradient(ellipse 85% 60% at 50% 0%, #000 28%, transparent 78%);
  opacity: .6;
}
/* oberer, warmer Lichtschein */
.tp::after {
  content: ""; position: absolute; left: 50%; top: -140px; z-index: -2;
  width: min(780px, 90%); height: 360px; transform: translateX(-50%);
  border-radius: 50%; filter: blur(22px);
  background: radial-gradient(circle, rgba(245,184,0,.16), transparent 70%);
}
/* weiche Glow-Orbs */
.tp__orb { position: absolute; z-index: -1; border-radius: 50%; filter: blur(64px); pointer-events: none; }
.tp__orb--a { width: 440px; height: 440px; left: -130px; top: 8%;  background: radial-gradient(circle, rgba(245,184,0,.20), transparent 65%); }
.tp__orb--b { width: 500px; height: 500px; right: -150px; bottom: -12%; background: radial-gradient(circle, rgba(42,125,240,.16), transparent 65%); }

/* Kopfbereich */
.tp__head { text-align: center; max-width: 760px; margin: 0 auto clamp(42px, 5vw, 66px); }
.tp__badge {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 9px 18px; border-radius: 100px;
  font-size: .76rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: #ffe486;
  background: rgba(245,184,0,.08);
  border: 1px solid rgba(245,184,0,.30);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.tp__badge svg { width: 16px; height: 16px; color: var(--yellow); }
.tp__head h2 { color: #fff; font-size: clamp(1.8rem, 3.6vw, 2.9rem); margin-top: 22px; line-height: 1.12; }
.tp__hl { background: linear-gradient(180deg, #ffdc33, var(--yellow-600)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.tp__sub { margin-top: 18px; color: #94a3b8; font-size: clamp(1rem, 1.5vw, 1.12rem); line-height: 1.6; }

/* Karten-Grid: 4 / 2 / 1 */
.tp__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(18px, 2vw, 26px); }

/* Glassmorphism-Karte */
.tp__card {
  position: relative; overflow: hidden; isolation: isolate;
  padding: clamp(26px, 2.4vw, 36px) clamp(22px, 2vw, 30px);
  border-radius: 22px;
  background: linear-gradient(165deg, rgba(255,255,255,.09), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.10);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  box-shadow: 0 18px 40px -22px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.10);
  transition: transform .5s var(--ease), border-color .5s var(--ease), box-shadow .5s var(--ease);
}
.tp__card:hover {
  transform: translateY(-10px);
  border-color: rgba(245,184,0,.45);
  box-shadow: 0 42px 70px -24px rgba(0,0,0,.75), 0 0 52px -12px rgba(245,184,0,.40);
}
/* Hover-Glow + oberer Akzentstrich */
.tp__glow { position: absolute; inset: 0; z-index: -1; opacity: 0; transition: opacity .5s var(--ease);
  background: radial-gradient(120% 80% at 50% 0%, rgba(245,184,0,.20), transparent 60%); }
.tp__card:hover .tp__glow { opacity: 1; }
.tp__card::before { content: ""; position: absolute; top: 0; left: 24px; right: 24px; height: 2px;
  background: linear-gradient(90deg, transparent, var(--yellow), transparent); opacity: .45; transition: opacity .5s var(--ease); }
.tp__card:hover::before { opacity: 1; }

/* Icon-Kachel */
.tp__icon {
  display: grid; place-items: center; width: 58px; height: 58px; border-radius: 16px;
  margin-bottom: 22px; color: var(--yellow);
  background: linear-gradient(150deg, rgba(245,184,0,.22), rgba(245,184,0,.06));
  border: 1px solid rgba(245,184,0,.30);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 8px 20px -10px rgba(245,184,0,.5);
  transition: transform .5s var(--ease);
}
.tp__card:hover .tp__icon { transform: translateY(-2px) scale(1.06); }
.tp__icon svg { width: 28px; height: 28px; }

/* Zahl, Titel, Vertrauenssatz */
.tp__num {
  font-family: var(--ff-display); font-weight: 800; line-height: 1; letter-spacing: -.04em;
  font-size: clamp(2.4rem, 3.6vw, 3.3rem);
  background: linear-gradient(180deg, #ffffff 0%, #ffe486 58%, var(--yellow-600) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.tp__title { color: #fff; font-size: 1.18rem; font-weight: 700; margin-top: 12px; letter-spacing: -.01em; }
.tp__text { color: #94a3b8; font-size: .95rem; line-height: 1.55; margin-top: 8px; }

@media (max-width: 980px) { .tp__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .tp__grid { grid-template-columns: 1fr; } .tp__head h2 br { display: none; } }

/* =========================================================
   MOBILE-FEINSCHLIFF — ausschließlich Smartphones/Tablets
   Alle Regeln stehen in Media Queries → Desktop bleibt 1:1 unverändert.
   ========================================================= */

/* ---- Tablet-Hochformat & Smartphones (≤640px) ---- */
@media (max-width: 640px) {
  /* Abschnitts-Rhythmus kompakter, bleibt großzügig */
  .section { padding-block: clamp(54px, 12vw, 88px); }
  .section-head { margin-bottom: clamp(28px, 7vw, 44px); }

  /* HERO: große Headline passend umbrechen statt überlaufen */
  .hero__grid { padding-block: clamp(38px, 9vw, 64px); gap: 32px; }
  .hero h1 { font-size: clamp(2rem, 8.4vw, 2.8rem); line-height: 1.15; margin-bottom: 18px; }
  .hero h1 .hl { white-space: normal; }        /* Kernfix: vorher nowrap → Überlauf */
  .hero h1 .hl::after { display: none; }        /* gelber Unterstrich nur Desktop (umbruchsicher) */
  .hero .lead { font-size: 1.04rem; max-width: none; }
  .hero__actions { margin-top: 26px; }
  .hero__trust { margin-top: 24px; padding-top: 22px; gap: 12px 20px; }
  .hero__trust .tcheck { font-size: .92rem; }

  /* HEADER/NAVI: Marke + Kontakt-Icons sauber & gut tappbar */
  .nav { gap: 10px; padding-block: 15px; }
  .site-header.scrolled .nav { padding-block: 11px; }
  .brand { gap: 10px; }
  .brand__mark, .site-header.scrolled .brand__mark { width: 42px; height: 42px; }
  .brand__mark img { width: 30px; }
  .brand__text { font-size: 1rem; }
  .brand__text small { font-size: .55rem; letter-spacing: .07em; margin-top: 4px; }
  .nav__cta { gap: 9px; }
  .iconbtn { width: 44px; height: 44px; }       /* ≥44px = komfortable Tap-Fläche */
  .iconbtn svg { width: 20px; height: 20px; }
  .nav__toggle { width: 46px; height: 46px; }
  .nav__links a { padding: 16px 16px; font-size: 1.06rem; }  /* große Tap-Ziele im Menü */

  /* PAGE-HERO (Unterseiten) passend skalieren */
  .pagehero .container { padding-block: clamp(52px, 11vw, 92px); }
  .pagehero h1 { font-size: clamp(2rem, 8.2vw, 2.7rem); }
  .pagehero p { font-size: 1.05rem; margin-top: 16px; }

  /* Trust-Leiste mittig statt auseinandergezogen */
  .trustbar .container { justify-content: center; gap: 14px 22px; padding-block: 22px; }
  .trustbar .ti { font-size: .94rem; }
}

/* ---- Smartphones (≤560px) ---- */
@media (max-width: 560px) {
  /* Karten-Raster strikt einspaltig — verhindert Überlauf der minmax()-Raster
     (auch der Inline-Styles auf Leistungen/Referenzen via !important) */
  .grid.cards, .cards { grid-template-columns: 1fr !important; }
  .gallery { grid-template-columns: 1fr; }

  /* Mehr Inhaltsbreite durch kompaktere Karten-Innenabstände */
  .card, .why__item, .testi__card { padding: 26px; }
  .service__body { padding: 24px; }
  .perk { padding: 22px; }

  /* HERO-Medien aufräumen (dezente Deko reduzieren, kein Beschnitt) */
  .hero__media { max-width: 360px; }
  .hero__media::after { display: none; }
  .hero__media::before { right: -10px; bottom: -10px; width: 56%; height: 56%; }
  .hero__badge { padding: 12px 16px; }
  .hero__badge b { font-size: 1.7rem; }
  .split__media::after { display: none; }

  /* Premium-Trust & CTA-Band kompakter */
  .tp { padding-block: clamp(52px, 13vw, 84px); }
  .tp__card { padding: 26px 22px; }
  .cta-band { padding: 32px 24px; }
  .btn--lg { padding: 18px 26px; }
}

/* ---- Sehr kleine Geräte (≤380px, z. B. iPhone SE / Galaxy S-mini) ---- */
@media (max-width: 380px) {
  .container { padding-inline: 16px; }          /* etwas mehr nutzbare Breite */
  .brand__mark, .site-header.scrolled .brand__mark { width: 38px; height: 38px; }
  .brand__mark img { width: 27px; }
  .brand__text { font-size: .9rem; }
  .brand__text small { font-size: .5rem; letter-spacing: .05em; }
  .nav__cta { gap: 7px; }
  .iconbtn { width: 42px; height: 42px; }
  .nav__toggle { width: 44px; height: 44px; }
  .hero h1 { font-size: clamp(1.8rem, 9vw, 2.2rem); }
  .tp__num { font-size: clamp(2.1rem, 11vw, 2.7rem); }
}

/* ---- Kontakt-Eintrag im Navi-Menü: standardmäßig versteckt (Desktop/Tablet unverändert) ---- */
.nav__contact-item { display: none; }
.nav__contact-item a { display: flex; align-items: center; gap: 12px; }
.nav__contact-item svg { width: 20px; height: 20px; color: var(--blue-600); flex: 0 0 auto; }

/* ≤360px: Telefon-Icon wandert aus dem Header ins Menü (mehr Platz im Header) */
@media (max-width: 360px) {
  .nav__cta .iconbtn--phone { display: none; }
  .nav__contact-item { display: block; border-top: 1px solid var(--line); margin-top: 6px; padding-top: 4px; }
  .nav__contact-item a { color: var(--blue-700); font-weight: 700; }
}

/* ============================================================
   Video-Showcase  ("Qualität, die man sehen kann")
   ============================================================ */
.vshow { position: relative; overflow: hidden; padding: clamp(64px, 9vw, 122px) 0;
  background: radial-gradient(125% 120% at 50% -10%, var(--blue-800) 0%, var(--blue-900) 58%, #061734 100%); color: #eaf2ff; }
.vshow__orb { position: absolute; border-radius: 50%; filter: blur(72px); opacity: .55; pointer-events: none; z-index: 0; }
.vshow__orb--a { width: 460px; height: 460px; top: -170px; left: -130px; background: radial-gradient(circle, rgba(42,125,240,.6), transparent 70%); }
.vshow__orb--b { width: 540px; height: 540px; bottom: -220px; right: -150px; background: radial-gradient(circle, rgba(255,210,0,.16), transparent 70%); }
.vshow .container { position: relative; z-index: 1; }

.vshow__head { text-align: center; max-width: 780px; margin: 0 auto clamp(42px, 5vw, 66px); }
.vshow__badge { display: inline-flex; align-items: center; gap: 9px; padding: 9px 18px; border-radius: 999px;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16); -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  font-weight: 600; font-size: .9rem; letter-spacing: .015em; color: #dbe9ff; }
.vshow__badge svg { width: 18px; height: 18px; color: var(--yellow); }
.vshow__head h2 { font-family: var(--ff-display); font-weight: 800; font-size: clamp(2rem, 4.6vw, 3.15rem); line-height: 1.08; margin: 20px 0 0; color: #fff; letter-spacing: -.01em; }
.vshow__hl { color: var(--yellow); }
.vshow__sub { margin: 18px auto 0; font-size: 1.07rem; line-height: 1.72; color: #b6cae6; }

.vshow__grid { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(20px, 3vw, 38px); }

.vcard { position: relative; margin: 0; flex: 0 1 384px; max-width: 420px;
  border-radius: var(--radius-lg); overflow: hidden;
  background: linear-gradient(162deg, #103662, #0a2042);
  border: 1px solid rgba(255,255,255,.09);
  box-shadow: 0 42px 92px -32px rgba(0,0,0,.72);
  transition: transform .55s var(--ease-out), box-shadow .55s var(--ease-out), border-color .55s var(--ease-out); }
.vcard:hover { transform: translateY(-9px); border-color: rgba(120,180,255,.35);
  box-shadow: 0 58px 120px -30px rgba(0,0,0,.8), 0 22px 60px -22px rgba(21,101,216,.55); }

.vcard__media { position: relative; aspect-ratio: 9 / 16; overflow: hidden;
  background: linear-gradient(160deg, #12376a 0%, #0a1f3d 100%); }
.vcard__media::before { /* dezenter Lade-Puls, bis das Video läuft */
  content: ""; position: absolute; inset: 0; z-index: 0;
  background: linear-gradient(110deg, rgba(255,255,255,0) 35%, rgba(255,255,255,.05) 50%, rgba(255,255,255,0) 65%);
  background-size: 220% 100%; animation: vcardLoad 1.8s linear infinite; }
.vcard.is-playing .vcard__media::before { display: none; }
@keyframes vcardLoad { from { background-position: 120% 0; } to { background-position: -120% 0; } }
.vcard__media::after { /* Verlauf unten für Lesbarkeit des Buttons */
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 42%; z-index: 2; pointer-events: none;
  background: linear-gradient(to top, rgba(4,12,26,.78), rgba(4,12,26,0)); }
.vcard__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 1; }

.vcard__shine { position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background: linear-gradient(115deg, transparent 32%, rgba(255,255,255,.20) 47%, transparent 62%);
  transform: translateX(-130%); transition: transform 1s var(--ease-out); }
.vcard:hover .vcard__shine { transform: translateX(130%); }

.vcard__tag { position: absolute; top: 14px; left: 14px; z-index: 3; display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 13px; border-radius: 999px; font-size: .8rem; font-weight: 700; letter-spacing: .01em;
  color: #06203f; background: var(--yellow); box-shadow: 0 8px 20px -8px rgba(0,0,0,.5); }
.vcard__tag svg { width: 14px; height: 14px; }

.vcard__sound { position: absolute; right: 14px; bottom: 14px; z-index: 4; display: inline-flex; align-items: center; gap: 8px;
  height: 46px; padding: 0 17px 0 14px; cursor: pointer; border-radius: 999px; color: #fff;
  background: rgba(8,20,40,.5); border: 1px solid rgba(255,255,255,.28); -webkit-backdrop-filter: blur(9px); backdrop-filter: blur(9px);
  font: 700 .9rem/1 var(--ff); box-shadow: 0 10px 24px -8px rgba(0,0,0,.55);
  transition: background .25s var(--ease), transform .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease); }
.vcard__sound:hover { background: rgba(21,101,216,.9); transform: translateY(-2px); border-color: rgba(255,255,255,.5); }
.vcard__sound:focus-visible { outline: 3px solid var(--yellow); outline-offset: 2px; }
.vcard__sound.is-on { background: var(--yellow); color: #06203f; border-color: transparent; }
.vcard__sound svg { width: 20px; height: 20px; flex: 0 0 auto; }
.vcard__sound .i-on { display: none; }
.vcard__sound.is-on .i-on { display: block; }
.vcard__sound.is-on .i-off { display: none; }

.vcard__cap { padding: 17px 20px 21px; position: relative; z-index: 1; }
.vcard__cap h3 { font-family: var(--ff-display); font-weight: 700; font-size: 1.13rem; color: #fff; margin: 0; }
.vcard__cap p { margin: 6px 0 0; color: #a7bedd; font-size: .95rem; line-height: 1.55; }

.vshow__trust { margin-top: clamp(38px, 5vw, 58px); display: flex; flex-wrap: wrap; justify-content: center;
  align-items: center; gap: 14px 34px; }
.vshow__trust span { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; font-size: 1rem; color: #cfe0f6; }
.vshow__trust svg { width: 21px; height: 21px; color: var(--yellow); flex: 0 0 auto; }

@media (max-width: 560px) {
  .vcard { flex-basis: min(84vw, 340px); max-width: 380px; }
  .vshow__trust { gap: 12px 22px; }
  .vshow__trust span { font-size: .94rem; }
}
@media (prefers-reduced-motion: reduce) {
  .vcard, .vcard__shine, .vcard__sound { transition: none; }
  .vcard__shine { display: none; }
  .vcard__media::before { animation: none; }
}

/* ====== Video: Vergrössern-Button + Lightbox ====== */
.vcard__zoom { position: absolute; top: 14px; right: 14px; z-index: 4; width: 42px; height: 42px;
  display: inline-flex; align-items: center; justify-content: center; cursor: pointer; border-radius: 50%;
  color: #fff; background: rgba(8,20,40,.5); border: 1px solid rgba(255,255,255,.28);
  -webkit-backdrop-filter: blur(9px); backdrop-filter: blur(9px); box-shadow: 0 10px 24px -8px rgba(0,0,0,.55);
  transition: background .25s var(--ease), transform .25s var(--ease), border-color .25s var(--ease); }
.vcard__zoom:hover { background: rgba(21,101,216,.9); transform: translateY(-2px); border-color: rgba(255,255,255,.5); }
.vcard__zoom:focus-visible { outline: 3px solid var(--yellow); outline-offset: 2px; }
.vcard__zoom svg { width: 19px; height: 19px; }

.vlb { position: fixed; inset: 0; z-index: 1000; display: none; align-items: center; justify-content: center;
  padding: 24px; background: rgba(4,10,22,.9); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  opacity: 0; transition: opacity .3s var(--ease); }
.vlb.is-open { display: flex; opacity: 1; }
.vlb__inner { position: relative; width: auto; max-width: min(92vw, 460px); }
.vlb__video { display: block; width: 100%; max-height: 86vh; border-radius: 18px; background: #000;
  box-shadow: 0 40px 100px -20px rgba(0,0,0,.8); }
.vlb__close { position: absolute; top: -14px; right: -14px; width: 44px; height: 44px; border: none; border-radius: 50%;
  cursor: pointer; background: #fff; color: #0e1a29; display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 28px -8px rgba(0,0,0,.6); transition: transform .2s var(--ease); }
.vlb__close:hover { transform: scale(1.08); }
.vlb__close svg { width: 22px; height: 22px; }
@media (max-width: 560px) { .vlb__close { top: 8px; right: 8px; } }
@media (prefers-reduced-motion: reduce) { .vcard__zoom, .vlb, .vlb__close { transition: none; } }

/* ============================================================
   Mobile-Feinschliff (additiv - greift nur ≤768px, Desktop unverändert)
   ============================================================ */
@media (max-width: 768px) {
  /* Kein horizontales Scrollen, nichts ragt heraus */
  html, body { max-width: 100%; overflow-x: clip; }

  /* Lange Wörter & Überschriften sauber umbrechen statt abschneiden */
  h1, h2, h3, h4, p, li, a, figcaption, .lead, .eyebrow { overflow-wrap: break-word; }
  h1, h2, h3, .tp__head h2, .vshow__head h2 { -webkit-hyphens: auto; hyphens: auto; }

  /* E-Mail-Adressen / Kontaktdaten dürfen nicht aus dem Bild laufen */
  .infoitem a, .infoitem span { overflow-wrap: anywhere; word-break: break-word; font-size: 1rem; }
  .footer__contact li, .footer__contact a { overflow-wrap: anywhere; word-break: break-word; }
  .topbar__links a { overflow-wrap: anywhere; }

  /* "Über 1.000 Kunden setzen auf Blitzgebäudereinigung" - Langwort umbrechen */
  .tp__head h2, .tp__hl { overflow-wrap: break-word; }

  /* Etwas mehr Innenabstand links/rechts auf kleinen Screens */
  .container { padding-inline: 20px; }

  /* Karten/Formulare: angenehmere mobile Abstände */
  .form { padding: clamp(22px, 6vw, 30px); }
  .infocard { padding: 22px; }

  /* Sticky-CTA-Leiste ("Anrufen"/"Angebot anfragen") soll Inhalte nicht verdecken:
     nur auf Seiten mit .float-cta unten Platz schaffen */
  body:has(.float-cta) .footer__bottom { padding-bottom: 96px; }
}

/* Fallback ohne :has() - schmale Geräte bekommen den Freiraum in jedem Fall */
@media (max-width: 600px) {
  .footer__bottom { padding-bottom: 92px; }
}

@media (max-width: 380px) {
  .container { padding-inline: 17px; }
  .infoitem a, .infoitem span { font-size: .95rem; }
  .footer__bottom { padding-bottom: 98px; }
}

/* ============================================================
   Video-Bereich - schlichte, robuste HTML5-Videos (native Controls)
   Ersetzt die früheren Overlay-Karten. Direkt im .vcard (figure).
   ============================================================ */
.vcard__video {
  position: static;            /* hebt altes position:absolute auf */
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 9 / 16;        /* Hochformat-Videos, kein Springen vor dem Laden */
  object-fit: cover;
  background: #0a1f3d;
  border: 0;
}
/* nicht mehr genutzte Overlay-Elemente sicher ausblenden (falls Cache/Reste) */
.vcard__shine, .vcard__tag, .vcard__sound, .vcard__zoom, .vcard__media::before, .vcard__media::after { display: none !important; }

/* ============================================================
   Video-Cards FINAL: Autoplay (stumm) + schlanker Ton-Button
   ============================================================ */
.vcard__frame { position: relative; aspect-ratio: 9 / 16; overflow: hidden; background: #0a1f3d; }
.vcard__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; border: 0; aspect-ratio: auto; max-height: none; }
.vsound { position: absolute; right: 12px; bottom: 12px; z-index: 3; width: 46px; height: 46px;
  display: inline-flex; align-items: center; justify-content: center; cursor: pointer;
  border: 1px solid rgba(255,255,255,.28); border-radius: 50%; color: #fff;
  background: rgba(8,20,40,.55); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: 0 8px 20px -6px rgba(0,0,0,.5); transition: background .25s var(--ease), transform .25s var(--ease); }
.vsound:hover { background: rgba(21,101,216,.9); transform: translateY(-2px); }
.vsound:focus-visible { outline: 3px solid var(--yellow); outline-offset: 2px; }
.vsound svg { width: 22px; height: 22px; }
.vsound__on { display: none; }
.vsound.is-on { background: var(--yellow); color: #06203f; border-color: transparent; }
.vsound.is-on .vsound__on { display: block; }
.vsound.is-on .vsound__off { display: none; }

/* ============================================================
   Mobile-Härtung v7 - Überlauf/Icons/Felder endgültig sichern
   ============================================================ */
/* Sicherheitsnetz: kein Inline-SVG sprengt je den Bildschirm (Größe kommt aus width/height-Attr + CSS) */
svg { max-width: 100%; }

@media (max-width: 768px) {
  /* Flex-Kinder mit langem Inhalt dürfen schrumpfen -> Kontaktkarte/E-Mail laufen nicht aus dem Container */
  .infoitem, .footer__contact li, .ti, .hero__trust li { min-width: 0; }
  .infoitem > div { min-width: 0; }
  .infoitem a, .infoitem span,
  .footer__contact li, .footer__contact a { overflow-wrap: anywhere; word-break: break-word; }
  /* Eingabefelder & Buttons nie breiter als der Container */
  input, select, textarea { width: 100%; max-width: 100%; }
  .btn { max-width: 100%; }
  /* Icons als zusätzlicher Deckel klein halten */
  .vshow__trust svg, .why__item .ic svg, .tp__icon svg, .infoitem .ic svg, .ti svg, .acc__q svg { max-width: 56px; max-height: 56px; }
  /* Kontaktkarte/Formular sauber im Viewport */
  .infocard, .form { max-width: 100%; }
}

/* ============================================================
   Hero-Bereich - Mobile-Fix (NUR ≤768px; Desktop & Video-Sektion unverändert)
   Behebt rechtsseitiges Abschneiden von Button/Headline/Trust auf dem Handy.
   ============================================================ */
@media (max-width: 768px) {
  .hero .container { width: 100%; max-width: 100%; }
  /* Überschrift sauber umbrechen, keine erzwungene Einzeile */
  .hero h1 { overflow-wrap: break-word; -webkit-hyphens: auto; hyphens: auto; }
  .hero h1 .hl { white-space: normal; }   /* vorher nowrap -> lief rechts heraus */
  .hero h1 .hl::after { display: none; }
  /* Buttons voll sichtbar: globales white-space:nowrap aufheben, Text darf umbrechen */
  .hero__actions { width: 100%; max-width: 100%; }
  .hero__actions .btn {
    white-space: normal;          /* hebt .btn{white-space:nowrap} auf -> nichts wird abgeschnitten */
    text-align: center; line-height: 1.25; height: auto; min-height: 54px;
    max-width: 100%; width: 100%;  /* beide Buttons volle Breite, vollständig sichtbar */
  }
  /* Trust-Badges dürfen nicht aus dem Screen laufen */
  .hero__trust { width: 100%; max-width: 100%; }
  .hero__trust .tcheck { max-width: 100%; min-width: 0; }
}

/* ============================================================
   Hero-Bereich - FINALER Mobile-Fix (NUR ≤768px; Desktop/Video/Footer unverändert)
   Kernursache: Grid-Items haben min-width:auto -> Spur wird durch breiten
   Inhalt (langer Button/Wort) breiter als der Viewport -> rechts abgeschnitten.
   ============================================================ */
@media (max-width: 768px) {
  html, body { overflow-x: clip; max-width: 100%; }
  .hero { max-width: 100%; }
  .hero .container { width: 100%; max-width: 100%; padding-inline: 20px; }
  .hero__grid { grid-template-columns: 1fr !important; gap: 28px; }
  /* KERNFIX: Grid-/Flex-Spuren dürfen schrumpfen */
  .hero__copy, .hero__media { min-width: 0; max-width: 100%; }
  /* Überschrift kleiner + sauber umbrechen */
  .hero h1 { font-size: clamp(1.7rem, 7.6vw, 2.3rem); line-height: 1.18;
    overflow-wrap: break-word; word-break: break-word; -webkit-hyphens: auto; hyphens: auto; }
  .hero h1 .hl { white-space: normal !important; }
  .hero h1 .hl::after { display: none; }
  .hero .lead { max-width: 100%; }
  /* CTA-Buttons: untereinander, volle Breite, vollständig sichtbar */
  .hero__actions { flex-direction: column; align-items: stretch; width: 100%; max-width: 100%; }
  .hero__actions .btn { width: 100% !important; max-width: 100% !important;
    white-space: normal !important; min-height: 54px; height: auto; line-height: 1.25; }
  /* Trust-Badges untereinander, nichts läuft heraus */
  .hero__trust { flex-direction: column; align-items: flex-start; width: 100%; max-width: 100%; }
  .hero__trust .tcheck { max-width: 100%; min-width: 0; }
  /* dekorative Akzente + Badge mobil aus -> kein Überstand rechts */
  .hero__media::before, .hero__media::after { display: none !important; }
  .hero__badge { right: 8px !important; }
}

/* ============================================================
   Footer - Premium-Redesign (NUR CSS; Markup & andere Sektionen unverändert)
   Hinweis: footer__bottom padding-bottom NICHT anfassen (Sticky-CTA-Freiraum).
   ============================================================ */
.footer {
  background:
    radial-gradient(900px 480px at 84% -25%, rgba(21,101,216,.20), transparent 60%),
    radial-gradient(720px 460px at -5% 120%, rgba(255,210,0,.08), transparent 62%),
    linear-gradient(180deg, #0e1a29 0%, #0a1422 100%);
  padding-top: clamp(72px, 9vw, 116px);
}
.footer::after { /* feine Punkt-Textur für dezente Tiefe */
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.5;
  background-image: radial-gradient(circle, rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 26px 26px;
  -webkit-mask-image: radial-gradient(ellipse 75% 55% at 50% 0%, #000, transparent 78%);
  mask-image: radial-gradient(ellipse 75% 55% at 50% 0%, #000, transparent 78%);
}
.footer .container { position: relative; z-index: 1; }
.footer__top { gap: clamp(32px, 4vw, 56px); padding-bottom: clamp(40px, 5vw, 60px); border-bottom: 1px solid rgba(255,255,255,.08); }

/* Markenblock */
.footer .brand__mark { background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; }
.footer p { color: #93a6bd; line-height: 1.7; max-width: 34ch; }

/* Überschriften als feines Label */
.footer h4 { font-size: .82rem; text-transform: uppercase; letter-spacing: .14em; color: #8298b0; font-weight: 700; margin-bottom: 18px; }

/* Navigations-/Leistungs-Links mit dezentem Akzent */
.footer__links a { color: #aebfd1; position: relative; }
.footer__links a:hover { color: #fff; padding-left: 14px; }
.footer__links a::before { content: ""; position: absolute; left: 0; top: 50%; width: 8px; height: 1.5px; background: var(--yellow); transform: translateY(-50%) scaleX(0); transform-origin: left; transition: transform .25s var(--ease); }
.footer__links a:hover::before { transform: translateY(-50%) scaleX(1); }

/* Kontakt - Icons als edle Chips */
.footer__contact li { align-items: center; gap: 12px; color: #c2d2e4; margin-bottom: 14px; }
.footer__contact svg { width: 36px; height: 36px; padding: 9px; box-sizing: border-box; margin-top: 0;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); border-radius: 10px; color: var(--yellow);
  transition: background .25s var(--ease), border-color .25s var(--ease); }
.footer__contact li:hover svg { background: rgba(255,210,0,.12); border-color: rgba(255,210,0,.28); }
.footer__contact a { color: #c2d2e4; transition: color .2s; overflow-wrap: anywhere; }
.footer__contact a:hover { color: #fff; }

/* CTA-Card - Glassmorphism + stärkerer Button */
.footer__cta {
  background: linear-gradient(160deg, rgba(255,255,255,.09), rgba(255,255,255,.025));
  border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius); padding: 24px; position: relative; overflow: hidden;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  box-shadow: 0 18px 44px -22px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.08);
}
.footer__cta::before { content: ""; position: absolute; top: -45%; right: -20%; width: 180px; height: 180px;
  background: radial-gradient(circle, rgba(255,210,0,.18), transparent 70%); pointer-events: none; }
.footer__cta p { color: #eaf2ff; font-weight: 700; font-size: 1.05rem; margin-bottom: 14px; position: relative; }
.footer__cta .btn { box-shadow: var(--shadow-yellow); }

/* Footer-Bottom - nur Typo/Links verfeinern (padding-bottom NICHT setzen!) */
.footer__bottom { padding-top: 24px; font-size: .86rem; color: #8298b0; }
.footer__bottom .legal { gap: 22px; }
.footer__bottom .legal a { color: #9fb1c6; transition: color .2s; }
.footer__bottom .legal a:hover { color: #fff; }

/* Mobile-Feinschliff Footer (kein padding-bottom hier -> Sticky-Freiraum bleibt) */
@media (max-width: 768px) {
  .footer__cta { padding: 20px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
}

/* ============================================================
   Footer - FINALES Premium-Redesign (NUR CSS; Markup/andere Bereiche unverändert)
   Fixes: Logo wieder helle Card · Instagram kein Buchstaben-Umbruch.
   ============================================================ */
.footer {
  background:
    radial-gradient(950px 520px at 85% -25%, rgba(21,101,216,.22), transparent 60%),
    radial-gradient(760px 480px at -6% 118%, rgba(255,210,0,.07), transparent 62%),
    linear-gradient(180deg, #0f1d30 0%, #0a1422 100%);
  padding-top: clamp(76px, 9vw, 120px);
}
.footer__top { gap: clamp(34px, 4vw, 60px); padding-bottom: clamp(44px, 5vw, 64px); border-bottom: 1px solid rgba(255,255,255,.08); }

/* Feine vertikale Trennlinien zwischen den Spalten (nur ab 4-Spalten-Layout) */
@media (min-width: 881px) {
  .footer__top > div + div { border-left: 1px solid rgba(255,255,255,.07); padding-left: clamp(26px, 2.6vw, 48px); }
}

/* LOGO-FIX: wieder helle, hochwertige Logo-Card */
.footer .brand { align-items: center; gap: 14px; }
.footer .brand__mark { background: #fff; border: 1px solid rgba(255,255,255,.65); border-radius: 14px;
  box-shadow: 0 12px 30px -12px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.5); }
.footer .brand__text { color: #fff; }
.footer .brand__text b { color: var(--yellow); }
.footer .brand__text small { color: #9ab0c8; }
.footer p { color: #93a6bd; line-height: 1.7; max-width: 34ch; margin-top: 14px; }

/* Spalten-Labels: edel, klare Hierarchie */
.footer h4 { font-size: .8rem; text-transform: uppercase; letter-spacing: .15em; color: #8298b0; font-weight: 700; margin-bottom: 18px; }

/* Links mit dezentem gelben Akzent */
.footer__links li + li { margin-top: 13px; }
.footer__links a { color: #aebfd1; position: relative; font-size: .96rem; }
.footer__links a:hover { color: #fff; padding-left: 14px; }
.footer__links a::before { content: ""; position: absolute; left: 0; top: 50%; width: 8px; height: 1.5px;
  background: var(--yellow); transform: translateY(-50%) scaleX(0); transform-origin: left; transition: transform .25s var(--ease); }
.footer__links a:hover::before { transform: translateY(-50%) scaleX(1); }

/* KONTAKT als edle Card mit einheitlichen kleinen Icon-Chips */
.footer__contact { background: rgba(255,255,255,.035); border: 1px solid rgba(255,255,255,.08); border-radius: 16px; padding: 16px 18px; }
.footer__contact li { align-items: center; flex-wrap: wrap; gap: 10px 12px; color: #c8d6e6; font-size: .94rem; margin-bottom: 12px; }
.footer__contact li:last-child { margin-bottom: 0; }
.footer__contact svg { width: 34px; height: 34px; padding: 8px; box-sizing: border-box; margin-top: 0;
  background: rgba(255,210,0,.10); border: 1px solid rgba(255,210,0,.20); border-radius: 10px; color: var(--yellow); }
/* Instagram-FIX: ganzer Handle in einer Zeile (kein einzelner Buchstabe), bricht als Ganzes um */
.footer__contact a { color: #c8d6e6; white-space: nowrap; transition: color .2s; }
.footer__contact a:hover { color: #fff; }

/* CTA - hochwertige Glass-Card + kräftiger gelber Button, mittig */
.footer__cta { margin-top: 18px; padding: 22px; border-radius: 18px; position: relative; overflow: hidden;
  background: linear-gradient(160deg, rgba(255,255,255,.10), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.14); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  box-shadow: 0 22px 50px -24px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.10); }
.footer__cta::before { content: ""; position: absolute; top: -50%; right: -25%; width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(255,210,0,.20), transparent 70%); pointer-events: none; }
.footer__cta p { position: relative; color: #fff; font-weight: 700; font-size: 1.08rem; text-align: center; margin-bottom: 16px; }
.footer__cta .btn { width: 100%; justify-content: center; font-weight: 800; }

/* Schlusszeile - ruhig & edel (padding-bottom NICHT setzen -> Sticky-Freiraum bleibt) */
.footer__bottom { padding-top: 26px; font-size: .85rem; color: #8298b0; }
.footer__bottom .legal { gap: 22px; }
.footer__bottom .legal a { color: #9fb1c6; transition: color .2s; }
.footer__bottom .legal a:hover { color: #fff; }

/* MOBILE */
@media (max-width: 768px) {
  .footer__contact { padding: 14px 16px; }
  .footer__cta { padding: 20px; }
  .footer__bottom { flex-direction: column; align-items: flex-start; gap: 12px; }
}
@media (max-width: 480px) {
  .footer__contact a { font-size: .85rem; }
  .footer__contact svg { width: 32px; height: 32px; padding: 7px; }
}

/* ============================================================
   Footer - Feinjustierung (NUR CSS; Premium-Stil bleibt)
   Fix: Kontakt-Items horizontal · Links einzeilig ohne Hover-Sprung · Spalten balanciert
   ============================================================ */
@media (min-width: 881px) {
  .footer__top { grid-template-columns: 1.2fr 1.2fr 0.8fr 1.6fr; }
  .footer__top > div + div { padding-left: clamp(20px, 1.8vw, 36px); }
}
/* Kontakt-Items: Icon links, Text rechts daneben, vertikal mittig - NIE unter dem Icon */
.footer__contact li { flex-wrap: nowrap; align-items: center; gap: 12px; overflow-wrap: anywhere; }
/* Instagram bricht nur am <wbr> (Unterstrich) - kein einzelner Buchstabe; sonst eine Zeile */
.footer__contact a { white-space: normal; overflow-wrap: normal; word-break: keep-all; }
/* Footer-Links: Desktop einzeilig + konstantes Padding -> KEIN Positions-Sprung beim Hover */
.footer__links a { white-space: nowrap; padding-left: 14px; font-size: .92rem; }
.footer__links a:hover { padding-left: 14px; }
.footer__links a::before { left: 0; }
/* Mobil: Links dürfen sauber umbrechen */
@media (max-width: 768px) {
  .footer__links a { white-space: normal; }
}
