/* ===== Reset & Base ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Prompt','Segoe UI',sans-serif;
  color:#1a1a2e;background:#ffffff;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

:root{
  --primary:#5b21b6;
  --primary-2:#7c3aed;
  --accent:#06b6d4;
  --dark:#0f172a;
  --muted:#64748b;
  --bg-soft:#f8fafc;
  --border:#e2e8f0;
  --gradient:linear-gradient(135deg,#5b21b6 0%,#7c3aed 50%,#06b6d4 100%);
  --shadow-md:0 10px 30px -10px rgba(91,33,182,.25);
  --shadow-lg:0 20px 50px -15px rgba(91,33,182,.3);
  --radius:14px;
}

.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ===== Header ===== */
.header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.logo{font-size:1.6rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.5px}
.nav-links{display:flex;gap:32px;list-style:none;align-items:center}
.nav-links a{font-weight:500;color:#334155;transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--primary)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:var(--gradient);border-radius:2px}
.nav-cta{padding:10px 22px;background:var(--gradient);color:#fff!important;border-radius:999px;font-weight:600;box-shadow:var(--shadow-md);transition:transform .2s}
.nav-cta:hover{transform:translateY(-2px)}
.menu-toggle{display:none;background:none;border:none;font-size:1.6rem;cursor:pointer;color:var(--dark)}

/* ===== Hero ===== */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#faf5ff 0%,#ffffff 100%);
  padding:80px 0 100px;
}
.hero::before{
  content:"";position:absolute;top:-100px;right:-100px;width:500px;height:500px;
  background:radial-gradient(circle,rgba(124,58,237,.15) 0%,transparent 70%);
  border-radius:50%;
}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-block;padding:6px 16px;background:#ede9fe;color:var(--primary);border-radius:999px;font-size:.85rem;font-weight:600;margin-bottom:20px}
.hero h1{font-size:clamp(2.2rem,4.5vw,3.5rem);line-height:1.15;font-weight:800;letter-spacing:-1px;margin-bottom:20px;color:var(--dark)}
.hero h1 span{background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:1.15rem;color:var(--muted);margin-bottom:32px;max-width:520px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:999px;font-weight:600;transition:all .25s;cursor:pointer;border:none;font-size:1rem}
.btn-primary{background:var(--gradient);color:#fff;box-shadow:var(--shadow-md)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.btn-outline{background:#fff;color:var(--dark);border:2px solid var(--border)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.hero-img{position:relative}
.hero-img img{border-radius:var(--radius);box-shadow:var(--shadow-lg)}

/* ===== Section ===== */
.section{padding:90px 0}
.section-soft{background:var(--bg-soft)}
.section-head{text-align:center;max-width:720px;margin:0 auto 60px}
.section-tag{display:inline-block;color:var(--primary);font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.85rem;margin-bottom:12px}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:800;letter-spacing:-.5px;margin-bottom:16px;color:var(--dark)}
.section-head p{color:var(--muted);font-size:1.1rem}

/* ===== Cards / Grid ===== */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;align-items:center}
.card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:32px;transition:all .3s;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card-icon{
  width:56px;height:56px;border-radius:14px;
  background:var(--gradient);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;margin-bottom:20px;
}
.card h3{font-size:1.3rem;margin-bottom:12px;color:var(--dark);font-weight:700}
.card p{color:var(--muted)}
.card ul{list-style:none;margin-top:14px}
.card li{padding:6px 0;color:#475569;display:flex;gap:8px}
.card li::before{content:"✓";color:var(--accent);font-weight:bold}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.stat{text-align:center;padding:24px;background:#fff;border-radius:var(--radius);border:1px solid var(--border)}
.stat-num{font-size:2.4rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-label{color:var(--muted);font-size:.95rem;margin-top:4px}

/* ===== Portfolio ===== */
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.portfolio-item{
  position:relative;border-radius:var(--radius);overflow:hidden;
  cursor:pointer;box-shadow:var(--shadow-md);transition:transform .3s;
}
.portfolio-item:hover{transform:translateY(-6px)}
.portfolio-item img{aspect-ratio:4/3;object-fit:cover;transition:transform .5s}
.portfolio-item:hover img{transform:scale(1.05)}
.portfolio-overlay{
  position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,23,42,.92) 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;
}
.portfolio-overlay h3{font-size:1.25rem;margin-bottom:6px}
.portfolio-overlay span{font-size:.85rem;opacity:.85;color:#a5f3fc}

/* ===== Process / Timeline ===== */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;position:relative}
.process-step{text-align:center;padding:28px 20px;background:#fff;border-radius:var(--radius);border:1px solid var(--border);position:relative}
.process-step .num{
  width:46px;height:46px;border-radius:50%;background:var(--gradient);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;margin:0 auto 16px;
}
.process-step h4{margin-bottom:8px;color:var(--dark)}
.process-step p{color:var(--muted);font-size:.95rem}

/* ===== Pricing ===== */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.price-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:36px 28px;
  text-align:center;transition:all .3s;position:relative;
}
.price-card.featured{
  border-color:transparent;background:var(--gradient);color:#fff;transform:scale(1.04);
  box-shadow:var(--shadow-lg);
}
.price-card.featured h3,.price-card.featured .price{color:#fff}
.price-card.featured li{color:rgba(255,255,255,.92)}
.price-card.featured li::before{color:#fff}
.price-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:#fff;color:var(--primary);padding:4px 14px;border-radius:999px;font-size:.8rem;font-weight:700}
.price-card h3{font-size:1.3rem;margin-bottom:8px}
.price{font-size:2.6rem;font-weight:800;color:var(--dark);margin:14px 0}
.price small{font-size:.9rem;font-weight:500;color:var(--muted)}
.price-card.featured .price small{color:rgba(255,255,255,.85)}
.price-card ul{list-style:none;text-align:left;margin:24px 0}
.price-card li{padding:8px 0;display:flex;gap:8px;color:#475569}
.price-card li::before{content:"✓";color:var(--accent);font-weight:bold}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:start}
.contact-info{background:var(--gradient);color:#fff;padding:40px;border-radius:var(--radius)}
.contact-info h3{font-size:1.5rem;margin-bottom:18px}
.contact-info p{opacity:.9;margin-bottom:30px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px}
.contact-list li{display:flex;gap:14px;align-items:flex-start}
.contact-icon{width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-list strong{display:block;margin-bottom:2px}
.form{background:#fff;padding:36px;border-radius:var(--radius);border:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{margin-bottom:18px}
.form-group label{display:block;margin-bottom:6px;font-weight:600;color:var(--dark);font-size:.95rem}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;
  font-family:inherit;font-size:1rem;transition:border-color .2s;background:#fff;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}
.form-group textarea{resize:vertical;min-height:120px}

/* ===== CTA Banner ===== */
.cta-banner{
  background:var(--gradient);color:#fff;padding:70px 40px;border-radius:var(--radius);
  text-align:center;box-shadow:var(--shadow-lg);
}
.cta-banner h2{font-size:clamp(1.6rem,3vw,2.3rem);margin-bottom:14px;font-weight:800}
.cta-banner p{opacity:.92;margin-bottom:28px;font-size:1.1rem}
.cta-banner .btn-outline{background:#fff;color:var(--primary);border-color:#fff}
.cta-banner .btn-outline:hover{background:transparent;color:#fff}

/* ===== FAQ ===== */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:12px;padding:20px 24px;cursor:pointer;transition:all .2s}
.faq-item:hover{border-color:var(--primary)}
.faq-q{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--dark)}
.faq-q::after{content:"+";font-size:1.4rem;color:var(--primary);transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s,margin .3s;color:var(--muted)}
.faq-item.open .faq-a{max-height:300px;margin-top:14px}

/* ===== Footer ===== */
.footer{background:#0f172a;color:#cbd5e1;padding:60px 0 24px;margin-top:0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer h4{color:#fff;margin-bottom:18px;font-size:1rem}
.footer p{color:#94a3b8;font-size:.95rem}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer ul a{color:#94a3b8;font-size:.95rem;transition:color .2s}
.footer ul a:hover{color:#fff}
.footer-logo{font-size:1.6rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:14px;display:inline-block}
.footer-bottom{border-top:1px solid #1e293b;padding-top:24px;text-align:center;color:#64748b;font-size:.9rem}
.socials{display:flex;gap:12px;margin-top:14px}
.socials a{width:38px;height:38px;border-radius:50%;background:#1e293b;display:flex;align-items:center;justify-content:center;color:#cbd5e1;transition:all .2s}
.socials a:hover{background:var(--gradient);color:#fff;transform:translateY(-3px)}

/* ===== Page Banner ===== */
.page-banner{
  background:var(--gradient);color:#fff;padding:80px 0 70px;text-align:center;
  position:relative;overflow:hidden;
}
.page-banner::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 50%,rgba(255,255,255,.15) 0%,transparent 50%);
}
.page-banner h1{font-size:clamp(2rem,4vw,3rem);font-weight:800;margin-bottom:12px;position:relative}
.page-banner p{opacity:.92;font-size:1.1rem;position:relative}
.breadcrumb{margin-top:14px;font-size:.9rem;opacity:.85;position:relative}
.breadcrumb a:hover{text-decoration:underline}

/* ===== Animations ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .8s ease both}
.fade-up.d1{animation-delay:.1s}.fade-up.d2{animation-delay:.2s}.fade-up.d3{animation-delay:.3s}

/* ===== Responsive ===== */
@media(max-width:900px){
  .hero-grid,.grid-2,.contact-grid{grid-template-columns:1fr;gap:40px}
  .grid-3,.portfolio-grid,.pricing,.process{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .price-card.featured{transform:none}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  .nav-links{
    position:fixed;top:70px;left:0;right:0;background:#fff;flex-direction:column;
    padding:24px;gap:18px;border-bottom:1px solid var(--border);
    transform:translateY(-130%);transition:transform .3s;
  }
  .nav-links.open{transform:translateY(0)}
  .menu-toggle{display:block}
  .grid-3,.portfolio-grid,.pricing,.process{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .section{padding:60px 0}
  .hero{padding:50px 0 70px}
}
