/* Reset e font */
*{margin:0;padding:0;box-sizing:border-box;font-family:'Open Sans',sans-serif;}
body{background:#0f0f0f;color:white;scroll-behavior:smooth;}

/* Header */
header{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px;background:#111;flex-wrap:wrap;transition:0.3s;
}
header.scrolled{background:#000;}
.logo{display:flex;align-items:center;gap:10px;cursor:pointer;}
.logo img{width:50px;}
nav a{
  color:white;margin-left:25px;text-decoration:none;font-weight:600;transition:0.3s;
}
nav a:hover{color:#5a3cff;text-shadow:0 0 10px #5a3cff;}

/* Hero Section */
.hero{
  position:relative;height:90vh;overflow:hidden;display:flex;align-items:center;
  justify-content:center;text-align:center;border-radius:15px;margin:20px;
}
.hero video,.hero img{position:absolute;width:100%;height:100%;object-fit:cover;z-index:-1;border-radius:15px;}
.hero-content{
  background:rgba(0,0,0,0.5);padding:40px;border-radius:15px;
  animation:fadeIn 1s;text-align:center;max-width:90%;
}
.hero-content h1{font-family:'Montserrat',sans-serif;font-size:42px;margin-bottom:15px;color:#fff;text-shadow:0 0 15px #5a3cff;}
.hero-content p{font-size:18px;margin-bottom:20px;color:#ccc;}
.btn{
  display:inline-block;padding:14px 28px;background:#5a3cff;color:white;
  text-decoration:none;border-radius:8px;transition:0.4s;
  box-shadow:0 0 10px #5a3cff33;
}
.btn:hover{
  background:#7c5cff;box-shadow:0 0 20px #7c5cffaa;transform:translateY(-3px);
}

/* About */
.about{padding:80px 20px;text-align:center;animation:fadeInUp 1s;}
.about h2{font-family:'Montserrat',sans-serif;font-size:36px;color:#5a3cff;margin-bottom:20px;}
.about p{font-size:18px;line-height:1.6;color:#ccc;max-width:800px;margin:auto;}

/* Services */
.services,.services-page{display:flex;justify-content:center;gap:20px;padding:60px 20px;flex-wrap:wrap;}
.card{
  background:linear-gradient(145deg,#1a1a1a,#222);
  padding:30px;border-radius:15px;width:250px;text-align:center;margin-bottom:20px;
  cursor:pointer;transition:0.4s;box-shadow:0 0 15px #0005;
}
.card:hover{
  transform:translateY(-8px);background:linear-gradient(145deg,#2a2a2a,#3a3a3a);
  box-shadow:0 0 25px #5a3cff66;
}
.price{margin-top:10px;font-size:22px;color:#7c5cff;font-weight:700;}

/* Portfolio */
.portfolio{padding:80px 20px;text-align:center;}
.portfolio h2{font-family:'Montserrat',sans-serif;font-size:36px;color:#5a3cff;margin-bottom:40px;}
.portfolio-grid{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;}
.portfolio-card{
  background:linear-gradient(145deg,#1a1a1a,#222);
  padding:30px;border-radius:15px;width:250px;text-decoration:none;color:white;
  transition:0.4s;box-shadow:0 0 15px #0005;text-align:center;
}
.portfolio-card:hover{
  transform:translateY(-8px);background:linear-gradient(145deg,#2a2a2a,#3a3a3a);
  box-shadow:0 0 25px #5a3cff66;
}

/* Modal */
.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;
background:rgba(0,0,0,0.85);justify-content:center;align-items:center;z-index:100;}
.modal-content{
  background:#1a1a1a;padding:30px;border-radius:15px;width:90%;max-width:600px;
  position:relative;animation:fadeIn 0.5s;box-shadow:0 0 25px #5a3cff66;
}
.close{position:absolute;top:15px;right:20px;font-size:28px;cursor:pointer;color:white;transition:0.3s;}
.close:hover{color:#5a3cff;transform:scale(1.1);}

/* Contact */
.contact{padding:80px 20px;text-align:center;animation:fadeInUp 1s;}
.contact h2{font-family:'Montserrat',sans-serif;font-size:36px;margin-bottom:20px;color:#5a3cff;}
.contact p{margin-bottom:30px;font-size:18px;color:#ccc;}
form{max-width:400px;margin:auto;display:flex;flex-direction:column;gap:15px;}
input,textarea{padding:14px;border:none;border-radius:10px;font-size:16px;background:#222;color:white;}
input:focus,textarea:focus{outline:none;border:2px solid #5a3cff;}
button{padding:14px;background:#5a3cff;color:white;border:none;border-radius:10px;cursor:pointer;font-size:16px;transition:0.4s;box-shadow:0 0 10px #5a3cff44;}
button:hover{background:#7c5cff;box-shadow:0 0 20px #7c5cffaa;transform:translateY(-3px);}

/* Footer */
footer{text-align:center;padding:20px;background:#111;margin-top:40px;color:#ccc;}

/* Animazioni */
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}

/* Responsive */
@media (max-width:768px){
header{flex-direction:column;gap:10px;}
.hero-content h1{font-size:32px;}
.services,.services-page{flex-direction:column;align-items:center;}
.card,.portfolio-card{width:90%;}
.modal-content{width:95%;}
.contact h2{font-size:28px;}
form input,form textarea{font-size:14px;}
button{font-size:14px;}
}