/* =========================================================
   TOKENS
========================================================= */
:root{
  --ink:#0B1130;
  --indigo:#121B45;
  --blue:#3357FF;
  --blue-2:#5B7CFF;
  --purple:#7C3AED;
  --purple-2:#A78BFA;
  --cloud:#F6F7FC;
  --white:#FFFFFF;
  --slate:#5B6584;
  --slate-dark:#3A4262;
  --line:#E4E7F3;
  --line-dark:#26305E;
  --green:#19C37D;
  --amber:#FFB020;

  --grad-1: linear-gradient(135deg,var(--blue) 0%, var(--purple) 100%);
  --grad-2: linear-gradient(135deg,#5B7CFF 0%, #9B6BFF 100%);
  --grad-soft: linear-gradient(180deg, rgba(91,124,255,.08), rgba(124,58,237,.04));

  --shadow-sm: 0 2px 10px rgba(18,27,69,.06);
  --shadow-md: 0 10px 30px rgba(18,27,69,.10);
  --shadow-lg: 0 24px 60px rgba(18,27,69,.16);

  --radius: 18px;
  --radius-sm: 10px;
  --container: 1180px;

  --font-display:'Space Grotesk', sans-serif;
  --font-body:'Inter', sans-serif;
  --font-mono:'JetBrains Mono', monospace;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  color:var(--slate-dark);
  background:var(--cloud);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
.container{max-width:var(--container);margin:0 auto;padding:0 24px;}
section{position:relative;}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.18;letter-spacing:-0.01em;}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:4px;}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.001ms !important; transition-duration:0.001ms !important;}
  html{scroll-behavior:auto;}
}

/* =========================================================
   UTILITIES
========================================================= */
.eyebrow{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  letter-spacing:.02em;
  color:var(--purple);
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-bottom:14px;
}
.eyebrow::before{content:"//";color:var(--blue-2);font-weight:600;}
.eyebrow.on-dark{color:var(--purple-2);}
.eyebrow.on-dark::before{color:#7E97FF;}

.section-head{max-width:640px;margin-bottom:56px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(28px,3.6vw,42px);margin-bottom:14px;}
.section-head p{color:var(--slate);font-size:16.5px;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 30px;border-radius:999px;font-weight:600;font-size:15px;
  font-family:var(--font-body);transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  white-space:nowrap;
}
.btn-primary{background:var(--grad-1);color:#fff;box-shadow:0 10px 24px rgba(91,69,237,.32);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(91,69,237,.42);}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line);}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-3px);}
.btn-ghost.on-dark{background:transparent;color:#fff;border-color:rgba(255,255,255,.28);}
.btn-ghost.on-dark:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-sm{padding:11px 22px;font-size:13.5px;}
.btn-block{width:100%;}

.tag{
  font-family:var(--font-mono);font-size:11.5px;font-weight:500;color:var(--blue);
  background:rgba(51,87,255,.08);border:1px solid rgba(51,87,255,.18);
  padding:5px 11px;border-radius:7px;display:inline-flex;align-items:center;gap:6px;
}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:translateY(0);}
.stagger > *{transition-delay:calc(var(--i,0) * 80ms);}

.blob{
  position:absolute;border-radius:50%;
  background:var(--grad-1);filter:blur(70px);opacity:.18;pointer-events:none;
}

/* =========================================================
   FLOATING BUTTONS
========================================================= */
.float-stack{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;flex-direction:column;gap:14px;align-items:center;}
.fab{
  width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:22px;box-shadow:var(--shadow-md);transition:transform .25s ease, box-shadow .25s ease;
}
.fab:hover{transform:translateY(-4px) scale(1.05);}
.fab-whatsapp{background:#21C463;}
.fab-call{background:var(--grad-1);display:none;}
.fab-top{
  width:46px;height:46px;background:#fff;color:var(--ink);border:1px solid var(--line);
  opacity:0;pointer-events:none;transform:translateY(10px);
}
.fab-top.show{opacity:1;pointer-events:auto;transform:translateY(0);}
@media (max-width:640px){.fab-call{display:flex;}}

/* =========================================================
   HEADER
========================================================= */
header{
  position:fixed;top:0;left:0;right:0;z-index:70;
  background:rgba(246,247,252,.7);
  backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:background .35s ease, border-color .35s ease, padding .35s ease;
  padding:20px 0;
}
header.scrolled{background:rgba(255,255,255,.88);border-bottom-color:var(--line);padding:13px 0;box-shadow:0 4px 24px rgba(18,27,69,.06);}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;}

.logo{display:flex;align-items:center;gap:11px;}
.logo-mark{
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  background:transparent;box-shadow:none;
}
.logo-mark img{
  width:150px;
  height:100%;
  object-fit:contain;
  display:block;
}
.logo-text{display:flex;flex-direction:column;line-height:1.1;}
.logo-text strong{font-family:var(--font-display);font-size:18px;color:var(--ink);font-weight:700;letter-spacing:-.01em;}
.logo-text span{font-size:10.5px;color:var(--slate);letter-spacing:.04em;font-weight:500;}

.nav-links{display:flex;align-items:center;gap:34px;}
.nav-links a{font-size:14.5px;font-weight:500;color:var(--slate-dark);position:relative;padding:4px 0;transition:color .2s;}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--grad-1);transition:width .25s ease;border-radius:2px;}
.nav-links a:hover{color:var(--ink);}
.nav-links a:hover::after{width:100%;}

.nav-cta{display:flex;align-items:center;gap:18px;}
.nav-cta .phone-pill{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:var(--ink);}
.nav-cta .phone-pill i{color:var(--blue);}
.hamburger{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;}
.hamburger span,.hamburger span::before,.hamburger span::after{content:"";display:block;width:18px;height:2px;background:var(--ink);position:relative;transition:.25s;}
.hamburger span::before{position:absolute;top:-6px;}
.hamburger span::after{position:absolute;top:6px;}
.hamburger.active span{background:transparent;}
.hamburger.active span::before{transform:rotate(45deg);top:0;}
.hamburger.active span::after{transform:rotate(-45deg);top:0;}

@media (max-width:920px){
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:min(78vw,320px);background:#fff;
    flex-direction:column;justify-content:flex-start;align-items:flex-start;padding:100px 32px 32px;
    gap:26px;transform:translateX(100%);transition:transform .35s ease;box-shadow:-12px 0 40px rgba(18,27,69,.12);}
  .nav-links.active{transform:translateX(0);}
  .nav-cta .phone-pill{display:none;}
  .hamburger{display:flex;}
}

/* =========================================================
   HERO
========================================================= */
.hero{padding:168px 0 100px;overflow:hidden;background:var(--cloud);}
.hero .blob.b1{width:480px;height:480px;top:-180px;right:-160px;}
.hero .blob.b2{width:340px;height:340px;bottom:-160px;left:-140px;background:var(--grad-2);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;}
.hero-copy h1{font-size:clamp(34px,4.6vw,56px);margin-bottom:22px;}
.hero-copy h1 .accent{background:var(--grad-1);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero-copy p.lead{font-size:17.5px;color:var(--slate);max-width:520px;margin-bottom:34px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:42px;}
.hero-trust{display:flex;gap:24px;flex-wrap:wrap;}
.hero-trust .trust-item{display:flex;align-items:center;gap:11px;}
.hero-trust-icon{width:38px;height:38px;border-radius:11px;background:var(--grad-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.hero-trust-text{display:flex;flex-direction:column;}
.hero-trust strong{font-family:var(--font-display);font-size:22px;color:var(--ink);}
.hero-trust span{font-size:12px;color:var(--slate);font-weight:500;}

/* code editor signature visual */
.hero-visual{position:relative;}
.code-card{
  background:var(--ink);border-radius:18px;box-shadow:var(--shadow-lg);
  overflow:hidden;border:1px solid #232c5c;
  transform:rotate(1.2deg);
}
.float-badge{
  position:absolute;display:flex;align-items:center;gap:9px;z-index:3;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:10px 15px;box-shadow:var(--shadow-md);font-size:13px;font-weight:600;color:var(--ink);
  animation:floatY 4.5s ease-in-out infinite;
}
.float-badge i{font-size:17px;}
.float-badge.b-react{top:-20px;left:-26px;animation-delay:0s;}
.float-badge.b-react i{color:#61DAFB;}
.float-badge.b-node{top:46%;right:-30px;animation-delay:1.2s;}
.float-badge.b-node i{color:#3C873A;}
.float-badge.b-aws{bottom:-20px;left:36px;animation-delay:2.3s;}
.float-badge.b-aws i{color:#FF9900;}
@keyframes floatY{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}
@media (max-width:1080px){.float-badge{display:none;}}
.code-tabbar{display:flex;align-items:center;gap:10px;padding:14px 18px;background:#0E1538;border-bottom:1px solid #232c5c;}
.code-dots{display:flex;gap:7px;}
.code-dots span{width:11px;height:11px;border-radius:50%;}
.code-dots span:nth-child(1){background:#FF6259;}
.code-dots span:nth-child(2){background:#FFBD2E;}
.code-dots span:nth-child(3){background:#28C940;}
.code-tabs{display:flex;gap:6px;margin-left:10px;font-family:var(--font-mono);font-size:11.5px;}
.code-tabs span{padding:5px 12px;border-radius:6px 6px 0 0;color:#8B96CC;}
.code-tabs span.active{background:#1A2358;color:#C7D2FF;}
.code-body{display:flex;font-family:var(--font-mono);font-size:13.2px;line-height:1.9;padding:22px 0;}
.code-lines{padding:0 16px;color:#3E4A85;text-align:right;user-select:none;}
.code-content{padding-right:22px;white-space:pre;color:#C7D2FF;}
.code-content .c1{color:#7E97FF;}
.code-content .c2{color:#A78BFA;}
.code-content .c3{color:#5FE3A1;}
.code-content .c4{color:#FFB020;}
.code-content .c5{color:#8B96CC;}
.cursor-blink{display:inline-block;width:7px;height:15px;background:#A78BFA;margin-left:3px;animation:blink 1s step-end infinite;vertical-align:-2px;}
@keyframes blink{50%{opacity:0;}}
.code-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 18px;background:#0E1538;border-top:1px solid #232c5c;font-family:var(--font-mono);font-size:11px;color:#5C6BA8;}
.code-footer .ok{color:#5FE3A1;}

@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;}
  .hero{padding:140px 0 70px;}
  .code-card{transform:none;}
}

/* =========================================================
   ABOUT
========================================================= */
.about{padding:100px 0;background:#fff;}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center;}
.about-visual{position:relative;}
.about-img-main{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5;background:var(--grad-soft);position:relative;}
.about-img-main img{width:100%;height:100%;object-fit:cover;}
.about-img-main .img-fallback-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--purple-2);background:var(--grad-soft);}
.about-img-sub{
  position:absolute;top:-22px;right:-30px;width:42%;aspect-ratio:1/1;border-radius:14px;overflow:hidden;
  border:5px solid #fff;box-shadow:var(--shadow-lg);background:var(--grad-soft);z-index:2;
}
.about-img-sub img{width:100%;height:100%;object-fit:cover;}
.about-img-sub .img-fallback-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--purple-2);background:var(--grad-soft);}
.about-float-card{
  position:absolute;bottom:-26px;right:-26px;background:#fff;border-radius:16px;padding:18px 22px;
  box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:14px;border:1px solid var(--line);
}
.about-float-card i{font-size:26px;color:var(--green);}
.about-float-card strong{display:block;font-family:var(--font-display);font-size:20px;color:var(--ink);}
.about-float-card span{font-size:11.5px;color:var(--slate);}
.about-body p{color:var(--slate);font-size:16px;margin-bottom:26px;}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:32px;}
.stat-card{background:var(--cloud);border-radius:14px;padding:20px 16px;border:1px solid var(--line);text-align:left;}
.stat-card i{font-size:16px;color:var(--blue);margin-bottom:9px;display:block;}
.stat-card strong{font-family:var(--font-display);font-size:clamp(22px,2.6vw,30px);color:var(--ink);display:block;}
.stat-card strong::after{content:"+";color:var(--blue);}
.stat-card span{font-size:12px;color:var(--slate);font-weight:500;}
.about-points{display:flex;flex-direction:column;gap:14px;margin-bottom:32px;}
.about-points li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--slate-dark);}
.about-points i{color:var(--blue);margin-top:3px;}
@media (max-width:980px){.about-grid{grid-template-columns:1fr;}.about-visual{max-width:380px;margin:0 auto 20px;}}
@media (max-width:560px){.about-stats{grid-template-columns:repeat(2,1fr);}.about-img-sub{top:-14px;right:-14px;width:38%;}.about-float-card{right:-10px;padding:14px 16px;}}

/* =========================================================
   SERVICES
========================================================= */
.services{padding:100px 0;background:var(--cloud);}
.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.service-card{
  background:#fff;border-radius:var(--radius);border:1px solid var(--line);
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;position:relative;overflow:hidden;
}
.service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-1);transform:scaleX(0);transform-origin:left;transition:transform .35s ease;z-index:3;}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent;}
.service-card:hover::before{transform:scaleX(1);}
.service-media{position:relative;aspect-ratio:16/10;background:var(--grad-soft);overflow:hidden;}
.service-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.service-card:hover .service-media img{transform:scale(1.08);}
.service-media .img-fallback-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:34px;color:var(--purple-2);}
.service-num{font-family:var(--font-mono);font-size:11px;color:#fff;background:rgba(11,17,48,.6);padding:4px 10px;border-radius:7px;position:absolute;top:14px;right:14px;z-index:2;}
.service-icon{width:56px;height:56px;border-radius:14px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:23px;color:var(--blue);box-shadow:var(--shadow-md);margin:-28px 0 0 24px;position:relative;z-index:2;}
.service-body{padding:18px 28px 30px;}
.service-card h3{font-size:19px;margin-bottom:10px;}
.service-card p{font-size:14.5px;color:var(--slate);margin-bottom:18px;}
.service-link{font-size:13.5px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:7px;}
.service-link i{transition:transform .2s;font-size:11px;}
.service-card:hover .service-link i{transform:translateX(4px);}
@media (max-width:980px){.service-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.service-grid{grid-template-columns:1fr;}}

/* =========================================================
   WHY CHOOSE US
========================================================= */
.why{padding:100px 0;background:var(--ink);position:relative;overflow:hidden;color:#fff;}
.why .blob{opacity:.28;}
.why .blob.w1{width:420px;height:420px;top:-200px;left:10%;}
.why .blob.w2{width:380px;height:380px;bottom:-200px;right:5%;background:var(--grad-2);}
.why .section-head h2{color:#fff;}
.why .section-head p{color:#A7B0DD;}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative;z-index:1;}
.why-card{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:26px 22px;
  transition:transform .3s ease, background .3s ease;
}
.why-card:hover{transform:translateY(-6px);background:rgba(255,255,255,.08);}
.why-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:19px;}
.why-icon.c-blue{background:rgba(91,124,255,.18);color:#8FA6FF;}
.why-icon.c-purple{background:rgba(167,139,250,.2);color:#C7B6FF;}
.why-icon.c-green{background:rgba(95,227,161,.18);color:#5FE3A1;}
.why-icon.c-amber{background:rgba(255,176,32,.18);color:#FFB020;}
.why-card h4{color:#fff;font-size:16px;margin-bottom:8px;font-family:var(--font-display);}
.why-card p{font-size:13px;color:#A7B0DD;}
@media (max-width:980px){.why-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.why-grid{grid-template-columns:1fr;}}

/* =========================================================
   INDUSTRIES
========================================================= */
.industries{padding:100px 0;background:#fff;}
.industry-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.industry-card{
  text-align:center;padding:32px 16px;border-radius:16px;background:var(--cloud);border:1px solid var(--line);
  transition:transform .3s ease, box-shadow .3s ease, background .3s ease;
}
.industry-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);background:#fff;}
.industry-icon{width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:22px;color:#fff;}
.industry-icon.g1{background:linear-gradient(135deg,#3357FF,#5B7CFF);}
.industry-icon.g2{background:linear-gradient(135deg,#7C3AED,#A78BFA);}
.industry-icon.g3{background:linear-gradient(135deg,#19C37D,#5FE3A1);}
.industry-icon.g4{background:linear-gradient(135deg,#FFB020,#FFCB6B);}
.industry-card span{font-size:14.5px;font-weight:600;color:var(--ink);}
@media (max-width:900px){.industry-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:600px){.industry-grid{grid-template-columns:repeat(2,1fr);}}

/* =========================================================
   PORTFOLIO
========================================================= */
.portfolio{padding:100px 0;background:var(--cloud);}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.project-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);transition:transform .3s ease, box-shadow .3s ease;}
.project-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);}
.project-media{position:relative;aspect-ratio:4/3;background:var(--grad-soft);overflow:hidden;}
.project-media .img-fallback-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:40px;color:var(--purple-2);}
.project-media img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.project-card:hover .project-media img{transform:scale(1.08);}
.project-media::after{
  content:"\f06e";font-family:"Font Awesome 6 Free";font-weight:900;
  position:absolute;inset:0;z-index:2;display:flex;align-items:center;justify-content:center;
  font-size:19px;color:#fff;background:rgba(11,17,48,0);opacity:0;
  transition:opacity .3s ease, background .3s ease;
}
.project-card:hover .project-media::after{opacity:1;background:rgba(11,17,48,.42);}
.project-cat{position:absolute;top:14px;left:14px;z-index:3;background:rgba(11,17,48,.78);color:#fff;font-family:var(--font-mono);font-size:11px;padding:5px 11px;border-radius:7px;}
.project-body{padding:24px;}
.project-body h3{font-size:18px;margin-bottom:8px;}
.project-body p{font-size:14px;color:var(--slate);margin-bottom:16px;}
.project-tags{display:flex;gap:8px;flex-wrap:wrap;}
@media (max-width:980px){.portfolio-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:640px){.portfolio-grid{grid-template-columns:1fr;}}

/* =========================================================
   DIRECTOR
========================================================= */
.director{padding:100px 0;background:#fff;}
.director-grid{display:grid;grid-template-columns:.55fr 1.45fr;gap:60px;align-items:center;}
.director-photo-wrap{position:relative;}
.director-photo{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-md);background:var(--grad-soft);position:relative;}
.director-photo img{width:100%;height:100%;object-fit:cover;}
.director-photo .img-fallback-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:54px;color:var(--purple-2);}
.director-quote-mark{position:absolute;top:-18px;left:-18px;width:52px;height:52px;border-radius:50%;background:var(--grad-1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:var(--shadow-md);}
.director-copy blockquote{font-size:clamp(18px,2vw,22px);color:var(--ink);font-family:var(--font-display);font-weight:500;line-height:1.5;margin-bottom:28px;}
.director-sign{display:flex;align-items:center;gap:18px;}
.signature-graphic{font-family:'Space Grotesk',cursive;font-size:30px;font-style:italic;color:var(--purple);font-weight:600;letter-spacing:.01em;}
.director-name strong{display:block;font-family:var(--font-display);font-size:16.5px;color:var(--ink);}
.director-name span{font-size:13px;color:var(--slate);}
.director-social{display:flex;gap:10px;margin-left:auto;}
.director-social a{width:38px;height:38px;border-radius:50%;background:var(--cloud);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:.25s;}
.director-social a:hover{background:var(--grad-1);color:#fff;border-color:transparent;transform:translateY(-3px);}
@media (max-width:900px){.director-grid{grid-template-columns:1fr;}.director-photo-wrap{max-width:280px;margin:0 auto;}.director-sign{flex-wrap:wrap;}.director-social{margin-left:0;}}

/* =========================================================
   TESTIMONIALS
========================================================= */
.testimonials{padding:100px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden;}
.testimonials .blob{opacity:.22;width:420px;height:420px;top:-180px;right:-120px;}
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative;z-index:1;}
.test-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:28px;transition:transform .3s ease;position:relative;}
.test-card:hover{transform:translateY(-6px);}
.test-quote-ic{position:absolute;top:22px;right:22px;font-size:26px;color:rgba(255,255,255,.1);}
.test-stars{color:var(--amber);font-size:13px;margin-bottom:14px;}
.test-card p{font-size:14.5px;color:#C9CFEE;margin-bottom:22px;}
.test-person{display:flex;align-items:center;gap:12px;}
.test-person img{width:46px;height:46px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.18);}
.test-person strong{display:block;font-size:14px;color:#fff;}
.test-person span{font-size:12px;color:#8C96CC;}
@media (max-width:980px){.test-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto;}}

/* =========================================================
   TECH STACK
========================================================= */
.stack{padding:100px 0;background:#fff;}
.stack-cats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.stack-cat{background:var(--cloud);border:1px solid var(--line);border-radius:16px;padding:26px 20px;}
.stack-cat h4{font-family:var(--font-mono);font-size:12.5px;color:var(--purple);text-transform:uppercase;letter-spacing:.05em;margin-bottom:18px;}
.stack-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.stack-tile{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;
  padding:18px 8px;border-radius:12px;background:#fff;border:1px solid var(--line);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.stack-tile:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:transparent;}
.stack-tile i{font-size:25px;color:var(--blue);}
.stack-tile span{font-size:12px;font-weight:600;color:var(--slate-dark);text-align:center;}
@media (max-width:980px){.stack-cats{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.stack-cats{grid-template-columns:1fr;}}

/* =========================================================
   CTA BANNER
========================================================= */
.cta-banner{position:relative;padding:90px 0;overflow:hidden;background:var(--ink);}
.cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.32;}
.cta-overlay{position:absolute;inset:0;background:linear-gradient(120deg, rgba(11,17,48,.94), rgba(51,87,255,.5));}
.cta-content{position:relative;z-index:1;text-align:center;max-width:660px;margin:0 auto;}
.cta-icon-row{display:flex;justify-content:center;gap:14px;margin-bottom:24px;flex-wrap:wrap;}
.cta-icon-row span{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;}
.cta-content h2{color:#fff;font-size:clamp(26px,3.4vw,38px);margin-bottom:16px;}
.cta-content p{color:#C9CFEE;margin-bottom:30px;font-size:16px;}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* =========================================================
   CONTACT
========================================================= */
.contact{padding:100px 0;background:var(--cloud);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;}
.contact-form{background:#fff;border-radius:var(--radius);padding:38px;border:1px solid var(--line);box-shadow:var(--shadow-sm);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.field label{font-size:13px;font-weight:600;color:var(--ink);}
.field input,.field select,.field textarea{
  padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:14.5px;
  background:var(--cloud);transition:border-color .2s, background .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);background:#fff;}
.field textarea{resize:vertical;min-height:110px;}
.form-note{font-size:12px;color:var(--slate);margin-top:14px;text-align:center;}
.form-success{display:none;align-items:center;gap:10px;background:rgba(25,195,125,.1);border:1px solid rgba(25,195,125,.3);color:#0E8F5B;padding:13px 16px;border-radius:10px;font-size:13.5px;margin-bottom:16px;font-weight:600;}
.form-success.show{display:flex;}
.form-error{display:none;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);color:#b91c1c;padding:13px 16px;border-radius:10px;font-size:13.5px;margin-bottom:16px;font-weight:600;}
.form-error.show{display:block;}
.form-error ul{margin:0;padding-left:18px;}
.form-error li+li{margin-top:6px;}

.contact-info{display:flex;flex-direction:column;gap:18px;}
.info-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 22px;display:flex;gap:16px;align-items:flex-start;}
.info-card i{width:42px;height:42px;border-radius:11px;background:var(--grad-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.info-card strong{display:block;font-size:14px;color:var(--ink);margin-bottom:3px;}
.info-card span,.info-card a{font-size:13.5px;color:var(--slate);display:block;}
.map-box{border-radius:14px;overflow:hidden;border:1px solid var(--line);height:220px;}
.map-box iframe{width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.05);}
@media (max-width:980px){.contact-grid{grid-template-columns:1fr;}}
@media (max-width:560px){.form-row{grid-template-columns:1fr;}}

/* =========================================================
   FOOTER
========================================================= */
footer{background:var(--ink);color:#A7B0DD;padding:80px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand .logo{
  align-items:flex-start;
}
.footer-brand .logo-mark{
  background:rgba(255,255,255,.97);
  padding:14px 18px;
  border-radius:16px;
  box-shadow:0 12px 30px rgba(0,0,0,.14);
}
.footer-brand .logo-mark img{
  width:170px;
}
.footer-brand .logo-text strong{color:#fff;}
.footer-brand p{font-size:13.5px;color:#8C96CC;margin:18px 0 22px;max-width:280px;}
.footer-social{display:flex;gap:10px;}
.footer-social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:#fff;transition:.25s;}
.footer-social a:hover{background:var(--grad-1);transform:translateY(-3px);border-color:transparent;}
.footer-col h5{color:#fff;font-family:var(--font-display);font-size:15px;margin-bottom:20px;}
.footer-col ul{display:flex;flex-direction:column;gap:11px;}
.footer-col a{font-size:13.5px;color:#A7B0DD;transition:color .2s;}
.footer-col a:hover{color:#fff;}
.footer-contact li{display:flex;gap:10px;font-size:13.5px;color:#A7B0DD;margin-bottom:14px;align-items:flex-start;}
.footer-contact i{color:var(--blue-2);margin-top:3px;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding:26px 0;font-size:12.5px;color:#7480B0;flex-wrap:wrap;gap:10px;}
.footer-bottom .prompt{font-family:var(--font-mono);color:#5FE3A1;}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}.footer-bottom{flex-direction:column;text-align:center;}}
