/* ===== Video-Hero (Liquid Glass) — ergänzt styles.css ===== */
.vhero{
  position:relative; min-height:100svh; display:flex; flex-direction:column;
  overflow:hidden; background:#000; color:#fff;
  font-family:'Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
.vhero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }

/* --- Liquid Glass --- */
.liquid-glass{
  background:rgba(0,0,0,.4); background-blend-mode:luminosity;
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  border:none; box-shadow:inset 0 1px 1px rgba(255,255,255,.1);
  position:relative; overflow:hidden;
}
.liquid-glass::before{
  content:''; position:absolute; inset:0; border-radius:inherit; padding:1.4px;
  background:linear-gradient(180deg,
    rgba(255,255,255,.3) 0%, rgba(255,255,255,.1) 20%,
    rgba(255,255,255,0) 40%, rgba(255,255,255,0) 60%,
    rgba(255,255,255,.1) 80%, rgba(255,255,255,.3) 100%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
}

/* --- Navbar --- */
.vnav-wrap{ position:relative; z-index:2; padding:1.5rem 1.5rem 0; }
@media(min-width:768px){ .vnav-wrap{ padding:1.5rem 3rem 0; } }
@media(min-width:1024px){ .vnav-wrap{ padding:1.5rem 4rem 0; } }
.vnav{ display:flex; align-items:center; justify-content:space-between;
  border-radius:.75rem; padding:.5rem 1rem; gap:1rem; }
.vnav__brand{ display:flex; align-items:center; line-height:0; }
.vnav__logo{ height:40px; width:auto; display:block; background:#fff; border-radius:.4rem; padding:3px 6px; }
.vnav__brandtext{ color:#fff; font-weight:700; font-size:1.25rem; letter-spacing:-.01em; }
.vnav__links{ display:none; gap:2rem; }
@media(min-width:768px){ .vnav__links{ display:flex; } }
.vnav__links a{ color:#fff; font-size:.875rem; text-decoration:none; transition:color .2s; }
.vnav__links a:hover{ color:#d1d5db; }
.vnav__cta{ background:#fff; color:#000; padding:.5rem 1.25rem; border-radius:.5rem;
  font-size:.875rem; font-weight:500; text-decoration:none; transition:background .2s; white-space:nowrap; }
.vnav__cta:hover{ background:#f3f4f6; }

/* --- Hero-Inhalt (unten) --- */
.vhero__inner{ position:relative; z-index:2; flex:1; display:flex; flex-direction:column;
  justify-content:flex-end; padding:0 1.5rem 3rem; }
@media(min-width:768px){ .vhero__inner{ padding:0 3rem 3rem; } }
@media(min-width:1024px){ .vhero__inner{ padding:0 4rem 4rem; } }
.vhero__grid{ display:block; }
@media(min-width:1024px){ .vhero__grid{ display:grid; grid-template-columns:1fr 1fr; align-items:end; gap:2rem; } }

.vhero__h1{
  font-family:'Inter',sans-serif; font-weight:400; color:#fff;
  font-size:clamp(1.9rem,4.6vw,3.5rem); line-height:1.06; letter-spacing:-.04em; margin:0 0 1rem;
  text-shadow:0 2px 18px rgba(0,0,0,.30);
}
.vhero__h1 .ah-line{ display:block; white-space:nowrap; }
.vhero__h1 .ah-char{ display:inline-block; opacity:0; transform:translateX(-18px);
  transition:opacity .5s ease, transform .5s ease; will-change:opacity,transform; }
.vhero__h1.is-in .ah-char{ opacity:1; transform:translateX(0); }

.vhero__sub{ font-size:1.125rem; color:#d1d5db; margin:0 0 1.25rem; max-width:34rem;
  text-shadow:0 1px 12px rgba(0,0,0,.4); }
.vhero__btns{ display:flex; flex-wrap:wrap; gap:1rem; }
.vbtn{ display:inline-block; padding:.75rem 2rem; border-radius:.5rem; font-weight:500;
  text-decoration:none; font-size:1rem; transition:background .2s,color .2s; cursor:pointer; }
.vbtn--solid{ background:#fff; color:#000; }
.vbtn--solid:hover{ background:#f3f4f6; }
.vbtn--glass{ color:#fff; }
.vbtn--glass:hover{ background:#fff; color:#000; }

.vhero__tag{ display:flex; align-items:end; justify-content:flex-start; margin-top:2rem; }
@media(min-width:1024px){ .vhero__tag{ justify-content:flex-end; margin-top:0; } }
.vhero__tagcard{ padding:.75rem 1.5rem; border-radius:.75rem; font-size:1.125rem; font-weight:300; color:#fff; }
@media(min-width:768px){ .vhero__tagcard{ font-size:1.5rem; } }

/* Fade-in (per JS) */
[data-fade]{ opacity:0; transition:opacity 1s ease; }

/* Rechner zentriert unter dem Hero */
.calc-section .calc--center{ max-width:560px; margin:0 auto; }

/* Schluss-CTA: helleres Bild zeigen (Abdunkelung sanfter), Text bleibt lesbar */
.finalcta__media::after{ background:linear-gradient(180deg, rgba(0,0,0,.34), rgba(0,0,0,.55)) !important; }
.finalcta h2, .finalcta p{ text-shadow:0 2px 14px rgba(0,0,0,.55); }
