.vsdemo-page{
  position:relative;
  overflow:clip;
  background:
    radial-gradient(920px 520px at 8% 8%, rgba(123,199,255,.12), transparent 55%),
    radial-gradient(760px 420px at 88% 12%, rgba(139,115,255,.14), transparent 52%),
    radial-gradient(720px 400px at 50% 100%, rgba(0,224,255,.06), transparent 60%),
    linear-gradient(180deg,#05070c 0%,#090c13 40%,#05070b 100%);
}

.vsdemo-page::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.02), rgba(255,255,255,0)),
    radial-gradient(circle at center, rgba(255,255,255,.03) 0, transparent 60%);
  opacity:.65;
}

.vsdemo-shell{
  width:min(calc(100% - 32px), 1180px);
  margin:0 auto;
  position:relative;
  z-index:1;
}

.vsdemo-hero{
  padding:118px 0 90px;
}

.vsdemo-hero__grid{
  display:grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 440px);
  gap:36px;
  align-items:center;
}

.vsdemo-copy{
  max-width:760px;
}

.vsdemo-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  margin:0 0 14px;
  color:#d8e9ff;
  font-size:.76rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:800;
}

.vsdemo-eyebrow::before{
  content:"";
  width:34px;
  height:1px;
  background:linear-gradient(90deg, rgba(123,199,255,.95), rgba(123,199,255,0));
  flex:none;
}

.vsdemo-title{
  margin:0 0 18px;
  max-width:920px;
  font-size:clamp(2.35rem, 4.2vw, 4.7rem);
  line-height:.96;
  letter-spacing:-.04em;
  font-weight:900;
  color:#fff;
  text-wrap:balance;
}

.vsdemo-subtitle,
.vsdemo-head p,
.vsdemo-feature-card p,
.vsdemo-use-card p,
.vsdemo-step p,
.vsdemo-final-card p,
.vsdemo-person span{
  color:rgba(223,232,245,.78);
  line-height:1.72;
}

.vsdemo-subtitle{
  max-width:760px;
  font-size:1.05rem;
}

.vsdemo-actions{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}

.vsdemo-actions--center{
  justify-content:center;
}

.vsdemo-trust{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:24px;
}

.vsdemo-trust span{
  padding:10px 15px;
  border-radius:999px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(255,255,255,.09);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 8px 24px rgba(0,0,0,.18);
  color:#d8e4f2;
  font-size:.87rem;
  font-weight:600;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
}

.vsdemo-device-wrap{
  position:relative;
  display:flex;
  justify-content:center;
}

.vsdemo-device-glow{
  position:absolute;
  inset:auto 50% 6% auto;
  width:320px;
  height:320px;
  transform:translateX(35%);
  border-radius:50%;
  background:radial-gradient(circle, rgba(123,199,255,.32) 0%, rgba(123,199,255,.14) 32%, transparent 72%);
  filter:blur(20px);
  pointer-events:none;
}

.vsdemo-phone{
  position:relative;
  width:min(100%, 390px);
  border-radius:36px;
  padding:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.12);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 24px 70px rgba(0,0,0,.42);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
}

.vsdemo-phone__top{
  display:flex;
  justify-content:center;
  padding:4px 0 10px;
}

.vsdemo-phone__top span{
  display:block;
  width:78px;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
}

.vsdemo-card{
  border-radius:28px;
  overflow:hidden;
  background:
    linear-gradient(180deg, rgba(9,17,31,.98), rgba(7,12,22,.98));
  border:1px solid rgba(255,255,255,.06);
}

.vsdemo-card__cover{
  height:120px;
  background:
    radial-gradient(320px 140px at 18% 10%, rgba(123,199,255,.32), transparent 56%),
    radial-gradient(280px 140px at 88% 0%, rgba(139,115,255,.28), transparent 56%),
    linear-gradient(135deg, #0d1422 0%, #111b2f 48%, #0c1321 100%);
}

.vsdemo-card__profile{
  position:relative;
  padding:0 20px 18px;
  margin-top:-42px;
}

.vsdemo-avatar{
  width:84px;
  height:84px;
  border-radius:22px;
  display:grid;
  place-items:center;
  font-weight:900;
  font-size:1.5rem;
  color:#06111f;
  background:linear-gradient(135deg, #7bc7ff 0%, #79f2d7 100%);
  border:4px solid rgba(8,13,22,1);
  box-shadow:0 14px 30px rgba(0,0,0,.28);
}

.vsdemo-person{
  margin-top:14px;
}

.vsdemo-person h2{
  margin:0 0 4px;
  font-size:1.35rem;
  line-height:1.08;
  color:#fff;
  letter-spacing:-.03em;
}

.vsdemo-person p{
  margin:0 0 4px;
  color:#96d5ff;
  font-weight:700;
}

.vsdemo-person span{
  font-size:.92rem;
}

.vsdemo-quick-actions{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:10px;
  padding:0 20px 18px;
}

.vsdemo-qbtn{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:44px;
  border-radius:14px;
  color:#ebf4ff;
  font-weight:700;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.045);
  transition:transform .2s ease, border-color .2s ease, background-color .2s ease;
}

.vsdemo-qbtn:hover{
  transform:translateY(-2px);
  border-color:rgba(123,199,255,.25);
  background:rgba(255,255,255,.07);
}

.vsdemo-info-list{
  display:grid;
  gap:10px;
  padding:0 20px 18px;
}

.vsdemo-info-item{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:13px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.06);
  background:rgba(255,255,255,.035);
}

.vsdemo-info-item strong{
  color:#f4f8ff;
  font-size:.95rem;
}

.vsdemo-info-item span{
  color:rgba(223,232,245,.72);
  text-align:right;
  font-size:.93rem;
}

.vsdemo-socials{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding:0 20px 18px;
}

.vsdemo-socials a{
  padding:9px 13px;
  border-radius:999px;
  font-size:.84rem;
  font-weight:700;
  text-decoration:none;
  color:#d8e4f2;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.08);
}

.vsdemo-bottom-actions{
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  padding:0 20px 22px;
}

.vsdemo-main-btn,
.vsdemo-secondary-btn{
  min-height:48px;
  border:none;
  border-radius:16px;
  font-weight:800;
  cursor:pointer;
  transition:transform .2s ease, opacity .2s ease;
}

.vsdemo-main-btn:hover,
.vsdemo-secondary-btn:hover{
  transform:translateY(-1px);
}

.vsdemo-main-btn{
  color:#06111f;
  background:linear-gradient(135deg, #7bc7ff 0%, #6fe5ff 46%, #79f2d7 100%);
  box-shadow:0 14px 34px rgba(123,199,255,.28);
}

.vsdemo-secondary-btn{
  padding:0 18px;
  color:#ecf4ff;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.09);
}

.vsdemo-section{
  position:relative;
  padding:84px 0;
}

.vsdemo-section--alt{
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
}

.vsdemo-head{
  max-width:800px;
  margin:0 auto 30px;
  text-align:center;
}

.vsdemo-head h2,
.vsdemo-final-card h2{
  margin:0 0 14px;
  color:#fff;
  font-size:clamp(1.8rem, 2.6vw, 3rem);
  line-height:1.02;
  letter-spacing:-.03em;
}

.vsdemo-feature-grid,
.vsdemo-use-grid,
.vsdemo-steps{
  display:grid;
  gap:18px;
}

.vsdemo-feature-grid{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.vsdemo-use-grid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.vsdemo-steps{
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.vsdemo-feature-card,
.vsdemo-use-card,
.vsdemo-step,
.vsdemo-final-card{
  position:relative;
  border-radius:24px;
  border:1px solid rgba(255,255,255,.11);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.08),
    0 24px 60px rgba(0,0,0,.24);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}

.vsdemo-feature-card::before,
.vsdemo-use-card::before,
.vsdemo-step::before,
.vsdemo-final-card::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,0));
}

.vsdemo-feature-card,
.vsdemo-use-card,
.vsdemo-step{
  padding:1.55rem;
}

.vsdemo-feature-card h3,
.vsdemo-use-card h3,
.vsdemo-step h3{
  margin:0 0 10px;
  color:#fff;
  font-size:1.08rem;
  line-height:1.2;
  letter-spacing:-.02em;
}

.vsdemo-icon,
.vsdemo-step span{
  display:inline-grid;
  place-items:center;
  width:42px;
  height:42px;
  margin-bottom:16px;
  border-radius:12px;
  background:linear-gradient(180deg, rgba(123,199,255,.18), rgba(123,199,255,.08));
  border:1px solid rgba(123,199,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
  color:#91d4ff;
  font-size:.95rem;
  font-weight:900;
}

.vsdemo-final{
  padding-bottom:110px;
}

.vsdemo-final-card{
  max-width:840px;
  margin:0 auto;
  padding:34px 28px;
  text-align:center;
}

@media (max-width: 1080px){
  .vsdemo-hero__grid{
    grid-template-columns:1fr;
  }

  .vsdemo-device-wrap{
    margin-top:8px;
  }

  .vsdemo-feature-grid,
  .vsdemo-steps{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px){
  .vsdemo-shell{
    width:min(calc(100% - 20px), 1180px);
  }

  .vsdemo-hero{
    padding:98px 0 70px;
  }

  .vsdemo-section{
    padding:72px 0;
  }

  .vsdemo-final{
    padding-bottom:92px;
  }

  .vsdemo-title{
    font-size:clamp(2rem, 10vw, 3.2rem);
    line-height:1.01;
  }

  .vsdemo-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .vsdemo-actions .vs-btn{
    width:100%;
    justify-content:center;
  }

  .vsdemo-trust{
    gap:10px;
  }

  .vsdemo-trust span{
    width:100%;
    text-align:center;
  }

  .vsdemo-feature-grid,
  .vsdemo-use-grid,
  .vsdemo-steps{
    grid-template-columns:1fr;
  }

  .vsdemo-quick-actions{
    grid-template-columns:1fr;
  }

  .vsdemo-bottom-actions{
    grid-template-columns:1fr;
  }

  .vsdemo-main-btn,
  .vsdemo-secondary-btn{
    width:100%;
  }

  .vsdemo-info-item{
    flex-direction:column;
    align-items:flex-start;
  }

  .vsdemo-info-item span{
    text-align:left;
  }
}