/* ============================================================
   ANVEXIS STACK - Design System v2
   Dark mode + Animations + Sticky footer
   ============================================================ */

:root {
  --bg:#ffffff;--bg-2:#f8f9fb;--bg-3:#f1f4f8;--bg-elevated:#ffffff;
  --fg:#0b0f19;--fg-2:#4b5563;--fg-3:#9ca3af;
  --border:rgba(0,0,0,0.08);--border-2:rgba(0,0,0,0.13);
  --nav-bg:rgba(255,255,255,0.88);--nav-border:rgba(0,0,0,0.07);
  --input-bg:#ffffff;--input-border:rgba(0,0,0,0.13);
  --dark:#0b0f19;--dark-2:#111827;--dark-3:#1a2235;--dark-4:#232d42;
  --dark-border:rgba(255,255,255,0.07);--dark-text:rgba(255,255,255,0.85);--dark-text-2:rgba(255,255,255,0.5);
  --indigo:#6366f1;--indigo-light:#818cf8;--indigo-dark:#4f46e5;--cyan:#06b6d4;--violet:#8b5cf6;
  --shadow-sm:0 1px 3px rgba(0,0,0,0.06);--shadow:0 4px 16px rgba(0,0,0,0.07);
  --shadow-lg:0 12px 40px rgba(0,0,0,0.09);--shadow-indigo:0 4px 20px rgba(99,102,241,0.3);
  --r-sm:8px;--r:12px;--r-lg:16px;--r-xl:20px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;--mono:'JetBrains Mono','Fira Code',monospace;
  --nav-h:64px;--t:0.18s ease;--t-slow:0.35s ease;
}

[data-theme="dark"] {
  --bg:#0b0f19;--bg-2:#0d1120;--bg-3:#111827;--bg-elevated:#111827;
  --fg:#f1f5f9;--fg-2:rgba(241,245,249,0.58);--fg-3:rgba(241,245,249,0.32);
  --border:rgba(255,255,255,0.08);--border-2:rgba(255,255,255,0.13);
  --nav-bg:rgba(11,15,25,0.92);--nav-border:rgba(255,255,255,0.07);
  --input-bg:#1a2235;--input-border:rgba(255,255,255,0.12);
  --dark:#060a12;--dark-2:#0b0f19;--dark-3:#111827;--dark-4:#1a2235;
  --dark-border:rgba(255,255,255,0.09);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.25);--shadow:0 4px 16px rgba(0,0,0,0.35);--shadow-lg:0 12px 40px rgba(0,0,0,0.5);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

body,h1,h2,h3,h4,p,a,span,div,button,input,select,textarea,li,nav,footer,main,section,aside,article {
  transition:background-color var(--t-slow),border-color var(--t-slow),color var(--t-slow),box-shadow var(--t-slow);
}

canvas,#hero-canvas,.reveal,.stagger-parent *{transition:none!important}

html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}

body{
  font-family:var(--font);background:var(--bg);color:var(--fg);
  line-height:1.6;overflow-x:hidden;
  display:flex;flex-direction:column;min-height:100vh;
}

main{flex:1 0 auto;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
ul{list-style:none;}

h1,h2,h3,h4,h5{font-weight:600;letter-spacing:-0.02em;line-height:1.2;color:var(--fg);}
h1{font-size:clamp(2rem,5vw,3.5rem);}
h2{font-size:clamp(1.6rem,3vw,2.4rem);}
h3{font-size:1.2rem;}h4{font-size:1rem;}
p{color:var(--fg-2);line-height:1.75;}

.text-gradient{
  background:linear-gradient(135deg,var(--indigo) 0%,var(--cyan) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

.container{max-width:1160px;margin:0 auto;padding:0 24px;}
.container--narrow{max-width:760px;}

/* NAVBAR */
.navbar{
  position:sticky;top:0;z-index:200;height:var(--nav-h);
  background:var(--nav-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--nav-border);
}
.navbar.scrolled{box-shadow:var(--shadow);}
.navbar__inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:24px;}
.navbar__logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.logo-mark{width:32px;height:32px;background:var(--indigo);color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;letter-spacing:.05em;flex-shrink:0;}
.logo-text{font-size:15px;font-weight:600;letter-spacing:-0.01em;color:var(--fg);}
.navbar__links{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;}
.nav-link{padding:6px 11px;font-size:13.5px;font-weight:500;color:var(--fg-2);border-radius:var(--r-sm);}
.nav-link:hover,.nav-link.active{color:var(--fg);background:var(--bg-2);}
.navbar__actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}

.theme-toggle{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--r-sm);border:1px solid var(--border-2);background:var(--bg-elevated);
  color:var(--fg-2);cursor:pointer;flex-shrink:0;
}
.theme-toggle:hover{color:var(--indigo);border-color:var(--indigo);}
.theme-toggle svg{width:16px;height:16px;}
.theme-toggle .icon-sun{display:none;}
.theme-toggle .icon-moon{display:block;}
[data-theme="dark"] .theme-toggle .icon-sun{display:block;}
[data-theme="dark"] .theme-toggle .icon-moon{display:none;}

.nav-toggle{display:none;padding:6px;color:var(--fg-2);border-radius:var(--r-sm);}
.nav-toggle:hover{background:var(--bg-2);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font);font-weight:500;font-size:14px;border-radius:var(--r-sm);padding:9px 18px;white-space:nowrap;text-decoration:none;border:1px solid transparent;cursor:pointer;}
.btn svg{width:15px;height:15px;}
.btn--primary{background:var(--indigo);color:#fff;border-color:var(--indigo);}
.btn--primary:hover{background:var(--indigo-dark);border-color:var(--indigo-dark);box-shadow:var(--shadow-indigo);transform:translateY(-1px);}
.btn--ghost{background:transparent;color:var(--fg);border-color:var(--border-2);}
.btn--ghost:hover{background:var(--bg-2);}
.btn--outline{background:transparent;color:var(--fg);border-color:var(--border-2);}
.btn--outline:hover{background:var(--bg-2);}
.btn--outline.btn--light{color:rgba(255,255,255,0.85);border-color:rgba(255,255,255,0.2);}
.btn--outline.btn--light:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.3);}
.btn--sm{padding:7px 14px;font-size:13px;}
.btn--lg{padding:12px 24px;font-size:15px;border-radius:var(--r);}
.btn--full{width:100%;justify-content:center;}

.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:100px;font-size:12px;font-weight:500;letter-spacing:.02em;}
.badge--indigo{background:rgba(99,102,241,0.1);color:var(--indigo);border:1px solid rgba(99,102,241,0.2);}
.section-label{display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--indigo);margin-bottom:12px;}
[data-theme="dark"] .section-label{color:var(--indigo-light);}

/* SECTIONS */
.section{padding:88px 0;background:var(--bg);}
.section--muted{background:var(--bg-2);}
.section--dark{background:var(--dark);}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff;}
.section--dark p{color:var(--dark-text-2);}
.section--dark .section-label{color:var(--indigo-light);}
.section--dark .section-title{color:#fff;}
.section--dark .section-sub{color:var(--dark-text-2);}
.section-header{text-align:center;max-width:600px;margin:0 auto 56px;}
.section-title{color:var(--fg);margin-bottom:12px;}
.section-sub{font-size:16px;color:var(--fg-2);}
.section-cta{text-align:center;margin-top:40px;}

/* HERO */
.hero{position:relative;padding:108px 0 88px;overflow:hidden;text-align:center;background:var(--bg);}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}
.hero-content{position:relative;z-index:1;}
.hero__eyebrow{margin-bottom:20px;}
.hero__headline{font-size:clamp(2.6rem,5.5vw,4.2rem);font-weight:700;letter-spacing:-0.035em;line-height:1.1;margin-bottom:20px;color:var(--fg);}
.hero__sub{font-size:18px;color:var(--fg-2);max-width:580px;margin:0 auto 36px;line-height:1.7;}
.hero__actions{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:44px;}
.hero__trust{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;font-size:13px;color:var(--fg-3);}
.trust-pills{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;}
.trust-pills span{padding:3px 11px;border-radius:100px;border:1px solid var(--border);font-size:12px;color:var(--fg-3);background:var(--bg-elevated);}

/* STATS BAR */
.stats-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg);}
.stats-bar__inner{display:flex;align-items:stretch;justify-content:space-around;flex-wrap:wrap;}
.stat-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 24px;gap:4px;flex:1;min-width:160px;}
.stat-number{font-size:2.2rem;font-weight:700;letter-spacing:-0.04em;color:var(--fg);}
.stat-label{font-size:13px;color:var(--fg-2);}
.stat-divider{width:1px;background:var(--border);align-self:stretch;}

/* SERVICES GRID */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.service-card{display:block;padding:28px;background:var(--bg-elevated);border-right:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;overflow:hidden;}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--indigo),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease;}
.service-card:hover{background:var(--bg-2);}
.service-card:hover::after{transform:scaleX(1);}
.service-card__icon{width:42px;height:42px;border-radius:var(--r-sm);background:rgba(99,102,241,0.1);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--indigo);border:1px solid rgba(99,102,241,0.15);}
.service-card__icon svg{width:18px;height:18px;}
.service-card:hover .service-card__icon{transform:scale(1.05);}
.service-card__title{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--fg);}
.service-card__desc{font-size:13.5px;color:var(--fg-2);line-height:1.6;margin-bottom:16px;}
.service-card__link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--indigo);}
.service-card__link svg{width:13px;height:13px;transition:transform var(--t);}
.service-card:hover .service-card__link svg{transform:translateX(4px);}

/* PORTFOLIO GRID */
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
.portfolio-card{display:flex;flex-direction:column;gap:16px;padding:28px;border:1px solid var(--dark-border);border-radius:var(--r-lg);background:var(--dark-2);}
.portfolio-card:hover{border-color:rgba(99,102,241,0.35);transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,0.3);}
.portfolio-card__industry{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--indigo-light);}
.portfolio-card__title{font-size:17px;font-weight:600;color:#fff;line-height:1.3;}
.portfolio-card__desc{font-size:13.5px;color:var(--dark-text-2);line-height:1.6;}
.portfolio-card__result{display:flex;align-items:flex-start;gap:10px;padding:14px;background:rgba(6,182,212,0.06);border:1px solid rgba(6,182,212,0.18);border-radius:var(--r-sm);font-size:13px;color:var(--cyan);line-height:1.5;}
.portfolio-card__result svg{width:14px;height:14px;flex-shrink:0;margin-top:2px;}
.portfolio-card__tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto;}

.tag{padding:3px 8px;border-radius:5px;font-size:11px;font-weight:500;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);border:1px solid rgba(255,255,255,0.08);}
.tag--lg{font-size:12px;padding:4px 10px;}
.tag--light{background:rgba(99,102,241,0.07);color:var(--indigo);border-color:rgba(99,102,241,0.15);}

/* PROCESS */
.process-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.process-step{padding:32px 28px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-elevated);}
.process-step:hover{background:var(--bg-2);}
.process-step__num{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--indigo);letter-spacing:.05em;margin-bottom:12px;}
.process-step h3{font-size:16px;margin-bottom:10px;color:var(--fg);}
.process-step p{font-size:13.5px;color:var(--fg-2);line-height:1.65;}

/* TESTIMONIALS */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.testimonial-card{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:16px;}
.testimonial-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.testimonial-card__stars{display:flex;gap:4px;}
.testimonial-card__stars svg{width:13px;height:13px;fill:#f59e0b;stroke:#f59e0b;}
.testimonial-card__quote{font-size:14px;color:var(--fg);line-height:1.75;font-style:normal;flex:1;}
.testimonial-card__author{display:flex;align-items:center;gap:12px;}
.author-avatar{width:36px;height:36px;border-radius:50%;background:var(--indigo);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;}
.author-name{font-size:13px;font-weight:600;color:var(--fg);}
.author-meta{font-size:12px;color:var(--fg-3);}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.blog-grid--full{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));}
.blog-card{display:flex;flex-direction:column;gap:12px;padding:24px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);}
.blog-card:hover{border-color:rgba(99,102,241,0.3);box-shadow:var(--shadow);transform:translateY(-2px);}
.blog-card__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.blog-card__cat{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--indigo);}
.blog-card__read,.blog-card__date{font-size:12px;color:var(--fg-3);}
.blog-card__title{font-size:16px;font-weight:600;color:var(--fg);line-height:1.35;}
.blog-card__excerpt{font-size:13.5px;color:var(--fg-2);line-height:1.65;flex:1;}
.blog-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.blog-card__author{font-size:12px;color:var(--fg-3);}
.blog-card__link{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:500;color:var(--indigo);}
.blog-card__link svg{width:13px;height:13px;transition:transform var(--t);}
.blog-card:hover .blog-card__link svg{transform:translateX(3px);}

.blog-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;}
.filter-btn{padding:6px 14px;border-radius:100px;font-size:13px;font-weight:500;color:var(--fg-2);border:1px solid var(--border);background:var(--bg-elevated);}
.filter-btn:hover,.filter-btn.active{background:var(--indigo);color:#fff;border-color:var(--indigo);}

/* CTA */
.cta-section{padding:80px 0;background:var(--dark);flex-shrink:0;}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;padding:52px;border:1px solid var(--dark-border);border-radius:var(--r-xl);background:var(--dark-2);}
.cta-label{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--indigo-light);margin-bottom:10px;}
.cta-content h2{color:#fff;font-size:clamp(1.4rem,2.5vw,2rem);}
.cta-content p{color:var(--dark-text-2);max-width:420px;margin-top:8px;}
.cta-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0;}

/* PAGE HERO */
.page-hero{padding:72px 0 60px;border-bottom:1px solid var(--border);background:var(--bg);}
.page-hero__title{margin-top:12px;margin-bottom:16px;}
.page-hero__sub{font-size:17px;color:var(--fg-2);max-width:560px;}
.page-hero--narrow{max-width:760px;}
.back-link{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--fg-2);margin-bottom:20px;}
.back-link:hover{color:var(--fg);}
.back-link svg{width:14px;height:14px;}
.service-hero-icon{width:56px;height:56px;border-radius:var(--r);background:rgba(99,102,241,0.1);border:1px solid rgba(99,102,241,0.2);display:flex;align-items:center;justify-content:center;color:var(--indigo);margin-bottom:20px;}
.service-hero-icon svg{width:24px;height:24px;}

/* CONTENT LAYOUT */
.content-layout{display:grid;grid-template-columns:1fr 300px;gap:48px;align-items:start;}
.content-layout--blog{grid-template-columns:1fr 280px;}
.prose h2{font-size:1.4rem;margin:32px 0 12px;color:var(--fg);}
.prose h3{font-size:1.15rem;margin:24px 0 10px;color:var(--fg);}
.prose p{margin-bottom:18px;font-size:15.5px;line-height:1.8;color:var(--fg-2);}
.prose ul{margin:16px 0 20px 20px;list-style:disc;}
.prose li{font-size:15px;color:var(--fg-2);margin-bottom:8px;line-height:1.6;}
.prose strong{color:var(--fg);font-weight:600;}
.prose code{font-family:var(--mono);font-size:13px;padding:2px 6px;background:var(--bg-2);border:1px solid var(--border);border-radius:4px;color:var(--indigo);}
.prose--blog p{font-size:16px;}

.sidebar-card{padding:24px;border-radius:var(--r-lg);background:var(--bg-2);margin-bottom:16px;border:1px solid var(--border);}
.sidebar-card--outline{background:var(--bg-elevated);}
.sidebar-card h4{font-size:14px;font-weight:600;margin-bottom:8px;color:var(--fg);}
.sidebar-card p{font-size:13.5px;margin-bottom:16px;color:var(--fg-2);}
.sidebar-links{display:flex;flex-direction:column;gap:4px;}
.sidebar-links li a{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--fg-2);padding:8px 10px;border-radius:var(--r-sm);}
.sidebar-links li a:hover{background:var(--bg-2);color:var(--fg);}
.sidebar-links svg{width:14px;height:14px;color:var(--indigo);flex-shrink:0;}

.result-highlight{display:flex;gap:16px;align-items:flex-start;padding:24px;background:rgba(6,182,212,0.04);border:1px solid rgba(6,182,212,0.2);border-radius:var(--r-lg);margin-bottom:32px;}
.result-highlight__icon{color:var(--cyan);flex-shrink:0;margin-top:2px;}
.result-highlight__icon svg{width:20px;height:20px;}
.result-highlight__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan);margin-bottom:6px;}
.result-highlight__text{font-size:15px;color:var(--fg);line-height:1.65;}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.two-col__text h2{margin-bottom:16px;}
.two-col__text p{margin-bottom:16px;font-size:15.5px;}
.two-col__text .btn{margin-top:8px;}
.check-list{margin:20px 0 24px;display:flex;flex-direction:column;gap:10px;}
.check-list li{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--fg-2);}
.check-list svg{width:15px;height:15px;color:var(--indigo);flex-shrink:0;}

.code-block{background:var(--dark);border:1px solid var(--dark-border);border-radius:var(--r-lg);overflow:hidden;}
.code-block__header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--dark-border);}
.dot{width:11px;height:11px;border-radius:50%;}
.dot.red{background:#ff5f57;}.dot.yellow{background:#febc2e;}.dot.green{background:#28c840;}
.code-block__filename{font-family:var(--mono);font-size:12px;color:var(--dark-text-2);margin-left:4px;}
.code-block pre{padding:24px;overflow-x:auto;}
.code-block code{font-family:var(--mono);font-size:12.5px;line-height:1.75;color:rgba(255,255,255,0.75);background:none;border:none;padding:0;}

/* PORTFOLIO LIST */
.portfolio-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.portfolio-list-item{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;padding:32px 28px;background:var(--bg-elevated);border-bottom:1px solid var(--border);}
.portfolio-list-item:hover{background:var(--bg-2);}
.portfolio-list-item__industry{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--indigo);margin-bottom:8px;display:block;}
.portfolio-list-item__title{font-size:18px;font-weight:600;margin-bottom:10px;color:var(--fg);}
.portfolio-list-item__desc{font-size:14px;color:var(--fg-2);line-height:1.65;margin-bottom:14px;}
.portfolio-list-item__tags{display:flex;gap:6px;flex-wrap:wrap;}
.portfolio-list-item__tags .tag{background:rgba(99,102,241,0.07);color:var(--indigo);border-color:rgba(99,102,241,0.15);}
.result-card{display:flex;gap:10px;align-items:flex-start;padding:16px;border:1px solid rgba(6,182,212,0.2);border-radius:var(--r);background:rgba(6,182,212,0.03);margin-bottom:12px;}
.result-card svg{width:14px;height:14px;color:var(--cyan);flex-shrink:0;margin-top:2px;}
.result-card p{font-size:13.5px;color:var(--fg-2);line-height:1.6;margin:0;}
.portfolio-list-item__cta{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--indigo);}
.portfolio-list-item__cta svg{width:13px;height:13px;}
.portfolio-tags{margin-top:32px;}
.portfolio-tags__label{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--fg-3);margin-bottom:12px;}
.portfolio-tags__list{display:flex;gap:8px;flex-wrap:wrap;}
.portfolio-tags__list .tag{background:rgba(99,102,241,0.07);color:var(--indigo);border-color:rgba(99,102,241,0.15);}

/* CONTACT */
.contact-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start;}
.contact-form{display:flex;flex-direction:column;gap:20px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:13px;font-weight:500;color:var(--fg);}
.required{color:var(--indigo);}
.form-group input,.form-group select,.form-group textarea{padding:10px 14px;border:1px solid var(--input-border);border-radius:var(--r-sm);font-family:var(--font);font-size:14px;color:var(--fg);background:var(--input-bg);outline:none;width:100%;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,0.12);}
.form-group textarea{resize:vertical;min-height:120px;}
.form-group.has-error input,.form-group.has-error textarea{border-color:#ef4444;}
.form-error{font-size:12px;color:#ef4444;}
.success-state{text-align:center;padding:60px 40px;border:1px solid rgba(34,197,94,0.2);border-radius:var(--r-xl);background:rgba(34,197,94,0.03);}
.success-state__icon{color:#22c55e;margin-bottom:16px;}
.success-state__icon svg{width:48px;height:48px;}
.success-state h3{margin-bottom:8px;}
.success-state p{margin-bottom:24px;font-size:15px;}
.success-state a:not(.btn){color:var(--indigo);}
.contact-info{display:flex;flex-direction:column;gap:20px;padding-top:8px;}
.contact-info__block{display:flex;gap:14px;align-items:flex-start;}
.contact-info__icon{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(99,102,241,0.09);display:flex;align-items:center;justify-content:center;color:var(--indigo);flex-shrink:0;}
.contact-info__icon svg{width:16px;height:16px;}
.contact-info__label{font-size:12px;color:var(--fg-3);margin-bottom:2px;}
.contact-info__value{font-size:14px;font-weight:500;color:var(--fg);}
.contact-info a:hover{color:var(--indigo);}
.contact-guarantee{padding:20px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-2);margin-top:8px;}
.contact-guarantee h4{font-size:13px;font-weight:600;margin-bottom:12px;color:var(--fg);}
.contact-guarantee ul{display:flex;flex-direction:column;gap:8px;}
.contact-guarantee li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-2);}
.contact-guarantee svg{width:14px;height:14px;color:var(--indigo);flex-shrink:0;}

/* PRICING */
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:24px;}
.pricing-card{padding:32px;border:1px solid var(--border);border-radius:var(--r-xl);background:var(--bg-elevated);display:flex;flex-direction:column;gap:24px;position:relative;}
.pricing-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.pricing-card--featured{border-color:var(--indigo);box-shadow:0 0 0 1px var(--indigo),var(--shadow-lg);}
.pricing-card__badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--indigo);color:#fff;font-size:11px;font-weight:600;letter-spacing:.04em;padding:3px 12px;border-radius:100px;white-space:nowrap;}
.pricing-card__icon{width:44px;height:44px;border-radius:var(--r-sm);background:rgba(99,102,241,0.09);display:flex;align-items:center;justify-content:center;color:var(--indigo);}
.pricing-card__icon svg{width:20px;height:20px;}
.pricing-card__header h3{font-size:18px;margin-bottom:8px;}
.pricing-card__header p{font-size:14px;color:var(--fg-2);}
.pricing-card__price{display:flex;align-items:baseline;gap:6px;}
.price-from{font-size:13px;color:var(--fg-3);}
.price-amount{font-size:2rem;font-weight:700;letter-spacing:-0.03em;color:var(--fg);}
.price-period{font-size:13px;color:var(--fg-3);}
.pricing-card__features{display:flex;flex-direction:column;gap:10px;flex:1;}
.pricing-card__features li{display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--fg-2);}
.pricing-card__features svg{width:14px;height:14px;color:var(--indigo);flex-shrink:0;}
.pricing-note{display:flex;gap:12px;align-items:flex-start;padding:16px 20px;background:var(--bg-2);border-radius:var(--r);border:1px solid var(--border);}
.pricing-note svg{width:16px;height:16px;color:var(--fg-3);flex-shrink:0;margin-top:2px;}
.pricing-note p{font-size:13.5px;margin:0;}
.support-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.support-card{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);display:flex;flex-direction:column;gap:12px;}
.support-card--featured{border-color:var(--indigo);}
.support-card h4{font-size:16px;font-weight:600;}
.support-price{font-size:1.8rem;font-weight:700;letter-spacing:-0.03em;color:var(--fg);}
.support-price span{font-size:14px;font-weight:400;color:var(--fg-3);}
.support-card p{font-size:13.5px;color:var(--fg-2);flex:1;}

/* FAQ */
.faq-list{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.faq-item{background:var(--bg-elevated);}
.faq-question{width:100%;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;font-size:15px;font-weight:500;color:var(--fg);background:var(--bg-elevated);border-bottom:1px solid var(--border);}
.faq-question:hover{background:var(--bg-2);}
.faq-icon{width:16px;height:16px;color:var(--fg-3);flex-shrink:0;transition:transform 0.25s ease;}
.faq-item.open .faq-icon{transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.25s;padding:0 24px;border-bottom:1px solid var(--border);}
.faq-item.open .faq-answer{max-height:250px;padding:16px 24px 20px;}
.faq-answer p{font-size:14.5px;color:var(--fg-2);line-height:1.75;margin:0;}

/* ABOUT */
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.about-stat{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);text-align:center;}
.about-stat:hover{box-shadow:var(--shadow);}
.about-stat__num{font-size:2.4rem;font-weight:700;letter-spacing:-0.03em;color:var(--indigo);}
.about-stat__label{font-size:13px;color:var(--fg-2);margin-top:4px;}
.principles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;}
.principle-card{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);}
.principle-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.principle-card__icon{width:40px;height:40px;border-radius:var(--r-sm);background:rgba(99,102,241,0.09);display:flex;align-items:center;justify-content:center;color:var(--indigo);margin-bottom:16px;}
.principle-card__icon svg{width:18px;height:18px;}
.principle-card h3{font-size:15px;margin-bottom:10px;}
.principle-card p{font-size:13.5px;color:var(--fg-2);line-height:1.65;}
.tech-grid{display:flex;flex-wrap:wrap;gap:10px;}
.tech-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--border);border-radius:100px;font-size:13px;font-weight:500;color:var(--fg-2);background:var(--bg-elevated);}
.tech-chip:hover{border-color:var(--indigo);color:var(--indigo);}
.tech-chip svg{width:14px;height:14px;}

/* BLOG DETAIL */
.blog-meta-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.blog-meta-date,.blog-meta-read{font-size:13px;color:var(--fg-3);}
.post-author{display:flex;align-items:center;gap:10px;margin-top:20px;}
.post-author span{font-size:14px;font-weight:500;color:var(--fg-2);}

/* INDUSTRIES */
.industries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.industry-card{padding:32px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);position:relative;overflow:hidden;}
.industry-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--indigo),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform 0.35s ease;}
.industry-card:hover{border-color:rgba(99,102,241,0.25);box-shadow:var(--shadow);transform:translateY(-3px);}
.industry-card:hover::before{transform:scaleX(1);}
.industry-card__icon{width:48px;height:48px;border-radius:var(--r);background:rgba(99,102,241,0.08);display:flex;align-items:center;justify-content:center;color:var(--indigo);margin-bottom:20px;border:1px solid rgba(99,102,241,0.15);}
.industry-card__icon svg{width:22px;height:22px;}
.industry-card h3{font-size:17px;font-weight:600;margin-bottom:10px;color:var(--fg);}
.industry-card p{font-size:13.5px;color:var(--fg-2);line-height:1.65;margin-bottom:20px;}
.industry-card__link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--indigo);}
.industry-card__link svg{width:13px;height:13px;transition:transform var(--t);}
.industry-card:hover .industry-card__link svg{transform:translateX(4px);}
.industry-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:32px 0;}
.industry-stat{padding:24px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);text-align:center;}
.industry-stat__num{font-size:2rem;font-weight:700;letter-spacing:-0.03em;color:var(--indigo);}
.industry-stat__label{font-size:12px;color:var(--fg-3);margin-top:4px;}

/* TECHNOLOGY */
.tech-category{margin-bottom:48px;}
.tech-category__title{font-size:18px;font-weight:600;margin-bottom:6px;color:var(--fg);}
.tech-category__desc{font-size:14px;color:var(--fg-2);margin-bottom:20px;}
.tech-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;}
.tech-item{display:flex;align-items:center;gap:12px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);}
.tech-item:hover{border-color:rgba(99,102,241,0.3);box-shadow:var(--shadow-sm);}
.tech-item__icon{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(99,102,241,0.08);display:flex;align-items:center;justify-content:center;color:var(--indigo);flex-shrink:0;}
.tech-item__icon svg{width:16px;height:16px;}
.tech-item__name{font-size:13.5px;font-weight:600;color:var(--fg);}
.tech-item__label{font-size:11px;color:var(--fg-3);margin-top:2px;}

/* CAREERS */
.job-grid{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;}
.job-card{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px 28px;background:var(--bg-elevated);border-bottom:1px solid var(--border);flex-wrap:wrap;}
.job-card:hover{background:var(--bg-2);}
.job-card__title{font-size:16px;font-weight:600;margin-bottom:6px;color:var(--fg);}
.job-card__meta{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.job-card__type{font-size:12px;padding:3px 9px;border-radius:100px;font-weight:500;}
.job-type--ft{background:rgba(99,102,241,0.1);color:var(--indigo);border:1px solid rgba(99,102,241,0.2);}
.job-type--remote{background:rgba(139,92,246,0.1);color:var(--violet);border:1px solid rgba(139,92,246,0.2);}
.job-card__loc{font-size:13px;color:var(--fg-3);display:flex;align-items:center;gap:5px;}
.job-card__loc svg{width:13px;height:13px;}

/* PARTNERS */
.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;}
.partner-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:28px 20px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);text-align:center;min-height:140px;}
.partner-card:hover{border-color:rgba(99,102,241,0.3);box-shadow:var(--shadow);}
.partner-card__icon{width:48px;height:48px;border-radius:var(--r);background:rgba(99,102,241,0.08);display:flex;align-items:center;justify-content:center;color:var(--indigo);}
.partner-card__icon svg{width:22px;height:22px;}
.partner-card__name{font-size:14px;font-weight:600;color:var(--fg);}
.partner-card__type{font-size:12px;color:var(--fg-3);}

/* RESOURCES */
.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.resource-card{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);display:flex;flex-direction:column;gap:12px;}
.resource-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);}
.resource-card__type{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--indigo);}
.resource-card__title{font-size:16px;font-weight:600;color:var(--fg);line-height:1.35;}
.resource-card__desc{font-size:13.5px;color:var(--fg-2);line-height:1.6;flex:1;}
.resource-card__link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--indigo);margin-top:auto;}
.resource-card__link svg{width:13px;height:13px;transition:transform var(--t);}
.resource-card:hover .resource-card__link svg{transform:translateX(3px);}

/* PROCESS TIMELINE */
.process-timeline{display:flex;flex-direction:column;}
.timeline-item{display:grid;grid-template-columns:80px 1fr;gap:28px;padding:32px 0;border-bottom:1px solid var(--border);align-items:start;}
.timeline-num{font-family:var(--mono);font-size:28px;font-weight:700;color:var(--indigo);opacity:0.35;}
.timeline-content h3{font-size:18px;font-weight:600;margin-bottom:10px;color:var(--fg);}
.timeline-content p{font-size:15px;color:var(--fg-2);line-height:1.75;margin-bottom:16px;}
.timeline-content ul{display:flex;flex-direction:column;gap:7px;}
.timeline-content li{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--fg-2);}
.timeline-content li::before{content:'—';color:var(--indigo);font-weight:600;flex-shrink:0;}

/* LEGAL */
.legal-content{max-width:760px;}
.legal-content h2{font-size:1.3rem;margin:40px 0 12px;padding-top:24px;border-top:1px solid var(--border);color:var(--fg);}
.legal-content h3{font-size:1.1rem;margin:24px 0 10px;color:var(--fg);}
.legal-content p{font-size:15px;line-height:1.8;color:var(--fg-2);margin-bottom:16px;}
.legal-content ul{margin:12px 0 20px 20px;list-style:disc;}
.legal-content li{font-size:15px;color:var(--fg-2);margin-bottom:8px;line-height:1.6;}

/* LANDING PAGES */
.landing-hero{padding:96px 0 72px;background:var(--dark);text-align:center;}
.landing-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.5rem);margin-bottom:16px;}
.landing-hero p{color:var(--dark-text-2);font-size:18px;max-width:560px;margin:0 auto 32px;}
.landing-hero__actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}
.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.feature-card{padding:28px;border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-elevated);}
.feature-card:hover{box-shadow:var(--shadow);}
.feature-card__icon{width:44px;height:44px;border-radius:var(--r);background:rgba(99,102,241,0.09);display:flex;align-items:center;justify-content:center;color:var(--indigo);margin-bottom:16px;}
.feature-card__icon svg{width:20px;height:20px;}
.feature-card h3{font-size:16px;font-weight:600;margin-bottom:8px;}
.feature-card p{font-size:13.5px;color:var(--fg-2);line-height:1.65;}
.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;}
.module-chip{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--r);background:var(--bg-elevated);font-size:13px;font-weight:500;color:var(--fg);}
.module-chip:hover{border-color:var(--indigo);background:rgba(99,102,241,0.04);}
.module-chip svg{width:15px;height:15px;color:var(--indigo);}

/* FOOTER - sticky via body flex */
.footer{background:var(--dark);padding:64px 0 0;flex-shrink:0;}
.footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer__brand .logo-text{color:#fff;}
.footer__tagline{font-size:13.5px;color:var(--dark-text-2);margin-top:12px;max-width:280px;line-height:1.6;}
.footer__social{display:flex;gap:10px;margin-top:20px;}
.footer__social a{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--dark-border);display:flex;align-items:center;justify-content:center;color:var(--dark-text-2);}
.footer__social a:hover{border-color:var(--indigo-light);color:var(--indigo-light);}
.footer__social svg{width:14px;height:14px;}
.footer__col h4{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--dark-text-2);margin-bottom:16px;}
.footer__col ul{display:flex;flex-direction:column;gap:10px;}
.footer__col li a{font-size:14px;color:rgba(255,255,255,0.45);}
.footer__col li a:hover{color:#fff;}
.footer__badge{display:inline-flex;align-items:center;gap:6px;margin-top:20px;padding:6px 12px;border:1px solid var(--dark-border);border-radius:100px;font-size:12px;color:var(--dark-text-2);}
.footer__badge svg{width:13px;height:13px;}
.footer__bottom{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-top:1px solid var(--dark-border);}
.footer__bottom p{font-size:13px;color:var(--dark-text-2);margin:0;}
.footer__bottom a{color:var(--dark-text-2);}
.footer__bottom a:hover{color:#fff;}

/* ERROR PAGES */
.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:80px 0;}
.error-inner{text-align:center;max-width:480px;}
.error-code{font-family:var(--mono);font-size:5rem;font-weight:700;color:var(--indigo);letter-spacing:-0.04em;line-height:1;margin-bottom:20px;opacity:0.5;}
.error-inner h1{margin-bottom:12px;}
.error-inner p{font-size:16px;margin-bottom:32px;}
.error-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:28px;}
.error-links{display:flex;align-items:center;gap:12px;justify-content:center;font-size:13px;color:var(--fg-3);flex-wrap:wrap;}
.error-links a{color:var(--indigo);font-weight:500;}

/* ANIMATION HELPERS */
.reveal{opacity:0;transform:translateY(22px);}
.reveal.is-visible{opacity:1;transform:translateY(0);transition:opacity 0.6s ease,transform 0.6s ease;}
.reveal-left{opacity:0;transform:translateX(-24px);}
.reveal-left.is-visible{opacity:1;transform:translateX(0);transition:opacity 0.6s ease,transform 0.6s ease;}
.reveal-right{opacity:0;transform:translateX(24px);}
.reveal-right.is-visible{opacity:1;transform:translateX(0);transition:opacity 0.6s ease,transform 0.6s ease;}
.stagger-parent .reveal:nth-child(1){transition-delay:0s;}
.stagger-parent .reveal:nth-child(2){transition-delay:.07s;}
.stagger-parent .reveal:nth-child(3){transition-delay:.14s;}
.stagger-parent .reveal:nth-child(4){transition-delay:.21s;}
.stagger-parent .reveal:nth-child(5){transition-delay:.28s;}
.stagger-parent .reveal:nth-child(6){transition-delay:.35s;}
.counter{transition:none!important;}

/* RESPONSIVE */
@media(max-width:1024px){
  .content-layout,.content-layout--blog{grid-template-columns:1fr;}
  .two-col{grid-template-columns:1fr;gap:40px;}
  .footer__grid{grid-template-columns:1fr 1fr;gap:32px;}
  .portfolio-list-item{grid-template-columns:1fr;}
  .contact-layout{grid-template-columns:1fr;}
  .industry-stats{grid-template-columns:1fr 1fr;}
}
@media(max-width:768px){
  .navbar__links{display:none;}
  .nav-toggle{display:flex;}
  .navbar__links.open{display:flex;flex-direction:column;position:absolute;top:var(--nav-h);left:0;right:0;background:var(--nav-bg);border-bottom:1px solid var(--nav-border);padding:16px;gap:4px;box-shadow:var(--shadow-lg);backdrop-filter:blur(20px);}
  .cta-inner{padding:32px 24px;}
  .cta-content,.cta-actions{width:100%;}
  .cta-actions{flex-direction:column;}
  .hero{padding:72px 0 56px;}
  .section{padding:60px 0;}
  .stats-bar__inner{flex-wrap:wrap;}
  .stat-divider{display:none;}
  .form-row{grid-template-columns:1fr;}
  .pricing-grid,.support-grid{grid-template-columns:1fr;}
  .footer__grid{grid-template-columns:1fr;gap:24px;}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center;}
  .services-grid{grid-template-columns:1fr;}
  .about-stats{grid-template-columns:1fr 1fr;}
  .industry-stats{grid-template-columns:1fr;}
  .timeline-item{grid-template-columns:1fr;gap:8px;}
}
@media(max-width:480px){
  h1{font-size:2rem;}
  .hero__actions{flex-direction:column;align-items:stretch;}
  .hero__actions .btn{justify-content:center;}
  .portfolio-grid,.testimonials-grid,.blog-grid{grid-template-columns:1fr;}
  .industries-grid,.feature-grid,.resource-grid{grid-template-columns:1fr;}
}
