*{margin:0;padding:0;box-sizing:border-box}body{font-family:Manrope,sans-serif;background:#f7f9fd;color:#182232;overflow:hidden}
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:100vh;align-items:center;padding:6vw;gap:5vw}
.badge{display:inline-block;padding:.6rem 1rem;background:#fff;border-radius:999px;box-shadow:0 10px 30px rgba(0,0,0,.08);margin-bottom:2rem}
h1{font-size:clamp(3.5rem,8vw,6.8rem);line-height:.95}
h1 span{background:linear-gradient(90deg,#4d7cff,#755cff);-webkit-background-clip:text;color:transparent}
p{max-width:36rem;margin:2rem 0;color:#5c6677;font-size:1.15rem;line-height:1.8}
.btn{display:inline-block;padding:1rem 1.8rem;border-radius:999px;text-decoration:none;color:#fff;background:linear-gradient(90deg,#4d7cff,#755cff);box-shadow:0 20px 50px rgba(77,124,255,.25)}
.visual{display:flex;justify-content:center}
.frame{width:min(540px,90vw);aspect-ratio:4/5;border-radius:32px;background:rgba(255,255,255,.7);backdrop-filter:blur(16px);box-shadow:0 30px 80px rgba(0,0,0,.12);overflow:hidden}
.frame img{width:100%;height:100%;object-fit:cover}
.blob{position:fixed;border-radius:50%;filter:blur(90px);opacity:.45;animation:f 12s ease-in-out infinite}
.b1{width:420px;height:420px;background:#755cff;right:-120px;top:-100px}.b2{width:380px;height:380px;background:#4d7cff;left:-120px;bottom:-120px;animation-delay:-6s}
footer{position:fixed;bottom:16px;width:100%;text-align:center;color:#7c8597}
@keyframes f{50%{transform:translate(20px,25px) scale(1.06)}}
@media(max-width:900px){body{overflow:auto}.hero{grid-template-columns:1fr;padding-top:4rem}.visual{order:-1}.frame{max-width:420px}}