.vgo-phone-wrap{ perspective: 1400px; pointer-events: none; }
.vgo-phone{
    width: 240px; height: 485px; border-radius: 40px;
    background: linear-gradient(160deg, #1a1f2e 0%, #0c0f17 100%);
    box-shadow:
        0 30px 60px -20px rgba(0,0,0,.55),
        0 0 0 1px rgba(255,255,255,.06) inset,
        0 0 0 8px #14171f,
        0 0 0 9px rgba(255,255,255,.04);
    transform: rotateY(-14deg) rotateX(6deg) rotateZ(-1deg);
    transform-style: preserve-3d;
    animation: vgoPhoneFloat 7.5s ease-in-out infinite;
}
.vgo-phone__screen{
    position: absolute; inset: 7px; border-radius: 35px; overflow: hidden;
    background: linear-gradient(170deg, #225193 0%, #00AFEF 60%, #0a3a73 100%);
}
.vgo-phone__island{
    position: absolute; top: 10px; left: 50%; transform: translateX(-50%);
    width: 82px; height: 22px; border-radius: 12px; background: #000; z-index: 4;
}
.vgo-phone__statusbar{
    position: absolute; top: 14px; left: 0; right: 0; z-index: 5;
    display: flex; justify-content: space-between; align-items: center;
    padding: 0 18px; color: #fff; font-size: 10px; font-weight: 700; pointer-events: none;
}
.vgo-phone__badge{
    position: absolute; backdrop-filter: blur(8px); background: rgba(255,255,255,.92);
    border-radius: 14px; padding: 8px 12px; box-shadow: 0 14px 30px -10px rgba(0,0,0,.35);
    animation: vgoPhoneFloat 6s ease-in-out infinite;
}
@keyframes vgoPhoneFloat{
    0%,100% { transform: rotateY(-14deg) rotateX(6deg) translateY(0)    rotateZ(-1deg); }
    50%     { transform: rotateY(-12deg) rotateX(5deg) translateY(-10px) rotateZ(-1deg); }
}
@media (min-width: 1280px){
    .hero-section{ min-height: 560px; height: clamp(560px, 64vh, 660px); }
}
@media (prefers-reduced-motion: reduce){
    .vgo-phone, .vgo-phone__badge { animation: none !important; }
}
