/* ============================================================
   Angelorum Solutions — Premium Agency Stylesheet
   ============================================================ */

/* ---------- Design Tokens (Angelorum Premium) ---------- */
:root {
  /* Rich, elegant dark backgrounds */
  --bg:           #0f0a1a;
  --bg-alt:       #16101f;
  --panel:        #1a1429;
  --panel-soft:   #231f3a;
  --text:         #f5f0ff;
  --muted:        #b8afd9;
  
  /* Deep purple primary (premium, trustworthy) */
  --primary:      #7c3aed;
  --primary-soft: #6d28d9;
  --primary-glow: rgba(124,58,237,.3);
  
  /* Gold accent (premium, elegant, eye-catching) */
  --accent:       #fbbf24;
  --accent-soft:  #f59e0b;
  --accent-glow:  rgba(251,191,36,.2);
  
  /* Additional palette */
  --purple-dark:  #5b21b6;
  --purple-light: #a78bfa;
  --gold-dark:    #d97706;
  --border:       #312e45;
  --success:      #10b981;
  
  /* Spacing & styling */
  --radius:       14px;
  --radius-sm:    10px;
  --radius-lg:    20px;
  --shadow:       0 8px 32px rgba(124,58,237,.15);
  --shadow-lg:    0 20px 60px rgba(124,58,237,.2);
  --shadow-accent: 0 8px 32px rgba(251,191,36,.15);
  --transition:   .3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- Reset & Base ---------- */
*,*::before,*::after{box-sizing:border-box}

html{scroll-behavior:smooth}

body{
  margin:0;
  font-family:"Inter","Segoe UI",Roboto,Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,p{margin-top:0}
h1{font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.1;margin-bottom:1rem;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.2;margin-bottom:1.2rem;letter-spacing:-.015em}
h3{font-size:1.15rem;margin-bottom:.6rem}
h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:1rem}

h1 em{font-style:normal;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}

.container{width:min(1180px,92%);margin:0 auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.8rem 1.3rem;border-radius:var(--radius-sm);border:1px solid transparent;
  background:linear-gradient(135deg,var(--primary),var(--primary-soft));
  color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;
  transition:all var(--transition);white-space:nowrap;position:relative;overflow:hidden;
}
.btn::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1));opacity:0;transition:opacity var(--transition)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);--primary-glow:rgba(124,58,237,.4)}
.btn:hover::before{opacity:1}

.btn-sm{padding:.5rem .85rem;font-size:.85rem}
.btn-lg{padding:1rem 1.8rem;font-size:1.05rem;border-radius:var(--radius)}
.btn-block{width:100%;text-align:center}

.btn-outline{
  background:transparent;border:2px solid var(--accent);color:var(--accent);
  transition:all var(--transition);
}
.btn-outline:hover{
  background:var(--accent);color:var(--bg);transform:translateY(-2px);
  box-shadow:var(--shadow-accent);
}

.btn-ghost{background:transparent;border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--panel-soft);border-color:var(--accent)}

.btn-white{
  background:#fff;color:var(--bg);border:none;font-weight:700;
}
.btn-white:hover{background:var(--accent);color:white;transform:translateY(-2px);box-shadow:var(--shadow-accent)}

.btn-glow{
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:#000;font-weight:700;box-shadow:var(--shadow-accent);
}
.btn-glow:hover{
  background:linear-gradient(135deg,var(--accent-soft),var(--accent));
  transform:translateY(-2px);box-shadow:0 12px 40px var(--accent-glow);
}

/* ---------- Nav ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  border-bottom:1px solid rgba(37,47,85,.6);
  background:rgba(10,15,30,.85);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}

.nav-wrap{
  min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:1rem;
}

.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.05rem}
.brand-mark{
  width:36px;height:36px;border-radius:11px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--primary),var(--accent));overflow:hidden;
}
.brand-logo{width:24px;height:24px;display:block}
.brand-text{color:var(--text)}
.brand-accent{color:var(--accent)}

.nav-links{display:flex;gap:1.6rem;font-size:.9rem;font-weight:500;color:var(--muted)}
.nav-links a{transition:color var(--transition);position:relative}
.nav-links a:hover{color:var(--text)}
.nav-links a::after{
  content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;
  background:var(--primary);border-radius:2px;transform:scaleX(0);
  transition:transform var(--transition);
}
.nav-links a:hover::after{transform:scaleX(1)}

.mobile-toggle{
  display:none;background:none;border:none;cursor:pointer;padding:.5rem;
  flex-direction:column;gap:5px;
}
.mobile-toggle span{
  display:block;width:24px;height:2px;background:var(--text);border-radius:2px;
  transition:all var(--transition);
}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  padding:6rem 0 4rem;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg-img{width:100%;height:100%;object-fit:cover;filter:brightness(.8) saturate(1.1)}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,10,26,.9) 0%,rgba(124,58,237,.15) 40%,rgba(15,10,26,.95) 100%);
}

.hero-content{position:relative;z-index:1;max-width:720px}

.badge{
  display:inline-block;padding:.4rem 1.1rem;border-radius:100px;
  background:linear-gradient(135deg,rgba(251,191,36,.15),rgba(251,191,36,.05));
  border:1.5px solid var(--accent);
  color:var(--accent);font-size:.8rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.2rem;
  box-shadow:0 4px 16px var(--accent-glow);
}

.lead{color:var(--muted);font-size:1.15rem;line-height:1.7;margin-bottom:2rem}

.hero-actions{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:2.5rem}

.hero-stats{
  display:flex;gap:2rem;padding-top:2rem;
  border-top:1px solid rgba(255,255,255,.1);
}
.stat{display:flex;flex-direction:column;gap:.15rem}
.stat strong{font-size:1.5rem;font-weight:800;color:#fff}
.stat span{font-size:.82rem;color:var(--muted)}

/* ---------- Logo Bar ---------- */
.logo-bar{
  padding:2rem 0;border-bottom:1px solid var(--border);
  background:var(--bg-alt);
}
.logo-bar-label{
  text-align:center;font-size:.78rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.1em;color:var(--muted);
  margin-bottom:1rem;
}
.logo-bar-row{
  display:flex;justify-content:center;flex-wrap:wrap;gap:2rem 3rem;
  font-size:.95rem;font-weight:600;color:rgba(255,255,255,.45);
}

/* ---------- Sections ---------- */
.section{padding:5rem 0}
.section-muted{
  background:rgba(14,21,48,.6);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.section-dark{
  background:linear-gradient(180deg,#080d1a 0%,#0c1228 100%);
}

.section-header{text-align:center;max-width:640px;margin:0 auto 3rem}
.section-header.light .eyebrow,
.section-header.light h2,
.section-header.light .section-sub{color:var(--text)}
.section-sub{color:var(--muted);font-size:1.05rem;line-height:1.6}

.eyebrow{
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);font-size:.78rem;font-weight:700;margin-bottom:.6rem;
}

/* ---------- Grid System ---------- */
.grid{display:grid;gap:1.5rem}
.cards-2{grid-template-columns:repeat(2,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Service Cards ---------- */
.service-card{
  background:linear-gradient(135deg,var(--panel),rgba(124,58,237,.08));
  border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  transition:all var(--transition);
  position:relative;
}
.service-card::before{content:"";position:absolute;top:0;right:0;width:100px;height:100px;background:radial-gradient(circle,rgba(251,191,36,.1),transparent);opacity:0;border-radius:50%;transition:all var(--transition)}
.service-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:var(--accent);
}
.service-card:hover::before{opacity:1;width:300px;height:300px}
.service-img{height:200px;overflow:hidden;position:relative}
.service-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(0.4,0,0.2,1)}
.service-card:hover .service-img img{transform:scale(1.08) rotate(.5deg)}
.service-body{padding:1.5rem;position:relative;z-index:1}
.service-body h3{color:var(--text)}
.service-body p{color:var(--muted);line-height:1.6;margin-bottom:0}

/* ---------- Portfolio ---------- */
.portfolio-grid{gap:1.5rem}
.portfolio-item{
  position:relative;margin:0;border-radius:var(--radius-lg);overflow:hidden;
  cursor:pointer;
}
.portfolio-item img{
  width:100%;height:280px;object-fit:cover;
  transition:transform .5s ease;
}
.portfolio-item:hover img{transform:scale(1.08)}
.portfolio-item figcaption{
  position:absolute;bottom:0;left:0;right:0;
  padding:1.5rem;
  background:linear-gradient(transparent,rgba(0,0,0,.85));
}
.portfolio-item figcaption h3{color:#fff;margin-bottom:.3rem}
.portfolio-item figcaption p{color:rgba(255,255,255,.7);font-size:.9rem;margin-bottom:0}

/* ---------- Process Timeline ---------- */
.process-timeline{
  display:flex;flex-direction:column;gap:2rem;
  max-width:900px;margin:0 auto;
}
.process-step{
  display:grid;grid-template-columns:60px 1fr 180px;
  gap:1.5rem;align-items:center;
  background:linear-gradient(135deg,var(--panel),rgba(251,191,36,.03));
  border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.8rem;
  transition:all var(--transition);
  position:relative;overflow:hidden;
}
.process-step::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(251,191,36,.05),transparent);opacity:0;transition:opacity var(--transition)}
.process-step:hover{
  border-color:var(--accent);
  box-shadow:0 8px 32px var(--primary-glow);
}
.process-step:hover::before{opacity:1}
.step-number{
  font-size:2.2rem;font-weight:900;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  position:relative;z-index:1;
}
.step-content{position:relative;z-index:1}
.step-content h3{margin-bottom:.4rem;color:var(--text)}
.step-content p{color:var(--muted);margin-bottom:0;font-size:.95rem;line-height:1.6}
.step-img{border-radius:var(--radius-sm);overflow:hidden;height:100px}
.step-img img{width:100%;height:100%;object-fit:cover}

/* ---------- Pricing ---------- */
.pricing-grid{align-items:stretch;gap:2rem;grid-auto-rows:1fr}
.pricing-card{
  background:linear-gradient(135deg,var(--panel),rgba(20,20,35,.6));
  border:1px solid rgba(251,191,36,.15);
  border-radius:var(--radius-lg);padding:2.5rem;
  position:relative;overflow:hidden;
  transition:all var(--transition);
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.pricing-card::before{
  content:"";position:absolute;top:-1px;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(251,191,36,.2),transparent);
}
.pricing-card:hover{
  transform:translateY(-8px);
  border-color:rgba(251,191,36,.3);
  box-shadow:0 12px 50px rgba(251,191,36,.15);
}
.pricing-card.featured{
  border-color:var(--accent);
  background:linear-gradient(135deg,rgba(251,191,36,.08) 0%,var(--panel) 50%,rgba(21,128,61,.05) 100%);
  box-shadow:0 0 0 1px var(--accent),0 0 30px rgba(251,191,36,.2),inset 0 1px 0 rgba(251,191,36,.1);
  transform:scale(1.06);
}
.pricing-card.featured::after{
  content:"";position:absolute;top:0;right:0;width:100px;height:100px;
  background:radial-gradient(circle,rgba(251,191,36,.1) 0%,transparent 70%);
  border-radius:0 var(--radius-lg) 0 100%;
}
.pricing-card.featured:hover{
  transform:scale(1.06) translateY(-8px);
  box-shadow:0 0 0 1px var(--accent),0 0 40px rgba(251,191,36,.3),inset 0 1px 0 rgba(251,191,36,.15);
}
.pricing-badge{
  position:absolute;top:1rem;right:1.5rem;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:var(--bg);font-size:.7rem;font-weight:800;
  padding:.5rem 1rem;
  border-radius:.4rem;
  text-transform:uppercase;letter-spacing:.08em;
  box-shadow:0 4px 15px rgba(251,191,36,.3);
  z-index:10;
}
.pricing-header{margin-bottom:2rem}
.pricing-card .plan{color:var(--accent);font-weight:700;margin-bottom:.5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;opacity:.9}
.pricing-card .price{font-size:3rem;font-weight:800;margin-bottom:.3rem;color:#fff;line-height:1}
.pricing-card .price-note{color:var(--muted);font-size:.8rem;margin-bottom:0;font-weight:500}
.pricing-card ul{margin-bottom:2.5rem;display:flex;flex-direction:column;gap:.9rem;flex-grow:1}
.pricing-card li{
  color:var(--muted);font-size:.93rem;padding-left:1.8rem;position:relative;line-height:1.5;
}
.pricing-card li::before{
  content:"✓";position:absolute;left:0;top:.05rem;color:var(--success);font-weight:700;font-size:1.2rem;
}

.pricing-card .btn{
  margin-top:auto;border:1px solid rgba(251,191,36,.2);
  transition:all var(--transition);
}
.pricing-card .btn:hover{
  border-color:var(--accent);
  box-shadow:0 8px 25px rgba(251,191,36,.2);
}
.pricing-card:not(.featured) .btn{
  background:linear-gradient(135deg,rgba(251,191,36,.15),rgba(251,191,36,.08));
  color:var(--accent);
}
.pricing-card:not(.featured) .btn:hover{
  background:linear-gradient(135deg,rgba(251,191,36,.25),rgba(251,191,36,.15));
}

.pricing-promo{
  text-align:center;margin-top:3rem;
  background:linear-gradient(135deg,rgba(251,191,36,.12),rgba(251,191,36,.06));
  border:1px solid rgba(251,191,36,.3);border-radius:var(--radius-lg);
  padding:2rem;color:#fff;
  box-shadow:0 8px 32px rgba(251,191,36,.1);
}
.pricing-promo p{margin:0;font-size:1.1rem;line-height:1.7}
.pricing-promo strong{color:var(--accent);font-weight:700}

/* ---------- Testimonials ---------- */
.testimonial-grid{gap:1.5rem}
.testimonial-card{
  background:linear-gradient(135deg,var(--panel),rgba(124,58,237,.05));
  border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.8rem;margin:0;
  transition:all var(--transition);
  position:relative;overflow:hidden;
}
.testimonial-card::before{content:"";position:absolute;top:-50%;left:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(251,191,36,.08),transparent);opacity:0;transition:opacity var(--transition)}
.testimonial-card:hover{
  border-color:var(--accent);box-shadow:0 8px 30px var(--primary-glow);
}
.testimonial-card:hover::before{opacity:1}
.stars{color:var(--accent);font-size:1.1rem;margin-bottom:.8rem;letter-spacing:4px}
.testimonial-card p{color:var(--muted);font-size:1rem;line-height:1.65;margin-bottom:1.2rem;font-style:italic}
.testimonial-card footer{display:flex;align-items:center;gap:.8rem;position:relative;z-index:1}
.testimonial-card footer div{display:flex;flex-direction:column}
.testimonial-card footer strong{font-size:.9rem;color:var(--text)}
.testimonial-card footer span{font-size:.78rem;color:var(--muted)}
.avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;border:3px solid var(--accent);box-shadow:0 0 12px var(--accent-glow)}

/* ---------- CTA Banner ---------- */
.cta-banner{
  position:relative;padding:5rem 0;text-align:center;overflow:hidden;
}
.cta-bg{position:absolute;inset:0;z-index:0}
.cta-bg-img{width:100%;height:100%;object-fit:cover;filter:brightness(.6) saturate(1.2)}
.cta-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(15,10,26,.88),rgba(124,58,237,.2)),linear-gradient(to bottom,rgba(251,191,36,.1),transparent);
}
.cta-content{position:relative;z-index:1;max-width:600px;margin:0 auto}
.cta-content h2{color:#fff;margin-bottom:.8rem;font-size:clamp(1.8rem,3vw,2.6rem)}
.cta-content p{color:rgba(255,255,255,.8);font-size:1.1rem;margin-bottom:2rem;line-height:1.7}

/* ---------- Contact ---------- */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start;
}
.contact-info h2{margin-bottom:.8rem}
.contact-info > p{color:var(--muted);margin-bottom:1.5rem;line-height:1.7}

.contact-points{display:flex;flex-direction:column;gap:.8rem;margin-bottom:2rem}
.contact-points li{
  display:flex;align-items:center;gap:.65rem;
  color:var(--muted);font-size:.92rem;
}
.contact-points li svg{flex-shrink:0;color:var(--accent)}

.contact-photo{
  border-radius:var(--radius-lg);overflow:hidden;
  max-height:220px;object-fit:cover;width:100%;
  border:1px solid var(--border);
}

.contact-form{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:2rem;
  display:flex;flex-direction:column;gap:1rem;
}
.contact-form label{display:flex;flex-direction:column;gap:.35rem}

.label-text{font-weight:600;font-size:.88rem;color:var(--text)}
.optional{color:var(--muted);font-weight:400;font-size:.78rem}

input,textarea,select{
  width:100%;padding:.75rem 1rem;
  border-radius:var(--radius-sm);border:1px solid var(--border);
  background:var(--panel-soft);color:var(--text);font:inherit;
  transition:border-color var(--transition),box-shadow var(--transition);
}
input:focus,textarea:focus{
  outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-glow);
}
input::placeholder,textarea::placeholder{color:rgba(176,190,223,.4)}

.form-status{min-height:1.2rem;margin:0;font-size:.9rem;color:var(--muted)}
.form-status.success{color:var(--success)}

/* ---------- Footer ---------- */
.footer{
  border-top:1px solid var(--border);
  padding-top:3rem;
  background:var(--bg);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;
  padding-bottom:2.5rem;
}
.footer-brand p{color:var(--muted);font-size:.9rem;line-height:1.6;margin-top:.8rem;max-width:300px}
.footer-col{display:flex;flex-direction:column;gap:.55rem}
.footer-col a{color:var(--muted);font-size:.9rem;transition:color var(--transition)}
.footer-col a:hover{color:var(--text)}
.footer-bottom{
  border-top:1px solid var(--border);padding:1.2rem 0;
  text-align:center;
}
.footer-bottom p{color:var(--muted);font-size:.82rem;margin-bottom:0}

/* ============================================================
   Responsive Breakpoints
   ============================================================ */
@media(max-width:1024px){
  .process-step{grid-template-columns:50px 1fr;gap:1rem}
  .step-img{display:none}
}

@media(max-width:980px){
  .contact-grid{grid-template-columns:1fr}
  .cards-3{grid-template-columns:repeat(2,1fr)}
  .cards-4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}

  .nav-links{
    display:none;
    position:fixed;top:72px;left:0;right:0;
    background:rgba(10,15,30,.97);backdrop-filter:blur(14px);
    flex-direction:column;padding:1.5rem 2rem;gap:1rem;
    border-bottom:1px solid var(--border);
  }
  .nav-links.open{display:flex}
  .mobile-toggle{display:flex}
}

@media(max-width:768px){
  .hero{min-height:auto;padding:8rem 0 3rem}
  .hero-stats{flex-direction:column;gap:1rem}
  .cards-2{grid-template-columns:1fr}
  .portfolio-item img{height:220px}
  .pricing-grid{gap:1.5rem}
  .pricing-card{padding:2rem}
  .pricing-card.featured{transform:none;scale:1}
  .pricing-card.featured:hover{transform:translateY(-8px)}
  .pricing-badge{top:1rem;right:1rem}
}

@media(max-width:640px){
  .cards-3{grid-template-columns:1fr}
  .cards-4{grid-template-columns:1fr}
  .hero-content h1{font-size:2rem}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{width:100%}
  .process-step{grid-template-columns:1fr;text-align:center}
  .step-number{justify-self:center}
  .footer-grid{grid-template-columns:1fr}
  .footer-brand{grid-column:auto}
  .topbar{position:sticky}
}

/* ---------- Animations & Keyframes ---------- */
@keyframes fadeInUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes slideInLeft{
  from{opacity:0;transform:translateX(-30px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes slideInRight{
  from{opacity:0;transform:translateX(30px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes scaleIn{
  from{opacity:0;transform:scale(.95)}
  to{opacity:1;transform:scale(1)}
}
@keyframes pulse{
  0%,100%{opacity:1}
  50%{opacity:.7}
}
@keyframes glow{
  0%,100%{box-shadow:0 0 20px var(--primary-glow)}
  50%{box-shadow:0 0 40px var(--primary-glow)}
}
@keyframes float{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@keyframes shimmer{
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
@keyframes countUp{
  from{opacity:0;transform:scale(.8)}
  to{opacity:1;transform:scale(1)}
}

/* Scroll-triggered animations */
@media(prefers-reduced-motion:no-preference){
  .service-card,.pricing-card,.testimonial-card,.process-step,.portfolio-item{
    opacity:0;transform:translateY(24px);
    animation:fadeInUp .7s var(--transition) forwards;
  }
  
  .service-card:nth-child(2),.pricing-card:nth-child(2),.testimonial-card:nth-child(2),.process-step:nth-child(2){animation-delay:.12s}
  .service-card:nth-child(3),.pricing-card:nth-child(3),.testimonial-card:nth-child(3),.process-step:nth-child(3){animation-delay:.24s}
  .process-step:nth-child(4){animation-delay:.36s}
  
  /* Stat animation for hero */
  .stat{animation:slideInLeft .8s var(--transition) forwards;opacity:0}
  .stat:nth-child(2){animation-delay:.1s;animation-name:fadeInUp}
  .stat:nth-child(3){animation-delay:.2s;animation-name:slideInRight}
  
  /* Badge entrance */
  .badge{animation:scaleIn .6s cubic-bezier(0.34,1.56,0.64,1) forwards;opacity:0}
  
  /* Button hover glow */
  .btn-glow{transition:all var(--transition);box-shadow:0 0 20px var(--primary-glow)}
  .btn-glow:hover{animation:glow 1.5s ease-in-out infinite}
}
