:root{
  --bg:#f4f6f8;
  --ink:#0c1724;
  --muted:#627083;
  --navy:#06192d;
  --navy2:#0b2746;
  --blue:#74d9ff;
  --line:rgba(12,23,36,.12);
  --white:#fff;
  --shadow:0 30px 80px rgba(7,25,45,.18);
  --r:28px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,sans-serif;color:var(--ink);background:var(--bg);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 40px));margin-inline:auto}
.section{padding:110px 0}

.page-loader{position:fixed;inset:0;z-index:99;background:var(--navy);display:grid;place-items:center;animation:loaderOut .9s ease 1s forwards}
.page-loader span{width:54px;height:54px;border-radius:50%;border:3px solid rgba(255,255,255,.2);border-top-color:var(--blue);animation:spin .8s linear infinite}
@keyframes spin{to{rotate:360deg}}
@keyframes loaderOut{to{opacity:0;visibility:hidden}}

/* NAVBAR WIE SCREENSHOT */
.site-header{position:fixed;top:0;left:0;right:0;z-index:30}
.nav-shell{width:100%;height:96px;display:flex;align-items:center;justify-content:space-between;padding:0 44px;border-bottom:1px solid rgba(255,255,255,.12);background:rgba(5,18,32,.72);backdrop-filter:blur(20px);box-shadow:0 18px 50px rgba(0,0,0,.18)}
.brand{display:flex;align-items:center;gap:16px;color:#fff;min-width:260px}
.brand img{width:50px;height:50px;object-fit:contain;border-radius:12px;background:#fff;padding:6px;box-shadow:0 14px 32px rgba(0,0,0,.22)}
.brand b{display:block;font-size:20px;line-height:.98;font-weight:950;letter-spacing:-.045em;color:#fff}
.brand small{display:block;margin-top:8px;font-size:12px;line-height:1;text-transform:uppercase;letter-spacing:.32em;color:#fff;font-weight:850}
.nav{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:48px;color:#fff;font-size:15px;font-weight:900}
.nav a{opacity:.9;transition:.25s ease}
.nav a:hover{opacity:1;color:var(--blue)}
.nav-cta{display:inline-flex;align-items:center;justify-content:center;min-width:160px;padding:18px 30px;border-radius:999px;background:#fff;color:#07192d;font-weight:950;box-shadow:0 18px 40px rgba(0,0,0,.2);transition:.25s ease}
.nav-cta:hover{transform:translateY(-2px)}
.menu-btn{display:none}

/* HERO WIE SCREENSHOT */
.hero{position:relative;min-height:100vh;padding:0;color:#fff;overflow:hidden;background:#06182b}
.hero-bg{position:absolute;inset:0;z-index:0;opacity:1}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(.92) contrast(1.05)}
.hero:before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(3,15,28,.98) 0%,rgba(3,15,28,.88) 32%,rgba(3,15,28,.48) 58%,rgba(3,15,28,.12) 100%)}
.hero:after{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(circle at 18% 16%,rgba(116,217,255,.18),transparent 33%);pointer-events:none}
.hero-grid{position:relative;z-index:2;min-height:100vh;display:grid;grid-template-columns:minmax(0,720px) 380px;gap:70px;align-items:center;padding-top:96px}
.hero-copy{padding-top:26px}
.eyebrow{margin:0 0 28px;text-transform:uppercase;letter-spacing:.36em;font-size:13px;font-weight:950;color:var(--blue)}
h1,h2,h3,p{margin-top:0}
.hero h1{font-size:clamp(4.2rem,7vw,7.4rem);line-height:.96;letter-spacing:-.085em;margin:0 0 28px;max-width:760px;text-wrap:balance;color:#fff;text-shadow:0 14px 42px rgba(0,0,0,.28)}
.lead{font-size:clamp(1.08rem,1.35vw,1.3rem);line-height:1.65;color:#eef7ff;max-width:720px;text-shadow:0 10px 32px rgba(0,0,0,.45)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:38px 0 30px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:18px 30px;border-radius:999px;font-weight:950;transition:.25s ease}
.btn.primary{background:#fff;color:#07192d;box-shadow:0 18px 42px rgba(0,0,0,.22)}
.btn.ghost{border:1px solid rgba(255,255,255,.22);color:#fff;background:rgba(255,255,255,.04);backdrop-filter:blur(12px)}
.btn:hover{transform:translateY(-2px)}
.trust-row{display:flex;gap:12px;flex-wrap:wrap}
.trust-row span{border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:13px 18px;color:#fff;background:rgba(255,255,255,.055);backdrop-filter:blur(12px);font-weight:850}

/* FORMULAR RECHTS */
.quote-card{width:100%;justify-self:end;background:rgba(255,255,255,.97);color:#0c1724;border-radius:22px;padding:32px;box-shadow:0 30px 90px rgba(0,0,0,.25);border:1px solid rgba(255,255,255,.62)}
.rating{display:flex;align-items:center;gap:10px;margin-bottom:28px}
.rating b{font-size:38px;letter-spacing:-.08em;color:#07192d}
.rating span{color:#f6bb20;letter-spacing:.08em;font-size:14px}
.rating small{color:var(--muted);font-weight:850;font-size:12px}
.quote-card h2{font-size:30px;line-height:1.08;letter-spacing:-.055em;margin-bottom:22px;color:#07192d}
.quote-card p{color:var(--muted);line-height:1.62;margin-bottom:22px}
.quote-card form,.contact-form{display:grid;gap:12px}
.quote-card input,.quote-card select,.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:999px;padding:17px 18px;font:inherit;background:#fff;color:var(--ink);outline:none}
.quote-card select{appearance:auto;color:#6b7585}
.quote-card button,.contact-form button{border:0;border-radius:999px;background:var(--navy);color:#fff;padding:18px;font-weight:950;cursor:pointer;transition:.25s ease}
.quote-card button:hover,.contact-form button:hover{transform:translateY(-2px);background:#0b2746}

/* INTRO */
.intro{padding:34px 0;background:#fff}
.intro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.intro-card{padding:30px;border-radius:24px;background:#f4f7fa;border:1px solid var(--line)}
.intro-card span{font-weight:900;color:#98a7b8}
.intro-card h3{font-size:28px;letter-spacing:-.04em;margin:12px 0}
.intro-card p{color:var(--muted);line-height:1.6;margin:0}

/* SERVICES */
.section-head{text-align:center;max-width:760px;margin:0 auto 54px}
.section-head h2,.split-copy h2,.review-main h2,.contact-copy h2{font-size:clamp(2.5rem,5vw,5.6rem);line-height:.95;letter-spacing:-.08em;margin-bottom:20px}
.section-head p:not(.eyebrow),.split-copy p,.review-main p,.contact-copy p{color:var(--muted);line-height:1.75;font-size:18px}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{border-radius:30px;overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:0 12px 35px rgba(7,25,45,.06);min-height:430px;display:flex;flex-direction:column}
.service-card img{height:230px;width:100%;object-fit:cover}
.service-card div{padding:28px}
.service-card span{color:#3aaee0;text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:900}
.service-card h3{font-size:30px;letter-spacing:-.055em;margin:12px 0}
.service-card p{color:var(--muted);line-height:1.65}
.service-dark{background:linear-gradient(rgba(4,12,24,.78),rgba(4,12,24,.88)),url("../img/wien.jpg") center/cover no-repeat;color:#fff;justify-content:end;position:relative;overflow:hidden;box-shadow:0 25px 80px rgba(0,0,0,.24)}
.service-dark p{color:#d8e4ef}
.service-dark a{display:inline-flex;margin-top:18px;color:#fff;border-bottom:1px solid var(--blue);font-weight:900}

/* QUALITY */
.split{background:#fff}
.split-grid{display:grid;grid-template-columns:.95fr 1fr;gap:72px;align-items:center}
.split-media img{height:640px;width:100%;object-fit:cover;border-radius:34px;box-shadow:var(--shadow)}
.check-list{list-style:none;margin:26px 0 0;padding:0;display:grid;gap:14px}
.check-list li{font-weight:800;padding:16px 18px;border-radius:16px;background:#f5f8fb;border:1px solid var(--line)}
.check-list li:before{content:"✓";color:#1a9ed8;margin-right:10px}

/* PROCESS */
.process{background:#07192d;color:#fff}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.step{padding:30px;border-radius:26px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12)}
.step b{color:var(--blue);font-size:24px}
.step h3{font-size:25px;letter-spacing:-.04em;margin:26px 0 12px}
.step p{color:#bfccd8;line-height:1.6}

/* REVIEWS */
.reviews{background:#eef3f7}
.reviews-grid{display:grid;grid-template-columns:1.1fr .7fr .7fr;gap:22px;align-items:stretch}
.review-main,.review-card{background:#fff;border:1px solid var(--line);border-radius:30px;padding:34px}
.review-card span{color:#f6bb20;letter-spacing:.08em;font-weight:900}
.review-card p{font-size:22px;letter-spacing:-.03em;line-height:1.45;margin:25px 0;color:#182537}
.review-card b{color:#6a7788}

/* CONTACT */
.contact{background:#07192d;color:#fff}
.contact-shell{display:grid;grid-template-columns:1fr .78fr;gap:42px;align-items:center;background:linear-gradient(145deg,rgba(255,255,255,.08),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.12);border-radius:38px;padding:52px}
.contact-copy{text-align:center}
.contact-copy p{color:#bfccd8}
.contact-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.contact-links a{background:#fff;color:#07192d;padding:16px 22px;border-radius:999px;font-weight:900}
.contact-form{background:#fff;border-radius:28px;padding:26px}
.contact-form textarea{height:130px;resize:none;border-radius:22px}

/* FOOTER + ANIMATION */
.footer{padding:30px 0;background:#04111f;color:#b7c5d2}
.footer-grid{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer a{margin-left:18px}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.delay-1{transition-delay:.12s}.delay-2{transition-delay:.24s}.delay-3{transition-delay:.36s}

@media(max-width:1120px){
  .hero-grid{grid-template-columns:1fr 360px;gap:42px}
  .hero h1{font-size:clamp(3.7rem,7.4vw,6.4rem)}
  .nav{gap:30px}
}

@media(max-width:980px){
  .nav,.nav-cta{display:none}
  .site-header{top:14px;padding-inline:14px}
  .nav-shell{height:70px;padding:0 10px 0 14px;border:1px solid rgba(255,255,255,.16);border-radius:999px;background:rgba(5,18,32,.82)}
  .menu-btn{display:grid;gap:5px;background:#fff;border:0;border-radius:50%;width:54px;height:54px;place-content:center}
  .menu-btn span{width:21px;height:2px;background:#07192d}
  .brand{min-width:0}.brand img{width:42px;height:42px}.brand small{display:none}
  .hero-grid,.split-grid,.contact-shell,.reviews-grid{grid-template-columns:1fr}
  .hero-grid{padding-top:135px;align-items:start;gap:28px}
  .hero-bg{opacity:.7}.hero:before{background:linear-gradient(180deg,rgba(4,17,31,.88),rgba(4,17,31,.76))}
  .quote-card{max-width:520px;justify-self:start}
  .service-grid,.intro-grid,.timeline{grid-template-columns:1fr 1fr}
  .contact-copy{text-align:left}.contact-links{justify-content:flex-start}
}

@media(max-width:640px){
  .container{width:min(100% - 24px,1180px)}
  .section{padding:76px 0}
  .hero{min-height:auto;padding-bottom:74px}
  .hero h1{font-size:clamp(3.05rem,15vw,4.25rem);line-height:.94}
  .hero-actions,.trust-row{display:grid}
  .quote-card{padding:22px;border-radius:22px}
  .service-grid,.intro-grid,.timeline{grid-template-columns:1fr}
  .split-media img{height:420px}.contact-shell{padding:26px;border-radius:28px}
  .footer-grid{display:grid}.footer a{margin:0 18px 0 0}
}

/* =========================
   AUDIT-FIX FINAL
   Fehlerursache war mehrfaches Überschreiben von opacity/display/animation.
   Hero-Text wird ab jetzt niemals mehr auf opacity:0 gesetzt.
========================= */

.page-loader{
  display:none !important;
}

.eyebrow{
  display:none !important;
}

/* Hero aus Reveal-System rausnehmen */
.hero-copy{
  opacity:1 !important;
  visibility:visible !important;
  transform:none !important;
  position:relative !important;
  z-index:50 !important;
}

/* Hero Überschrift */
.hero-title{
  display:block !important;
  opacity:1 !important;
  visibility:visible !important;
  color:#fff !important;
  margin:0 0 24px !important;
  max-width:680px !important;
  font-size:clamp(2.8rem,5.2vw,5.25rem) !important;
  line-height:.96 !important;
  letter-spacing:-.055em !important;
  font-weight:740 !important;
  position:relative !important;
  z-index:60 !important;
  perspective:1000px;
}

.title-line{
  display:block !important;
  overflow:hidden !important;
  padding-bottom:.04em;
}

.title-word{
  display:inline-block !important;
  opacity:1 !important;
  visibility:visible !important;
  color:#fff !important;
  text-shadow:none !important;
  filter:none !important;
  transform-origin:center bottom;
  animation:gjSafeFlip .8s cubic-bezier(.16,1,.3,1) both;
}

.title-line:nth-child(1) .title-word{
  animation-delay:.12s;
}

.title-line:nth-child(2) .title-word{
  animation-delay:.34s;
}

.title-line:nth-child(3) .title-word{
  animation-delay:.56s;
}

@keyframes gjSafeFlip{
  0%{
    transform:rotateX(-58deg) translateY(20px);
  }

  70%{
    transform:rotateX(6deg) translateY(-2px);
  }

  100%{
    transform:rotateX(0) translateY(0);
  }
}

/* Textblock darunter: sichtbar, kommt danach leicht hoch */
.hero .lead{
  display:block !important;
  opacity:1 !important;
  visibility:visible !important;
  color:#fff !important;
  max-width:620px !important;
  position:relative !important;
  z-index:60 !important;
  filter:none !important;
  animation:gjSafeTextUp .65s ease 1.05s both;
}

.hero-actions{
  display:flex !important;
  opacity:1 !important;
  visibility:visible !important;
  position:relative !important;
  z-index:60 !important;
  filter:none !important;
  animation:gjSafeTextUp .65s ease 1.22s both;
}

.trust-row{
  display:flex !important;
  opacity:1 !important;
  visibility:visible !important;
  position:relative !important;
  z-index:60 !important;
  filter:none !important;
  animation:gjSafeTextUp .65s ease 1.38s both;
}

@keyframes gjSafeTextUp{
  0%{
    transform:translateY(18px);
  }

  100%{
    transform:translateY(0);
  }
}

/* Unten Bewertungsbereich kleiner */
.review-main h2,
.reviews .section-head h2{
  font-size:clamp(2.1rem,3.6vw,3.7rem) !important;
  line-height:1 !important;
  letter-spacing:-.055em !important;
}

/* Kontakt unten kleiner */
.contact-copy h2{
  font-size:clamp(2.15rem,3.7vw,3.8rem) !important;
  line-height:1 !important;
  letter-spacing:-.055em !important;
}

/* Footer Upgrade */
.footer{
  padding:54px 0 34px !important;
  background:
    radial-gradient(circle at 15% 0%,rgba(122,216,255,.16),transparent 34%),
    linear-gradient(135deg,#020a13,#07192d 54%,#04111f) !important;
  color:#d7e3ee !important;
  border-top:1px solid rgba(255,255,255,.12);
}

.footer-grid{
  align-items:center;
  padding:26px 28px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  background:rgba(255,255,255,.045);
  backdrop-filter:blur(18px);
  box-shadow:0 22px 70px rgba(0,0,0,.25);
}

.footer p{
  margin:0;
  font-weight:700;
}

.footer a{
  display:inline-flex;
  padding:11px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:800;
  transition:.25s ease;
}

.footer a:hover{
  background:#fff;
  color:#07192d;
}

@media(max-width:980px){
  .hero-grid{
    padding-top:92px !important;
  }
}

@media(max-width:640px){
  .hero{
    padding-top:0 !important;
  }

  .hero-grid{
    padding-top:84px !important;
  }

  .hero-title{
    font-size:clamp(2.35rem,10.8vw,3.25rem) !important;
    line-height:1.03 !important;
  }

  .hero-actions,
  .trust-row{
    display:grid !important;
  }

  .review-main h2,
  .reviews .section-head h2,
  .contact-copy h2{
    font-size:2.25rem !important;
  }

  .footer-grid{
    padding:22px;
    gap:18px;
  }

  .footer a{
    margin:0 8px 8px 0 !important;
  }
}


/* =========================
   MOBILE BURGER + FOOTER FIX
========================= */

@media(max-width:980px){

  #nav{
    position:absolute;
    top:82px;
    left:0;
    right:0;

    display:flex;
    flex-direction:column;
    gap:0;

    padding:14px;
    border-radius:24px;

    background:rgba(7,25,45,.97);
    backdrop-filter:blur(18px);

    border:1px solid rgba(255,255,255,.08);

    opacity:0;
    visibility:hidden;
    transform:translateY(-10px);

    transition:
      opacity .28s ease,
      transform .28s ease,
      visibility .28s ease;

    z-index:999;
  }

  #nav.is-open{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
  }

  #nav a{
    padding:16px 12px;
    border-bottom:1px solid rgba(255,255,255,.06);
    color:#fff !important;
    font-size:15px;
    font-weight:800;
  }

  #nav a:last-child{
    border-bottom:0;
  }

  .menu-btn{
    display:grid !important;
    cursor:pointer;
    z-index:1001;
  }

  .footer{
    text-align:center !important;
  }

  .footer-grid{
    justify-content:center !important;
    text-align:center !important;
  }

  .footer-links{
    display:flex;
    justify-content:center;
    flex-wrap:wrap;
    gap:10px;
    width:100%;
  }

  .footer p{
    width:100%;
    text-align:center;
  }
}


/* =========================
   PRO MOBILE MENU + ANCHOR FIX
========================= */

html{
  scroll-padding-top:110px;
}

section[id]{
  scroll-margin-top:110px;
}

@media(max-width:980px){

  html{
    scroll-padding-top:96px;
  }

  section[id]{
    scroll-margin-top:96px;
  }

  .site-header{
    z-index:2000;
  }

  .nav-shell{
    position:relative;
  }

  #nav{
    position:absolute;
    top:calc(100% + 14px);
    left:0;
    right:0;

    display:grid !important;
    grid-template-columns:1fr;
    gap:8px;

    padding:12px;

    border-radius:28px;
    border:1px solid rgba(255,255,255,.12);

    background:
      linear-gradient(180deg,rgba(10,28,49,.98),rgba(4,14,27,.98));

    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);

    box-shadow:
      0 30px 80px rgba(0,0,0,.38),
      inset 0 1px 0 rgba(255,255,255,.08);

    opacity:0;
    visibility:hidden;
    transform:translateY(-8px) scale(.97);
    transform-origin:top center;

    transition:
      opacity .28s ease,
      transform .28s ease,
      visibility .28s ease;

    pointer-events:none;
    z-index:2001;
  }

  #nav.is-open{
    opacity:1;
    visibility:visible;
    transform:translateY(0) scale(1);
    pointer-events:auto;
  }

  #nav a{
    display:flex;
    align-items:center;
    justify-content:space-between;

    min-height:52px;
    padding:0 16px;

    border-radius:18px;
    border:1px solid rgba(255,255,255,.07);

    background:rgba(255,255,255,.045);

    color:#fff !important;
    font-size:15px;
    font-weight:850;
    letter-spacing:-.02em;

    transition:
      background .22s ease,
      transform .22s ease,
      border-color .22s ease;
  }

  #nav a::after{
    content:"›";
    font-size:24px;
    line-height:1;
    color:rgba(122,216,255,.9);
    transform:translateY(-1px);
  }

  #nav a:hover,
  #nav a:active{
    background:rgba(255,255,255,.1);
    border-color:rgba(122,216,255,.28);
    transform:translateX(3px);
  }

  .menu-btn{
    display:grid !important;
    place-content:center;
    gap:0;

    width:54px;
    height:54px;

    border:1px solid rgba(255,255,255,.14) !important;
    border-radius:50%;

    background:
      linear-gradient(180deg,#fff,#eef4f7) !important;

    box-shadow:
      0 12px 34px rgba(0,0,0,.26),
      inset 0 1px 0 rgba(255,255,255,.9);

    cursor:pointer;
    z-index:2002;
  }

  .menu-btn span{
    display:block;
    width:22px;
    height:2px;
    margin:3px 0;

    border-radius:999px;
    background:#07192d !important;

    transition:
      transform .28s ease,
      opacity .22s ease;
  }

  .menu-btn.is-open span:first-child{
    transform:translateY(4px) rotate(45deg);
  }

  .menu-btn.is-open span:last-child{
    transform:translateY(-4px) rotate(-45deg);
  }
}

@media(max-width:640px){

  html{
    scroll-padding-top:88px;
  }

  section[id]{
    scroll-margin-top:88px;
  }

  #nav{
    top:calc(100% + 10px);
    border-radius:24px;
  }

  #nav a{
    min-height:50px;
  }
}


/* =========================
   LAPTOP RESPONSIVE FIX
   13 / 15 / 16 / 17 Zoll
========================= */

html{
  scroll-padding-top:105px;
}

#top,
.hero{
  scroll-margin-top:0 !important;
}

/* Desktop: Hero immer in sichtbarer Höhe halten */
@media(min-width:981px){

  .hero{
    min-height:100svh !important;
    padding-top:118px !important;
    padding-bottom:42px !important;
    display:flex;
    align-items:center;
  }

  .hero-grid{
    width:min(1180px,calc(100% - 64px));
    margin-inline:auto;
    display:grid;
    grid-template-columns:minmax(0,1fr) clamp(300px,28vw,390px) !important;
    gap:clamp(28px,4vw,66px) !important;
    align-items:center !important;
  }

  .hero-copy{
    max-width:680px;
  }

  .hero-title{
    font-size:clamp(2.65rem,5.2vw,5.25rem) !important;
    line-height:.95 !important;
    margin-bottom:clamp(16px,2vh,24px) !important;
  }

  .hero .lead{
    font-size:clamp(.98rem,1.15vw,1.12rem) !important;
    line-height:1.65 !important;
    max-width:590px !important;
  }

  .hero-actions{
    margin:clamp(20px,3vh,34px) 0 clamp(16px,2.2vh,28px) !important;
    gap:12px !important;
  }

  .btn{
    padding:clamp(13px,1.5vw,17px) clamp(18px,2.2vw,26px) !important;
  }

  .trust-row{
    gap:10px !important;
  }

  .trust-row span{
    padding:clamp(9px,1vw,12px) clamp(13px,1.4vw,17px) !important;
    font-size:clamp(.8rem,.9vw,.95rem) !important;
  }

  .quote-card{
    width:100%;
    max-width:390px;
    padding:clamp(22px,2.3vw,34px) !important;
    border-radius:clamp(22px,2vw,30px) !important;
  }

  .rating{
    margin-bottom:clamp(14px,2vh,24px) !important;
  }

  .rating b{
    font-size:clamp(2rem,2.8vw,2.7rem) !important;
  }

  .quote-card h2{
    font-size:clamp(1.55rem,2vw,2.15rem) !important;
    line-height:1.08 !important;
    margin-bottom:14px !important;
  }

  .quote-card p{
    font-size:clamp(.88rem,.95vw,1rem) !important;
    line-height:1.55 !important;
    margin-bottom:16px !important;
  }

  .quote-card form{
    gap:10px !important;
  }

  .quote-card input,
  .quote-card select{
    padding:clamp(12px,1.2vw,16px) 16px !important;
    min-height:auto !important;
    font-size:clamp(.86rem,.9vw,.98rem) !important;
  }

  .quote-card button{
    padding:clamp(13px,1.2vw,17px) !important;
    font-size:clamp(.86rem,.9vw,.98rem) !important;
  }
}

/* kleine Laptop-Höhe: alles kompakter, damit Formular + Hero reinpassen */
@media(min-width:981px) and (max-height:820px){

  .site-header{
    top:14px !important;
  }

  .nav-shell{
    height:64px !important;
  }

  .brand img{
    width:38px !important;
    height:38px !important;
  }

  .brand b{
    font-size:15px !important;
  }

  .brand small{
    font-size:9px !important;
  }

  .nav a{
    font-size:13px !important;
  }

  .nav-cta{
    padding:13px 21px !important;
  }

  .hero{
    padding-top:92px !important;
    padding-bottom:28px !important;
  }

  .hero-title{
    font-size:clamp(2.45rem,4.55vw,4.7rem) !important;
    margin-bottom:14px !important;
  }

  .hero .lead{
    font-size:.98rem !important;
    line-height:1.55 !important;
  }

  .hero-actions{
    margin:18px 0 14px !important;
  }

  .btn{
    padding:12px 20px !important;
  }

  .trust-row span{
    padding:8px 12px !important;
  }

  .quote-card{
    max-width:350px !important;
    padding:20px !important;
  }

  .rating b{
    font-size:2rem !important;
  }

  .quote-card h2{
    font-size:1.55rem !important;
  }

  .quote-card p{
    font-size:.86rem !important;
    line-height:1.45 !important;
  }

  .quote-card input,
  .quote-card select{
    padding:11px 14px !important;
  }

  .quote-card button{
    padding:12px !important;
  }
}

/* 13 Zoll / kleine Breite */
@media(min-width:981px) and (max-width:1280px){

  .hero-grid{
    width:min(1120px,calc(100% - 46px));
    grid-template-columns:minmax(0,1fr) 330px !important;
    gap:34px !important;
  }

  .hero-title{
    font-size:clamp(2.35rem,4.4vw,4.35rem) !important;
  }

  .hero .lead{
    max-width:540px !important;
  }

  .quote-card{
    max-width:330px !important;
  }
}

/* 15 Zoll Standard */
@media(min-width:1281px) and (max-width:1500px){

  .hero-grid{
    width:min(1180px,calc(100% - 56px));
    grid-template-columns:minmax(0,1fr) 360px !important;
    gap:44px !important;
  }

  .hero-title{
    font-size:clamp(2.8rem,4.7vw,5rem) !important;
  }
}

/* 16/17 Zoll */
@media(min-width:1501px){

  .hero-grid{
    width:min(1280px,calc(100% - 72px));
    grid-template-columns:minmax(0,1fr) 390px !important;
  }
}

/* Wenn Viewport extrem niedrig ist, Formular noch etwas kleiner */
@media(min-width:981px) and (max-height:700px){

  .hero{
    padding-top:78px !important;
    padding-bottom:18px !important;
  }

  .hero-title{
    font-size:clamp(2.1rem,4vw,4.1rem) !important;
  }

  .hero .lead{
    font-size:.9rem !important;
    line-height:1.45 !important;
  }

  .quote-card{
    max-width:320px !important;
    padding:18px !important;
  }

  .rating{
    margin-bottom:10px !important;
  }

  .quote-card h2{
    font-size:1.35rem !important;
  }

  .quote-card p{
    font-size:.8rem !important;
    margin-bottom:10px !important;
  }

  .quote-card input,
  .quote-card select{
    padding:9px 12px !important;
  }

  .quote-card button{
    padding:10px !important;
  }

  .trust-row{
    display:none !important;
  }
}


/* =========================
   FINAL RESPONSIVE + ANCHOR FIX
   Ziel: keine abgeschnittene Navbar, kompaktere Anzeige, saubere Sprungmarken.
========================= */

html{
  scroll-padding-top:90px !important;
}

body{
  min-width:0;
}

/* Navbar nicht mehr abschneiden */
.site-header{
  position:fixed !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  z-index:3000 !important;
  padding:10px 18px 0 !important;
  transform:none !important;
}

.site-header.is-scrolled{
  transform:none !important;
}

.nav-shell{
  width:100% !important;
  max-width:1440px !important;
  margin-inline:auto !important;
  height:72px !important;
  padding:0 clamp(18px,3vw,38px) !important;
  border-radius:0 !important;
  border:0 !important;
  border-bottom:1px solid rgba(255,255,255,.12) !important;
  background:rgba(5,18,32,.78) !important;
  backdrop-filter:blur(20px) !important;
}

.brand{
  flex-shrink:0;
}

.brand img{
  width:42px !important;
  height:42px !important;
}

.brand b{
  font-size:15px !important;
}

.brand small{
  font-size:9px !important;
  letter-spacing:.18em !important;
}

.nav{
  gap:clamp(22px,3vw,44px) !important;
}

.nav a{
  font-size:14px !important;
}

.nav-cta{
  padding:14px 24px !important;
}

/* Allgemein kompakter */
.section{
  padding:clamp(68px,8vw,104px) 0 !important;
}

.section-head h2,
.split-copy h2,
.review-main h2,
.contact-copy h2{
  font-size:clamp(2rem,4.2vw,4.5rem) !important;
}

/* Hero skaliert an Bildschirmhöhe */
@media(min-width:981px){

  .hero{
    min-height:100svh !important;
    height:100svh !important;
    padding:82px 0 28px !important;
    display:flex !important;
    align-items:center !important;
    overflow:hidden !important;
  }

  .hero-grid{
    min-height:calc(100svh - 110px) !important;
    padding-top:0 !important;
    width:min(1240px,calc(100% - 56px)) !important;
    margin-inline:auto !important;
    display:grid !important;
    grid-template-columns:minmax(0,1fr) clamp(300px,28vw,370px) !important;
    gap:clamp(26px,4vw,58px) !important;
    align-items:center !important;
  }

  .hero-title{
    font-size:clamp(2.35rem,4.6vw,5rem) !important;
    line-height:.96 !important;
    margin-bottom:clamp(14px,2vh,24px) !important;
    max-width:650px !important;
  }

  .hero .lead{
    font-size:clamp(.88rem,1vw,1.08rem) !important;
    line-height:1.55 !important;
    max-width:570px !important;
  }

  .hero-actions{
    margin:clamp(18px,2.5vh,30px) 0 clamp(12px,2vh,24px) !important;
    gap:10px !important;
  }

  .btn{
    padding:clamp(11px,1.2vw,15px) clamp(17px,2vw,25px) !important;
    font-size:clamp(.82rem,.9vw,.95rem) !important;
  }

  .trust-row{
    gap:9px !important;
  }

  .trust-row span{
    padding:clamp(8px,.9vw,11px) clamp(12px,1.2vw,16px) !important;
    font-size:clamp(.75rem,.85vw,.9rem) !important;
  }

  .quote-card{
    align-self:center !important;
    width:100% !important;
    max-width:370px !important;
    padding:clamp(18px,2vw,28px) !important;
    border-radius:26px !important;
  }

  .rating{
    margin-bottom:clamp(10px,1.6vh,18px) !important;
  }

  .rating b{
    font-size:clamp(1.8rem,2.4vw,2.45rem) !important;
  }

  .quote-card h2{
    font-size:clamp(1.35rem,1.7vw,1.9rem) !important;
    line-height:1.06 !important;
    margin-bottom:12px !important;
  }

  .quote-card p{
    font-size:clamp(.78rem,.9vw,.94rem) !important;
    line-height:1.45 !important;
    margin-bottom:14px !important;
  }

  .quote-card form{
    gap:9px !important;
  }

  .quote-card input,
  .quote-card select{
    padding:clamp(10px,1vw,14px) 14px !important;
    font-size:clamp(.78rem,.86vw,.94rem) !important;
  }

  .quote-card button{
    padding:clamp(11px,1vw,14px) !important;
    font-size:clamp(.78rem,.86vw,.94rem) !important;
  }
}

/* 13-14 Zoll / kleine Laptops */
@media(min-width:981px) and (max-width:1280px){

  .site-header{
    padding-inline:12px !important;
  }

  .nav-shell{
    height:64px !important;
    padding:0 24px !important;
  }

  .brand img{
    width:38px !important;
    height:38px !important;
  }

  .nav{
    gap:28px !important;
  }

  .nav a{
    font-size:13px !important;
  }

  .nav-cta{
    padding:12px 20px !important;
  }

  .hero{
    padding-top:72px !important;
    padding-bottom:20px !important;
  }

  .hero-grid{
    min-height:calc(100svh - 92px) !important;
    width:min(1120px,calc(100% - 34px)) !important;
    grid-template-columns:minmax(0,1fr) 310px !important;
    gap:28px !important;
  }

  .hero-title{
    font-size:clamp(2.1rem,4vw,3.85rem) !important;
    max-width:560px !important;
  }

  .hero .lead{
    font-size:.88rem !important;
    line-height:1.45 !important;
    max-width:520px !important;
  }

  .quote-card{
    max-width:310px !important;
    padding:18px !important;
  }

  .quote-card h2{
    font-size:1.35rem !important;
  }

  .quote-card p{
    font-size:.78rem !important;
  }

  .quote-card input,
  .quote-card select{
    padding:9px 12px !important;
  }

  .quote-card button{
    padding:10px !important;
  }
}

/* Sehr niedrige Browserhöhe */
@media(min-width:981px) and (max-height:760px){

  .nav-shell{
    height:60px !important;
  }

  .hero{
    padding-top:64px !important;
    padding-bottom:14px !important;
  }

  .hero-grid{
    min-height:calc(100svh - 78px) !important;
  }

  .hero-title{
    font-size:clamp(1.95rem,3.7vw,3.65rem) !important;
    margin-bottom:10px !important;
  }

  .hero .lead{
    font-size:.82rem !important;
    line-height:1.38 !important;
  }

  .hero-actions{
    margin:12px 0 10px !important;
  }

  .trust-row{
    display:none !important;
  }

  .quote-card{
    max-width:300px !important;
    padding:16px !important;
  }

  .rating{
    margin-bottom:8px !important;
  }

  .rating b{
    font-size:1.7rem !important;
  }

  .quote-card h2{
    font-size:1.22rem !important;
    margin-bottom:8px !important;
  }

  .quote-card p{
    font-size:.73rem !important;
    margin-bottom:8px !important;
  }

  .quote-card input,
  .quote-card select{
    padding:8px 11px !important;
  }

  .quote-card button{
    padding:9px !important;
  }
}

/* Anchor Ziele nicht unter Navbar kleben */
section[id]{
  scroll-margin-top:92px !important;
}

/* Mobile insgesamt kleiner/effizienter */
@media(max-width:980px){

  .site-header{
    padding:10px 12px 0 !important;
  }

  .nav-shell{
    height:64px !important;
    border-radius:999px !important;
    padding:0 10px 0 14px !important;
  }

  .hero{
    min-height:100svh !important;
    padding-top:0 !important;
    padding-bottom:54px !important;
  }

  .hero-grid{
    min-height:auto !important;
    padding-top:92px !important;
  }

  .hero-title{
    font-size:clamp(2.2rem,10vw,3.25rem) !important;
    line-height:1.02 !important;
  }

  .hero .lead{
    font-size:.95rem !important;
    line-height:1.55 !important;
  }

  .section{
    padding:64px 0 !important;
  }

  section[id]{
    scroll-margin-top:82px !important;
  }
}

@media(max-width:640px){

  .container{
    width:min(100% - 22px,1180px) !important;
  }

  .hero-grid{
    padding-top:84px !important;
  }

  .hero-title{
    font-size:clamp(2rem,9.6vw,3rem) !important;
  }

  .quote-card{
    padding:18px !important;
  }
}


/* =========================
   NAVBAR FULL WIDTH FIX
   Navbar soll wie im Screenshot bis zum Rand durchlaufen.
========================= */

.site-header{
  padding:0 !important;
  top:0 !important;
  left:0 !important;
  right:0 !important;
  width:100% !important;
}

.site-header .container{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
}

.nav-shell{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;

  border-radius:0 !important;
  border-left:0 !important;
  border-right:0 !important;
  border-top:0 !important;

  padding-left:clamp(28px,3.2vw,56px) !important;
  padding-right:clamp(28px,3.2vw,56px) !important;

  background:rgba(5,18,32,.82) !important;
}

/* Hero direkt sauber unter der Fullwidth Navbar */
@media(min-width:981px){
  .hero{
    padding-top:72px !important;
  }
}

/* Mobile bleibt pill-style, weil es dort professioneller wirkt */
@media(max-width:980px){
  .site-header{
    padding:10px 12px 0 !important;
  }

  .site-header .container{
    width:100% !important;
  }

  .nav-shell{
    border-radius:999px !important;
    padding-left:14px !important;
    padding-right:10px !important;
  }
}


/* =========================
   LEGAL PAGES
========================= */

.legal-page{
  min-height:100vh;
  background:
    radial-gradient(circle at 12% 0%,rgba(122,216,255,.14),transparent 34%),
    linear-gradient(135deg,#020a13,#07192d 54%,#04111f);
  color:#fff;
}

.legal-main{
  padding:140px 0 90px;
}

.legal-hero{
  max-width:980px;
  margin-inline:auto;
  text-align:center;
  padding:54px 34px 36px;
}

.legal-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  padding:10px 16px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:#7ad8ff;
  font-size:12px;
  font-weight:900;
  letter-spacing:.18em;
  text-transform:uppercase;
}

.legal-hero h1{
  margin:0 0 18px;
  font-size:clamp(2.6rem,6vw,5.6rem);
  line-height:.95;
  letter-spacing:-.075em;
}

.legal-hero p{
  max-width:720px;
  margin:0 auto;
  color:#c4d1dc;
  line-height:1.75;
  font-size:clamp(1rem,1.4vw,1.15rem);
}

.legal-shell{
  width:min(1080px,calc(100% - 32px));
  margin:34px auto 0;
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:26px;
  align-items:start;
}

.legal-nav{
  position:sticky;
  top:104px;
  padding:18px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:28px;
  background:rgba(255,255,255,.055);
  backdrop-filter:blur(18px);
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}

.legal-nav b{
  display:block;
  margin:0 0 12px;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#7ad8ff;
}

.legal-nav a{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:13px 14px;
  border-radius:16px;
  color:#e8f0f7;
  font-weight:800;
  font-size:14px;
}

.legal-nav a:hover{
  background:rgba(255,255,255,.08);
}

.legal-card{
  padding:34px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:32px;
  background:rgba(230, 230, 230);
  color:#0c1724;
  box-shadow:0 30px 90px rgba(0,0,0,.26);
}

.legal-card section{
  padding:0 0 30px;
  margin:0 0 30px;
  border-bottom:1px solid rgba(12,23,36,.12);
}

.legal-card section:last-child{
  margin-bottom:0;
  padding-bottom:0;
  border-bottom:0;
}

.legal-card h2{
  margin:0 0 16px;
  font-size:clamp(1.6rem,2.5vw,2.4rem);
  line-height:1.05;
  letter-spacing:-.045em;
}

.legal-card h3{
  margin:22px 0 10px;
  font-size:1.1rem;
}

.legal-card p,
.legal-card li{
  color:#526173;
  line-height:1.75;
}

.legal-card p{
  margin:0 0 14px;
}

.legal-card ul{
  margin:0;
  padding-left:20px;
}

.legal-data{
  display:grid;
  gap:12px;
  margin-top:18px;
}

.legal-row{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:18px;
  padding:15px 0;
  border-bottom:1px solid rgba(12,23,36,.1);
}

.legal-row:last-child{
  border-bottom:0;
}

.legal-row span{
  color:#758195;
  font-weight:800;
}

.legal-row strong{
  color:#0c1724;
}

.legal-note{
  padding:18px 20px;
  border-radius:22px;
  background:#f3f7fb;
  border:1px solid rgba(12,23,36,.1);
}

.legal-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
  margin-top:28px;
}

.legal-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:0 20px;
  border-radius:999px;
  font-weight:900;
}

.legal-actions .primary{
  background:#fff;
  color:#07192d;
}

.legal-actions .ghost{
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  background:rgba(255,255,255,.06);
}

@media(max-width:900px){
  .legal-main{
    padding:110px 0 70px;
  }

  .legal-shell{
    grid-template-columns:1fr;
  }

  .legal-nav{
    position:relative;
    top:auto;
  }

  .legal-row{
    grid-template-columns:1fr;
    gap:5px;
  }
}

@media(max-width:640px){
  .legal-hero{
    padding:38px 18px 24px;
  }

  .legal-card{
    padding:24px 18px;
    border-radius:26px;
  }

  .legal-nav{
    border-radius:24px;
  }
}


/* Legal Übersicht: korrektes Scroll-Ziel */
.legal-card section{
  scroll-margin-top:115px;
}

.legal-nav a{
  cursor:pointer;
}


/* Formular Karten leicht himmelblau statt rein weiß */
.hero-form,
.contact-form,
.form-card{
  background:linear-gradient(
    180deg,
    rgba(240,247,255,.96) 0%,
    rgba(232,242,255,.94) 100%
  ) !important;
  backdrop-filter:blur(12px);
}

/* Inputs leicht softer */
.hero-form input,
.hero-form select,
.hero-form textarea,
.contact-form input,
.contact-form select,
.contact-form textarea{
  background:rgba(255,255,255,.72);
}


/* =========================
   COOKIE BANNER
========================= */

.cookie-banner{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:99999;

  background:rgba(8,18,35,.92);
  backdrop-filter:blur(18px);

  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;

  padding:20px;
  box-shadow:0 20px 60px rgba(0,0,0,.45);

  transform:translateY(140%);
  opacity:0;
  pointer-events:none;

  transition:.45s ease;
}

.cookie-banner.show{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}

.cookie-content{
  display:flex;
  justify-content:space-between;
  gap:24px;
  align-items:center;
}

.cookie-text h3{
  color:#fff;
  margin-bottom:6px;
}

.cookie-text p{
  color:rgba(255,255,255,.72);
  max-width:680px;
}

.cookie-actions{
  display:flex;
  gap:12px;
}

.cookie-btn{
  border:none;
  border-radius:999px;
  padding:14px 22px;
  font-weight:700;
  cursor:pointer;
}

.cookie-btn.primary{
  background:#fff;
  color:#081223;
}

.cookie-btn.secondary{
  background:rgba(255,255,255,.08);
  color:#fff;
}

@media(max-width:768px){

  .cookie-content{
    flex-direction:column;
    align-items:flex-start;
  }

  .cookie-actions{
    width:100%;
  }

  .cookie-btn{
    flex:1;
  }

}
	  
@media(max-width:640px){

  .legal-hero h1{
    font-size:clamp(2.35rem,11vw,3.35rem) !important;
    line-height:1.02 !important;
    letter-spacing:-.06em !important;
    max-width:100% !important;
    overflow-wrap:break-word !important;
  }

  .legal-hero{
    overflow:hidden;
  }

}
