/* ============================================================
   HEXTASOFT — Design System v2.0
   Modern, High-Performance Website
   ============================================================ */

/* ─── 1. CSS CUSTOM PROPERTIES ─────────────────────────── */
:root {
  --clr-brand-950: #130328;
  --clr-brand-900: #2D0B5E;
  --clr-brand-800: #3D1080;
  --clr-brand-700: #5B1E9C;
  --clr-brand-600: #7B35C1;
  --clr-brand-500: #9B4FE0;
  --clr-brand-400: #A855F7;
  --clr-brand-300: #C084FC;
  --clr-brand-200: #DDB6FA;
  --clr-brand-100: #F3E8FF;
  --clr-brand-50:  #FAF5FF;
  --clr-accent-600: #C2185B;
  --clr-accent-500: #E91E8C;
  --clr-accent-400: #F472B6;
  --clr-gray-950:  #080810;
  --clr-gray-900:  #0F0F1A;
  --clr-gray-850:  #141422;
  --clr-gray-800:  #1A1A2E;
  --clr-gray-700:  #252540;
  --clr-gray-600:  #3A3A5C;
  --clr-gray-500:  #5A5A7A;
  --clr-gray-400:  #7A7A9A;
  --clr-gray-300:  #A0A0BE;
  --clr-gray-200:  #C5C5DC;
  --clr-gray-100:  #EEEEF8;
  --clr-gray-50:   #F8F8FC;
  --clr-white:     #FFFFFF;
  --clr-success: #22C55E;
  --clr-warning: #F59E0B;
  --clr-error:   #EF4444;
  --ff-sans: 'Inter', system-ui, -apple-system, sans-serif;
  --ff-mono: 'JetBrains Mono', 'Fira Code', monospace;
  --fz-xs:   0.75rem;   --fz-sm:   0.875rem;  --fz-base: 1rem;
  --fz-lg:   1.125rem;  --fz-xl:   1.25rem;   --fz-2xl:  1.5rem;
  --fz-3xl:  1.875rem;  --fz-4xl:  2.25rem;
  --fz-5xl:  clamp(2.25rem, 4vw, 3rem);
  --fz-hero: clamp(2.75rem, 6vw, 4.25rem);
  --lh-tight: 1.2; --lh-snug: 1.35; --lh-normal: 1.6; --lh-loose: 1.75;
  --sp-1:0.25rem; --sp-2:0.5rem;  --sp-3:0.75rem; --sp-4:1rem;
  --sp-5:1.25rem; --sp-6:1.5rem;  --sp-8:2rem;    --sp-10:2.5rem;
  --sp-12:3rem;   --sp-16:4rem;   --sp-20:5rem;   --sp-24:6rem;
  --radius-xs:0.25rem; --radius-sm:0.375rem; --radius-md:0.625rem;
  --radius-lg:1rem;    --radius-xl:1.25rem;  --radius-2xl:1.75rem;
  --radius-full:9999px;
  --shadow-sm:    0 1px 3px rgba(0,0,0,.12);
  --shadow-md:    0 4px 16px rgba(0,0,0,.18);
  --shadow-lg:    0 10px 36px rgba(0,0,0,.28);
  --shadow-xl:    0 20px 60px rgba(0,0,0,.4);
  --shadow-brand: 0 8px 32px rgba(123,53,193,.22);
  --shadow-glow:  0 0 48px rgba(123,53,193,.35);
  --shadow-glow-sm: 0 0 24px rgba(123,53,193,.28);
  --ease:    cubic-bezier(.4,0,.2,1);
  --tr-fast: 150ms cubic-bezier(.4,0,.2,1);
  --tr-base: 250ms cubic-bezier(.4,0,.2,1);
  --tr-slow: 400ms cubic-bezier(.4,0,.2,1);
  --container: 1280px;
  --nav-h:     72px;
  --sec-py:    clamp(3.5rem,7vw,5.5rem);
  /* Glass card tokens */
  --clr-glass-bg:     rgba(255,255,255,.07);
  --clr-glass-border: rgba(255,255,255,.13);
}

/* ─── 2. RESET & BASE ───────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:var(--nav-h);-webkit-text-size-adjust:100%}
body{font-family:var(--ff-sans);font-size:var(--fz-base);line-height:var(--lh-normal);color:var(--clr-gray-300);background:var(--clr-gray-950);overflow-x:hidden}
img,video,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}

/* ─── 3. TYPOGRAPHY ─────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-weight:700;line-height:var(--lh-tight);color:var(--clr-white)}
/* Light-background sections need dark headings */
.services-section h1,.services-section h2,.services-section h3,.services-section h4,.services-section h5,.services-section h6,
.lowcode-section h1,.lowcode-section h2,.lowcode-section h3,.lowcode-section h4,.lowcode-section h5,.lowcode-section h6,
.tech-section h1,.tech-section h2,.tech-section h3,.tech-section h4,.tech-section h5,.tech-section h6,
.portfolio-section h1,.portfolio-section h2,.portfolio-section h3,.portfolio-section h4,.portfolio-section h5,.portfolio-section h6,
.industries-section h1,.industries-section h2,.industries-section h3,.industries-section h4,.industries-section h5,.industries-section h6,
.contact-section h1,.contact-section h2,.contact-section h3,.contact-section h4,.contact-section h5,.contact-section h6,
.contact-form-wrap h1,.contact-form-wrap h2,.contact-form-wrap h3,.contact-form-wrap h4,.contact-form-wrap h5,.contact-form-wrap h6{color:var(--clr-gray-900)}
/* Light-background section subtitles */
.services-section .section-subtitle,.lowcode-section .section-subtitle,.tech-section .section-subtitle,
.portfolio-section .section-subtitle,.industries-section .section-subtitle,.contact-section .section-subtitle{color:var(--clr-gray-600)}

.gradient-text{
  background:linear-gradient(135deg,var(--clr-brand-400) 0%,var(--clr-accent-500) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.section-label{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-size:var(--fz-xs);font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--clr-brand-600);background:var(--clr-brand-100);
  border:1px solid rgba(123,53,193,.2);padding:var(--sp-1) var(--sp-3);
  border-radius:var(--radius-full);margin-bottom:var(--sp-5)
}
.section-label.light{color:var(--clr-brand-300);background:rgba(123,53,193,.15);border-color:rgba(123,53,193,.3)}
.section-title{font-size:var(--fz-4xl);font-weight:800;line-height:var(--lh-snug);margin-bottom:var(--sp-4)}
.section-title.light{color:var(--clr-white)}
.section-subtitle{font-size:var(--fz-lg);color:var(--clr-gray-300);max-width:600px;line-height:var(--lh-loose)}
.section-subtitle.light{color:var(--clr-gray-300)}
.text-center{text-align:center}
.text-center .section-subtitle{margin-inline:auto}
.section-pad{padding-block:var(--sec-py)}

/* ─── 4. NAVIGATION ─────────────────────────────────────── */
.site-header{position:fixed;top:0;left:0;right:0;z-index:999;transition:background var(--tr-base),box-shadow var(--tr-base)}
.site-header .navbar{padding:1rem 0;background:transparent;transition:all var(--tr-base)}
.site-header.scrolled .navbar{
  background:rgba(8,8,16,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:.5rem 0;border-bottom:1px solid rgba(123,53,193,.2);box-shadow:0 4px 32px rgba(0,0,0,.3)
}
.navbar-brand img{height:80px;width:auto}
.navbar-nav{gap:.125rem}
.navbar-nav .nav-link{
  color:rgba(255,255,255,.82)!important;font-size:var(--fz-sm);font-weight:500;
  padding:.5rem .875rem!important;border-radius:var(--radius-sm);
  transition:color var(--tr-fast),background var(--tr-fast)
}
.navbar-nav .nav-link:hover,.navbar-nav .nav-link.active{color:var(--clr-white)!important;background:rgba(123,53,193,.22)}
.navbar-nav .dropdown-menu{
  background:var(--clr-gray-850);border:1px solid rgba(123,53,193,.25);
  border-radius:var(--radius-lg);padding:.5rem;min-width:230px;
  margin-top:.5rem;box-shadow:var(--shadow-xl);animation:dropdownFade var(--tr-base) forwards
}
.navbar-nav .dropdown-item{
  color:var(--clr-gray-200)!important;font-size:var(--fz-sm);
  padding:.5rem 1rem;border-radius:var(--radius-sm);
  transition:all var(--tr-fast);display:flex;align-items:center;gap:.5rem
}
.navbar-nav .dropdown-item:hover{background:rgba(123,53,193,.22);color:var(--clr-white)!important}
.navbar-nav .dropdown-item i{font-size:1rem;color:var(--clr-brand-400);width:1.25rem}
.btn-nav-cta{
  display:inline-flex;align-items:center;gap:.375rem;
  background:var(--clr-brand-600);color:var(--clr-white)!important;
  font-size:var(--fz-sm);font-weight:600;padding:.5rem 1.25rem;
  border-radius:var(--radius-full);transition:all var(--tr-base);white-space:nowrap
}
.btn-nav-cta:hover{background:var(--clr-brand-500);transform:translateY(-1px);box-shadow:var(--shadow-glow-sm)}
.navbar-toggler{border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-sm);padding:.375rem .55rem;background:rgba(123,53,193,.15)}
.navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,.9%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}

/* ─── 5. BUTTONS ────────────────────────────────────────── */
.btn-primary-brand{
  display:inline-flex;align-items:center;gap:.5rem;
  background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));
  color:var(--clr-white);font-weight:600;font-size:var(--fz-base);
  padding:.875rem 1.875rem;border-radius:var(--radius-full);border:none;
  transition:all var(--tr-base);box-shadow:0 4px 20px rgba(123,53,193,.35);cursor:pointer
}
.btn-primary-brand:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(123,53,193,.5);filter:brightness(1.08);color:var(--clr-white)}
.btn-outline-brand{
  display:inline-flex;align-items:center;gap:.5rem;
  background:transparent;color:var(--clr-white);font-weight:600;font-size:var(--fz-base);
  padding:.875rem 1.875rem;border-radius:var(--radius-full);
  border:1px solid rgba(255,255,255,.3);transition:all var(--tr-base);cursor:pointer
}
.btn-outline-brand:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.65);color:var(--clr-white);transform:translateY(-2px)}
.btn-brand-solid{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--clr-brand-600);color:var(--clr-white);font-weight:600;font-size:var(--fz-base);
  padding:.875rem 1.875rem;border-radius:var(--radius-full);border:none;
  transition:all var(--tr-base);cursor:pointer
}
.btn-brand-solid:hover{background:var(--clr-brand-700);transform:translateY(-2px);box-shadow:var(--shadow-brand);color:var(--clr-white)}
.btn-sm{padding:.5rem 1.25rem!important;font-size:var(--fz-sm)!important}
.btn-lg{padding:1rem 2.25rem!important;font-size:var(--fz-lg)!important}

/* ─── 6. HERO ────────────────────────────────────────────── */
.hero-section{
  min-height:100vh;position:relative;display:flex;align-items:center;
  padding-top:calc(var(--nav-h) + 2rem);padding-bottom:4rem;overflow:hidden;background:var(--clr-gray-950)
}
.hero-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 20% 45%,rgba(91,30,156,.45) 0%,transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 15%,rgba(233,30,140,.22) 0%,transparent 55%),
    radial-gradient(ellipse 50% 40% at 65% 80%,rgba(59,19,100,.55) 0%,transparent 50%),
    linear-gradient(180deg,#080810 0%,#130328 55%,#080810 100%)
}
.hero-section::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(123,53,193,.14) 1px,transparent 1px);
  background-size:30px 30px;opacity:.6
}
.hero-content{position:relative;z-index:2}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(123,53,193,.18);border:1px solid rgba(123,53,193,.4);
  color:var(--clr-brand-300);font-size:var(--fz-xs);font-weight:600;
  letter-spacing:.05em;padding:.375rem 1rem;border-radius:var(--radius-full);
  margin-bottom:var(--sp-6);backdrop-filter:blur(8px)
}
.hero-badge-dot{
  width:6px;height:6px;border-radius:50%;background:var(--clr-brand-400);
  box-shadow:0 0 8px var(--clr-brand-400);animation:pulseDot 2s infinite
}
.hero-title{font-size:var(--fz-hero);font-weight:800;line-height:1.1;color:var(--clr-white);margin-bottom:var(--sp-6);letter-spacing:-.02em}
.hero-subtitle{font-size:var(--fz-xl);color:var(--clr-gray-300);line-height:var(--lh-loose);margin-bottom:var(--sp-10);max-width:540px}
.hero-actions{display:flex;align-items:center;flex-wrap:wrap;gap:var(--sp-4);margin-bottom:var(--sp-12)}
.hero-trust{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}
.hero-trust-label{font-size:var(--fz-xs);color:var(--clr-gray-400);font-weight:500}
.hero-trust-avatars{display:flex}
.hero-trust-avatars span{
  width:30px;height:30px;border-radius:50%;border:2px solid var(--clr-gray-800);
  background:linear-gradient(135deg,var(--clr-brand-700),var(--clr-accent-500));
  display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:white;margin-left:-8px
}
.hero-trust-avatars span:first-child{margin-left:0}

.hero-visual{position:relative;z-index:2}
.hero-card{
  background:rgba(20,20,34,.85);border:1px solid rgba(123,53,193,.25);
  border-radius:var(--radius-xl);padding:var(--sp-6);
  backdrop-filter:blur(16px);box-shadow:var(--shadow-xl),var(--shadow-glow);
  animation:float 6s ease-in-out infinite, cardGlowPulse 4s 1s ease-in-out infinite
}
@keyframes cardGlowPulse{
  0%,100%{box-shadow:var(--shadow-xl),0 0 24px rgba(123,53,193,.2)}
  50%{box-shadow:var(--shadow-xl),0 0 48px rgba(123,53,193,.5),0 0 80px rgba(233,30,140,.15)}
}
.hero-card-header{
  display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-5);
  padding-bottom:var(--sp-4);border-bottom:1px solid rgba(123,53,193,.2)
}
.card-dots{display:flex;gap:6px}
.card-dots span{width:10px;height:10px;border-radius:50%}
.card-dots span:nth-child(1){background:#EF4444}
.card-dots span:nth-child(2){background:#F59E0B}
.card-dots span:nth-child(3){background:#22C55E}
.card-title-bar{font-size:var(--fz-xs);color:var(--clr-gray-400);font-weight:500}
.hero-code{font-family:var(--ff-mono);font-size:.8rem;line-height:1.9;color:var(--clr-gray-300)}
.hero-code .kw{color:#C084FC}.hero-code .fn{color:#60A5FA}
.hero-code .str{color:#34D399}.hero-code .cm{color:var(--clr-gray-500);font-style:italic}
.hero-code .num{color:#FB923C}
.hero-stat-pills{display:flex;gap:var(--sp-3);margin-top:var(--sp-5);flex-wrap:wrap}
.hero-stat-pill{
  background:rgba(123,53,193,.2);border:1px solid rgba(123,53,193,.3);
  border-radius:var(--radius-full);padding:var(--sp-2) var(--sp-4);
  display:flex;align-items:center;gap:var(--sp-2)
}
.hero-stat-pill .val{font-size:var(--fz-sm);font-weight:700;color:var(--clr-brand-300)}
.hero-stat-pill .lbl{font-size:var(--fz-xs);color:var(--clr-gray-400)}
.float-card{
  position:absolute;background:rgba(20,20,34,.92);
  border:1px solid rgba(123,53,193,.3);border-radius:var(--radius-lg);
  padding:var(--sp-3) var(--sp-4);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg)
}
.float-card-1{top:-24px;right:-16px;animation:floatCardIn .6s .4s cubic-bezier(.34,1.56,.64,1) both, float 5s 1.2s ease-in-out infinite}
.float-card-2{bottom:-18px;left:-24px;animation:floatCardIn .6s .7s cubic-bezier(.34,1.56,.64,1) both, float 7s 2s ease-in-out infinite reverse}
@keyframes floatCardIn{
  from{opacity:0;transform:scale(.7) translateY(12px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.float-card .fc-label{font-size:9px;color:var(--clr-gray-400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.float-card .fc-value{font-size:var(--fz-base);font-weight:700;color:var(--clr-white);display:flex;align-items:center;gap:6px}
.fc-dot{width:7px;height:7px;border-radius:50%;background:var(--clr-success);box-shadow:0 0 8px var(--clr-success)}

/* ─── 7. STATS ───────────────────────────────────────────── */
.stats-section{background:var(--clr-gray-50);border-top:1px solid var(--clr-gray-100);border-bottom:1px solid var(--clr-gray-100);padding-block:3rem}
.stat-item{text-align:center;padding:1rem}
.stat-number{font-size:var(--fz-5xl);font-weight:800;line-height:1;color:var(--clr-brand-700);display:block;margin-bottom:var(--sp-2)}
.stat-suffix{color:var(--clr-accent-500)}
.stat-label{font-size:var(--fz-sm);color:var(--clr-gray-500);font-weight:500}

/* ─── 8. SERVICES ────────────────────────────────────────── */
.services-section{padding-block:var(--sec-py);background:var(--clr-white)}
.service-card{
  background:var(--clr-white);border:1px solid var(--clr-gray-100);
  border-radius:var(--radius-xl);padding:var(--sp-8) var(--sp-6);
  height:100%;transition:all var(--tr-base);position:relative;overflow:hidden
}
.service-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(123,53,193,.04),rgba(233,30,140,.03));
  opacity:0;transition:opacity var(--tr-base);pointer-events:none
}
.service-card:hover{border-color:rgba(123,53,193,.4);box-shadow:var(--shadow-brand);transform:translateY(-6px)}
.service-card:hover::before{opacity:1}
.service-icon{
  width:52px;height:52px;
  background:linear-gradient(135deg,var(--clr-brand-100),rgba(233,30,140,.08));
  border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;color:var(--clr-brand-600);margin-bottom:var(--sp-5);transition:all var(--tr-base)
}
.service-card:hover .service-icon{background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));color:var(--clr-white);box-shadow:var(--shadow-glow-sm)}
.service-card h3{font-size:var(--fz-lg);font-weight:700;color:var(--clr-gray-900);margin-bottom:var(--sp-3)}
.service-card p{font-size:var(--fz-sm);color:var(--clr-gray-500);line-height:var(--lh-loose);margin-bottom:var(--sp-5)}
.service-link{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fz-sm);font-weight:600;color:var(--clr-brand-600);transition:gap var(--tr-fast);position:relative;z-index:1}
.service-link:hover{gap:var(--sp-3);color:var(--clr-brand-600)}

/* ─── 9. CLOUD ───────────────────────────────────────────── */
.cloud-section{padding-block:var(--sec-py);background:var(--clr-gray-950);position:relative;overflow:hidden}
.cloud-section::before{content:'';position:absolute;top:-40%;right:-15%;width:550px;height:550px;background:radial-gradient(circle,rgba(123,53,193,.1) 0%,transparent 65%);pointer-events:none}
.cloud-tabs{
  display:flex;gap:var(--sp-2);background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);
  padding:var(--sp-1);margin-bottom:var(--sp-10);width:fit-content
}
.cloud-tab-btn{
  display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-5);
  border-radius:var(--radius-full);font-size:var(--fz-sm);font-weight:600;
  color:var(--clr-gray-400);background:transparent;border:none;cursor:pointer;
  transition:all var(--tr-base);white-space:nowrap
}
.cloud-tab-btn.active{background:var(--clr-brand-600);color:var(--clr-white);box-shadow:var(--shadow-glow-sm)}
.cloud-tab-btn:hover:not(.active){color:var(--clr-white);background:rgba(255,255,255,.08)}
.cloud-pane{display:none}
.cloud-pane.active{display:flex;gap:var(--sp-8)}
.cloud-feature-list{display:flex;flex-direction:column;gap:var(--sp-3);flex:1}
.cloud-feature{
  display:flex;gap:var(--sp-4);align-items:flex-start;padding:var(--sp-4);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg);transition:all var(--tr-base)
}
.cloud-feature:hover{background:rgba(123,53,193,.12);border-color:rgba(123,53,193,.3)}
.cloud-feature-icon{
  width:40px;height:40px;flex-shrink:0;background:rgba(123,53,193,.2);
  border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;
  color:var(--clr-brand-300);font-size:1.1rem
}
.cloud-feature h4{font-size:var(--fz-base);font-weight:600;color:var(--clr-white);margin-bottom:var(--sp-1)}
.cloud-feature p{font-size:var(--fz-sm);color:var(--clr-gray-400);margin:0}
.cloud-visual{
  background:rgba(255,255,255,.03);border:1px solid rgba(123,53,193,.2);
  border-radius:var(--radius-2xl);padding:var(--sp-8);text-align:center;
  position:relative;overflow:hidden;min-width:240px;
  display:flex;flex-direction:column;align-items:center;justify-content:center
}
.cloud-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(123,53,193,.1) 0%,transparent 70%)}
.cloud-logo-wrap{font-size:4.5rem;margin-bottom:var(--sp-4);position:relative;z-index:1}
.cloud-provider-name{font-size:var(--fz-2xl);font-weight:700;color:var(--clr-white);margin-bottom:var(--sp-2);position:relative;z-index:1}
.cloud-provider-tag{font-size:var(--fz-sm);color:var(--clr-gray-400);margin-bottom:var(--sp-6);position:relative;z-index:1}
.cloud-chips{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-2);position:relative;z-index:1;width:100%}
.cloud-chip{background:rgba(123,53,193,.15);border:1px solid rgba(123,53,193,.25);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3);font-size:var(--fz-xs);font-weight:600;color:var(--clr-brand-300);text-align:center}

/* ─── 10. AI / ML ────────────────────────────────────────── */
.ai-section{padding-block:var(--sec-py);background:var(--clr-gray-900);position:relative;overflow:hidden}
.ai-section::before{content:'';position:absolute;bottom:-30%;left:-10%;width:650px;height:650px;background:radial-gradient(circle,rgba(233,30,140,.07) 0%,transparent 60%);pointer-events:none}
.ai-feature-item{
  display:flex;gap:var(--sp-5);padding:var(--sp-5) var(--sp-6);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-xl);margin-bottom:var(--sp-4);
  transition:all var(--tr-base);align-items:flex-start
}
.ai-feature-item:hover{background:rgba(123,53,193,.1);border-color:rgba(123,53,193,.3);transform:translateX(4px)}
.ai-feature-num{
  width:40px;height:40px;flex-shrink:0;
  background:linear-gradient(135deg,var(--clr-brand-700),var(--clr-accent-600));
  border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;
  font-size:var(--fz-sm);font-weight:800;color:var(--clr-white)
}
.ai-feature-body h4{font-size:var(--fz-lg);font-weight:700;color:var(--clr-white);margin-bottom:var(--sp-2)}
.ai-feature-body p{font-size:var(--fz-sm);color:var(--clr-gray-400);margin:0;line-height:var(--lh-loose)}
.ai-tech-stack{display:flex;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-8)}
.tech-badge{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:var(--fz-xs);font-weight:600;padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-full);cursor:default}
.tech-badge.dark{background:rgba(123,53,193,.18);color:var(--clr-brand-300);border:1px solid rgba(123,53,193,.3)}
.tech-badge.light{background:var(--clr-brand-100);color:var(--clr-brand-700);border:1px solid rgba(123,53,193,.2)}
.ai-visual{display:flex;align-items:center;justify-content:center;min-height:360px;position:relative}
.nn-wrap{position:relative;width:100%;height:360px}
.nn-layer{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;height:100%;top:0}
.nn-l1{left:6%}.nn-l2{left:34%}.nn-l3{left:62%}.nn-l4{left:84%}
.nn-node{width:18px;height:18px;border-radius:50%;background:var(--clr-brand-600);box-shadow:0 0 12px rgba(123,53,193,.7);animation:nodeGlow 2.5s ease-in-out infinite}
.nn-node:nth-child(2){animation-delay:.4s;background:var(--clr-brand-500)}
.nn-node:nth-child(3){animation-delay:.8s}
.nn-node:nth-child(4){animation-delay:1.2s;background:var(--clr-accent-500)}
.nn-svg{position:absolute;top:0;left:0;width:100%;height:100%}
.nn-line{stroke:rgba(0,200,220,.5);stroke-width:1;stroke-dasharray:5 5;animation:dashFlow 3s linear infinite}
.nn-line:nth-child(2n){animation-delay:-.5s;stroke:rgba(0,180,200,.35)}
.nn-lbl{font-size:9px;font-weight:600;fill:var(--clr-gray-500);text-transform:uppercase}

/* ─── 11. LOW-CODE ───────────────────────────────────────── */
.lowcode-section{padding-block:var(--sec-py);background:var(--clr-gray-50)}
.lowcode-card{background:var(--clr-white);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);padding:var(--sp-8) var(--sp-6);height:100%;transition:all var(--tr-base);text-align:center}
.lowcode-card:hover{border-color:var(--clr-brand-300);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.lowcode-icon{width:64px;height:64px;margin:0 auto var(--sp-5);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:2rem}
.lc-powerbi{background:#FFF9E6;color:#F2C811}
.lc-powerapps{background:#F0E6FF;color:#742774}
.lc-automate{background:#E6F0FF;color:#0066FF}
.lc-analytics{background:#FFE6F4;color:var(--clr-accent-500)}
.lc-outsystems{background:#FDECEA;color:#E42127}
.lc-mendix{background:#E6F4FD;color:#0595DB}
.lc-appian{background:#E6F2F4;color:#00647E}
.lowcode-card h3{font-size:var(--fz-lg);font-weight:700;margin-bottom:var(--sp-3);color:var(--clr-gray-900)}
.lowcode-card p{font-size:var(--fz-sm);color:var(--clr-gray-500);line-height:var(--lh-loose);margin:0}

/* ─── 12. TECHNOLOGIES ───────────────────────────────────── */
.tech-section{padding-block:var(--sec-py);background:var(--clr-white)}
.tech-filters{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-10);justify-content:center}
.tech-filter-btn{padding:var(--sp-2) var(--sp-5);border-radius:var(--radius-full);font-size:var(--fz-sm);font-weight:600;color:var(--clr-gray-500);background:var(--clr-gray-100);border:1px solid transparent;transition:all var(--tr-fast);cursor:pointer}
.tech-filter-btn.active,.tech-filter-btn:hover{background:var(--clr-brand-100);color:var(--clr-brand-700);border-color:rgba(123,53,193,.25)}
.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:var(--sp-4)}
.tech-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);padding:var(--sp-5) var(--sp-3);background:var(--clr-gray-50);border:1px solid var(--clr-gray-100);border-radius:var(--radius-lg);transition:all var(--tr-base);cursor:default;text-align:center}
.tech-item:hover{background:var(--clr-white);border-color:rgba(123,53,193,.3);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.tech-item i{font-size:2.25rem}
.tech-item span{font-size:var(--fz-xs);font-weight:600;color:var(--clr-gray-600)}
.tech-item.hidden{display:none}

/* ─── 13. PROCESS ────────────────────────────────────────── */
.process-section{padding-block:var(--sec-py);background:var(--clr-gray-950);position:relative;overflow:hidden}
.process-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(123,53,193,.07) 1px,transparent 1px);background-size:38px 38px}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6);position:relative}
.process-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--sp-6)}
.step-num{width:62px;height:62px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--clr-brand-700),var(--clr-accent-600));display:flex;align-items:center;justify-content:center;font-size:var(--fz-xl);font-weight:800;color:var(--clr-white);margin-bottom:var(--sp-5);box-shadow:var(--shadow-glow-sm);position:relative;z-index:1}
.process-step h3{font-size:var(--fz-lg);font-weight:700;color:var(--clr-white);margin-bottom:var(--sp-3)}
.process-step p{font-size:var(--fz-sm);color:var(--clr-gray-400);line-height:var(--lh-loose);margin:0}

/* ─── 14. PORTFOLIO ──────────────────────────────────────── */
.portfolio-section{padding-block:var(--sec-py);background:var(--clr-white)}
.portfolio-bento{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--sp-5)}
.portfolio-card{background:var(--clr-gray-50);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);overflow:hidden;position:relative;transition:all var(--tr-base);cursor:pointer}
.portfolio-card:hover{border-color:rgba(123,53,193,.35);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.p-feat{grid-column:span 7}.p-reg{grid-column:span 5}.p-half{grid-column:span 6}
.portfolio-thumb{width:100%;height:190px;overflow:hidden;background:linear-gradient(135deg,var(--clr-brand-900),var(--clr-gray-800));display:flex;align-items:center;justify-content:center;font-size:3.5rem;transition:transform var(--tr-slow)}
.p-feat .portfolio-thumb{height:260px}
.portfolio-card:hover .portfolio-thumb{transform:scale(1.04)}
.portfolio-body{padding:var(--sp-5) var(--sp-6)}
.portfolio-tags{display:flex;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:var(--sp-3)}
.p-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--clr-brand-600);background:var(--clr-brand-100);border-radius:var(--radius-full);padding:2px 9px}
.portfolio-body h3{font-size:var(--fz-xl);font-weight:700;color:var(--clr-gray-900);margin-bottom:var(--sp-2)}
.portfolio-body p{font-size:var(--fz-sm);color:var(--clr-gray-500);margin:0}
.portfolio-arrow{position:absolute;top:var(--sp-4);right:var(--sp-4);width:34px;height:34px;background:var(--clr-brand-600);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:.8rem;opacity:0;transition:opacity var(--tr-base)}
.portfolio-card:hover .portfolio-arrow{opacity:1}

/* ─── 15. INDUSTRIES ─────────────────────────────────────── */
.industries-section{padding-block:var(--sec-py);background:var(--clr-gray-50)}
.industries-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp-4)}
.industry-card{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3);padding:var(--sp-8) var(--sp-4);background:var(--clr-white);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);text-align:center;transition:all var(--tr-base);cursor:default}
.industry-card:hover{border-color:rgba(123,53,193,.3);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.industry-icon{font-size:2.25rem;line-height:1}
.industry-card h4{font-size:var(--fz-sm);font-weight:700;color:var(--clr-gray-800);margin:0}

/* ─── 16. TESTIMONIALS ───────────────────────────────────── */
.testimonials-section{padding-block:var(--sec-py);background:var(--clr-white)}
.testimonial-card{background:var(--clr-gray-50);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);padding:var(--sp-8);height:100%}
.testi-stars{display:flex;gap:3px;margin-bottom:var(--sp-5)}
.testi-stars i{color:#F59E0B;font-size:.95rem}
.testi-quote{font-size:var(--fz-lg);color:var(--clr-gray-700);line-height:var(--lh-loose);margin-bottom:var(--sp-6);font-style:italic}
.testi-author{display:flex;align-items:center;gap:var(--sp-4)}
.testi-avatar{width:46px;height:46px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--fz-lg);color:white}
.testi-name{font-size:var(--fz-base);font-weight:700;color:var(--clr-gray-900);display:block}
.testi-title{font-size:var(--fz-xs);color:var(--clr-gray-500)}
.testimonials-swiper .swiper-pagination-bullet{background:var(--clr-brand-300)}
.testimonials-swiper .swiper-pagination-bullet-active{background:var(--clr-brand-600);width:20px;border-radius:4px}

/* ─── 17. CTA ────────────────────────────────────────────── */
.cta-section{padding-block:var(--sec-py);text-align:center;background:linear-gradient(135deg,var(--clr-brand-900) 0%,var(--clr-gray-950) 50%,var(--clr-brand-900) 100%);position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(123,53,193,.28) 0%,transparent 65%);pointer-events:none}
.cta-section::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.cta-content{position:relative;z-index:2}
.cta-title{font-size:var(--fz-5xl);font-weight:800;color:var(--clr-white);margin-bottom:var(--sp-4);line-height:var(--lh-snug)}
.cta-subtitle{font-size:var(--fz-xl);color:var(--clr-gray-300);margin-bottom:var(--sp-10);max-width:560px;margin-inline:auto;display:block}
.cta-actions{display:flex;gap:var(--sp-4);justify-content:center;flex-wrap:wrap}

/* ─── 18. CONTACT ────────────────────────────────────────── */
.contact-section{padding-block:var(--sec-py);background:var(--clr-gray-50)}
.contact-info{background:linear-gradient(145deg,var(--clr-brand-900),var(--clr-gray-900));border-radius:var(--radius-2xl);padding:var(--sp-10) var(--sp-8);height:100%;position:relative;overflow:hidden}
.contact-info::before{content:'';position:absolute;bottom:-25%;right:-15%;width:280px;height:280px;background:radial-gradient(circle,rgba(123,53,193,.25) 0%,transparent 65%)}
.contact-info h3{color:var(--clr-white);font-size:var(--fz-2xl);font-weight:700;margin-bottom:var(--sp-3)}
.contact-info>.p-desc{color:var(--clr-gray-300);margin-bottom:var(--sp-8);font-size:var(--fz-base);line-height:var(--lh-loose)}
.contact-detail{display:flex;align-items:center;gap:var(--sp-4);padding:var(--sp-4);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);margin-bottom:var(--sp-3)}
.contact-detail i{font-size:1.2rem;color:var(--clr-brand-300);width:1.5rem;text-align:center;flex-shrink:0}
.contact-detail span{font-size:var(--fz-sm);color:var(--clr-gray-200);word-break:break-all}
.contact-form-wrap{background:var(--clr-white);border:1px solid var(--clr-gray-100);border-radius:var(--radius-2xl);padding:var(--sp-10) var(--sp-8)}
.form-group{margin-bottom:var(--sp-5)}
.form-label{display:block;font-size:var(--fz-sm);font-weight:600;color:var(--clr-gray-700);margin-bottom:var(--sp-2)}
.form-input{width:100%;padding:.75rem 1rem;background:var(--clr-gray-50);border:1.5px solid var(--clr-gray-200);border-radius:var(--radius-md);font-size:var(--fz-base);color:var(--clr-gray-900);outline:none;transition:border-color var(--tr-fast),box-shadow var(--tr-fast),background var(--tr-fast)}
.form-input:focus{border-color:var(--clr-brand-500);background:white;box-shadow:0 0 0 3px rgba(123,53,193,.15),0 0 16px rgba(123,53,193,.12)}
.form-input:hover:not(:focus){border-color:var(--clr-gray-400)}
.form-input::placeholder{color:var(--clr-gray-400)}
select.form-input{cursor:pointer}
textarea.form-input{resize:vertical;min-height:130px}

/* ─── 19. FOOTER ─────────────────────────────────────────── */
.site-footer{background:var(--clr-gray-950);border-top:1px solid rgba(255,255,255,.06);padding-top:var(--sp-16);padding-bottom:var(--sp-8)}
.footer-brand{margin-bottom:var(--sp-5)}
.footer-brand img{height:70px;width:auto}
.footer-tagline{font-size:var(--fz-sm);color:var(--clr-gray-300);line-height:var(--lh-loose);max-width:270px;margin-bottom:var(--sp-6)}
.footer-socials{display:flex;gap:var(--sp-3)}
.footer-social{width:36px;height:36px;background:rgba(123,53,193,.15);border:1px solid rgba(123,53,193,.25);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--clr-brand-300);font-size:.95rem;transition:all var(--tr-fast)}
.footer-social:hover{background:var(--clr-brand-600);border-color:var(--clr-brand-600);color:white;transform:translateY(-2px)}
.footer-heading{font-size:var(--fz-sm);font-weight:700;color:var(--clr-white);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--sp-5)}
.footer-links{display:flex;flex-direction:column;gap:var(--sp-3)}
.footer-link{font-size:var(--fz-sm);color:var(--clr-gray-300);transition:color var(--tr-fast)}
.footer-link:hover{color:var(--clr-brand-300)}
.footer-divider{border:none;border-top:1px solid rgba(255,255,255,.06);margin:var(--sp-10) 0 var(--sp-6)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--sp-4)}
.footer-copy{font-size:var(--fz-xs);color:var(--clr-gray-400)}
.footer-copy a{color:var(--clr-brand-400)}
.footer-legal{display:flex;gap:var(--sp-5)}
.footer-legal a{font-size:var(--fz-xs);color:var(--clr-gray-400);transition:color var(--tr-fast)}
.footer-legal a:hover{color:var(--clr-gray-300)}

/* ─── 20. PAGE HEROES (INNER PAGES) ─────────────────────── */
.page-hero{padding-top:calc(var(--nav-h) + 4rem);padding-bottom:4.5rem;background:var(--clr-gray-950);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 80% at 50% 100%,rgba(91,30,156,.32) 0%,transparent 60%),radial-gradient(ellipse 50% 60% at 20% 0%,rgba(233,30,140,.14) 0%,transparent 50%)}
.page-hero-content{position:relative;z-index:2}
.breadcrumb-nav{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);font-size:var(--fz-sm);color:var(--clr-gray-400);margin-bottom:var(--sp-5)}
.breadcrumb-nav a{color:var(--clr-brand-300)}
.breadcrumb-nav i{font-size:.6rem}
.page-hero-title{font-size:var(--fz-5xl);font-weight:800;color:var(--clr-white);margin-bottom:var(--sp-4);line-height:var(--lh-snug)}
.page-hero-subtitle{font-size:var(--fz-xl);color:var(--clr-gray-300);max-width:580px;margin-inline:auto;line-height:var(--lh-loose)}

/* ─── 21. ABOUT PAGE ─────────────────────────────────────── */
.value-card{text-align:center;padding:var(--sp-8) var(--sp-6);background:var(--clr-gray-50);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);transition:all var(--tr-base)}
.value-card:hover{border-color:rgba(123,53,193,.3);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.value-icon{font-size:2.5rem;margin-bottom:var(--sp-4);display:block}
.value-card h3{font-size:var(--fz-lg);font-weight:700;margin-bottom:var(--sp-3)}
.value-card p{font-size:var(--fz-sm);color:var(--clr-gray-500);margin:0;line-height:var(--lh-loose)}
.team-card{text-align:center;background:var(--clr-white);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);padding:var(--sp-6);transition:all var(--tr-base)}
.team-card:hover{border-color:rgba(123,53,193,.3);box-shadow:var(--shadow-brand);transform:translateY(-4px)}
.team-avatar{width:80px;height:80px;border-radius:50%;margin:0 auto var(--sp-4);background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:white}
.team-card h4{font-size:var(--fz-lg);font-weight:700;margin-bottom:var(--sp-1)}
.team-card span{font-size:var(--fz-sm);color:var(--clr-gray-500)}

/* ─── 22. SERVICES PAGE ──────────────────────────────────── */
.service-detail-card{background:var(--clr-white);border:1px solid var(--clr-gray-100);border-radius:var(--radius-xl);overflow:hidden;margin-bottom:var(--sp-8);transition:all var(--tr-base)}
.service-detail-card:hover{border-color:rgba(123,53,193,.2);box-shadow:var(--shadow-md)}
.service-detail-header{padding:var(--sp-8);border-bottom:1px solid var(--clr-gray-100);background:linear-gradient(135deg,var(--clr-brand-50),rgba(233,30,140,.04));display:flex;gap:var(--sp-5);align-items:flex-start}
.service-detail-icon{width:60px;height:60px;flex-shrink:0;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));display:flex;align-items:center;justify-content:center;font-size:1.75rem;color:white}
.service-detail-header h3{font-size:var(--fz-2xl);font-weight:800;color:var(--clr-gray-900);margin-bottom:var(--sp-2)}
.service-detail-header p{font-size:var(--fz-base);color:var(--clr-gray-500);line-height:var(--lh-loose);margin:0}
.service-detail-body{padding:var(--sp-8)}
.service-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-4);margin-bottom:var(--sp-6)}
.service-feature-item{display:flex;gap:var(--sp-3);align-items:flex-start}
.service-feature-item i{color:var(--clr-brand-600);font-size:1.1rem;margin-top:2px;flex-shrink:0}
.service-feature-item span{font-size:var(--fz-sm);color:var(--clr-gray-600);line-height:var(--lh-normal)}
.service-tech-stack{display:flex;flex-wrap:wrap;gap:var(--sp-2)}

/* ─── 23. KEYFRAMES ──────────────────────────────────────── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(168,85,247,.6)}50%{box-shadow:0 0 0 6px rgba(168,85,247,0)}}
@keyframes dropdownFade{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes nodeGlow{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
@keyframes dashFlow{to{stroke-dashoffset:-20}}

/* ─── 24. RESPONSIVE ─────────────────────────────────────── */
@media(max-width:1199px){
  .p-feat,.p-reg{grid-column:span 12}
  .p-half{grid-column:span 6}
}
@media(max-width:991px){
  .site-header .navbar{background:rgba(8,8,16,.96)!important;backdrop-filter:blur(20px);padding:.8rem 0}
  .navbar-brand img{height:50px}
  .navbar-collapse{background:var(--clr-gray-900);border:1px solid rgba(123,53,193,.2);border-radius:var(--radius-lg);padding:1rem;margin-top:.75rem}
  .navbar-nav .nav-link{padding:.7rem 1rem!important}
  .btn-nav-cta{width:100%;justify-content:center;margin-top:.75rem}
  .navbar-nav .dropdown-menu{background:var(--clr-gray-800);border:none;border-left:2px solid var(--clr-brand-600);border-radius:0;padding-left:1rem;margin:0}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .industries-grid{grid-template-columns:repeat(3,1fr)}
  .service-features-grid{grid-template-columns:1fr}
  .cloud-pane.active{flex-direction:column}
}
@media(max-width:767px){
  :root{--sec-py:3.25rem}
  .hero-visual{display:none}
  .hero-title{font-size:clamp(2rem,8vw,2.75rem)}
  .hero-actions{flex-direction:column;align-items:stretch}
  .btn-primary-brand,.btn-outline-brand{justify-content:center}
  .section-title{font-size:var(--fz-3xl)}
  .cta-title{font-size:var(--fz-3xl)}
  .page-hero-title{font-size:var(--fz-4xl)}
  .cloud-tabs{overflow-x:auto;padding-bottom:2px}
  .process-grid{grid-template-columns:1fr}
  .p-feat,.p-reg,.p-half{grid-column:span 12}
  .industries-grid{grid-template-columns:repeat(2,1fr)}
  .cta-actions{flex-direction:column;align-items:center}
  .cta-actions .btn-primary-brand,.cta-actions .btn-outline-brand{width:100%;max-width:320px}
  .contact-form-wrap{padding:var(--sp-6) var(--sp-5)}
  .contact-info{padding:var(--sp-6) var(--sp-5)}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-legal{justify-content:center}
  .tech-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}
}
@media(max-width:480px){
  .hero-badge{font-size:10px}
  .section-label{font-size:10px}
  .industries-grid{grid-template-columns:repeat(2,1fr)}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ─── HERO CODE TYPEWRITER ────────────────────────────────── */
.hero-code > div,.hero-code > br{opacity:0;animation:codeLine .25s ease forwards}
.hero-code > div:nth-child(1){animation-delay:.9s}
.hero-code > div:nth-child(2){animation-delay:1.2s}
.hero-code > div:nth-child(3){animation-delay:1.5s}
.hero-code > div:nth-child(4){animation-delay:1.8s}
.hero-code > div:nth-child(5){animation-delay:2.1s}
.hero-code > div:nth-child(6){animation-delay:2.4s}
.hero-code > div:nth-child(7){animation-delay:2.7s}
.hero-code > div:nth-child(8){animation-delay:3.0s}
.hero-code > br:nth-child(9){animation-delay:3.1s}
.hero-code > div:nth-child(10){animation-delay:3.2s}
.hero-code > div:nth-child(11){animation-delay:3.5s}
@keyframes codeLine{
  from{opacity:0;transform:translateX(-6px)}
  to{opacity:1;transform:translateX(0)}
}
/* blinking cursor on last code line */
.hero-code > div:last-child::after{
  content:'|';color:var(--clr-brand-300);margin-left:2px;
  animation:cursorBlink 1s step-end infinite;animation-delay:3.8s;opacity:0
}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}

/* ─── SCROLL-TO-TOP BUTTON ────────────────────────────────── */
#scrollTopBtn{
  position:fixed;bottom:90px;right:24px;z-index:9998;
  width:44px;height:44px;border-radius:50%;border:none;cursor:pointer;
  background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));
  color:#fff;font-size:1.1rem;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 16px rgba(123,53,193,.4);
  opacity:0;transform:translateY(12px);pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease),box-shadow .2s
}
#scrollTopBtn.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#scrollTopBtn:hover{box-shadow:0 6px 24px rgba(123,53,193,.6);transform:translateY(-3px)}

/* ─── SCROLL PROGRESS BAR ─────────────────────────────────── */
#scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0%;z-index:9999;
  background:linear-gradient(90deg,var(--clr-brand-600),var(--clr-accent-500));
  transition:width .1s linear;
  border-radius:0 2px 2px 0;
  box-shadow:0 0 8px rgba(123,53,193,.6);
}

/* ─── ABOUT PAGE ─────────────────────────────────────────── */
.about-hero-visual{display:flex;align-items:center;justify-content:center}
.about-stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;width:100%}
.about-stat-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-xl);padding:1.75rem 1.25rem;text-align:center;backdrop-filter:blur(12px)}
.about-stat-card .stat-num{display:block;font-size:2.5rem;font-weight:800;line-height:1}
.about-stat-card .stat-lbl{display:block;font-size:.8rem;color:var(--clr-gray-300);margin-top:.5rem;text-transform:uppercase;letter-spacing:.08em}

.story-visual{display:flex;flex-direction:column;gap:1.25rem}
.story-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);backdrop-filter:blur(12px);border-radius:var(--radius-xl);padding:1.5rem 1.75rem}
.story-card--accent{border-color:rgba(233,30,140,.3);background:rgba(233,30,140,.07)}
.story-card--secondary{border-color:rgba(123,53,193,.4);background:rgba(123,53,193,.08)}
.story-year{font-size:1.4rem;font-weight:800;margin-bottom:.5rem}
.story-points{list-style:none;padding:0;margin:.75rem 0 0;display:flex;flex-direction:column;gap:.4rem}
.story-points li{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--clr-gray-200);line-height:1.4}
.story-points li i{color:var(--clr-brand-500);font-size:.85rem;flex-shrink:0}
.story-highlights{display:flex;flex-direction:column;gap:.75rem}
.story-highlight-item{display:flex;align-items:flex-start;gap:.75rem;color:var(--clr-gray-300);font-size:.95rem}
.story-highlight-item i{color:var(--clr-brand-600);flex-shrink:0;margin-top:.15rem}

.mvv-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-xl);padding:2.25rem 2rem;backdrop-filter:blur(10px);transition:transform .25s,box-shadow .25s}
.mvv-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.25)}
.mvv-card--accent{border-color:rgba(233,30,140,.3);background:rgba(233,30,140,.06)}
.mvv-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:rgba(123,53,193,.18);display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--clr-brand-400);margin-bottom:1.25rem}
.mvv-icon--accent{background:rgba(233,30,140,.18);color:var(--clr-accent-500)}
.mvv-title{font-size:1.15rem;font-weight:700;color:var(--clr-white);margin-bottom:.75rem}
.mvv-text{color:var(--clr-gray-300);line-height:1.75;font-size:.95rem}
.mvv-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}
.mvv-list li{color:var(--clr-gray-300);font-size:.95rem;display:flex;align-items:center;gap:.5rem}
.mvv-list i{color:var(--clr-brand-400);font-size:1.1rem}

.why-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-xl);padding:2rem 1.75rem;backdrop-filter:blur(10px);transition:transform .25s,box-shadow .25s,border-color .25s}
.why-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.25);border-color:rgba(123,53,193,.5)}
.why-card-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(123,53,193,.25),rgba(233,30,140,.15));display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:var(--clr-brand-400);margin-bottom:1.25rem}
.why-card h4{font-size:1.05rem;font-weight:700;color:var(--clr-white);margin-bottom:.6rem}
.why-card p{color:var(--clr-gray-300);font-size:.9rem;line-height:1.7;margin:0}

.industries-grid-about{display:flex;flex-wrap:wrap;gap:.75rem}
.industry-chip{display:inline-flex;align-items:center;gap:.5rem;background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:50px;padding:.5rem 1.1rem;font-size:.85rem;color:var(--clr-gray-200);font-weight:500;transition:background .2s,border-color .2s,color .2s}
.industry-chip:hover{background:rgba(123,53,193,.2);border-color:rgba(123,53,193,.5);color:var(--clr-white)}
.industry-chip i{color:var(--clr-brand-400)}

.team-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-xl);overflow:hidden;backdrop-filter:blur(10px);transition:transform .25s,box-shadow .25s}
.team-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.team-avatar{height:180px;background:linear-gradient(135deg,rgba(123,53,193,.3),rgba(233,30,140,.2));display:flex;align-items:center;justify-content:center}
.team-avatar-placeholder{font-size:4rem;color:rgba(255,255,255,.3)}
.team-info{padding:1.5rem}
.team-name{font-size:1.05rem;font-weight:700;color:var(--clr-white);margin-bottom:.25rem}
.team-role{font-size:.8rem;color:var(--clr-accent-500);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}
.team-bio{font-size:.88rem;color:var(--clr-gray-300);line-height:1.7;margin:0}

.cta-section{background:var(--clr-gray-950)}
.cta-banner{background:linear-gradient(135deg,rgba(123,53,193,.25) 0%,rgba(233,30,140,.15) 100%);border:1px solid rgba(123,53,193,.4);border-radius:var(--radius-2xl);padding:3rem 2.5rem;backdrop-filter:blur(12px);position:relative;z-index:2}
.cta-title{font-size:clamp(1.6rem,4vw,2.25rem);font-weight:800;color:var(--clr-white);margin-bottom:.75rem}
.cta-text{color:var(--clr-gray-300);font-size:1rem;line-height:1.7;margin:0}

/* ─── SERVICES PAGE ──────────────────────────────────────── */
.services-quicknav{background:var(--clr-gray-850);border-bottom:1px solid rgba(255,255,255,.06);padding:.75rem 0;position:sticky;top:var(--nav-h);z-index:90}
.quicknav-pills{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.quicknav-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .9rem;border-radius:50px;font-size:.8rem;font-weight:600;color:var(--clr-gray-300);background:transparent;border:1px solid transparent;text-decoration:none;transition:all .2s;white-space:nowrap}
.quicknav-pill:hover{background:rgba(123,53,193,.2);border-color:rgba(123,53,193,.4);color:var(--clr-white)}

.service-detail-section{overflow:hidden}
.bg-subtle{background:var(--clr-gray-850)}
.service-features{display:flex;flex-direction:column;gap:.75rem;margin-top:1.5rem}
.sf-item{display:flex;align-items:flex-start;gap:.75rem;color:var(--clr-gray-300);font-size:.95rem;line-height:1.55}
.sf-item i{color:var(--clr-brand-500);flex-shrink:0;font-size:1rem;margin-top:.15rem}

.service-visual-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-2xl);padding:2.25rem;backdrop-filter:blur(14px)}
.service-visual-card--dark{background:rgba(13,4,25,.8);border-color:rgba(123,53,193,.35)}
.svc-card-icon{width:60px;height:60px;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(123,53,193,.3),rgba(233,30,140,.2));display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--clr-brand-400);margin-bottom:1.25rem}
.svc-card-icon--accent{background:linear-gradient(135deg,rgba(233,30,140,.3),rgba(123,53,193,.2));color:var(--clr-accent-400)}
.service-visual-card h3{font-size:1rem;font-weight:700;color:var(--clr-white);margin-bottom:1rem}
.svc-tech-chips{display:flex;flex-wrap:wrap;gap:.5rem}
.tech-chip{display:inline-block;background:rgba(123,53,193,.18);border:1px solid rgba(123,53,193,.3);border-radius:50px;padding:.28rem .75rem;font-size:.78rem;font-weight:600;color:var(--clr-brand-300)}
.svc-highlight-list{display:flex;flex-direction:column;gap:.6rem}
.svc-hl-item{display:flex;align-items:center;gap:.6rem;font-size:.88rem;color:var(--clr-gray-300)}
.svc-hl-item i{color:var(--clr-brand-400);font-size:1rem;flex-shrink:0}

.cloud-certs{display:flex;gap:.75rem;flex-wrap:wrap}
.cloud-cert-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:50px;font-size:.82rem;font-weight:700;border:1px solid transparent}
.aws-badge{background:rgba(255,153,0,.12);border-color:rgba(255,153,0,.35);color:#ff9900}
.azure-badge{background:rgba(0,120,212,.12);border-color:rgba(0,120,212,.35);color:#0078d4}
.gcp-badge{background:rgba(66,133,244,.12);border-color:rgba(66,133,244,.35);color:#4285f4}

.lowcode-platform-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1rem}
.lcp-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:1.25rem .75rem;text-align:center;font-size:.82rem;font-weight:600;color:var(--clr-gray-200)}
.lcp-icon{font-size:1.6rem;line-height:1}

.custom-process-steps{display:flex;flex-direction:column;gap:1.25rem;margin-top:.5rem}
.cps-step{display:flex;align-items:flex-start;gap:1rem}
.cps-num{min-width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--clr-brand-600),var(--clr-accent-500));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:#fff;flex-shrink:0}
.cps-step strong{font-size:.95rem;color:var(--clr-white);display:block;margin-bottom:.25rem}
.cps-step p{font-size:.85rem;color:var(--clr-gray-300);line-height:1.55;margin:0}

/* ─── CONTACT PAGE ───────────────────────────────────────── */
.page-hero--contact{text-align:center}
.contact-info-full{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-2xl);padding:2.25rem;backdrop-filter:blur(14px)}
.contact-info-full h3{font-size:1.4rem;font-weight:700;color:var(--clr-white);margin-bottom:.75rem}
.contact-detail-full{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.cdf-icon{width:44px;height:44px;border-radius:var(--radius-lg);background:rgba(123,53,193,.18);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--clr-brand-400);flex-shrink:0}
.cdf-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-gray-400);font-weight:600;margin-bottom:.15rem}
.cdf-value{font-size:.95rem;color:var(--clr-gray-200);font-weight:500;text-decoration:none}
a.cdf-value:hover{color:var(--clr-brand-400)}

.form-required{color:var(--clr-accent-500)}
.timeline-radio-group{display:flex;flex-wrap:wrap;gap:.5rem}
.timeline-radio{display:inline-block;cursor:pointer}
.timeline-radio input{display:none}
.timeline-radio span{display:inline-block;padding:.4rem .9rem;border-radius:50px;border:1px solid var(--clr-glass-border);font-size:.82rem;font-weight:600;color:var(--clr-gray-300);background:var(--clr-glass-bg);transition:all .2s;cursor:pointer}
.timeline-radio input:checked + span,.timeline-radio span:hover{background:rgba(123,53,193,.25);border-color:var(--clr-brand-500);color:var(--clr-white)}

.promise-card{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border);border-radius:var(--radius-xl);padding:2rem 1.75rem;backdrop-filter:blur(10px);transition:transform .25s,border-color .25s}
.promise-card:hover{transform:translateY(-4px);border-color:rgba(123,53,193,.5)}
.promise-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:linear-gradient(135deg,rgba(123,53,193,.5),rgba(233,30,140,.35));display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:#fff;margin-bottom:1.25rem;box-shadow:0 4px 16px rgba(123,53,193,.3)}
.promise-card h4{font-size:1.05rem;font-weight:700;color:var(--clr-white);margin-bottom:.6rem}
.promise-card p{color:var(--clr-gray-300);font-size:.9rem;line-height:1.7;margin:0}

.schedule-card{background:linear-gradient(135deg,rgba(123,53,193,.2) 0%,rgba(233,30,140,.12) 100%);border:1px solid rgba(123,53,193,.4);border-radius:var(--radius-2xl);padding:3rem 2.5rem;backdrop-filter:blur(12px)}
.schedule-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(123,53,193,.2);border:1px solid rgba(123,53,193,.4);border-radius:50px;padding:.35rem .9rem;font-size:.78rem;font-weight:700;color:var(--clr-brand-300);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}
.schedule-title{font-size:clamp(1.5rem,3.5vw,2rem);font-weight:800;color:var(--clr-white);margin-bottom:.75rem;line-height:1.3}
.schedule-text{color:var(--clr-gray-300);font-size:.95rem;line-height:1.75;margin-bottom:1.25rem}
.schedule-features{display:flex;flex-wrap:wrap;gap:1rem}
.schedule-features span{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;color:var(--clr-gray-300)}
.schedule-features i{color:var(--clr-brand-400)}

.faq-accordion .faq-item{background:var(--clr-glass-bg);border:1px solid var(--clr-glass-border)!important;border-radius:var(--radius-xl)!important;margin-bottom:.75rem;overflow:hidden}
.faq-btn{background:transparent!important;color:var(--clr-white)!important;font-weight:600;font-size:.95rem;padding:1.25rem 1.5rem;box-shadow:none!important;border-radius:var(--radius-xl)!important}
.faq-btn::after{filter:invert(1)}
.faq-btn:not(.collapsed){color:var(--clr-brand-300)!important}
.faq-body{color:var(--clr-gray-300);font-size:.92rem;line-height:1.75;padding:0 1.5rem 1.25rem;background:transparent}

/* ─── RESPONSIVE ADDITIONS ───────────────────────────────── */
@media(max-width:991px){
  .about-stat-grid{grid-template-columns:repeat(2,1fr)}
  .services-quicknav{position:static}
}
@media(max-width:767px){
  .about-stat-grid{grid-template-columns:1fr 1fr}
  .cta-banner{padding:2rem 1.5rem}
  .schedule-card{padding:2rem 1.5rem}
  .quicknav-pills{justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}
  .quicknav-pill{white-space:nowrap}
  .service-visual-card{padding:1.75rem 1.25rem}
  .lowcode-platform-grid{grid-template-columns:repeat(4,1fr)}
  .schedule-features{flex-direction:column;gap:.5rem}
}
