/* ================================================================
   Softex Technologies — style.css v5
   Futuristic · AI · Dream Fantasy · Orange Brand
================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
  /* ── Logo extracted gradient palette ── */
  --l1:     #F20D5A;   /* Deep Magenta */
  --l2:     #F44A6A;   /* Coral Pink   */
  --l3:     #F78B3D;   /* Orange       */
  --l4:     #FBBF24;   /* Golden Yellow */
  --logo-g: linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);

  /* ── Legacy aliases (kept for compat) ── */
  --or:     #F78B3D;
  --or-l:   #F44A6A;
  --or-d:   #d9650a;
  --or-s:   rgba(247,139,61,.09);
  --or-g:   rgba(247,139,61,.25);
  --pink:   #F20D5A;
  --cyan:   #06b6d4;
  --pu:     #8b5cf6;

  --bg0:    #020308;
  --bg1:    #05080f;
  --bg2:    #080d1a;
  --bg3:    #0d1525;
  --bg4:    #111e35;
  --bg5:    #162340;

  --bd:     rgba(242,13,90,.14);
  --bd2:    rgba(255,255,255,.05);

  --t1:     #f1f5f9;
  --t2:     #94a3b8;
  --t3:     #475569;

  --fh:     'Exo 2', sans-serif;
  --fb:     'Space Grotesk', sans-serif;

  --mw:     1220px;
  --px:     clamp(1rem, 4vw, 2rem);
  --sp:     clamp(4.5rem, 9vw, 7rem);
  --r:      10px;
  --rl:     18px;
  --ta:     .18s ease;
  --tb:     .32s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--fb);background:var(--bg0);color:var(--t1);
  line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none}
::selection{background:rgba(249,115,22,.4);color:#fff}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg0)}
::-webkit-scrollbar-thumb{background:var(--or-d);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--or)}

/* ── Layout ──────────────────────────────────────────────────── */
.wrap{max-width:var(--mw);margin:0 auto;padding:0 var(--px)}
.section{padding:var(--sp) 0;position:relative}

/* ================================================================
   FUTURISTIC BACKGROUND SYSTEM
================================================================ */
/* Scanline overlay */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:repeating-linear-gradient(
    0deg,transparent 0px,transparent 2px,
    rgba(6,182,212,.012) 2px,rgba(6,182,212,.012) 4px
  );
}

/* Noise texture */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}

/* Glowing orbs */
.orb{position:absolute;border-radius:50%;filter:blur(110px);pointer-events:none;z-index:0}
.orb-or{background:radial-gradient(circle,rgba(249,115,22,.22) 0%,transparent 70%)}
.orb-cy{background:radial-gradient(circle,rgba(6,182,212,.12) 0%,transparent 70%)}
.orb-pu{background:radial-gradient(circle,rgba(139,92,246,.1) 0%,transparent 70%)}
.orb-pk{background:radial-gradient(circle,rgba(236,72,153,.09) 0%,transparent 70%)}

/* Grid pattern */
.grid-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(249,115,22,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(249,115,22,.06) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 30%,black 0%,transparent 100%);
}

/* Dot matrix */
.dots-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(249,115,22,.15) 1px,transparent 1px);
  background-size:30px 30px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 0%,transparent 100%);
}

/* Glowing border top */
.glow-top::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--or),rgba(6,182,212,.8),var(--or),transparent);
  animation:glowLine 4s ease-in-out infinite;
}
@keyframes glowLine{0%,100%{opacity:.5;left:10%;right:10%}50%{opacity:1;left:5%;right:5%}}

/* ================================================================
   TYPOGRAPHY
================================================================ */
.eyebrow{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#F78B3D;
  background:linear-gradient(135deg,rgba(242,13,90,.1),rgba(247,139,61,.06));
  border:1px solid rgba(242,13,90,.3);
  padding:.32rem .85rem;border-radius:100px;margin-bottom:1.1rem;
  position:relative;overflow:hidden;
}
.eyebrow::before{
  content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(242,13,90,.2),transparent);
  animation:shimmer 3s infinite;
}
@keyframes shimmer{to{left:200%}}

.h1{
  font-family:var(--fh);
  font-size:clamp(2.8rem,5.8vw,5rem);
  font-weight:900;line-height:1.02;letter-spacing:-.025em;
  color:var(--t1);
}
.h2{
  font-family:var(--fh);
  font-size:clamp(2rem,4vw,3.2rem);
  font-weight:800;line-height:1.08;letter-spacing:-.02em;
  color:var(--t1);
}
.h3{font-family:var(--fh);font-size:clamp(1.3rem,2.2vw,1.8rem);font-weight:700;color:var(--t1)}

.gradient-text{
  background:linear-gradient(135deg,#F20D5A,#F21C6A,#F44A6A,#F78B3D,#FBBF24,#F78B3D,#F44A6A,#F20D5A);
  background-size:300% 300%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradientShift 4s ease infinite;
}
@keyframes gradientShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

/* Typing cursor */
.typing-cursor{
  display:inline-block;width:3px;margin-left:4px;
  background:linear-gradient(180deg,#F20D5A,#F78B3D);
  animation:cursorBlink .8s step-end infinite;
  vertical-align:text-bottom;border-radius:2px;
  box-shadow:0 0 8px rgba(242,13,90,.6);
}
@keyframes cursorBlink{0%,100%{opacity:1}50%{opacity:0}}

/* Dynamic typing text — inherits gradient-text animation */
.dynamic-text{
  background:linear-gradient(135deg,#F20D5A,#F21C6A,#F44A6A,#F78B3D,#FBBF24,#F78B3D,#F44A6A,#F20D5A);
  background-size:300% 300%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:gradientShift 4s ease infinite;
  display:inline;font-family:var(--fh);font-weight:900;
  letter-spacing:-.025em;
}

.cyan-text{
  background:linear-gradient(120deg,var(--cyan) 0%,var(--pu) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.lead{font-size:clamp(.95rem,1.6vw,1.08rem);color:var(--t2);line-height:1.9;max-width:560px}
.lead.wide{max-width:680px}
.center{text-align:center}.center .lead{margin:0 auto}.center .eyebrow{display:inline-flex}

/* ================================================================
   BUTTONS
================================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--fb);font-size:.87rem;font-weight:600;
  padding:.72rem 1.6rem;border-radius:8px;border:none;
  transition:var(--tb);letter-spacing:.02em;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,#F20D5A 0%,#F44A6A 35%,#F78B3D 70%,#FBBF24 100%);
  background-size:200% 200%;
  color:#fff;
  box-shadow:0 0 0 1px rgba(242,13,90,.3),0 4px 20px rgba(242,13,90,.35);
  animation:btnGradShift 3s ease infinite;
}
@keyframes btnGradShift{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.2),transparent);
  opacity:0;transition:opacity .2s;
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 0 0 1px #F44A6A,0 8px 30px rgba(242,13,90,.5),0 0 50px rgba(242,13,90,.2);
  animation-play-state:paused;
  background-position:100% 50%;
}
.btn-primary:hover::before{opacity:1}

.btn-ghost{
  background:rgba(255,255,255,.04);color:var(--t1);
  border:1px solid rgba(242,13,90,.35);
  backdrop-filter:blur(10px);
  position:relative;
}
.btn-ghost::before{
  content:'';position:absolute;inset:-1px;border-radius:9px;
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  opacity:0;z-index:-1;transition:opacity .25s;
}
.btn-ghost:hover{
  border-color:transparent;color:#fff;
  background:linear-gradient(135deg,rgba(242,13,90,.15),rgba(247,139,61,.1));
  transform:translateY(-2px);
  box-shadow:0 0 25px rgba(242,13,90,.25);
}
.btn-ghost:hover::before{opacity:.15}
.btn-lg{padding:.95rem 2.1rem;font-size:.92rem}
.btn-block{width:100%;justify-content:center}
.btn-cyan{
  background:transparent;color:var(--cyan);
  border:1px solid rgba(6,182,212,.35);
}
.btn-cyan:hover{background:rgba(6,182,212,.1);border-color:var(--cyan);box-shadow:0 0 20px rgba(6,182,212,.2)}

/* ================================================================
   GRADIENT ICON UTILITY
   Applies logo gradient to Font Awesome & any inline icon
================================================================ */
.gi, /* gradient icon helper */
.tech-item i,
.eyebrow i,
.hero-chip i,
.svc-more i,
.hdr-phone i,
.mob-nav a i,
.footer-contact-col p i,
.footer-col ul li a i,
.ci-ico i,
.soc-btn:hover i,
.err-link i,
.breadcrumb i {
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline-block; /* required for background-clip on inline elements */
}

/* ================================================================
   SCROLL ANIMATIONS
================================================================ */
[data-reveal]{opacity:0;transform:translateY(30px);transition:opacity .65s ease,transform .65s ease}
[data-reveal].visible{opacity:1;transform:none}
[data-delay="1"]{transition-delay:.1s}[data-delay="2"]{transition-delay:.2s}
[data-delay="3"]{transition-delay:.3s}[data-delay="4"]{transition-delay:.4s}

/* ================================================================
   HEADER
================================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:.9rem 0;
  transition:background .3s,box-shadow .3s,padding .3s;
}
.site-header.sticky{
  background:rgba(2,3,8,.92);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  box-shadow:0 1px 0 var(--bd),0 4px 30px rgba(0,0,0,.4);
  padding:.65rem 0;
}
.site-header::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(242,13,90,.4) 30%,rgba(247,139,61,.3) 50%,rgba(242,13,90,.4) 70%,transparent 100%);
  opacity:0;transition:opacity .3s;
}
.site-header.sticky::after{opacity:1}

.header-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo{display:flex;align-items:center;gap:.6rem;flex-shrink:0}
.logo-img{
  height:44px;width:auto;object-fit:contain;
  mix-blend-mode:screen; /* removes black bg from logo */
  filter:brightness(1.1) saturate(1.1);
}
.logo-name{font-family:var(--fh);font-size:1.2rem;font-weight:800;color:var(--t1)}

.main-nav{display:flex;align-items:center;gap:.1rem}
.main-nav a{
  font-size:.84rem;font-weight:500;color:var(--t2);
  padding:.42rem .85rem;border-radius:6px;transition:var(--ta);
  position:relative;
}
.main-nav a::after{
  content:'';position:absolute;bottom:0;left:50%;right:50%;height:1px;
  background:linear-gradient(90deg,#F20D5A,#F78B3D);transition:var(--tb);
}
.main-nav a:hover,.main-nav a.active{color:var(--t1)}
.main-nav a:hover::after,.main-nav a.active::after{left:10%;right:10%}
.main-nav a.active{color:#F44A6A}

.hdr-cta{display:flex;align-items:center;gap:.65rem;flex-shrink:0}
.hdr-phone{
  font-size:.78rem;font-weight:600;color:var(--t2);
  display:flex;align-items:center;gap:.4rem;
  padding:.46rem .85rem;border-radius:6px;
  border:1px solid var(--bd2);transition:var(--ta);
}
.hdr-phone:hover{color:var(--or-l);border-color:var(--bd);background:var(--or-s)}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:linear-gradient(135deg,rgba(242,13,90,.12),rgba(247,139,61,.08));
  border:1px solid rgba(242,13,90,.35);border-radius:8px;padding:.52rem .58rem;
  cursor:pointer;z-index:1001;flex-shrink:0;
}
.hamburger span{
  width:22px;height:2px;border-radius:2px;display:block;transition:var(--tb);
  background:linear-gradient(90deg,#F20D5A,#F78B3D,#FBBF24);
}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile drawer */
.mob-nav{
  display:none;position:fixed;inset:0;top:60px;
  background:rgba(2,3,8,.98);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-top:1px solid rgba(242,13,90,.2);
  flex-direction:column;padding:1.5rem;gap:.15rem;
  z-index:1000;overflow-y:auto;
}
.mob-nav.open{display:flex;animation:slideIn .28s ease}
.mob-nav a{
  font-size:1.05rem;font-weight:600;color:var(--t2);
  padding:.95rem 1.2rem;border-radius:10px;
  border-bottom:1px solid rgba(242,13,90,.08);
  transition:var(--ta);display:flex;align-items:center;gap:.75rem;
}
.mob-nav a:hover,.mob-nav a.active{
  color:var(--t1);
  background:linear-gradient(135deg,rgba(242,13,90,.1),rgba(247,139,61,.05));
  border-bottom-color:rgba(242,13,90,.2);
}
.mob-nav a.active{color:#F44A6A}
.mob-nav .btn{margin-top:1rem}
@keyframes slideIn{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}

/* ================================================================
   HERO
================================================================ */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:8rem 0 5rem;overflow:hidden;position:relative;
}
.hero-wrap{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;
}

/* Chip */
.hero-chip{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:#F44A6A;
  background:linear-gradient(135deg,rgba(242,13,90,.1),rgba(247,139,61,.06));
  border:1px solid rgba(242,13,90,.32);
  padding:.35rem 1rem .35rem .5rem;border-radius:100px;margin-bottom:1.5rem;
}
.chip-dot{
  width:8px;height:8px;border-radius:50%;
  background:radial-gradient(circle,#F20D5A 0%,#F78B3D 100%);
  box-shadow:0 0 8px #F20D5A;
  animation:dotPulse 2s infinite;
}
@keyframes dotPulse{0%,100%{box-shadow:0 0 4px #F20D5A}50%{box-shadow:0 0 14px #F20D5A,0 0 24px rgba(242,13,90,.4)}}

.hero-title{
  font-family:var(--fh);
  font-size:clamp(2.6rem,5vw,4.8rem);
  font-weight:900;line-height:1.02;letter-spacing:-.025em;
  color:var(--t1);margin-bottom:1.4rem;
}

.hero-desc{
  font-size:1.05rem;color:var(--t2);line-height:1.88;
  max-width:480px;margin-bottom:2.2rem;
}
.hero-btns{display:flex;gap:.85rem;flex-wrap:wrap;margin-bottom:3rem}

/* Trust bar */
.hero-trust{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}
.trust-av{display:flex}
.trust-av span{
  width:33px;height:33px;border-radius:50%;
  border:2px solid var(--bg0);
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  display:grid;place-items:center;font-size:.68rem;font-weight:700;color:#fff;
  margin-left:-9px;flex-shrink:0;
}
.trust-av span:first-child{margin-left:0}
.trust-label{font-size:.78rem;color:var(--t2)}
.trust-label strong{color:var(--t1)}

/* Hero visual — glass terminal */
.hero-visual{position:relative;z-index:2}
.hero-panel{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid rgba(249,115,22,.2);
  background:linear-gradient(145deg,rgba(13,21,37,.9),rgba(8,13,26,.95));
  padding:1.5rem;
  box-shadow:
    0 0 0 1px rgba(249,115,22,.08),
    0 30px 80px rgba(0,0,0,.6),
    inset 0 0 60px rgba(6,182,212,.03),
    0 0 80px rgba(249,115,22,.05);
  backdrop-filter:blur(12px);
}
.hero-panel::before{
  content:'';position:absolute;top:-1px;left:15%;right:15%;height:1px;
  background:linear-gradient(90deg,transparent,var(--or),var(--cyan),var(--or),transparent);
  animation:topGlow 3s ease-in-out infinite;
}
@keyframes topGlow{0%,100%{opacity:.6}50%{opacity:1}}

.panel-bar{display:flex;align-items:center;gap:.5rem;margin-bottom:1.2rem}
.p-dot{width:10px;height:10px;border-radius:50%}
.p-dot.r{background:#ff5f57}.p-dot.y{background:#febc2e}.p-dot.g{background:#28c840}
.p-title{font-size:.74rem;color:var(--t3);margin-left:.5rem;font-family:monospace}

.code-area{font-family:'JetBrains Mono','Fira Code','Courier New',monospace;font-size:.78rem;line-height:2}
.c-cm{color:#4b5563}.c-kw{color:#c084fc}.c-fn{color:#34d399}.c-st{color:#fbbf24}
.c-or{color:var(--or-l)}.c-cy{color:var(--cyan)}.c-nu{color:#fb923c}
.c-cu{
  display:inline-block;width:2px;height:.82em;
  background:var(--or);animation:cur .9s step-end infinite;
  vertical-align:text-bottom;margin-left:1px;
  box-shadow:0 0 6px var(--or);
}
@keyframes cur{0%,100%{opacity:1}50%{opacity:0}}

/* Floating pills */
.float-pill{
  position:absolute;
  background:linear-gradient(135deg,rgba(13,21,37,.95),rgba(17,30,53,.9));
  border:1px solid rgba(249,115,22,.2);
  border-radius:12px;padding:.5rem .95rem;
  display:flex;align-items:center;gap:.5rem;
  font-size:.75rem;font-weight:600;color:var(--t1);
  box-shadow:0 8px 24px rgba(0,0,0,.4),0 0 20px rgba(249,115,22,.08);
  animation:levitate 5s ease-in-out infinite;z-index:3;white-space:nowrap;
  backdrop-filter:blur(8px);
}
.fp-ico{font-size:1rem}
.fp-1{top:-18px;right:10px;animation-delay:0s}
.fp-2{bottom:18px;left:-16px;animation-delay:2s}
.fp-3{top:46%;right:-18px;animation:levitate3 5s ease-in-out 3.5s infinite}
@keyframes levitate{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes levitate3{0%,100%{transform:translateY(-50%)}50%{transform:translateY(calc(-50% - 8px))}}

/* Hero grid overlay */
.hero-grid-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(249,115,22,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(249,115,22,.05) 1px,transparent 1px);
  background-size:50px 50px;
  mask-image:radial-gradient(ellipse 90% 70% at 45% 40%,black 0%,transparent 100%);
}

/* ================================================================
   SCROLLING STRIPS
================================================================ */
.strip-wrap{
  overflow:hidden;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);
  position:relative;background:linear-gradient(180deg,var(--bg1),var(--bg2));
}
.strip-wrap::before,.strip-wrap::after{
  content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none;
}
.strip-wrap::before{left:0;background:linear-gradient(90deg,var(--bg1),transparent)}
.strip-wrap::after{right:0;background:linear-gradient(-90deg,var(--bg1),transparent)}

.strip-inner{padding:1.3rem 0;overflow:hidden}
.marquee-track{display:flex;align-items:center;white-space:nowrap;width:max-content}
.marquee-track.fwd{animation:marqueeL 32s linear infinite}
.marquee-track.rev{animation:marqueeR 35s linear infinite}
.strip-wrap:hover .marquee-track{animation-play-state:paused}
@keyframes marqueeL{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes marqueeR{from{transform:translateX(-50%)}to{transform:translateX(0)}}

.tech-item{
  display:flex;align-items:center;gap:.55rem;flex-shrink:0;
  padding:.4rem 1.5rem;font-size:.74rem;font-weight:600;
  color:var(--t3);letter-spacing:.08em;text-transform:uppercase;
  border-right:1px solid rgba(249,115,22,.1);
}
.tech-item i{font-size:.8rem}

/* Client logo strip */
.client-item{
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  padding:.6rem 2.5rem;border-right:1px solid rgba(249,115,22,.08);
  transition:var(--tb);
}
.client-item:hover{background:rgba(249,115,22,.06)}
.cl-text{
  font-family:var(--fh);font-size:.9rem;font-weight:700;
  color:rgba(255,255,255,.25);letter-spacing:.06em;
  transition:color var(--tb),text-shadow var(--tb);
}
.client-item:hover .cl-text{
  color:var(--or-l);
  text-shadow:0 0 20px rgba(249,115,22,.4);
}

/* ================================================================
   ABOUT / SPLIT LAYOUT
================================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.split.flip .split-visual{order:-1}
.split-visual{position:relative}
.img-frame{
  border-radius:20px;overflow:hidden;position:relative;
  border:1px solid rgba(249,115,22,.15);
  aspect-ratio:4/3;background:var(--bg3);
  box-shadow:0 30px 70px rgba(0,0,0,.5),0 0 0 1px rgba(249,115,22,.06);
}
.img-frame::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(249,115,22,.08) 0%,transparent 50%,rgba(6,182,212,.05) 100%);
  pointer-events:none;
}
.img-frame img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.img-frame:hover img{transform:scale(1.04)}
.img-badge{
  position:absolute;bottom:-18px;right:-18px;
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  border-radius:16px;padding:1.1rem 1.5rem;text-align:center;
  box-shadow:0 16px 40px rgba(242,13,90,.45),0 0 40px rgba(242,13,90,.15);
  border:1px solid rgba(255,255,255,.1);
}
.img-badge .num{font-family:var(--fh);font-size:2rem;font-weight:900;color:#fff;line-height:1}
.img-badge .lbl{font-size:.67rem;color:rgba(255,255,255,.8);margin-top:.2rem}

.split-text p{color:var(--t2);line-height:1.92;margin-bottom:1.1rem}

.check-list{margin:1.5rem 0 2rem;display:flex;flex-direction:column;gap:.65rem}
.check-list li{
  display:flex;align-items:flex-start;gap:.75rem;
  font-size:.9rem;color:var(--t1);line-height:1.55;
}
.check-list li .chk{
  width:20px;height:20px;flex-shrink:0;margin-top:2px;
  border-radius:50%;
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  border:none;
  display:grid;place-items:center;font-size:.65rem;color:#fff;font-weight:700;
  box-shadow:0 0 10px rgba(242,13,90,.3);
}

/* ================================================================
   STATS BAND
================================================================ */
.stats-band{
  position:relative;overflow:hidden;
  padding:5rem 0;
}
.stats-band-inner{
  background:linear-gradient(135deg,rgba(249,115,22,.12) 0%,rgba(6,182,212,.06) 50%,rgba(249,115,22,.08) 100%);
  border:1px solid rgba(249,115,22,.2);
  border-radius:24px;padding:4rem 3rem;position:relative;overflow:hidden;
  backdrop-filter:blur(8px);
}
.stats-band-inner::before{
  content:'';position:absolute;inset:0;border-radius:24px;
  background:linear-gradient(145deg,rgba(13,21,37,.8),rgba(8,13,26,.9));
  z-index:0;
}
.stats-band-inner::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(249,115,22,.12) 1px,transparent 1px);
  background-size:25px 25px;z-index:0;opacity:.5;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;position:relative;z-index:1}
.stat-box{text-align:center}
.stat-num{font-family:var(--fh);font-size:clamp(2.5rem,4vw,3.6rem);font-weight:900;line-height:1}
.stat-label{font-size:.82rem;color:var(--t2);margin-top:.5rem}

/* ================================================================
   SERVICE CARDS
================================================================ */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:3rem}
.svc-card{
  background:linear-gradient(145deg,rgba(13,21,37,.8),rgba(8,13,26,.6));
  border:1px solid rgba(249,115,22,.1);
  border-radius:var(--rl);padding:2rem;position:relative;overflow:hidden;
  transition:var(--tb);backdrop-filter:blur(8px);
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--or),transparent);
  opacity:0;transition:var(--tb);
}
.svc-card:hover{
  border-color:rgba(249,115,22,.35);
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,0,0,.4),0 0 40px rgba(249,115,22,.08);
}
.svc-card:hover::before{opacity:1}
.svc-icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,rgba(249,115,22,.15),rgba(249,115,22,.05));
  border:1px solid rgba(249,115,22,.25);
  display:grid;place-items:center;font-size:1.4rem;margin-bottom:1.2rem;
  transition:var(--tb);
  box-shadow:0 0 20px rgba(249,115,22,.1);
}
.svc-card:hover .svc-icon{
  box-shadow:0 0 30px rgba(249,115,22,.3);
  background:linear-gradient(135deg,rgba(249,115,22,.25),rgba(249,115,22,.1));
}
.svc-title{font-family:var(--fh);font-size:1.1rem;font-weight:700;color:var(--t1);margin-bottom:.5rem}
.svc-desc{font-size:.87rem;color:var(--t2);line-height:1.78}
.svc-more{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.8rem;font-weight:600;
  background:linear-gradient(135deg,#F44A6A,#F78B3D,#FBBF24);
  background-size:200% 200%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-top:1rem;transition:var(--ta);
}
.svc-more:hover{gap:.65rem;filter:brightness(1.15)}

/* ================================================================
   PORTFOLIO
================================================================ */
.filters{display:flex;gap:.45rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{
  font-size:.78rem;font-weight:600;padding:.4rem 1rem;border-radius:100px;
  border:1px solid rgba(249,115,22,.15);background:transparent;
  color:var(--t3);transition:var(--ta);
}
.filter-btn:hover{color:var(--t1);border-color:rgba(249,115,22,.35)}
.filter-btn.active{
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D);
  border-color:transparent;color:#fff;
  box-shadow:0 4px 14px rgba(242,13,90,.4),0 0 20px rgba(242,13,90,.15);
}

.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.pf-card{
  border-radius:var(--rl);overflow:hidden;
  background:linear-gradient(145deg,rgba(13,21,37,.8),rgba(8,13,26,.6));
  border:1px solid rgba(249,115,22,.1);transition:var(--tb);
  backdrop-filter:blur(6px);
}
.pf-card:hover{
  border-color:rgba(249,115,22,.4);transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 40px rgba(249,115,22,.1);
}
.pf-card.pf-hidden{display:none !important}
.pf-img{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--bg4)}
.pf-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.pf-card:hover .pf-img img{transform:scale(1.07)}
.pf-overlay{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(2,3,8,.85),rgba(249,115,22,.15));
  display:flex;align-items:center;justify-content:center;gap:.75rem;
  opacity:0;transition:var(--tb);backdrop-filter:blur(4px);
}
.pf-card:hover .pf-overlay{opacity:1}
.pf-overlay a{
  width:44px;height:44px;border-radius:50%;
  background:rgba(249,115,22,.9);display:grid;place-items:center;
  color:#fff;font-size:.95rem;transition:var(--ta);
  box-shadow:0 0 20px rgba(249,115,22,.5);
}
.pf-overlay a:hover{background:var(--or);box-shadow:0 0 30px rgba(249,115,22,.8)}
.pf-body{padding:1.2rem 1.5rem 1.5rem}
.pf-cat{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:linear-gradient(135deg,#F20D5A,#F78B3D,#FBBF24);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  margin-bottom:.3rem;display:inline-block;
}
.pf-title{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--t1);margin-bottom:.4rem}
.pf-desc{font-size:.8rem;color:var(--t3);line-height:1.65;margin-bottom:.8rem}
.tech-tags{display:flex;flex-wrap:wrap;gap:.3rem}
.tech-tag{
  font-size:.67rem;font-weight:600;padding:.18rem .55rem;border-radius:100px;
  background:rgba(242,13,90,.07);
  color:#F44A6A;
  border:1px solid rgba(242,13,90,.2);
}

/* ================================================================
   TESTIMONIALS
================================================================ */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.5rem;margin-top:3rem}
.testi-card{
  background:linear-gradient(145deg,rgba(13,21,37,.8),rgba(8,13,26,.6));
  border:1px solid rgba(249,115,22,.1);border-radius:var(--rl);
  padding:2rem;position:relative;overflow:hidden;transition:var(--tb);
  backdrop-filter:blur(8px);
}
.testi-card::before{
  content:'';position:absolute;top:0;right:0;
  width:90px;height:90px;
  background:radial-gradient(circle at 100% 0%,rgba(249,115,22,.12),transparent 70%);
}
.testi-card:hover{border-color:rgba(249,115,22,.3);transform:translateY(-4px)}
.testi-stars{
  font-size:.82rem;letter-spacing:.06em;margin-bottom:.9rem;
  background:linear-gradient(135deg,#F20D5A,#F78B3D,#FBBF24);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  display:inline-block;
  filter:drop-shadow(0 0 6px rgba(242,13,90,.4));
}
.testi-text{font-size:.88rem;color:var(--t2);line-height:1.85;margin-bottom:1.4rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.85rem}
.testi-av{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  display:grid;place-items:center;font-weight:700;color:#fff;font-size:.95rem;
  box-shadow:0 0 16px rgba(242,13,90,.4);
}
.testi-name{font-size:.88rem;font-weight:700;color:var(--t1)}
.testi-role{font-size:.76rem;color:var(--t3)}

/* ================================================================
   PROCESS STEPS
================================================================ */
.process-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:0;position:relative;margin-top:3.5rem;
}
.process-grid::before{
  content:'';position:absolute;top:26px;left:7%;width:86%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(249,115,22,.3),rgba(6,182,212,.3),rgba(249,115,22,.3),transparent);
  animation:lineGlow 4s ease-in-out infinite;
}
@keyframes lineGlow{0%,100%{opacity:.5}50%{opacity:1}}
.proc-step{position:relative;z-index:1;text-align:center;padding:0 .7rem}
.proc-num{
  width:52px;height:52px;border-radius:50%;margin:0 auto 1.1rem;
  background:linear-gradient(135deg,rgba(13,21,37,.9),rgba(8,13,26,.8));
  border:2px solid #F44A6A;
  display:grid;place-items:center;
  font-family:var(--fh);font-size:.88rem;font-weight:800;
  background:linear-gradient(135deg,#F20D5A,#F44A6A,#F78B3D,#FBBF24);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  box-shadow:0 0 20px rgba(242,13,90,.25),inset 0 0 20px rgba(242,13,90,.05);
}
.proc-title{font-size:.9rem;font-weight:700;color:var(--t1);margin-bottom:.35rem}
.proc-desc{font-size:.78rem;color:var(--t3);line-height:1.65}

/* ================================================================
   TEAM CARDS
================================================================ */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:1.5rem;margin-top:3rem}
.team-card{
  background:linear-gradient(145deg,rgba(13,21,37,.8),rgba(8,13,26,.6));
  border:1px solid rgba(249,115,22,.1);border-radius:var(--rl);
  overflow:hidden;text-align:center;transition:var(--tb);backdrop-filter:blur(6px);
}
.team-card:hover{
  border-color:rgba(249,115,22,.35);transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(0,0,0,.4),0 0 30px rgba(249,115,22,.08);
}
.team-photo{aspect-ratio:1;overflow:hidden;background:var(--bg4);position:relative}
.team-photo::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:40%;
  background:linear-gradient(transparent,rgba(2,3,8,.8));pointer-events:none;
}
.team-photo img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease;filter:saturate(.9)}
.team-card:hover .team-photo img{transform:scale(1.06);filter:saturate(1.1)}
.team-info{padding:1rem}
.team-name{font-family:var(--fh);font-size:.95rem;font-weight:700;color:var(--t1)}
.team-role{
  font-size:.73rem;font-weight:600;margin-top:.2rem;
  background:linear-gradient(135deg,#F44A6A,#F78B3D,#FBBF24);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  display:inline-block;
}

/* ================================================================
   CTA BAND
================================================================ */
.cta-band{position:relative;overflow:hidden;text-align:center;padding:var(--sp) 0}
.cta-box{
  position:relative;z-index:2;max-width:700px;margin:0 auto;
  background:linear-gradient(145deg,rgba(13,21,37,.7),rgba(8,13,26,.5));
  border:1px solid rgba(249,115,22,.2);border-radius:24px;
  padding:4rem 3rem;backdrop-filter:blur(12px);
  box-shadow:0 0 0 1px rgba(249,115,22,.06),0 40px 80px rgba(0,0,0,.4);
}
.cta-box::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,var(--or),var(--cyan),var(--or),transparent);
}
.cta-box h2{font-family:var(--fh);font-size:clamp(1.9rem,3.8vw,3rem);font-weight:900;color:var(--t1);margin-bottom:.9rem}
.cta-box p{color:var(--t2);font-size:1.02rem;margin-bottom:2rem;line-height:1.85}
.cta-btns{display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap}

/* ================================================================
   PAGE HERO
================================================================ */
.page-hero{padding:9rem 0 5rem;text-align:center;position:relative;overflow:hidden}
.page-hero-content{position:relative;z-index:2}
.breadcrumb{display:inline-flex;align-items:center;gap:.4rem;font-size:.76rem;color:var(--t3);margin-bottom:1rem}
.breadcrumb a{color:var(--t3);transition:var(--ta)}.breadcrumb a:hover{color:var(--t1)}
.breadcrumb .sep{opacity:.3}

/* ================================================================
   CONTACT
================================================================ */
.contact-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start;margin-top:3rem}
.ci-block{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.7rem}
.ci-ico{
  width:46px;height:46px;flex-shrink:0;border-radius:12px;
  background:linear-gradient(135deg,rgba(242,13,90,.15),rgba(247,139,61,.05));
  border:1px solid rgba(242,13,90,.28);
  display:grid;place-items:center;font-size:1rem;
  box-shadow:0 0 14px rgba(242,13,90,.15);
}
.ci-head{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--t3);margin-bottom:.22rem}
.ci-val{font-size:.88rem;font-weight:600;color:var(--t1)}
.ci-val a{color:#F44A6A}.ci-val a:hover{color:var(--t1)}
.social-strip{display:flex;gap:.55rem;margin-top:1.4rem}
.soc-btn{
  width:38px;height:38px;border-radius:8px;
  border:1px solid rgba(249,115,22,.15);display:grid;place-items:center;
  color:var(--t3);transition:var(--ta);
}
.soc-btn:hover{border-color:#F44A6A;color:#F44A6A;background:rgba(242,13,90,.08);box-shadow:0 0 12px rgba(242,13,90,.2)}

.cf-box{
  background:linear-gradient(145deg,rgba(13,21,37,.85),rgba(8,13,26,.7));
  border:1px solid rgba(249,115,22,.15);border-radius:var(--rl);
  padding:2.5rem;position:relative;overflow:hidden;backdrop-filter:blur(10px);
}
.cf-box::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--or) 30%,var(--cyan) 60%,var(--or) 80%,transparent);
}
.cf-heading{font-family:var(--fh);font-size:1.4rem;font-weight:800;color:var(--t1);margin-bottom:.35rem}
.cf-sub{font-size:.83rem;color:var(--t3);margin-bottom:1.85rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:.8rem;font-weight:600;color:var(--t2);margin-bottom:.42rem}
.form-group label .req{color:var(--or)}
.form-group input,.form-group textarea,.form-group select{
  width:100%;background:rgba(5,8,15,.7);
  border:1px solid rgba(249,115,22,.15);border-radius:8px;
  padding:.72rem .95rem;font-family:var(--fb);font-size:.87rem;color:var(--t1);
  transition:var(--ta);outline:none;resize:vertical;appearance:none;
  backdrop-filter:blur(8px);
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:#F44A6A;box-shadow:0 0 0 3px rgba(242,13,90,.1),0 0 20px rgba(242,13,90,.08);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--t3)}
.form-group select option{background:var(--bg2);color:var(--t1)}
.form-group textarea{min-height:130px}
.form-group input.error,.form-group textarea.error,.form-group select.error{
  border-color:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.1);
}
.alert{display:none;padding:.8rem 1rem;border-radius:8px;font-size:.84rem;margin-bottom:1.3rem}
.alert.show{display:flex;align-items:flex-start;gap:.6rem}
.alert-ok{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:#6ee7b7}
.alert-err{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#fca5a5}
.alert i{margin-top:.1rem;flex-shrink:0}

/* ================================================================
   FOOTER
================================================================ */
.site-footer{
  background:var(--bg0);
  border-top:1px solid rgba(249,115,22,.12);
  padding:5rem 0 2rem;position:relative;
}
.site-footer::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,#F20D5A,#F44A6A,#F78B3D,#FBBF24,#F78B3D,#F20D5A,transparent);
  animation:glowLine 5s ease-in-out infinite;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:3rem;margin-bottom:4rem}
.footer-brand p{font-size:.84rem;color:var(--t3);line-height:1.85;max-width:265px;margin:1rem 0 1.3rem}
.footer-col h5{
  font-family:var(--fh);font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;color:var(--t1);margin-bottom:1.1rem;
  position:relative;
}
.footer-col h5::after{
  content:'';position:absolute;bottom:-5px;left:0;width:28px;height:2px;
  background:linear-gradient(90deg,#F20D5A,#F78B3D,transparent);
  border-radius:2px;
}
.footer-col ul li{margin-bottom:.52rem}
.footer-col ul li a{
  font-size:.82rem;color:var(--t3);
  display:inline-flex;align-items:center;gap:.3rem;transition:var(--ta);
}
.footer-col ul li a:hover{color:#F44A6A;text-shadow:0 0 10px rgba(242,13,90,.3)}
.footer-contact-col p{
  display:flex;align-items:flex-start;gap:.55rem;
  font-size:.82rem;color:var(--t3);margin-bottom:.75rem;line-height:1.6;
}
.footer-contact-col p i{flex-shrink:0;margin-top:.16rem;font-size:.82rem}
.footer-contact-col a{color:var(--t3);transition:var(--ta)}
.footer-contact-col a:hover{color:#F44A6A}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
  padding-top:1.8rem;border-top:1px solid rgba(249,115,22,.08);
}
.footer-bottom p{font-size:.78rem;color:var(--t3)}

/* ================================================================
   AWARDS ROW
================================================================ */
.awards-row{display:flex;align-items:center;gap:1rem;margin-top:1rem}
.awards-row img{height:40px;width:auto;object-fit:contain;filter:brightness(.7);transition:filter var(--tb)}
.awards-row img:hover{filter:brightness(1)}

/* ================================================================
   RESPONSIVE
================================================================ */
@media(max-width:1100px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .main-nav,.hdr-phone,.hdr-cta{display:none}
  .hamburger{display:flex !important}
  .hero-wrap{grid-template-columns:1fr}
  .hero-visual{display:none}
  .split{grid-template-columns:1fr;gap:2.5rem}
  .split.flip .split-visual{order:0}
  .contact-wrap{grid-template-columns:1fr}
  .process-grid::before{display:none}
  .stats-band-inner{padding:2.5rem 1.5rem}
  .header-inner{justify-content:space-between}
}
@media(max-width:640px){
  .footer-grid{grid-template-columns:1fr;gap:2rem}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .cta-btns{flex-direction:column;align-items:center}
  .form-row{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-box{padding:2.5rem 1.5rem}
}
@media(max-width:400px){
  .process-grid{grid-template-columns:1fr}
  .hero-trust{flex-direction:column;align-items:flex-start}
}
