/* ============ VITA Sicherheit & Services ============ */
:root{
  --bg:#0B0B0D;
  --bg-2:#121216;
  --bg-3:#17171C;
  --line:rgba(255,255,255,.08);
  --txt:#F2F2EF;
  --txt-dim:rgba(242,242,239,.62);
  --red:#D22630;
  --red-soft:rgba(210,38,48,.14);
  --max:1200px;
  --ease:cubic-bezier(.22,.7,.25,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--txt);
  font-family:'Jost',system-ui,-apple-system,sans-serif;
  font-weight:300;line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}
em{font-style:normal;color:var(--red)}

h1,h2,h3,h4{font-weight:600;line-height:1.12;letter-spacing:.01em}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:1.25rem;font-weight:500;letter-spacing:.04em}

/* ---------- kicker / accents ---------- */
.kicker{
  display:flex;align-items:center;gap:14px;
  font-size:.8rem;font-weight:500;letter-spacing:.42em;color:var(--txt-dim);
  margin-bottom:18px;text-transform:uppercase;
}
.red-dash{display:inline-block;width:42px;height:2px;background:var(--red);flex:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;padding:14px 34px;
  font-family:inherit;font-size:.92rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid transparent;cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s, color .35s, border-color .35s;
}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(210,38,48,.55);background:#E03340}
.btn-ghost{border-color:rgba(255,255,255,.35);color:var(--txt)}
.btn-ghost:hover{border-color:#fff;transform:translateY(-2px)}
.btn-outline{border-color:var(--red);color:var(--txt)}
.btn-outline:hover{background:var(--red);color:#fff;transform:translateY(-2px)}
.btn-lg{padding:18px 44px;font-size:1.05rem}

/* ---------- nav ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  padding:18px 0;
  transition:background .4s,padding .4s,box-shadow .4s;
}
.nav.scrolled{
  background:rgba(11,11,13,.86);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  padding:10px 0;
  box-shadow:0 1px 0 var(--line);
}
.nav-inner{max-width:var(--max);margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:42px;width:auto;transition:height .4s}
.nav.scrolled .nav-logo img{height:34px}
.nav-links{display:flex;align-items:center;gap:38px}
.nav-links a{
  font-size:.88rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--txt-dim);
  position:relative;padding:4px 0;transition:color .3s;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1.5px;
  background:var(--red);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease);
}
.nav-links a:hover{color:var(--txt)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-links a.nav-cta{
  border:1px solid var(--red);padding:9px 22px;color:var(--txt);
}
.nav-links a.nav-cta::after{display:none}
.nav-links a.nav-cta:hover{background:var(--red);color:#fff}
.nav-burger{display:none;background:none;border:0;width:38px;height:32px;position:relative;cursor:pointer}
.nav-burger span{position:absolute;left:6px;right:6px;height:2px;background:var(--txt);transition:all .3s var(--ease)}
.nav-burger span:nth-child(1){top:8px}.nav-burger span:nth-child(2){top:15px}.nav-burger span:nth-child(3){top:22px}
.nav-burger.open span:nth-child(1){top:15px;transform:rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){top:15px;transform:rotate(-45deg)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-bg img{
  width:100%;height:100%;object-fit:cover;
  animation:kenburns 24s var(--ease) both;
  will-change:transform;
}
@keyframes kenburns{from{transform:scale(1.14) translate(2%,1%)}to{transform:scale(1)}}
.hero-vignette{
  position:absolute;inset:0;
  background:
    linear-gradient(100deg,rgba(11,11,13,.94) 22%,rgba(11,11,13,.55) 55%,rgba(11,11,13,.25) 100%),
    linear-gradient(0deg,var(--bg) 0%,transparent 26%),
    linear-gradient(180deg,rgba(11,11,13,.55) 0%,transparent 22%);
}
.hero-content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:120px 24px 80px;width:100%}
.hero-kicker{
  display:flex;align-items:center;gap:16px;
  font-size:.85rem;font-weight:500;letter-spacing:.5em;color:var(--txt-dim);margin-bottom:26px;
}
.hero h1{font-size:clamp(2.8rem,8vw,5.6rem);font-weight:700;text-transform:uppercase;letter-spacing:.015em}
.hero h1 .line{display:block}
.hero h1 .accent{color:var(--red)}
.hero-sub{max-width:560px;margin:28px 0 40px;font-size:1.12rem;color:var(--txt-dim)}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap}
.scroll-hint{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;
  width:26px;height:44px;border:1.5px solid rgba(255,255,255,.4);border-radius:14px;
}
.scroll-hint span{
  position:absolute;top:8px;left:50%;width:3px;height:9px;margin-left:-1.5px;
  background:var(--red);border-radius:2px;animation:scrollhint 1.8s infinite var(--ease);
}
@keyframes scrollhint{0%{transform:translateY(0);opacity:1}70%{transform:translateY(16px);opacity:0}100%{opacity:0}}

/* hero reveal */
.reveal-hero{opacity:0;transform:translateY(34px);animation:heroin 1s var(--ease) forwards;animation-delay:var(--d,0s)}
@keyframes heroin{to{opacity:1;transform:none}}

/* ---------- stats ---------- */
.stats{border-block:1px solid var(--line);background:var(--bg-2)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding-block:54px}
.stat{text-align:center}
.stat-num{font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--txt)}
.stat-num .count{color:var(--red)}
.stat-label{font-size:.85rem;letter-spacing:.24em;text-transform:uppercase;color:var(--txt-dim);margin-top:6px}

/* ---------- marquee ---------- */
.marquee{overflow:hidden;padding:26px 0;border-bottom:1px solid var(--line);position:relative}
.marquee::before,.marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.marquee-track{display:flex;gap:44px;width:max-content;animation:marquee 36s linear infinite}
.marquee-track span{
  font-size:1.05rem;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:rgba(242,242,239,.32);white-space:nowrap;
}
.marquee-track i{color:var(--red);font-style:normal;opacity:.75}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
.section{padding:110px 0}
.section-alt{background:var(--bg-2);border-block:1px solid var(--line)}
.section-head{max-width:640px;margin-bottom:64px}
.section-head p{color:var(--txt-dim);margin-top:16px;font-size:1.05rem}

/* ---------- cards ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{
  background:var(--bg-3);border:1px solid var(--line);
  overflow:hidden;position:relative;
  transition:transform .5s var(--ease),border-color .5s,box-shadow .5s var(--ease);
}
.card::after{
  content:"";position:absolute;left:0;bottom:0;height:3px;width:100%;
  background:var(--red);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.card:hover{transform:translateY(-8px);border-color:rgba(210,38,48,.4);box-shadow:0 26px 60px -24px rgba(0,0,0,.8)}
.card:hover::after{transform:scaleX(1)}
.card-img{aspect-ratio:16/10;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease);filter:saturate(.92)}
.card:hover .card-img img{transform:scale(1.07)}
.card-body{padding:26px 26px 30px}
.card-body h3{margin-bottom:10px}
.card-body p{color:var(--txt-dim);font-size:.98rem}

/* ---------- split sections ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.split-rev .split-text{order:1}
.split-rev .split-media{order:2}
.split-media{position:relative}
.split-media img{width:100%;aspect-ratio:4/3.4;object-fit:cover;position:relative;z-index:1}
.split-media-frame{
  position:absolute;inset:-18px 18px 18px -18px;border:1px solid rgba(210,38,48,.5);z-index:0;
}
.split-text h2{margin-bottom:20px}
.split-text>p{color:var(--txt-dim);margin-bottom:26px}
.checklist{list-style:none;margin-bottom:36px}
.checklist li{
  padding:13px 0 13px 38px;position:relative;border-bottom:1px solid var(--line);
  font-weight:400;letter-spacing:.02em;
}
.checklist li::before{
  content:"";position:absolute;left:2px;top:50%;transform:translateY(-50%) rotate(-45deg);
  width:12px;height:7px;border-left:2.5px solid var(--red);border-bottom:2.5px solid var(--red);
}

/* ---------- values ---------- */
.values{display:grid;gap:26px;margin-top:34px}
.value{display:flex;gap:20px;align-items:flex-start}
.value img{flex:none;margin-top:5px}
.value h4{font-size:1.06rem;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.value p{color:var(--txt-dim);font-size:.96rem}

/* ---------- CTA band ---------- */
.cta{
  position:relative;overflow:hidden;text-align:center;
  padding:120px 0;background:linear-gradient(120deg,#15070a 0%,var(--bg-2) 60%);
  border-block:1px solid var(--line);
}
.cta-mark{position:absolute;right:-4%;top:50%;transform:translateY(-50%);width:420px;opacity:.05;pointer-events:none}
.cta-inner{position:relative;z-index:1}
.cta h2{margin-bottom:14px}
.cta p{color:var(--txt-dim);margin-bottom:34px}

/* ---------- kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:start}
.contact-info{display:grid;gap:18px}
.contact-tile{
  display:block;background:var(--bg-3);border:1px solid var(--line);padding:24px 26px;
  transition:border-color .35s,transform .35s var(--ease);
}
a.contact-tile:hover{border-color:var(--red);transform:translateX(6px)}
.contact-label{display:block;font-size:.78rem;letter-spacing:.3em;text-transform:uppercase;color:var(--txt-dim);margin-bottom:6px}
.contact-value{font-size:1.18rem;font-weight:500}
.contact-form{display:grid;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.contact-form label{display:grid;gap:8px;font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;color:var(--txt-dim)}
.contact-form input,.contact-form textarea{
  background:var(--bg-3);border:1px solid var(--line);color:var(--txt);
  padding:14px 16px;font-family:inherit;font-size:1rem;font-weight:300;
  transition:border-color .3s;resize:vertical;
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--red)}
.contact-form .btn{justify-self:start}
.form-note{font-size:.8rem;color:var(--txt-dim);letter-spacing:.02em}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:60px 0 40px;background:var(--bg-2)}
.footer-inner{display:grid;gap:28px;justify-items:center;text-align:center}
.footer-links{display:flex;gap:30px;flex-wrap:wrap;justify-content:center}
.footer-links a{font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;color:var(--txt-dim);transition:color .3s}
.footer-links a:hover{color:var(--red)}
.footer-copy{font-size:.82rem;color:var(--txt-dim)}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ease),transform .9s var(--ease);transition-delay:var(--d,0s)}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .cards{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:46px}
  .split-rev .split-text{order:2}
  .split-rev .split-media{order:1}
  .stats-grid{grid-template-columns:1fr 1fr;gap:36px 20px}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:720px){
  .cards{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section{padding:80px 0}
  .nav-links{
    position:fixed;inset:0;background:rgba(11,11,13,.97);
    flex-direction:column;justify-content:center;gap:34px;
    opacity:0;pointer-events:none;transition:opacity .35s;
  }
  .nav-links.open{opacity:1;pointer-events:auto}
  .nav-links a{font-size:1.05rem}
  .nav-burger{display:block;z-index:110}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .reveal,.reveal-hero{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
