/* ═══════════════════════════════════════════════════════════════
   LEPIXO v8 — "Navy Voltage"
   Palette: Navy #0B0E1A + Blue #4F6EFF + Mint #00E5B4 + White
   Font: Space Grotesk
   Concept: Asymmetric, diagonal sections, overlapping elements
   ═══════════════════════════════════════════════════════════════ */

:root {
  --navy:     #0B0E1A;
  --navy-2:   #111525;
  --navy-3:   #1A1F35;
  --navy-4:   #252B45;
  --blue:     #4F6EFF;
  --blue-2:   #3A55E0;
  --blue-glow:rgba(79,110,255,.2);
  --mint:     #00E5B4;
  --mint-dim: rgba(0,229,180,.12);
  --white:    #FFFFFF;
  --white-2:  rgba(255,255,255,.85);
  --white-3:  rgba(255,255,255,.5);
  --white-4:  rgba(255,255,255,.15);
  --white-5:  rgba(255,255,255,.06);

  --container: 1200px;
  --nav-h:     68px;
  --sp:        clamp(5rem,9vw,8rem);
  --ease:      cubic-bezier(0.16,1,0.3,1);
  --ease-sharp:cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;scroll-behavior:smooth}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  font-size:1rem;line-height:1.6;
  color:var(--white-2);
  background:var(--navy);
  overflow-x:hidden;
  cursor:none;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{background:none;border:none;font:inherit;cursor:none}

/* ── Custom Cursor ──────────────── */
.cursor{
  position:fixed;width:40px;height:40px;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:transform .08s linear;
  will-change:transform;
}
.cursor__inner{
  width:100%;height:100%;border-radius:50%;
  border:1.5px solid var(--blue);
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s;
}
body.hovered .cursor__inner{
  background:rgba(79,110,255,.15);
  border-color:var(--mint);
  width:100%;height:100%;
}

/* ── Wrap / Layout ──────────────── */
.wrap{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,5vw,3rem)}

/* ── Typography ─────────────────── */
h1,h2,h3,h4{
  font-family:'Space Grotesk',sans-serif;
  font-weight:700;
  line-height:1.0;
  letter-spacing:-.02em;
  color:var(--white);
}

.mono{font-family:'Space Mono',monospace;font-size:.72rem;letter-spacing:.06em}

.tag{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:'Space Mono',monospace;
  font-size:.65rem;font-weight:400;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--mint);padding:.25rem 0;
  margin-bottom:1.25rem;
}
.tag::before{content:'//';margin-right:.25rem;opacity:.5}

/* ── Buttons ─────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.875rem 2rem;border-radius:4px;
  font-family:'Space Grotesk',sans-serif;
  font-size:.875rem;font-weight:600;
  letter-spacing:.02em;
  transition:all .25s var(--ease);
  cursor:none;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;
  background:rgba(255,255,255,.08);opacity:0;
  transition:opacity .2s;
}
.btn:hover::before{opacity:1}

.btn--primary{
  background:var(--blue);color:var(--white);
  box-shadow:0 0 30px var(--blue-glow);
}
.btn--primary:hover{background:var(--blue-2);transform:translateY(-2px);box-shadow:0 0 50px rgba(79,110,255,.35)}

.btn--mint{
  background:var(--mint);color:var(--navy);
  font-weight:700;
}
.btn--mint:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(0,229,180,.3)}

.btn--outline{
  background:transparent;
  border:1px solid var(--white-4);
  color:var(--white-2);
}
.btn--outline:hover{border-color:var(--blue);color:var(--white);transform:translateY(-2px)}

.btn--lg{padding:1.1rem 2.5rem;font-size:1rem}

/* ═══════════════════════════════════════════════════════════════
   NAV
   ═══════════════════════════════════════════════════════════════ */
.nav{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);z-index:1000;
  display:flex;align-items:center;
  transition:background .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(11,14,26,.9);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-color:var(--white-4);
}
.nav__wrap{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:var(--container);
  margin:0 auto;padding:0 clamp(1.25rem,5vw,3rem);
  gap:2rem;
}
.nav__logo{
  display:flex;align-items:center;gap:.625rem;
  font-weight:700;font-size:1.1rem;
  color:var(--white);flex-shrink:0;
  letter-spacing:-.01em;
}
.nav__links{display:flex;align-items:center;gap:.125rem;flex:1;justify-content:center}
.nav__a{
  padding:.45rem .9rem;border-radius:4px;
  font-size:.84rem;font-weight:500;
  color:var(--white-3);
  transition:color .2s,background .2s;
  position:relative;
}
.nav__a::after{
  content:'';position:absolute;bottom:0;left:.9rem;right:.9rem;
  height:1px;background:var(--mint);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s var(--ease);
}
.nav__a:hover{color:var(--white)}
.nav__a:hover::after,.nav__a.active::after{transform:scaleX(1)}
.nav__a.active{color:var(--white)}

.nav__right{display:flex;align-items:center;gap:1rem;flex-shrink:0}
.nav__phone{
  display:flex;align-items:center;gap:.375rem;
  font-size:.8rem;font-weight:500;color:var(--white-3);
  transition:color .2s;
}
.nav__phone:hover{color:var(--mint)}
.nav__btn{
  padding:.5rem 1.25rem;background:var(--blue);
  color:var(--white);border-radius:4px;
  font-size:.8rem;font-weight:600;
  transition:background .2s,transform .2s;
  cursor:none;
}
.nav__btn:hover{background:var(--blue-2);transform:translateY(-1px)}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{display:block;width:22px;height:1.5px;background:var(--white);transition:transform .3s,opacity .3s}

.nav__mobile{
  display:none;position:fixed;inset:0;
  background:var(--navy);z-index:999;
  padding:calc(var(--nav-h) + 2rem) 2rem 2rem;
  flex-direction:column;gap:.5rem;
  transform:translateX(100%);transition:transform .4s var(--ease);
}
.nav__mobile.open{transform:translateX(0)}
.nav__mobile a{
  font-size:clamp(1.75rem,5vw,2.5rem);
  font-weight:700;color:var(--white-3);
  padding:.625rem 0;
  border-bottom:1px solid var(--white-4);
  transition:color .2s;display:block;
}
.nav__mobile a:hover{color:var(--mint)}
.nav__mobile-cta{
  margin-top:1.5rem;background:var(--blue);
  color:var(--white) !important;text-align:center;
  padding:1rem;border-radius:4px;
  border-bottom:none !important;font-size:1rem;
}

/* ═══════════════════════════════════════════════════════════════
   HERO — Asymmetric with floating number accent
   ═══════════════════════════════════════════════════════════════ */
.hero{
  min-height:100svh;
  padding-top:var(--nav-h);
  background:var(--navy);
  position:relative;
  overflow:hidden;
  display:flex;flex-direction:column;
}

/* Diagonal line decoration */
.hero::before{
  content:'';
  position:absolute;
  top:0;right:0;
  width:55%;height:100%;
  background:linear-gradient(135deg,transparent 50%,var(--navy-2) 50%);
  pointer-events:none;
}

/* Grid dots background */
.hero::after{
  content:'';
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(79,110,255,.15) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 80% at 80% 50%,black 20%,transparent 100%);
}

.hero__wrap{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  max-width:var(--container);
  width:100%;
  margin:0 auto;
  padding:0 clamp(1.25rem,5vw,3rem) clamp(2.5rem,5vw,4rem);
  position:relative;
  z-index:2;
}

/* Floating big number — bottom left, no layout impact */
.hero__bg-num{
  position:absolute;
  left:-1%;
  bottom:-2rem;
  font-family:'Space Mono',monospace;
  font-size:clamp(10rem,18vw,17rem);
  font-weight:700;
  color:rgba(79,110,255,.04);
  line-height:1;
  pointer-events:none;
  user-select:none;
  white-space:nowrap;
  letter-spacing:-.05em;
  z-index:0;
}

/* Status bar */
.hero__status{
  display:inline-flex;align-items:center;gap:.75rem;
  padding:.45rem .9rem;
  background:var(--white-5);
  border:1px solid var(--white-4);
  border-radius:4px;
  margin-bottom:1.5rem;
  width:fit-content;
}
.hero__status-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--mint);
  box-shadow:0 0 10px var(--mint);
  animation:glow 2s ease-in-out infinite;
}
@keyframes glow{0%,100%{box-shadow:0 0 6px var(--mint)}50%{box-shadow:0 0 18px var(--mint),0 0 30px rgba(0,229,180,.4)}}
.hero__status span{font-family:'Space Mono',monospace;font-size:.65rem;letter-spacing:.1em;color:var(--white-3)}

/* Main title */
.hero__title{
  font-size:clamp(3.5rem,9vw,8.5rem);
  font-weight:700;
  line-height:.92;
  letter-spacing:-.03em;
  color:var(--white);
  margin-bottom:2rem;
  max-width:14ch;
}
.hero__title .accent{
  color:transparent;
  -webkit-text-stroke:1.5px var(--blue);
}
.hero__title .hl{color:var(--mint)}
.hero__line{display:block;overflow:hidden}
.hero__word{display:inline-block}

/* Two-col bottom */
.hero__bottom{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(2rem,5vw,5rem);
  align-items:end;
  padding-top:clamp(2rem,4vw,3.5rem);
  border-top:1px solid var(--white-4);
}
.hero__desc{
  font-size:clamp(.95rem,1.5vw,1.1rem);
  color:var(--white-3);
  line-height:1.7;
  margin-bottom:2rem;
}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}

/* Stats on right */
.hero__metrics{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--white-4);
  border:1px solid var(--white-4);
  border-radius:4px;
  overflow:hidden;
}
.hero__metric{
  background:var(--navy-2);
  padding:1.25rem 1rem;
  text-align:center;
  transition:background .3s;
}
.hero__metric:hover{background:var(--navy-3)}
.hero__metric-val{
  font-family:'Space Mono',monospace;
  font-size:clamp(1.5rem,2.5vw,2rem);
  font-weight:700;
  color:var(--white);
  line-height:1;
  display:block;
}
.hero__metric-val span{color:var(--mint)}
.hero__metric-lbl{
  font-size:.65rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--white-3);
  margin-top:.375rem;display:block;
}

/* Ticker */
.hero__ticker{
  border-top:1px solid var(--white-4);
  height:38px;display:flex;align-items:center;
  overflow:hidden;background:var(--navy-2);
  position:relative;z-index:1;
}
.hero__ticker-inner{
  display:flex;white-space:nowrap;
  animation:tk 22s linear infinite;
}
@keyframes tk{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.hero__tick{
  display:inline-flex;align-items:center;gap:1rem;
  padding:0 1.5rem;
  font-family:'Space Mono',monospace;
  font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--white-3);
}
.hero__tick-dot{color:var(--mint);font-size:.4rem}

/* ═══════════════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════════════ */
.marquee{
  height:46px;display:flex;align-items:center;
  overflow:hidden;
  background:var(--blue);
  border-top:1px solid rgba(255,255,255,.1);
}
.marquee__track{
  display:flex;white-space:nowrap;
  animation:mq 20s linear infinite;
}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}
.marquee__item{
  display:inline-flex;align-items:center;gap:1.25rem;
  padding:0 2rem;
  font-family:'Space Grotesk',sans-serif;
  font-size:.75rem;font-weight:600;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.marquee__dot{color:var(--mint);font-size:.4rem}

/* ═══════════════════════════════════════════════════════════════
   SERVICES — Numbered list, NOT cards
   ═══════════════════════════════════════════════════════════════ */
.services{
  padding:var(--sp) 0;
  background:var(--navy);
  position:relative;
}
/* Side accent line */
.services::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;
  width:2px;
  background:linear-gradient(to bottom,transparent,var(--blue),transparent);
}

.services__hd{margin-bottom:clamp(3rem,6vw,5rem)}
.services__hd .tag{display:inline-flex}

.services__title{
  font-size:clamp(2.5rem,5vw,4.5rem);
  line-height:.95;letter-spacing:-.03em;
  color:var(--white);
  max-width:12ch;
}
.services__title em{
  font-style:normal;color:transparent;
  -webkit-text-stroke:1px var(--blue);
}

.services__layout{
  display:grid;
  grid-template-columns:1fr 2fr;
  gap:clamp(3rem,6vw,6rem);
  align-items:start;
}

.services__sidebar{position:sticky;top:calc(var(--nav-h) + 2rem)}

.services__intro{
  font-size:1rem;color:var(--white-3);
  line-height:1.7;margin-bottom:2rem;
}
.services__cta-note{
  font-family:'Space Mono',monospace;
  font-size:.7rem;color:var(--mint);
  line-height:1.5;
  padding:1rem;
  border:1px solid var(--mint-dim);
  border-left:2px solid var(--mint);
  border-radius:0 4px 4px 0;
}

.svc-list{}
.svc-item{
  display:flex;gap:1.5rem;
  padding:2rem 0;
  border-bottom:1px solid var(--white-4);
  transition:padding .3s var(--ease);
  cursor:default;
}
.svc-item:first-child{border-top:1px solid var(--white-4)}
.svc-item:hover{padding-left:.5rem}

.svc-item__num{
  font-family:'Space Mono',monospace;
  font-size:.75rem;color:var(--blue);
  padding-top:.2rem;
  flex-shrink:0;width:2.5rem;
  opacity:.6;
  transition:opacity .3s;
}
.svc-item:hover .svc-item__num{opacity:1}

.svc-item__body{flex:1}
.svc-item__head{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:.875rem;
}
.svc-item__icon{
  width:38px;height:38px;
  background:var(--navy-3);
  border:1px solid var(--white-4);
  border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);
  flex-shrink:0;
  transition:background .3s,border-color .3s,color .3s;
}
.svc-item:hover .svc-item__icon{background:var(--blue);border-color:var(--blue);color:var(--white)}

.svc-item__title{
  font-size:clamp(1.1rem,2vw,1.35rem);
  font-weight:700;color:var(--white);
  letter-spacing:-.01em;
}
.svc-item__desc{font-size:.9rem;color:var(--white-3);line-height:1.7;margin-bottom:1rem}
.svc-item__tags{display:flex;flex-wrap:wrap;gap:.375rem}
.svc-item__tag{
  padding:.2rem .7rem;
  background:var(--navy-3);
  border:1px solid var(--white-4);
  border-radius:2px;
  font-family:'Space Mono',monospace;
  font-size:.62rem;letter-spacing:.06em;
  color:var(--white-3);
  transition:border-color .2s,color .2s;
}
.svc-item:hover .svc-item__tag{border-color:var(--blue);color:var(--blue)}

/* ═══════════════════════════════════════════════════════════════
   ABOUT — Split with diagonal clip
   ═══════════════════════════════════════════════════════════════ */
.about{
  background:var(--navy-2);
  padding:var(--sp) 0;
  position:relative;
  clip-path:polygon(0 3%,100% 0,100% 97%,0 100%);
  margin:-3vw 0;
  padding-top:calc(var(--sp) + 3vw);
  padding-bottom:calc(var(--sp) + 3vw);
}

.about__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(3rem,7vw,7rem);
  align-items:center;
}

/* Visual: big number + decorative */
.about__visual{position:relative}
.about__big-num{
  font-family:'Space Mono',monospace;
  font-size:clamp(8rem,18vw,16rem);
  font-weight:700;
  line-height:1;
  color:transparent;
  -webkit-text-stroke:1px rgba(79,110,255,.3);
  letter-spacing:-.05em;
  user-select:none;
}
.about__big-label{
  position:absolute;
  top:40%;left:0;
  font-family:'Space Grotesk',sans-serif;
  font-size:clamp(1rem,2vw,1.5rem);
  font-weight:700;
  color:var(--white);
}
.about__big-label strong{
  display:block;
  font-size:clamp(3rem,5vw,4.5rem);
  color:var(--mint);
  line-height:1;
  letter-spacing:-.03em;
}

.about__stat-row{
  display:flex;gap:1.5rem;
  margin-top:2rem;
}
.about__stat-box{
  flex:1;padding:1.25rem;
  background:var(--navy-3);
  border:1px solid var(--white-4);
  border-radius:4px;
  text-align:center;
  transition:border-color .3s;
}
.about__stat-box:hover{border-color:var(--blue)}
.about__stat-box strong{
  display:block;
  font-family:'Space Mono',monospace;
  font-size:1.5rem;font-weight:700;
  color:var(--white);line-height:1;
}
.about__stat-box span{
  display:block;font-size:.65rem;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--white-3);margin-top:.25rem;
}

/* Content */
.about__tag{display:inline-flex}
.about__title{
  font-size:clamp(2rem,4vw,3.5rem);
  line-height:1.0;letter-spacing:-.02em;
  margin-bottom:1.5rem;
  color:var(--white);
}
.about__lead{
  font-size:1rem;color:var(--white-3);
  line-height:1.75;margin-bottom:2rem;
}
.about__points{
  display:flex;flex-direction:column;
  gap:.75rem;margin-bottom:2.5rem;
}
.about__point{
  display:flex;align-items:flex-start;gap:.875rem;
  padding:.875rem 1rem;
  background:var(--navy-3);
  border-left:2px solid var(--blue);
  border-radius:0 4px 4px 0;
  transition:border-color .3s,background .3s;
}
.about__point:hover{border-color:var(--mint);background:var(--navy-4)}
.about__point-bullet{
  width:20px;height:20px;
  background:var(--mint-dim);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:.1rem;
}
.about__point-bullet::before{
  content:'';width:6px;height:6px;
  border-radius:50%;background:var(--mint);
}
.about__point strong{display:block;font-size:.9rem;font-weight:600;color:var(--white);margin-bottom:.15rem}
.about__point p{font-size:.825rem;color:var(--white-3);margin:0}

/* ═══════════════════════════════════════════════════════════════
   PROCESS — Timeline horizontal
   ═══════════════════════════════════════════════════════════════ */
.process{
  padding:var(--sp) 0;
  background:var(--navy);
  position:relative;z-index:1;
}
.process__hd{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  gap:2rem;
  margin-bottom:clamp(3rem,6vw,5rem);
  flex-wrap:wrap;
}
.process__title{
  font-size:clamp(2.5rem,4.5vw,4rem);
  line-height:.95;letter-spacing:-.03em;
  color:var(--white);
}
.process__title em{font-style:normal;color:var(--blue)}
.process__sub{
  max-width:320px;font-size:.9rem;
  color:var(--white-3);line-height:1.65;
}

.process__steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  position:relative;
  gap:0;
}
/* Connecting line */
.process__steps::before{
  content:'';
  position:absolute;
  top:2.25rem;left:2.5rem;right:2.5rem;
  height:1px;
  background:linear-gradient(to right,var(--blue),rgba(79,110,255,.2));
  z-index:0;
}

.p-step{
  position:relative;z-index:1;
  padding:0 1.5rem 0 0;
}
.p-step__node{
  width:44px;height:44px;
  background:var(--navy);
  border:1px solid var(--blue);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem;
  transition:background .3s,box-shadow .3s;
  position:relative;
}
.p-step:hover .p-step__node{
  background:var(--blue);
  box-shadow:0 0 30px var(--blue-glow);
}
.p-step__icon{width:18px;height:18px;color:var(--blue);transition:color .3s}
.p-step:hover .p-step__icon{color:var(--white)}

.p-step__num{
  position:absolute;top:-8px;right:-8px;
  width:20px;height:20px;
  background:var(--mint);
  color:var(--navy);
  border-radius:50%;
  font-family:'Space Mono',monospace;
  font-size:.6rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}

.p-step h3{font-size:1rem;font-weight:600;color:var(--white);margin-bottom:.5rem;letter-spacing:-.01em}
.p-step p{font-size:.845rem;color:var(--white-3);line-height:1.65}

/* ═══════════════════════════════════════════════════════════════
   CLIENTS — Dark grid
   ═══════════════════════════════════════════════════════════════ */
.clients{
  padding:var(--sp) 0;
  background:var(--navy-2);
}
.clients__hd{
  display:flex;align-items:flex-end;
  justify-content:space-between;
  gap:2rem;
  margin-bottom:clamp(2.5rem,5vw,4rem);
  flex-wrap:wrap;
}
.clients__title{
  font-size:clamp(2rem,4vw,3.5rem);
  line-height:.95;letter-spacing:-.03em;color:var(--white);
}

.logo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--white-4);
  border:1px solid var(--white-4);
  border-radius:4px;
  overflow:hidden;
  margin-bottom:clamp(3rem,5vw,4rem);
}
.logo-cell{
  background:var(--navy-2);
  padding:2rem 1.5rem;
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  transition:background .3s;
}
.logo-cell:hover{background:var(--navy-3)}
.logo-cell__mark{
  font-family:'Space Mono',monospace;
  font-size:1.25rem;font-weight:700;
  color:var(--navy-4);
  transition:color .3s;
}
.logo-cell:hover .logo-cell__mark{color:var(--blue)}
.logo-cell__name{font-size:.68rem;color:var(--white-3);text-align:center;letter-spacing:.04em}

.kpi-row{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--white-4);
  border:1px solid var(--white-4);border-radius:4px;overflow:hidden;
}
.kpi-cell{
  background:var(--navy-2);padding:2rem 1.5rem;
  text-align:center;transition:background .3s;
  position:relative;overflow:hidden;
}
.kpi-cell::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--blue-glow),transparent);
  opacity:0;transition:opacity .4s;
}
.kpi-cell:hover{background:var(--navy-3)}
.kpi-cell:hover::before{opacity:1}
.kpi-val{
  font-family:'Space Mono',monospace;
  font-size:clamp(1.75rem,3vw,2.5rem);font-weight:700;
  color:var(--white);line-height:1;display:block;
  position:relative;
}
.kpi-val span{color:var(--mint)}
.kpi-lbl{
  font-size:.65rem;text-transform:uppercase;
  letter-spacing:.12em;color:var(--white-3);
  margin-top:.5rem;display:block;position:relative;
}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS
   ═══════════════════════════════════════════════════════════════ */
.testimonials{padding:var(--sp) 0;background:var(--navy)}
.testimonials__hd{margin-bottom:clamp(2.5rem,5vw,4rem)}

.testi-wrap{overflow:hidden}
.testi-track{display:flex;gap:1.5rem;transition:transform .65s var(--ease)}
.testi-card{
  flex:0 0 calc(50% - .75rem);
  background:var(--navy-2);
  border:1px solid var(--white-4);
  border-radius:4px;
  padding:clamp(1.75rem,3.5vw,2.5rem);
  transition:border-color .3s,transform .3s var(--ease);
  position:relative;
  overflow:hidden;
}
.testi-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(to right,var(--blue),var(--mint));
  opacity:0;transition:opacity .4s;
}
.testi-card:hover{border-color:var(--blue);transform:translateY(-4px)}
.testi-card:hover::before{opacity:1}

.testi-card__quote{
  font-size:2rem;color:var(--blue);
  font-family:'Space Mono',monospace;
  line-height:1;margin-bottom:.75rem;
}
.testi-card__text{
  font-size:clamp(.875rem,1.5vw,1rem);
  color:var(--white-2);line-height:1.75;
  margin-bottom:1.75rem;
}
.testi-card__author{display:flex;align-items:center;gap:.875rem}
.testi-card__avatar{
  width:40px;height:40px;
  background:var(--blue);border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Space Mono',monospace;font-weight:700;
  font-size:.75rem;color:var(--white);flex-shrink:0;
}
.testi-card__name{display:block;font-size:.875rem;font-weight:600;color:var(--white)}
.testi-card__role{display:block;font-size:.75rem;color:var(--white-3)}
.testi-card__stars{
  display:flex;gap:.2rem;margin-bottom:1rem;
}
.testi-card__stars span{color:var(--mint);font-size:.8rem}

.testi-controls{
  display:flex;align-items:center;gap:1rem;
  margin-top:2rem;justify-content:flex-start;
}
.testi-btn{
  width:40px;height:40px;
  border:1px solid var(--white-4);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  color:var(--white-3);transition:all .2s;cursor:none;
}
.testi-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-glow)}
.testi-dots{display:flex;gap:.5rem}
.testi-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--white-4);transition:all .3s;cursor:none;
}
.testi-dot.active{width:24px;border-radius:2px;background:var(--mint)}

/* ═══════════════════════════════════════════════════════════════
   CTA — Full bleed dark
   ═══════════════════════════════════════════════════════════════ */
.cta-band{
  background:var(--navy-2);
  padding:var(--sp) 0;
  position:relative;overflow:hidden;
  border-top:1px solid var(--white-4);
}
.cta-band::after{
  content:'LEPIXO';
  position:absolute;
  right:-2rem;bottom:-1rem;
  font-family:'Space Mono',monospace;
  font-size:clamp(10rem,22vw,20rem);
  font-weight:700;
  color:rgba(79,110,255,.04);
  line-height:1;
  pointer-events:none;user-select:none;
  letter-spacing:-.05em;
}

.cta-band__inner{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(3rem,6vw,6rem);
  align-items:center;
}

.cta-band__left .tag{display:inline-flex}
.cta-band__title{
  font-size:clamp(2rem,4.5vw,4rem);
  line-height:.95;letter-spacing:-.03em;
  color:var(--white);
  margin-bottom:1.25rem;
}
.cta-band__title em{font-style:normal;color:var(--mint)}
.cta-band__desc{font-size:.95rem;color:var(--white-3);line-height:1.7;margin-bottom:2rem}
.cta-band__actions{display:flex;gap:1rem;flex-wrap:wrap}

.cta-band__right{
  display:flex;flex-direction:column;gap:1rem;
}
.cta-info{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1.25rem;
  background:var(--navy-3);
  border:1px solid var(--white-4);
  border-radius:4px;
  transition:border-color .3s;
}
.cta-info:hover{border-color:var(--blue)}
.cta-info__icon{
  width:36px;height:36px;
  background:var(--blue-glow);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  color:var(--blue);flex-shrink:0;
}
.cta-info__icon svg{width:16px;height:16px}
.cta-info__title{font-size:.75rem;font-weight:600;color:var(--white-3);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:.2rem}
.cta-info__val{font-size:.95rem;font-weight:600;color:var(--white)}
.cta-info__val a{transition:color .2s}
.cta-info__val a:hover{color:var(--mint)}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.site-footer{background:var(--navy);border-top:1px solid var(--white-4)}
.site-footer__top{
  display:grid;grid-template-columns:1fr 2fr;
  gap:clamp(3rem,6vw,6rem);
  padding:clamp(3rem,6vw,5rem) clamp(1.25rem,5vw,3rem);
  max-width:var(--container);margin:0 auto;
  border-bottom:1px solid var(--white-4);
}
.site-footer__logo{
  display:flex;align-items:center;gap:.625rem;
  font-weight:700;font-size:1.1rem;
  color:var(--white);margin-bottom:1.25rem;
}
.site-footer__brand p{font-size:.875rem;color:var(--white-3);max-width:260px;line-height:1.65;margin-bottom:1.5rem}
.site-footer__socials{display:flex;gap:.75rem}
.site-footer__socials a{
  width:34px;height:34px;
  background:var(--navy-3);border:1px solid var(--white-4);
  border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:600;color:var(--white-3);
  transition:all .2s;
}
.site-footer__socials a:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-glow)}
.site-footer__nav{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.site-footer__nav h5{
  font-family:'Space Mono',monospace;
  font-size:.65rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;
  color:var(--mint);margin-bottom:1.25rem;
}
.site-footer__nav a,.site-footer__nav span{
  display:block;font-size:.875rem;
  color:var(--white-3);margin-bottom:.5rem;transition:color .2s;
}
.site-footer__nav a:hover{color:var(--white)}
.site-footer__bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.25rem clamp(1.25rem,5vw,3rem);
  max-width:var(--container);margin:0 auto;
  font-size:.8rem;color:var(--white-3);
}


/* ═══════════════════════════════════════════════════════════════
   BRAIN 3D — FIXED CANVAS (follows scroll across all sections)
   ═══════════════════════════════════════════════════════════════ */

/* Brain canvas is created by JS as fixed overlay — z-index 0 */
#brainCanvas {
  position: fixed !important;
  inset: 0 !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

/* All sections sit above the brain */
.nav        { z-index: 1000; }
.hero       { z-index: 1; background: transparent; position: relative; }
.marquee-band { z-index: 1; position: relative; }
.services, .about, .process, .clients, .testimonials, .cta-band { position: relative; z-index: 1; }
.site-footer  { position: relative; z-index: 1; }

/* Sections have semi-transparent bg so brain glows through subtly */
.services    { background: rgba(11,14,26,0.96) !important; }
.about       { background: rgba(17,21,37,0.97) !important; }
.process     { background: rgba(11,14,26,0.96) !important; }
.clients     { background: rgba(17,21,37,0.96) !important; }
.testimonials{ background: rgba(11,14,26,0.96) !important; }
.cta-band    { background: rgba(17,21,37,0.98) !important; }

/* Hero: no background so brain shows fully */
.hero { background: transparent !important; }
.hero::before, .hero::after { display: none !important; }

/* Hero text z-index above brain */
.hero__bg-num, .hero__wrap, .hero__ticker { z-index: 2; position: relative; }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .services__layout{grid-template-columns:1fr}
  .services__sidebar{position:static}
  .about__grid{grid-template-columns:1fr}
  .process__steps{grid-template-columns:repeat(2,1fr)}
  .process__steps::before{display:none}
  .cta-band__inner{grid-template-columns:1fr}
  .testi-card{flex:0 0 100%}
}
@media(max-width:768px){
  :root{--sp:4rem}
  body{cursor:auto}
  .cursor{display:none}
  button,a{cursor:pointer}
  .nav__links,.nav__right{display:none}
  .nav__burger{display:flex}
  .nav__mobile{display:flex}
  .hero::before{display:none}
  .hero__bottom{grid-template-columns:1fr}
  .hero__metrics{grid-template-columns:repeat(3,1fr)}
  .about__grid{grid-template-columns:1fr}
  .about__big-num{font-size:8rem}
  .process__steps{grid-template-columns:1fr 1fr}
  .logo-grid{grid-template-columns:repeat(2,1fr)}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
  .site-footer__top{grid-template-columns:1fr}
  .site-footer__nav{grid-template-columns:1fr 1fr}
  .site-footer__bottom{flex-direction:column;gap:.75rem;text-align:center}
  .about{clip-path:none;margin:0;padding:var(--sp) 0}
}
@media(max-width:480px){
  .process__steps{grid-template-columns:1fr}
  .kpi-row{grid-template-columns:1fr 1fr}
  .hero__metrics{grid-template-columns:1fr 1fr 1fr}
  .site-footer__nav{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none !important;transition-duration:.01ms !important}}
:focus-visible{outline:2px solid var(--mint);outline-offset:3px;border-radius:2px}

/* ── Contact page spacing ────────── */
.contact-page-spacer {
  height: clamp(4rem, 8vw, 7rem);
  background: var(--navy);
}

/* ── Section bottom gap before footer ── */
main > section:last-of-type,
main > .cta-band {
  margin-bottom: 0;
}

/* Ensure footer has top border separation */
.site-footer {
  margin-top: 0;
  border-top: 1px solid var(--white-4);
}

/* ── Form input placeholder color fix ── */
input::placeholder,
textarea::placeholder {
  color: rgba(255,255,255,.2) !important;
  font-family: 'Space Grotesk', sans-serif;
}
input:focus, textarea:focus {
  border-color: var(--blue) !important;
  box-shadow: 0 0 0 3px rgba(79,110,255,.12);
}

/* ── Contact page button explicit styles ── */
.contact-submit-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .625rem !important;
  width: 100% !important;
  padding: 1.05rem 2.5rem !important;
  background: var(--blue) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 4px !important;
  font-family: 'Space Grotesk', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background .2s, transform .2s, box-shadow .2s !important;
  box-shadow: 0 0 30px rgba(79,110,255,.3) !important;
}
.contact-submit-btn:hover {
  background: var(--blue-2) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 0 50px rgba(79,110,255,.45) !important;
}
.contact-submit-btn svg path { stroke: #ffffff !important; }

/* Brain canvas — pointer cursor to invite clicks */
#heroCanvas { cursor: crosshair; }

/* ── Client logo images ──────────────── */
.logo-cell__img {
  max-height: 48px;
  max-width: 140px;
  object-fit: contain;
  opacity: 0.7;
  filter: grayscale(30%);
  transition: opacity .3s, filter .3s;
}
.logo-cell:hover .logo-cell__img {
  opacity: 1;
  filter: grayscale(0%);
}

/* ── Clients Carousel ─────────────────────────────────────── */
.clients-carousel {
  position: relative;
  overflow: hidden;
  margin-bottom: clamp(3rem, 6vw, 5rem);
  border-top: 1px solid var(--white-4);
  border-bottom: 1px solid var(--white-4);
  mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 6%, black 94%, transparent 100%);
}

.clients-carousel:hover .clients-carousel__track {
  animation-play-state: paused;
}

.clients-carousel__track {
  display: flex;
  align-items: center;
  animation: clientsScroll 28s linear infinite;
  width: max-content;
}

@keyframes clientsScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-33.333%); }
}

.clients-carousel__item {
  flex-shrink: 0;
  width: 155px;
  height: 150px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 1.75rem;
  border-right: 1px solid var(--white-4);
  transition: background .3s;
}

.clients-carousel__item:hover { background: var(--navy-3); }

.clients-carousel__img {
  max-height: 150px;
  max-width: 150px;
  object-fit: contain;
  opacity: 0.6;
  filter: grayscale(15%);
  transition: opacity .3s, filter .3s;
  display: block;
}

.clients-carousel__item:hover .clients-carousel__img {
  opacity: 1;
  filter: grayscale(0%) drop-shadow(0 0 8px rgba(79,110,255,.4));
}

/* Fallback when no logo uploaded yet */
.clients-carousel__fallback {
  font-family: 'Space Mono', monospace;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: rgba(255,255,255,.18);
  text-transform: uppercase;
  transition: color .3s;
  white-space: nowrap;
}

.clients-carousel__item:hover .clients-carousel__fallback {
  color: var(--blue);
}

/* ── Partners Section ──────────────────────────────────── */
.partners {
  padding: var(--sp) 0;
  background: var(--navy-2);
  border-top: 1px solid var(--white-4);
  border-bottom: 1px solid var(--white-4);
}

.partners-row {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
}

.partner-item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 90px;
  padding: 1.5rem 2rem;
  border-right: 1px solid var(--white-4);
  border-bottom: 1px solid var(--white-4);
  transition: background .3s;
  text-decoration: none;
}
.partner-item:last-child { border-right: none; }
.partner-item:hover { background: var(--navy-3); }

.partner-img {
  max-height: 46px;
  max-width: 140px;
  object-fit: contain;
  opacity: 0.6;
  filter: grayscale(10%);
  transition: opacity .3s, filter .3s;
}
.partner-item:hover .partner-img {
  opacity: 1;
  filter: grayscale(0%);
}

.partner-fallback {
  font-family: 'Space Mono', monospace;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  color: rgba(255,255,255,.2);
  text-transform: uppercase;
}
.partner-item:hover .partner-fallback { color: var(--blue); }

@media(max-width:768px) {
  .partner-item { width: 50%; }
  .partner-item:nth-child(2n) { border-right: none; }
}
