/* =========================================
   AnspireX — Full Design System
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap');

/* ─── Variables ─────────────────────────── */
:root {
  --bg:           #08080F;
  --bg2:          #0C0C1A;
  --bg-card:      #0F0F1F;
  --bg-card2:     #121224;
  --purple:       #8B5CF6;
  --purple-light: #A78BFA;
  --purple-dim:   rgba(139,92,246,0.14);
  --orange:       #F97316;
  --orange-light: #FB923C;
  --orange-dim:   rgba(249,115,22,0.14);
  --grad:         linear-gradient(135deg,#8B5CF6,#F97316);
  --grad-soft:    linear-gradient(135deg,rgba(139,92,246,.18),rgba(249,115,22,.18));
  --white:        #FFFFFF;
  --text2:        #9494B8;
  --text3:        #50506A;
  --border:       rgba(139,92,246,0.14);
  --border2:      rgba(255,255,255,0.06);
  --glow:         0 0 60px rgba(139,92,246,0.18);
  --shadow:       0 8px 32px rgba(0,0,0,0.5);
  --font-h:       'Space Grotesk', sans-serif;
  --font-b:       'Inter', sans-serif;
  --r:            14px;
  --rl:           24px;
  --pill:         100px;
  --t:            all 0.3s cubic-bezier(.4,0,.2,1);
}

/* ─── Reset ─────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-b);
  line-height:1.65;
  overflow-x:hidden;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; display:block; }
ul { list-style:none; }
button { cursor:pointer; font-family:var(--font-b); }
input, textarea, select { font-family:var(--font-b); }

/* ─── Container ─────────────────────────── */
.container {
  max-width:1220px;
  margin:0 auto;
  padding:0 24px;
}

/* ─── Typography ────────────────────────── */
h1,h2,h3,h4,h5 { font-family:var(--font-h); font-weight:700; line-height:1.15; }
h1 { font-size:clamp(2.6rem,6vw,5rem); }
h2 { font-size:clamp(2rem,4vw,3.2rem); }
h3 { font-size:clamp(1.3rem,2.5vw,1.75rem); }
h4 { font-size:1.2rem; }
p  { color:var(--text2); }

.grad-text {
  background:var(--grad);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.section-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.78rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--purple-light);
  background:var(--purple-dim);
  border:1px solid var(--border);
  border-radius:var(--pill);
  padding:6px 18px;
  margin-bottom:20px;
}
.section-eyebrow::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--purple);
}
.section-title { margin-bottom:16px; }
.section-sub { color:var(--text2); max-width:560px; font-size:1.05rem; }
.text-center { text-align:center; }
.text-center .section-sub { margin:0 auto; }

/* ─── Buttons ───────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 30px;
  border-radius:var(--pill);
  font-size:.95rem; font-weight:600;
  border:none; transition:var(--t);
  cursor:pointer;
}
.btn-primary {
  background:var(--grad);
  color:#fff;
  box-shadow:0 4px 24px rgba(139,92,246,.3);
}
.btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 36px rgba(139,92,246,.45);
}
.btn-outline {
  background:transparent;
  color:var(--white);
  border:1.5px solid var(--border2);
}
.btn-outline:hover {
  border-color:var(--purple);
  color:var(--purple-light);
  background:var(--purple-dim);
}
.btn-sm { padding:10px 22px; font-size:.85rem; }
.btn-lg { padding:18px 40px; font-size:1.05rem; }

/* ─── Badge ─────────────────────────────── */
.badge {
  display:inline-block;
  padding:4px 12px; border-radius:var(--pill);
  font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
}
.badge-purple { background:var(--purple-dim); color:var(--purple-light); border:1px solid var(--border); }
.badge-orange { background:var(--orange-dim); color:var(--orange-light); border:1px solid rgba(249,115,22,.2); }

/* ─── Cards ─────────────────────────────── */
.card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  transition:var(--t);
}
.card:hover {
  border-color:var(--border);
  box-shadow:var(--glow);
  transform:translateY(-4px);
}

/* ─── Section spacing ───────────────────── */
section { padding:100px 0; }

/* ─── Divider ───────────────────────────── */
.divider {
  height:1px;
  background:linear-gradient(90deg,transparent,var(--border),transparent);
  margin:0;
}

/* ══════════════════════════════════════════
   NAVIGATION
══════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:999;
  padding:20px 0;
  transition:var(--t);
}
.nav.scrolled {
  padding:14px 0;
  background:rgba(8,8,15,.85);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav__inner {
  display:flex; align-items:center; justify-content:space-between;
}
.nav__logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--font-h); font-size:1.35rem; font-weight:700;
}
.nav__logo-mark {
  width:36px; height:36px; border-radius:10px;
  background:var(--grad);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:800; color:#fff;
}
.nav__links {
  display:flex; align-items:center; gap:36px;
}
.nav__links a {
  font-size:.9rem; font-weight:500; color:var(--text2);
  transition:var(--t); position:relative;
}
.nav__links a:hover, .nav__links a.active { color:var(--white); }
.nav__links a.active::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:2px; border-radius:2px;
  background:var(--grad);
}
.nav__actions { display:flex; align-items:center; gap:14px; }
.nav__hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.nav__hamburger span {
  display:block; width:24px; height:2px; border-radius:2px;
  background:var(--white); transition:var(--t);
}
.nav__mobile {
  display:none; position:fixed; inset:0; z-index:998;
  background:rgba(8,8,15,.97);
  flex-direction:column; align-items:center; justify-content:center; gap:32px;
  backdrop-filter:blur(20px);
}
.nav__mobile.open { display:flex; }
.nav__mobile a {
  font-family:var(--font-h); font-size:2rem; font-weight:600;
  color:var(--white); transition:var(--t);
}
.nav__mobile a:hover { color:var(--purple-light); }
.nav__mobile .btn { margin-top:8px; }
.nav__mobile-close {
  position:absolute; top:24px; right:24px;
  background:none; border:none; color:var(--white);
  font-size:1.6rem; cursor:pointer;
}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero {
  min-height:100vh;
  display:flex; align-items:center;
  position:relative; overflow:hidden;
  padding:140px 0 80px;
}
.hero__orb {
  position:absolute; border-radius:50%;
  filter:blur(100px); pointer-events:none;
}
.hero__orb--1 {
  width:600px; height:600px;
  background:radial-gradient(circle,rgba(139,92,246,.22),transparent 70%);
  top:-100px; left:-100px;
}
.hero__orb--2 {
  width:500px; height:500px;
  background:radial-gradient(circle,rgba(249,115,22,.16),transparent 70%);
  bottom:-80px; right:-60px;
}
.hero__grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:center;
}
.hero__content { position:relative; z-index:1; }
.hero__trust {
  display:flex; align-items:center; gap:16px;
  margin-bottom:28px; flex-wrap:wrap;
}
.hero__stars { color:#FACC15; font-size:.9rem; }
.hero__trust-text { font-size:.82rem; color:var(--text2); }
.hero__trust-text span { color:var(--white); font-weight:600; }
.hero h1 { margin-bottom:22px; }
.hero__sub {
  font-size:1.1rem; color:var(--text2); max-width:520px;
  margin-bottom:36px; line-height:1.75;
}
.hero__actions { display:flex; gap:14px; flex-wrap:wrap; }
.hero__visual {
  position:relative; z-index:1;
}
.hero__card-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
.hero__mini-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--r);
  padding:24px;
  transition:var(--t);
}
.hero__mini-card:hover { border-color:var(--border); }
.hero__mini-card i {
  font-size:1.6rem; margin-bottom:12px;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero__mini-card h4 { font-size:.95rem; margin-bottom:4px; }
.hero__mini-card p { font-size:.8rem; color:var(--text2); }
.hero__mini-card--span { grid-column:1/-1; }

/* ══════════════════════════════════════════
   MARQUEE
══════════════════════════════════════════ */
.marquee-section { padding:40px 0; overflow:hidden; }
.marquee-label {
  text-align:center; font-size:.78rem; color:var(--text3);
  letter-spacing:.1em; text-transform:uppercase;
  margin-bottom:24px;
}
.marquee-track {
  display:flex; gap:48px; align-items:center;
  animation:marquee 28s linear infinite;
  width:max-content;
}
.marquee-track:hover { animation-play-state:paused; }
.marquee-item {
  white-space:nowrap;
  font-family:var(--font-h); font-size:1rem; font-weight:600;
  color:var(--text3);
  transition:var(--t);
  display:flex; align-items:center; gap:10px;
}
.marquee-item:hover { color:var(--text2); }
.marquee-item::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--grad);
  display:inline-block; flex-shrink:0;
}
@keyframes marquee {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* ══════════════════════════════════════════
   STATS
══════════════════════════════════════════ */
.stats { padding:60px 0; }
.stats__grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:2px;
  background:var(--border2);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  overflow:hidden;
}
.stats__item {
  background:var(--bg-card);
  padding:40px 32px; text-align:center;
}
.stats__num {
  font-family:var(--font-h); font-size:2.8rem; font-weight:700;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:6px;
}
.stats__label { font-size:.85rem; color:var(--text2); font-weight:500; }

/* ══════════════════════════════════════════
   SERVICES GRID
══════════════════════════════════════════ */
.services-grid { padding:100px 0; }
.services-grid__header { margin-bottom:60px; }
.services-grid__grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.service-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  padding:36px 32px;
  transition:var(--t);
  position:relative; overflow:hidden;
}
.service-card::before {
  content:''; position:absolute; inset:0;
  background:var(--grad-soft);
  opacity:0; transition:var(--t);
  border-radius:var(--rl);
}
.service-card:hover {
  border-color:var(--border);
  box-shadow:var(--glow);
  transform:translateY(-6px);
}
.service-card:hover::before { opacity:1; }
.service-card--featured { grid-column:span 2; }
.service-card__icon {
  width:52px; height:52px; border-radius:14px;
  background:var(--purple-dim);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:22px; position:relative; z-index:1;
}
.service-card__icon i {
  font-size:1.4rem; color:var(--purple-light);
}
.service-card__title {
  font-size:1.15rem; font-weight:700;
  margin-bottom:10px; position:relative; z-index:1;
}
.service-card__desc {
  font-size:.88rem; color:var(--text2); line-height:1.7;
  margin-bottom:20px; position:relative; z-index:1;
}
.service-card__link {
  font-size:.85rem; font-weight:600;
  color:var(--purple-light);
  display:inline-flex; align-items:center; gap:6px;
  transition:var(--t); position:relative; z-index:1;
}
.service-card__link:hover { gap:10px; color:var(--orange-light); }

/* ══════════════════════════════════════════
   HOW IT WORKS
══════════════════════════════════════════ */
.how-it-works { padding:100px 0; background:var(--bg2); }
.how-it-works__steps {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:40px; margin-top:60px; position:relative;
}
.how-it-works__steps::before {
  content:''; position:absolute;
  top:48px; left:calc(16.666% + 24px); right:calc(16.666% + 24px);
  height:1px;
  background:linear-gradient(90deg,var(--purple),var(--orange));
  opacity:.3;
}
.step-card {
  text-align:center; position:relative;
}
.step-card__num {
  width:64px; height:64px; border-radius:50%;
  background:var(--grad);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:1.3rem; font-weight:700; color:#fff;
  margin:0 auto 24px;
  box-shadow:0 8px 24px rgba(139,92,246,.35);
  position:relative; z-index:1;
}
.step-card h3 { margin-bottom:12px; font-size:1.2rem; }
.step-card p { font-size:.9rem; color:var(--text2); }

/* ══════════════════════════════════════════
   CASE STUDIES
══════════════════════════════════════════ */
.case-studies { padding:100px 0; }
.case-studies__grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:60px;
}
.case-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  overflow:hidden;
  transition:var(--t);
}
.case-card:hover {
  border-color:var(--border);
  transform:translateY(-6px);
  box-shadow:var(--glow);
}
.case-card__img {
  height:220px; overflow:hidden; position:relative;
  background:var(--bg-card2);
}
.case-card__img-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:8px;
}
.case-card__img-placeholder i { font-size:2.5rem; opacity:.3; }
.case-card__img-placeholder span { font-size:.78rem; color:var(--text3); }
.case-card__body { padding:28px; }
.case-card__tags { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.case-card__title { margin-bottom:10px; font-size:1.15rem; }
.case-card__result {
  font-size:1.5rem; font-weight:700;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:8px;
}
.case-card__desc { font-size:.85rem; color:var(--text2); margin-bottom:20px; }
.case-card__link {
  font-size:.85rem; font-weight:600;
  color:var(--purple-light);
  display:inline-flex; align-items:center; gap:6px;
  transition:var(--t);
}
.case-card__link:hover { gap:10px; }

/* ══════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════ */
.testimonials { padding:100px 0; background:var(--bg2); }
.testimonials__slider { margin-top:60px; }
.testimonials__track { overflow:hidden; }
.testimonials__slides {
  display:flex;
  transition:transform .5s cubic-bezier(.4,0,.2,1);
}
.testimonial-slide { min-width:100%; }
.testimonial-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  padding:48px 48px;
  max-width:780px; margin:0 auto;
  position:relative;
}
.testimonial-card__quote {
  font-size:3rem; line-height:1;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  margin-bottom:16px;
}
.testimonial-card__text {
  font-size:1.05rem; color:var(--text2);
  line-height:1.8; margin-bottom:32px;
  font-style:italic;
}
.testimonial-card__author {
  display:flex; align-items:center; gap:16px;
}
.testimonial-card__avatar {
  width:52px; height:52px; border-radius:50%;
  background:var(--grad);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:1.1rem; font-weight:700; color:#fff;
  flex-shrink:0;
}
.testimonial-card__name { font-weight:700; font-size:.95rem; margin-bottom:2px; }
.testimonial-card__role { font-size:.82rem; color:var(--text2); }
.testimonial-card__stars { color:#FACC15; font-size:.85rem; margin-top:4px; }
.testimonials__nav {
  display:flex; justify-content:center; align-items:center; gap:16px; margin-top:36px;
}
.testimonials__btn {
  width:44px; height:44px; border-radius:50%;
  background:var(--bg-card); border:1px solid var(--border2);
  color:var(--white); font-size:1rem;
  display:flex; align-items:center; justify-content:center;
  transition:var(--t); cursor:pointer;
}
.testimonials__btn:hover { border-color:var(--purple); background:var(--purple-dim); }
.testimonials__dots { display:flex; gap:8px; }
.testimonials__dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--text3); border:none; cursor:pointer;
  transition:var(--t);
}
.testimonials__dot.active {
  background:var(--purple); width:24px; border-radius:var(--pill);
}

/* ══════════════════════════════════════════
   WHY US
══════════════════════════════════════════ */
.why-us { padding:100px 0; }
.why-us__grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:60px;
}
.why-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--r);
  padding:32px;
  transition:var(--t);
}
.why-card:hover { border-color:var(--border); }
.why-card__icon {
  width:48px; height:48px; border-radius:12px;
  background:var(--orange-dim);
  border:1px solid rgba(249,115,22,.2);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px;
}
.why-card__icon i { font-size:1.3rem; color:var(--orange-light); }
.why-card h4 { margin-bottom:8px; }
.why-card p { font-size:.88rem; color:var(--text2); }

/* ══════════════════════════════════════════
   PRICING
══════════════════════════════════════════ */
.pricing { padding:100px 0; background:var(--bg2); }
.pricing__grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:60px; align-items:start;
}
.price-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  padding:40px 36px;
  transition:var(--t); position:relative;
}
.price-card:hover { transform:translateY(-4px); }
.price-card--popular {
  border-color:var(--purple);
  box-shadow:var(--glow);
  transform:translateY(-8px);
}
.price-card--popular:hover { transform:translateY(-12px); }
.price-card__popular-badge {
  position:absolute; top:-14px; left:50%; transform:translateX(-50%);
  background:var(--grad); color:#fff;
  padding:4px 18px; border-radius:var(--pill);
  font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em;
  white-space:nowrap;
}
.price-card__name {
  font-size:.85rem; font-weight:600; color:var(--text2);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:12px;
}
.price-card__price {
  font-family:var(--font-h); font-size:2.8rem; font-weight:700;
  margin-bottom:4px;
}
.price-card__price span { font-size:1rem; color:var(--text2); font-weight:400; }
.price-card__desc { font-size:.85rem; color:var(--text2); margin-bottom:28px; }
.price-card__features { margin-bottom:32px; }
.price-card__feature {
  display:flex; align-items:center; gap:10px;
  font-size:.88rem; padding:8px 0;
  border-bottom:1px solid var(--border2);
  color:var(--text2);
}
.price-card__feature:last-child { border-bottom:none; }
.price-card__feature i { color:var(--purple-light); font-size:.8rem; flex-shrink:0; }
.price-card__note {
  text-align:center; font-size:.78rem; color:var(--text3); margin-top:20px;
}
.pricing__footer {
  text-align:center; margin-top:40px;
  font-size:.9rem; color:var(--text2);
}
.pricing__footer a { color:var(--purple-light); }

/* ══════════════════════════════════════════
   BLOG PREVIEW
══════════════════════════════════════════ */
.blog-preview { padding:100px 0; }
.blog-preview__grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:60px;
}
.blog-card {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  overflow:hidden; transition:var(--t);
}
.blog-card:hover {
  border-color:var(--border);
  transform:translateY(-4px);
  box-shadow:var(--glow);
}
.blog-card__img {
  height:200px; background:var(--bg-card2);
  display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; position:relative; overflow:hidden;
}
.blog-card__img-bg {
  position:absolute; inset:0;
  opacity:.08;
}
.blog-card__body { padding:28px; }
.blog-card__meta {
  display:flex; align-items:center; gap:12px;
  margin-bottom:14px;
}
.blog-card__cat {
  font-size:.72rem; font-weight:600; color:var(--purple-light);
  text-transform:uppercase; letter-spacing:.08em;
}
.blog-card__time { font-size:.75rem; color:var(--text3); }
.blog-card h3 { font-size:1.05rem; margin-bottom:10px; line-height:1.4; }
.blog-card p { font-size:.85rem; color:var(--text2); margin-bottom:20px; }
.blog-card__link {
  font-size:.85rem; font-weight:600;
  color:var(--purple-light);
  display:inline-flex; align-items:center; gap:6px;
  transition:var(--t);
}
.blog-card__link:hover { gap:10px; }

/* ══════════════════════════════════════════
   CTA BANNER
══════════════════════════════════════════ */
.cta-banner { padding:80px 0; }
.cta-banner__inner {
  background:var(--grad);
  border-radius:var(--rl);
  padding:70px 60px;
  text-align:center; position:relative; overflow:hidden;
}
.cta-banner__inner::before {
  content:''; position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Ccircle cx='30' cy='30' r='30'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.cta-banner h2 { color:#fff; margin-bottom:14px; position:relative; }
.cta-banner p { color:rgba(255,255,255,.8); margin-bottom:36px; font-size:1.05rem; position:relative; }
.cta-banner__actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; }
.btn-white {
  background:#fff;
  color:#08080F;
  font-weight:700;
}
.btn-white:hover { background:rgba(255,255,255,.9); transform:translateY(-2px); }
.btn-ghost {
  background:transparent;
  color:#fff;
  border:2px solid rgba(255,255,255,.4);
}
.btn-ghost:hover { border-color:#fff; background:rgba(255,255,255,.1); }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer {
  background:var(--bg2);
  border-top:1px solid var(--border2);
  padding:80px 0 0;
}
.footer__grid {
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr;
  gap:60px; margin-bottom:60px;
}
.footer__brand .nav__logo { margin-bottom:16px; }
.footer__brand p { font-size:.88rem; color:var(--text2); margin-bottom:24px; max-width:280px; }
.footer__socials { display:flex; gap:12px; }
.footer__social {
  width:38px; height:38px; border-radius:10px;
  background:var(--bg-card); border:1px solid var(--border2);
  display:flex; align-items:center; justify-content:center;
  color:var(--text2); font-size:.9rem;
  transition:var(--t);
}
.footer__social:hover { border-color:var(--purple); color:var(--purple-light); }
.footer__col h5 {
  font-size:.78rem; font-weight:700; text-transform:uppercase;
  letter-spacing:.12em; color:var(--text3); margin-bottom:20px;
}
.footer__links { display:flex; flex-direction:column; gap:10px; }
.footer__links a {
  font-size:.88rem; color:var(--text2); transition:var(--t);
}
.footer__links a:hover { color:var(--white); }
.footer__contact-item {
  display:flex; align-items:flex-start; gap:10px;
  font-size:.88rem; color:var(--text2); margin-bottom:12px;
}
.footer__contact-item i { color:var(--purple-light); margin-top:2px; flex-shrink:0; }
.footer__newsletter { margin-top:20px; }
.footer__newsletter p { font-size:.82rem; color:var(--text3); margin-bottom:12px; }
.footer__newsletter-form {
  display:flex; gap:8px;
}
.footer__newsletter-form input {
  flex:1; padding:10px 16px; border-radius:var(--pill);
  background:var(--bg-card); border:1px solid var(--border2);
  color:var(--white); font-size:.85rem;
  outline:none; transition:var(--t);
}
.footer__newsletter-form input:focus { border-color:var(--purple); }
.footer__newsletter-form button {
  padding:10px 18px; border-radius:var(--pill);
  background:var(--grad); border:none; color:#fff;
  font-size:.82rem; font-weight:600; transition:var(--t);
}
.footer__newsletter-form button:hover { opacity:.9; }
.footer__bottom {
  border-top:1px solid var(--border2);
  padding:24px 0;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
}
.footer__bottom p { font-size:.82rem; color:var(--text3); }
.footer__bottom-links { display:flex; gap:24px; }
.footer__bottom-links a { font-size:.82rem; color:var(--text3); transition:var(--t); }
.footer__bottom-links a:hover { color:var(--text2); }

/* ══════════════════════════════════════════
   WHATSAPP FLOAT
══════════════════════════════════════════ */
.whatsapp-float {
  position:fixed; bottom:28px; right:28px; z-index:900;
  width:58px; height:58px; border-radius:50%;
  background:#25D366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.4);
  transition:var(--t);
  animation:whatsapp-pulse 2.5s ease infinite;
}
.whatsapp-float:hover { transform:scale(1.1); box-shadow:0 12px 40px rgba(37,211,102,.5); }
.whatsapp-float i { font-size:1.6rem; color:#fff; }
@keyframes whatsapp-pulse {
  0%,100% { box-shadow:0 8px 28px rgba(37,211,102,.4); }
  50%      { box-shadow:0 8px 28px rgba(37,211,102,.7),0 0 0 10px rgba(37,211,102,.08); }
}

/* ══════════════════════════════════════════
   INNER PAGE HERO
══════════════════════════════════════════ */
.page-hero {
  padding:160px 0 80px;
  text-align:center; position:relative; overflow:hidden;
}
.page-hero__orb {
  position:absolute; border-radius:50%; filter:blur(100px); pointer-events:none;
}
.page-hero__orb--1 {
  width:400px; height:400px;
  background:radial-gradient(circle,rgba(139,92,246,.2),transparent 70%);
  top:-100px; left:50%; transform:translateX(-50%);
}
.breadcrumb {
  display:flex; align-items:center; gap:8px; justify-content:center;
  font-size:.8rem; color:var(--text3); margin-bottom:20px;
}
.breadcrumb a { color:var(--text3); transition:var(--t); }
.breadcrumb a:hover { color:var(--purple-light); }
.breadcrumb i { font-size:.65rem; }

/* ══════════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════════ */
.about-story { padding:100px 0; }
.about-story__grid {
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;
}
.about-story__visual {
  position:relative;
}
.about-story__img-box {
  background:var(--bg-card);
  border:1px solid var(--border2);
  border-radius:var(--rl);
  height:420px;
  display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.about-story__img-box i { font-size:4rem; color:var(--purple-dim); }
.about-card-float {
  position:absolute; bottom:-20px; right:-20px;
  background:var(--bg-card2);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:18px 22px;
  box-shadow:var(--shadow);
}
.about-card-float__num {
  font-family:var(--font-h); font-size:2rem; font-weight:700;
  background:var(--grad);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.about-card-float__text { font-size:.8rem; color:var(--text2); }
.about-story__content h2 { margin-bottom:20px; }
.about-story__content p { margin-bottom:16px; }
.about-values { padding:80px 0; background:var(--bg2); }
.values-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:60px;
}
.value-card {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--r); padding:32px;
}
.value-card__num {
  font-family:var(--font-h); font-size:2.5rem; font-weight:700;
  background:var(--grad-soft);
  -webkit-background-clip:text; -webkit-text-fill-color:var(--purple-dim);
  background-clip:text;
  margin-bottom:12px; line-height:1;
}
.value-card h4 { margin-bottom:8px; }
.value-card p { font-size:.88rem; color:var(--text2); }
.team-section { padding:100px 0; }
.team-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:60px;
}
.team-card {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--rl); padding:32px;
  text-align:center; transition:var(--t);
}
.team-card:hover { border-color:var(--border); transform:translateY(-4px); }
.team-card__avatar {
  width:80px; height:80px; border-radius:50%;
  background:var(--grad); margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-h); font-size:1.6rem; font-weight:700; color:#fff;
}
.team-card h4 { margin-bottom:4px; font-size:1rem; }
.team-card__role { font-size:.82rem; color:var(--purple-light); font-weight:600; }

/* ══════════════════════════════════════════
   SERVICES PAGE
══════════════════════════════════════════ */
.services-page { padding:100px 0; }
.services-full-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:60px;
}
.service-full-card {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--rl); padding:40px 36px;
  display:flex; gap:24px;
  transition:var(--t);
}
.service-full-card:hover { border-color:var(--border); box-shadow:var(--glow); transform:translateY(-4px); }
.service-full-card__icon {
  width:56px; height:56px; border-radius:16px;
  background:var(--purple-dim); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.service-full-card__icon i { font-size:1.5rem; color:var(--purple-light); }
.service-full-card__content h3 { margin-bottom:10px; }
.service-full-card__content p { font-size:.88rem; color:var(--text2); margin-bottom:16px; }
.service-full-card__features { display:flex; flex-wrap:wrap; gap:8px; }
.service-full-card__feat {
  font-size:.75rem; padding:4px 12px; border-radius:var(--pill);
  background:var(--bg-card2); border:1px solid var(--border2);
  color:var(--text2);
}

/* ══════════════════════════════════════════
   SERVICE DETAIL PAGE
══════════════════════════════════════════ */
.service-detail { padding:100px 0; }
.service-detail__grid {
  display:grid; grid-template-columns:1fr 360px; gap:60px; align-items:start;
}
.service-detail__content h2 { margin-bottom:20px; }
.service-detail__content p { margin-bottom:20px; }
.service-detail__benefits { margin:40px 0; }
.service-detail__benefits h3 { margin-bottom:24px; }
.benefit-item {
  display:flex; gap:16px; margin-bottom:20px;
}
.benefit-item__icon {
  width:44px; height:44px; border-radius:12px;
  background:var(--purple-dim); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.benefit-item__icon i { font-size:1.1rem; color:var(--purple-light); }
.benefit-item__text h4 { margin-bottom:4px; font-size:1rem; }
.benefit-item__text p { font-size:.85rem; color:var(--text2); }
.service-detail__sidebar { position:sticky; top:100px; }
.service-detail__cta-card {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--rl); padding:36px; margin-bottom:24px;
}
.service-detail__cta-card h3 { margin-bottom:12px; font-size:1.2rem; }
.service-detail__cta-card p { font-size:.88rem; margin-bottom:24px; }
.service-detail__cta-card .btn { width:100%; justify-content:center; }
.faq-section { margin-top:60px; }
.faq-section h2 { margin-bottom:32px; }
.faq-item {
  border:1px solid var(--border2); border-radius:var(--r); margin-bottom:12px;
  overflow:hidden; transition:var(--t);
}
.faq-item.open { border-color:var(--border); }
.faq-question {
  padding:20px 24px; font-weight:600; font-size:.95rem;
  cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  background:var(--bg-card);
}
.faq-question i { transition:var(--t); color:var(--purple-light); font-size:.85rem; }
.faq-item.open .faq-question i { transform:rotate(180deg); }
.faq-answer {
  padding:0 24px; max-height:0; overflow:hidden;
  transition:max-height .35s ease, padding .35s ease;
  background:var(--bg-card);
}
.faq-answer p { font-size:.88rem; color:var(--text2); }
.faq-item.open .faq-answer {
  max-height:300px; padding:0 24px 20px;
}

/* ══════════════════════════════════════════
   PORTFOLIO PAGE
══════════════════════════════════════════ */
.portfolio-page { padding:100px 0; }
.portfolio-filters {
  display:flex; gap:10px; flex-wrap:wrap; margin-bottom:48px; justify-content:center;
}
.filter-btn {
  padding:8px 20px; border-radius:var(--pill);
  background:var(--bg-card); border:1px solid var(--border2);
  color:var(--text2); font-size:.85rem; font-weight:500;
  cursor:pointer; transition:var(--t);
}
.filter-btn:hover, .filter-btn.active {
  background:var(--purple-dim); border-color:var(--purple);
  color:var(--purple-light);
}
.portfolio-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}

/* ══════════════════════════════════════════
   BLOG PAGE
══════════════════════════════════════════ */
.blog-page { padding:100px 0; }
.blog-page__layout {
  display:grid; grid-template-columns:1fr 320px; gap:60px; margin-top:60px;
}
.blog-main-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:24px;
}
.blog-featured { grid-column:1/-1; }
.blog-featured .blog-card__img { height:300px; }
.blog-sidebar { display:block; }
.sidebar-widget {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--r); padding:28px; margin-bottom:24px;
}
.sidebar-widget h4 { margin-bottom:20px; font-size:1rem; }
.sidebar-category {
  display:flex; align-items:center; justify-content:space-between;
  padding:8px 0; border-bottom:1px solid var(--border2);
  font-size:.88rem; color:var(--text2); transition:var(--t); cursor:pointer;
}
.sidebar-category:last-child { border-bottom:none; }
.sidebar-category:hover { color:var(--white); }
.sidebar-category span {
  font-size:.75rem; background:var(--purple-dim);
  color:var(--purple-light); padding:2px 8px; border-radius:var(--pill);
}

/* ══════════════════════════════════════════
   BLOG POST PAGE
══════════════════════════════════════════ */
.blog-post { padding:60px 0 100px; }
.blog-post__layout { display:grid; grid-template-columns:1fr 300px; gap:60px; }
.blog-post__header { margin-bottom:40px; }
.blog-post__meta { display:flex; gap:16px; align-items:center; flex-wrap:wrap; margin-bottom:20px; }
.blog-post__date, .blog-post__readtime { font-size:.8rem; color:var(--text3); }
.blog-post__img { height:420px; background:var(--bg-card); border-radius:var(--rl); margin-bottom:48px; display:flex; align-items:center; justify-content:center; }
.blog-post__content h2 { font-size:1.6rem; margin:40px 0 16px; }
.blog-post__content h3 { font-size:1.25rem; margin:32px 0 12px; }
.blog-post__content p { margin-bottom:20px; font-size:.96rem; color:var(--text2); line-height:1.8; }
.blog-post__content ul { padding-left:24px; margin-bottom:20px; }
.blog-post__content li { font-size:.96rem; color:var(--text2); margin-bottom:8px; }
.blog-post__content li::marker { color:var(--purple); }
.blog-post__blockquote {
  border-left:3px solid var(--purple); padding:20px 28px;
  background:var(--purple-dim); border-radius:0 var(--r) var(--r) 0;
  margin:32px 0; font-style:italic; color:var(--text2);
}

/* ══════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════ */
.contact-page { padding:100px 0; }
.contact-page__grid { display:grid; grid-template-columns:1fr 1.4fr; gap:80px; align-items:start; }
.contact-info h2 { margin-bottom:16px; }
.contact-info p { margin-bottom:36px; }
.contact-info-item {
  display:flex; align-items:flex-start; gap:14px; margin-bottom:24px;
}
.contact-info-item__icon {
  width:48px; height:48px; border-radius:14px;
  background:var(--purple-dim); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.contact-info-item__icon i { font-size:1.1rem; color:var(--purple-light); }
.contact-info-item h4 { font-size:.9rem; margin-bottom:3px; }
.contact-info-item p { font-size:.88rem; margin:0; }
.contact-whatsapp {
  display:flex; align-items:center; gap:14px;
  background:rgba(37,211,102,.1); border:1px solid rgba(37,211,102,.2);
  border-radius:var(--r); padding:18px 20px; margin-top:32px;
  transition:var(--t);
}
.contact-whatsapp:hover { background:rgba(37,211,102,.15); }
.contact-whatsapp i { font-size:1.8rem; color:#25D366; }
.contact-whatsapp div h4 { font-size:.95rem; margin-bottom:2px; }
.contact-whatsapp div p { font-size:.82rem; margin:0; }
.contact-form-wrap {
  background:var(--bg-card); border:1px solid var(--border2);
  border-radius:var(--rl); padding:48px 44px;
}
.contact-form-wrap h3 { margin-bottom:8px; font-size:1.4rem; }
.contact-form-wrap > p { margin-bottom:32px; font-size:.9rem; }
.form-group { margin-bottom:20px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group label {
  display:block; font-size:.82rem; font-weight:600; color:var(--text2);
  margin-bottom:8px;
}
.form-group input, .form-group textarea, .form-group select {
  width:100%; padding:13px 18px;
  background:var(--bg); border:1px solid var(--border2);
  border-radius:var(--r); color:var(--white); font-size:.9rem;
  outline:none; transition:var(--t);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  border-color:var(--purple);
  box-shadow:0 0 0 3px var(--purple-dim);
}
.form-group textarea { resize:vertical; min-height:130px; }
.form-group select option { background:var(--bg2); }
.budget-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:8px;
}
.budget-option {
  position:relative;
}
.budget-option input[type="radio"] { position:absolute; opacity:0; width:0; height:0; }
.budget-option label {
  display:block; padding:12px 10px; text-align:center;
  border:1px solid var(--border2); border-radius:var(--r);
  font-size:.8rem; font-weight:600; color:var(--text2);
  cursor:pointer; transition:var(--t); margin:0;
}
.budget-option input[type="radio"]:checked + label {
  border-color:var(--purple); background:var(--purple-dim);
  color:var(--purple-light);
}
.budget-option label:hover { border-color:var(--border); color:var(--text2); }
.form-submit { width:100%; margin-top:8px; justify-content:center; font-size:1rem; padding:16px; }

/* ══════════════════════════════════════════
   PRICING FULL PAGE
══════════════════════════════════════════ */
.pricing-page { padding:100px 0; }
.pricing-faq { padding:80px 0; }

/* ══════════════════════════════════════════
   SCROLL ANIMATIONS
══════════════════════════════════════════ */
.fade-up {
  opacity:0; transform:translateY(30px);
  transition:opacity .6s ease, transform .6s ease;
}
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-up-delay-1 { transition-delay:.1s; }
.fade-up-delay-2 { transition-delay:.2s; }
.fade-up-delay-3 { transition-delay:.3s; }
.fade-up-delay-4 { transition-delay:.4s; }

/* ══════════════════════════════════════════
   UTILITIES
══════════════════════════════════════════ */
.mt-60 { margin-top:60px; }
.mt-40 { margin-top:40px; }
.flex-center { display:flex; align-items:center; justify-content:center; }
.section-header-row {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:60px; flex-wrap:wrap; gap:20px;
}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1024px) {
  .hero__grid { grid-template-columns:1fr; gap:48px; }
  .hero__visual { display:none; }
  .footer__grid { grid-template-columns:1fr 1fr; gap:40px; }
  .about-story__grid { grid-template-columns:1fr; }
  .about-story__visual { display:none; }
  .service-detail__grid { grid-template-columns:1fr; }
  .service-detail__sidebar { position:static; }
  .blog-page__layout { grid-template-columns:1fr; }
  .blog-post__layout { grid-template-columns:1fr; }
  .contact-page__grid { grid-template-columns:1fr; gap:48px; }
  .team-grid { grid-template-columns:repeat(2,1fr); }
}

@media (max-width:768px) {
  section { padding:72px 0; }
  .nav__links, .nav__actions .btn { display:none; }
  .nav__hamburger { display:flex; }
  .hero { padding:120px 0 60px; }
  .stats__grid { grid-template-columns:repeat(2,1fr); }
  .services-grid__grid { grid-template-columns:1fr; }
  .service-card--featured { grid-column:span 1; }
  .how-it-works__steps { grid-template-columns:1fr; }
  .how-it-works__steps::before { display:none; }
  .case-studies__grid { grid-template-columns:1fr; }
  .why-us__grid { grid-template-columns:1fr 1fr; }
  .pricing__grid { grid-template-columns:1fr; }
  .price-card--popular { transform:none; }
  .blog-preview__grid { grid-template-columns:1fr; }
  .cta-banner__inner { padding:48px 32px; }
  .footer__grid { grid-template-columns:1fr 1fr; }
  .services-full-grid { grid-template-columns:1fr; }
  .portfolio-grid { grid-template-columns:1fr 1fr; }
  .blog-main-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .budget-grid { grid-template-columns:repeat(2,1fr); }
  .values-grid { grid-template-columns:1fr 1fr; }
  .testimonial-card { padding:36px 28px; }
  .contact-form-wrap { padding:36px 28px; }
}

@media (max-width:480px) {
  .stats__grid { grid-template-columns:1fr 1fr; }
  .why-us__grid { grid-template-columns:1fr; }
  .footer__grid { grid-template-columns:1fr; }
  .portfolio-grid { grid-template-columns:1fr; }
  .values-grid { grid-template-columns:1fr; }
  .team-grid { grid-template-columns:1fr 1fr; }
  .hero__actions { flex-direction:column; align-items:flex-start; }
  .budget-grid { grid-template-columns:1fr 1fr; }
}

/* ─── WordPress Admin Bar ───────────────── */
body.admin-bar .nav { top:32px; }
@media screen and (max-width:782px) {
  body.admin-bar .nav { top:46px; }
}
