.hero-video{
  position:absolute;
  inset:0;

  width:100%;
  height:100%;

  object-fit:cover;

  opacity:.42;

  z-index:1;

  filter:
    saturate(1.15)
    contrast(1.05)
    brightness(.75);
}

.hero{
  position:relative;

  min-height:100vh;

  display:flex;
  align-items:center;

  padding:120px 60px;
}

.hero-bg{
  position:absolute;
  inset:0;

  background:
    radial-gradient(circle at top left,
      rgba(0,140,255,.25),
      transparent 35%
    ),
    radial-gradient(circle at bottom right,
      rgba(255,120,0,.18),
      transparent 30%
    ),
    linear-gradient(
      180deg,
      #050816 0%,
      #02040d 100%
    );

  z-index:0;
}

.hero-overlay{
  position:absolute;
  inset:0;

  background:
    linear-gradient(
      to bottom,
      rgba(0,0,0,.35),
      rgba(0,0,0,.65)
    );

  z-index:2;
}

.hero-content{
  position:relative;
  z-index:20;
  max-width:900px;
}

.hero-kicker{
  display:inline-flex;
  align-items:center;
  padding:10px 18px;

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

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

  border-radius:999px;

  color:rgba(255,255,255,.7);

  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;

  margin-bottom:28px;

  backdrop-filter:blur(10px);
}

.hero h1{
  font-size:clamp(64px,9vw,120px);
  line-height:.95;
  font-weight:800;
  letter-spacing:-.05em;

  margin:0;

  color:white;

  max-width:900px;
}

.hero p{
  margin-top:36px;

  max-width:760px;

  font-size:22px;
  line-height:1.8;

  color:rgba(255,255,255,.72);
}

.hero-actions{
  display:flex;
  gap:18px;
  margin-top:42px;
  flex-wrap:wrap;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:16px 28px;

  border-radius:18px;

  text-decoration:none;

  font-weight:700;

  transition:.25s ease;
}

.btn.primary{
  background:linear-gradient(
    135deg,
    #0ea5ff,
    #2563eb
  );

  color:white;

  box-shadow:
    0 10px 40px rgba(37,99,235,.35);
}

.btn.primary:hover{
  transform:translateY(-2px);
}

.btn.secondary{
  border:1px solid rgba(255,255,255,.1);

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

  color:white;

  backdrop-filter:blur(10px);
}

.btn.secondary:hover{
  background:rgba(255,255,255,.09);
}

@media(max-width:768px){

  .hero{
    padding:100px 28px;
  }

  .hero h1{
    font-size:56px;
  }

  .hero p{
    font-size:18px;
    line-height:1.7;
  }

}
.hero-grid{
  position:relative;
  z-index:20;

  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:60px;

  width:100%;

  align-items:center;
}

.hero-visual{
  position:relative;

  display:flex;
  flex-direction:column;
  gap:20px;

  align-items:flex-end;
}

.glass-card{
  width:320px;

  padding:22px;

  border-radius:24px;

  background:
    linear-gradient(
      135deg,
      rgba(255,255,255,.09),
      rgba(255,255,255,.03)
    );

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

  backdrop-filter:blur(24px);

  box-shadow:
    0 10px 40px rgba(0,0,0,.35);

  display:flex;
  align-items:center;
  gap:18px;

  transition:.3s ease;
}

.glass-card:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.16);
}

.glass-card.big{
  width:360px;

  background:
    linear-gradient(
      135deg,
      rgba(14,165,255,.18),
      rgba(37,99,235,.08)
    );
}

.service-icon{
  width:52px;
  height:52px;

  border-radius:16px;

  display:flex;
  align-items:center;
  justify-content:center;

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

  font-size:24px;
}

.glass-card strong{
  display:block;
  font-size:18px;
  color:white;
}

.glass-card span{
  color:rgba(255,255,255,.6);
  font-size:14px;
}

.status-dot{
  width:12px;
  height:12px;

  border-radius:999px;

  background:#22c55e;

  box-shadow:
    0 0 20px #22c55e;
}

@media(max-width:1100px){

  .hero-grid{
    grid-template-columns:1fr;
  }

  .hero-visual{
    align-items:flex-start;
  }

}
.hero::after{
  content:"";

  position:absolute;
  inset:0;

  background:
    radial-gradient(
      circle at center,
      transparent 40%,
      rgba(0,0,0,.45) 100%
    );

  z-index:3;

  pointer-events:none;
}
.glass-card{
  animation:float 6s ease-in-out infinite;
}

.glass-card:nth-child(2){
  animation-delay:1s;
}

.glass-card:nth-child(3){
  animation-delay:2s;
}

@keyframes float{

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

  50%{
    transform:translateY(-10px);
  }

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

}

.hero{
  position:relative;
  z-index:5;
}
.services,
.timeline-section,
.contact{
  position:relative;
  z-index:10;
}
