/* reset */
*,*::before,*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  background:#060e1a;
  color:#eef4fb;
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;
  font-size:16px;
  line-height:1.7;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto;}
button,select,input,textarea{font:inherit;}
button{background:none;border:none;color:inherit;}
::selection{background:#0ea5e9;color:#000;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-track{background:#060e1a;}
::-webkit-scrollbar-thumb{background:#0ea5e9;border-radius:2px;}
body::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23g)' opacity='0.03'/%3E%3C/svg%3E");
  opacity:.45;
}

/* variables */
:root{
  --navy:#060e1a;
  --deep:#0b1828;
  --card:#0e1f33;
  --accent:#0ea5e9;
  --accent2:#06b6d4;
  --dim:#8ba3bc;
  --muted:#3d5a73;
  --border:rgba(14,165,233,0.1);
  --glass:rgba(14,165,233,0.04);
  --white:#eef4fb;
  --font-head:'Playfair Display',Georgia,serif;
  --font-body:'Plus Jakarta Sans',system-ui,sans-serif;
  /* spacing scale */
  --sp-xxs:4px; --sp-xs:8px; --sp-sm:12px; --sp:16px; --sp-md:24px; --sp-lg:32px; --sp-xl:48px; --sp-3xl:72px;
  /* font scale */
  --fs-sm:0.85rem; --fs-base:1rem; --fs-lg:1.125rem; --fs-xl:1.5rem;
}

/* layout */
.container{
  max-width:1180px;
  margin:0 auto;
  padding:0 2rem;
}
section{position:relative;z-index:1;}
main{position:relative;z-index:1;}
.text-center{text-align:center;}

/* components */
.tag{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  font-family:var(--font-body);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  border:1px solid rgba(14,165,233,.22);
  background:rgba(14,165,233,.06);
  padding:.28rem .8rem;
  border-radius:100px;
  margin-bottom:1.4rem;
}
.tag::before{
  content:'';
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 8px var(--accent);
  flex-shrink:0;
}
.section-title{
  font-family:var(--font-head);
  font-size:clamp(1.85rem,3.6vw,2.8rem);
  font-weight:800;
  line-height:1.15;
  letter-spacing:-.01em;
  margin-bottom:1rem;
}
.section-lead{
  font-size:1rem;
  color:var(--dim);
  max-width:520px;
  line-height:1.82;
  font-weight:400;
}
.section-lead--center{margin:0 auto;}

[data-lang="en"] .vi{display:none!important;}
[data-lang="vi"] .en{display:none!important;}

.site-nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:100;
  padding:1.2rem 0;
  transition:background .35s,padding .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.site-nav.scrolled{
  background:rgba(6,14,26,.93);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom-color:var(--border);
  padding:.8rem 0;
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.5rem;
}
.nav-brand{display:flex;align-items:center;text-decoration:none;flex-shrink:0;}
.site-logo{height:36px;width:auto;transition:opacity .2s;}
.nav-brand:hover .site-logo{opacity:.85;}
.nav-links{
  display:flex;
  align-items:center;
  gap:2.2rem;
  list-style:none;
}
.nav-links a{
  font-size:.875rem;
  font-weight:500;
  color:var(--dim);
  text-decoration:none;
  transition:color .2s;
  position:relative;
}
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:-3px;
  left:0;
  right:0;
  height:1px;
  background:var(--accent);
  transform:scaleX(0);
  transition:transform .25s;
}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{transform:scaleX(1);}
.nav-cta{
  background:var(--accent)!important;
  color:#000!important;
  font-weight:700!important;
  padding:.45rem 1.15rem!important;
  border-radius:7px;
  transition:opacity .2s,transform .2s!important;
}
.btn-icon{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem;border-radius:10px;min-height:44px;min-width:44px}
.nav-cta:hover{opacity:.85;transform:translateY(-1px);}
.nav-actions{
  display:flex;
  align-items:center;
  gap:1rem;
}
.nav-hamburger{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  flex-direction:column;
  gap:5px;
  padding:.25rem;
}
.nav-hamburger span{
  display:block;
  width:22px;
  height:2px;
  background:var(--white);
  border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.lang-btn{
  display:flex;
  align-items:center;
  background:rgba(14,165,233,.07);
  border:1px solid rgba(14,165,233,.18);
  border-radius:8px;
  overflow:hidden;
  flex-shrink:0;
}
.lang-opt{
  padding:.36rem .72rem;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.06em;
  color:var(--dim);
  cursor:pointer;
  background:none;
  line-height:1;
  transition:background .2s,color .2s;
}
.lang-opt.active{background:var(--accent);color:#000;}
.lang-opt:not(.active):hover{color:var(--white);}
.mobile-menu{
  display:none;
  position:fixed;
  inset:0;
  z-index:99;
  background:rgba(6,14,26,.97);
  backdrop-filter:blur(20px);
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2rem;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{
  font-family:var(--font-head);
  font-size:1.85rem;
  font-weight:800;
  color:var(--white);
  text-decoration:none;
  transition:color .2s;
  font-style:italic;
}
.mobile-menu a:hover{color:var(--accent);}
.mobile-close{
  position:absolute;
  top:1.5rem;
  right:1.8rem;
  background:none;
  border:none;
  color:var(--dim);
  cursor:pointer;
  font-size:1.4rem;
  line-height:1;
}
.mobile-logo svg{height:40px;width:auto;}

.site-hero{min-height:100vh;display:flex;align-items:center;padding:8rem 0 6rem;position:relative;overflow:hidden;background-color:var(--navy);}
.hero-bg{position:absolute;inset:0;pointer-events:none;}
.orb{position:absolute;border-radius:50%;filter:blur(80px);}
.orb-1{width:650px;height:650px;background:var(--accent);opacity:.13;top:-180px;right:-100px;}
.orb-2{width:400px;height:400px;background:#0f3460;opacity:.2;bottom:-80px;left:-80px;}
.orb-3{width:280px;height:280px;background:var(--accent2);opacity:.06;top:45%;left:42%;}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(14,165,233,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(14,165,233,.045) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 75% 75% at 65% 45%,black 0%,transparent 100%);}
.hero-inner{position:relative;max-width:840px;}
.hero-eyebrow{display:flex;align-items:center;gap:.8rem;margin-bottom:2rem;opacity:0;animation:fadeUp .8s ease forwards .15s;}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 14px var(--accent);animation:blink 2.2s ease infinite;flex-shrink:0;}
.hero-eyebrow-txt{font-size:.74rem;font-weight:600;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;}
.hero-title{
  font-family:var(--font-head);
  font-size:clamp(3rem,7.5vw,5.8rem);
  font-weight:900;
  line-height:1.04;
  letter-spacing:-.025em;
  margin-bottom:1.8rem;
  opacity:0;
  animation:fadeUp .9s ease forwards .35s;
}
.hero-title .ital{font-style:italic;color:transparent;-webkit-text-stroke:1.5px var(--accent);}
.hero-title .acc{color:var(--accent);}
.hero-desc{
  font-size:1.1rem;
  color:var(--dim);
  line-height:1.82;
  max-width:560px;
  margin-bottom:2.8rem;
  font-weight:400;
  opacity:0;
  animation:fadeUp .9s ease forwards .55s;
}
.hero-actions{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .9s ease forwards .75s;}
.btn-primary,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  border-radius:9px;
  text-decoration:none;
  font-family:var(--font-body);
  transition:transform .22s,box-shadow .22s,color .22s,border-color .22s;
}
.btn-primary{
  background:var(--accent);
  color:#000;
  font-weight:700;
  font-size:.9rem;
  padding:.85rem 2rem;
  box-shadow:0 0 40px rgba(14,165,233,.3);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 60px rgba(14,165,233,.45);}
.btn-ghost{
  color:var(--dim);
  font-size:.9rem;
  font-weight:500;
  border:1px solid rgba(255,255,255,.1);
  padding:.85rem 1.8rem;
}
.btn-ghost:hover{color:var(--white);border-color:rgba(255,255,255,.22);}
.hero-stats{display:flex;gap:2rem;margin-top:4rem;opacity:0;animation:fadeUp .9s ease forwards .95s;padding-top:2.5rem;border-top:1px solid var(--border);flex-wrap:wrap;}
.hero-stats > div{min-width:120px;}
.stat-num{font-family:var(--font-head);font-size:2.4rem;font-weight:800;line-height:1;color:var(--white);}
.stat-num em{font-style:normal;color:var(--accent);}
.stat-label{font-size:.76rem;color:var(--muted);margin-top:.25rem;font-weight:600;}

.lead-cta{margin-top:2.2rem;}
.hero-form{
  display:grid;
  grid-template-columns:minmax(140px,1fr) minmax(190px,1.25fr) minmax(140px,1fr) auto;
  gap:.55rem;
  align-items:center;
  max-width:860px;
}
.lead-form input,
.lead-form textarea{
  width:100%;
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  background:rgba(6,14,26,.42);
  color:var(--white);
  padding:.72rem .95rem;
  outline:none;
  transition:border-color .2s,background .2s;
}
.lead-form textarea{resize:vertical;min-height:130px;}
.lead-form input:focus,
.lead-form textarea:focus{border-color:rgba(14,165,233,.55);background:rgba(14,165,233,.06);}
.lead-form .error{border-color:#f87171;}
.form-success{display:none;color:var(--accent);font-size:.85rem;font-weight:600;}

#clients{padding:5rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.clients-head{text-align:center;max-width:720px;margin:0 auto 3rem;}
.clients-head .section-lead{margin:1rem auto 0;}
.client-logo-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1rem;
  margin-bottom:3.5rem;
}
.client-logo-card{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:88px;
  padding:1.1rem 1rem;
  background:linear-gradient(145deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border:1px solid rgba(14,165,233,.1);
  border-radius:16px;
  position:relative;
  overflow:hidden;
  transition:border-color .3s,transform .3s,box-shadow .3s,background .3s;
}
.client-logo-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(14,165,233,.08),transparent 70%);
  opacity:0;
  transition:opacity .3s;
}
.client-logo-card:hover{
  transform:translateY(-3px);
  border-color:rgba(14,165,233,.28);
  box-shadow:0 12px 32px rgba(0,0,0,.25),0 0 0 1px rgba(14,165,233,.08);
  background:linear-gradient(145deg,rgba(14,165,233,.06),rgba(255,255,255,.02));
}
.client-logo-card:hover::before{opacity:1;}
.client-logo-card img{
  position:relative;
  z-index:1;
  width:auto;
  height:34px;
  max-width:100%;
  object-fit:contain;
  filter:grayscale(.15) brightness(1.05);
  opacity:.88;
  transition:opacity .3s,filter .3s,transform .3s;
}
.client-logo-card:hover img{
  opacity:1;
  filter:grayscale(0) brightness(1.1);
  transform:scale(1.03);
}
.testimonial-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;}
.testimonial-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:18px;
  padding:2rem 2rem 1.8rem;
  position:relative;
}
.testimonial-card::before{
  content:'"';
  position:absolute;
  top:.5rem;
  left:1.4rem;
  font-family:var(--font-head);
  font-size:3.5rem;
  line-height:1;
  color:var(--accent);
  opacity:.25;
}
.testimonial-quote{
  font-size:.925rem;
  line-height:1.8;
  color:var(--dim);
  margin-bottom:1.4rem;
  padding-top:1.5rem;
}
.testimonial-meta{font-size:.75rem;color:var(--muted);font-weight:600;letter-spacing:.04em;text-transform:uppercase;}
.founder-card{
  display:flex;
  gap:1.75rem;
  align-items:center;
  background:linear-gradient(135deg,rgba(14,165,233,.07),rgba(6,182,212,.03));
  border:1px solid rgba(14,165,233,.22);
  border-radius:20px;
  padding:1.75rem;
  margin:1.75rem 0;
  position:relative;
  overflow:hidden;
  transition:border-color .3s,box-shadow .3s;
}
.founder-card::before{
  content:'';
  position:absolute;
  top:-40%;
  left:-20%;
  width:55%;
  height:140%;
  background:radial-gradient(circle,rgba(14,165,233,.12),transparent 70%);
  pointer-events:none;
}
.founder-card:hover{
  border-color:rgba(14,165,233,.38);
  box-shadow:0 16px 40px rgba(0,0,0,.22),0 0 0 1px rgba(14,165,233,.1);
}
.founder-card--featured{
  padding:2rem 2rem 2rem 1.75rem;
  margin:2rem 0 2.25rem;
}
.founder-avatar{
  flex-shrink:0;
  width:96px;
  height:96px;
  border-radius:50%;
  padding:3px;
  background:linear-gradient(145deg,var(--accent),var(--accent2));
  box-shadow:0 0 0 4px rgba(14,165,233,.12),0 0 28px rgba(14,165,233,.35),0 10px 28px rgba(0,0,0,.35);
  position:relative;
  z-index:1;
  transition:transform .35s,box-shadow .35s;
}
.founder-card:hover .founder-avatar{
  transform:scale(1.04);
  box-shadow:0 0 0 5px rgba(14,165,233,.18),0 0 36px rgba(14,165,233,.45),0 12px 32px rgba(0,0,0,.4);
}
.founder-card--featured .founder-avatar{
  width:120px;
  height:120px;
  padding:4px;
}
.founder-photo{
  width:100%;
  height:100%;
  border-radius:50%;
  object-fit:cover;
  object-position:center 18%;
  border:3px solid var(--navy);
  display:block;
  background:var(--deep);
}
.founder-card--featured .founder-photo{border-width:4px;}
.founder-body{position:relative;z-index:1;min-width:0;}
.founder-name{font-size:1.1rem;font-weight:700;color:var(--white);margin-bottom:.2rem;}
.founder-card--featured .founder-name{font-size:1.25rem;}
.founder-role{font-size:.8rem;color:var(--accent);font-weight:600;margin-bottom:.65rem;letter-spacing:.02em;}
.founder-link{font-size:.875rem;color:var(--dim);line-height:1.75;}
.founder-link a{color:var(--accent);text-decoration:none;}
.founder-link a:hover{text-decoration:underline;}
.trust-close{
  margin-top:2rem;
  padding:1.5rem 2rem;
  border-left:3px solid var(--accent);
  background:rgba(14,165,233,.04);
  border-radius:0 12px 12px 0;
  font-size:.975rem;
  line-height:1.85;
  color:var(--white);
  font-weight:500;
}

.clients-label{font-size:.67rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;margin-bottom:1.8rem;font-weight:600;}
.marquee-wrap{overflow:hidden;}
.marquee-track{display:flex;align-items:center;gap:3.5rem;width:max-content;animation:marquee 30s linear infinite;}
.marquee-track:hover{animation-play-state:paused;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.client-pill{font-size:.875rem;font-weight:600;color:var(--muted);white-space:nowrap;cursor:default;transition:color .25s;}
.client-pill:hover{color:var(--white);}
.sep{color:var(--muted);opacity:.3;}

#about{padding:8rem 0;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.about-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px;
  padding:2.5rem;
  position:relative;
  overflow:hidden;
}
.about-card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--accent) 50%,transparent);
}
.glow-p{
  position:absolute;
  top:-70px;
  right:-70px;
  width:220px;
  height:220px;
  border-radius:50%;
  background:var(--accent);
  opacity:.05;
  filter:blur(50px);
  pointer-events:none;
}
.about-badge{
  display:inline-flex;
  align-items:baseline;
  gap:.5rem;
  background:rgba(14,165,233,.08);
  border:1px solid rgba(14,165,233,.18);
  border-radius:10px;
  padding:.7rem 1.1rem;
  margin-bottom:1.8rem;
}
.badge-num{font-family:var(--font-head);font-size:1.6rem;font-weight:900;color:var(--accent);line-height:1;}
.badge-sub{font-size:.75rem;color:var(--dim);font-weight:500;}
.card-body{font-size:.84rem;color:var(--dim);line-height:1.82;margin-bottom:1.8rem;}
.facts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.fact-box{
  background:rgba(255,255,255,.025);
  border:1px solid var(--border);
  border-radius:12px;
  padding:1.1rem 1rem;
}
.fact-n{font-family:var(--font-head);font-size:1.9rem;font-weight:900;line-height:1;color:var(--white);}
.fact-n em{font-style:normal;color:var(--accent);}
.fact-l{font-size:.7rem;color:var(--muted);margin-top:.25rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;}
.about-text p{color:var(--dim);margin-bottom:1.2rem;font-size:.975rem;line-height:1.85;font-weight:400;}

#services{padding:8rem 0;}
.services-head{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:3.5rem;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:18px;overflow:hidden;}
.svc-card{
  background:var(--deep);
  padding:2.4rem;
  position:relative;
  overflow:hidden;
  transition:background .3s;
  cursor:default;
}
.svc-card:hover{background:#0d2540;}
.svc-card::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:1.5px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s ease;
}
.svc-card:hover::after{transform:scaleX(1);}
.svc-icon{
  width:50px;
  height:50px;
  border-radius:13px;
  background:rgba(14,165,233,.08);
  border:1px solid rgba(14,165,233,.18);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.8rem;
  font-weight:800;
  letter-spacing:.04em;
  margin-bottom:1.5rem;
  transition:background .3s;
}
.svc-card:hover .svc-icon{background:rgba(14,165,233,.16);}
.svc-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--white);margin-bottom:.7rem;line-height:1.3;}
.svc-desc{font-size:.84rem;color:var(--muted);line-height:1.75;}

.page-hero{
  padding:11rem 0 5rem;
  background:linear-gradient(180deg,rgba(14,165,233,.08),rgba(6,14,26,0));
  border-bottom:1px solid var(--border);
}
.page-hero .section-title{max-width:820px;font-size:clamp(2.2rem,5vw,4.3rem);}
.page-hero .section-lead{max-width:690px;}

#value,#products,#proof,#fit,#contact-page{padding:8rem 0;}
.outcome-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.outcome-card{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:16px;
  padding:2rem;
}
.outcome-card .metric{
  font-family:var(--font-head);
  font-size:2.4rem;
  font-weight:900;
  line-height:1;
  color:var(--accent);
  margin-bottom:1.1rem;
}
.outcome-card h3{
  font-family:var(--font-head);
  font-size:1.15rem;
  color:var(--white);
  margin-bottom:.7rem;
}
.outcome-card p{font-size:.9rem;color:var(--muted);line-height:1.78;}

.product-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
}
.product-card,
.product-detail{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:16px;
  padding:2rem;
  transition:border-color .25s,background .25s,transform .25s;
}
.product-card:hover,
.product-detail:hover{
  border-color:rgba(14,165,233,.28);
  background:rgba(14,165,233,.05);
  transform:translateY(-3px);
}
.product-card h3,
.product-detail h2{
  font-family:var(--font-head);
  color:var(--white);
  line-height:1.22;
  margin-bottom:.85rem;
}
.product-card h3{font-size:1.08rem;}
.product-detail h2{font-size:1.55rem;}
.product-card p,
.product-detail p{
  color:var(--muted);
  font-size:.88rem;
  line-height:1.78;
}
.product-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.product-detail ul{
  list-style:none;
  margin-top:1.4rem;
}
.product-detail li{
  color:var(--dim);
  font-size:.9rem;
  padding:.55rem 0 .55rem 1.4rem;
  border-top:1px solid rgba(255,255,255,.05);
  position:relative;
}
.product-detail li::before{
  content:'';
  position:absolute;
  left:0;
  top:1.15rem;
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--accent);
}
.section-actions{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:2rem;
}

.case-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
}
.case-card,
.case-study,
.service-detail,
.contact-panel,
.contact-form{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:16px;
  padding:2rem;
}
.case-meta{
  font-size:.72rem;
  font-weight:800;
  letter-spacing:.13em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1rem;
}
.case-card h3,
.case-study h2,
.service-detail h2,
.contact-panel h2{
  font-family:var(--font-head);
  color:var(--white);
  line-height:1.2;
  margin-bottom:.9rem;
}
.case-card h3{font-size:1.15rem;}
.case-study h2,
.service-detail h2,
.contact-panel h2{font-size:1.55rem;}
.case-card p,
.case-study p,
.service-detail p,
.contact-panel p{font-size:.9rem;color:var(--muted);line-height:1.78;}
.case-results{
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  margin-top:1.4rem;
}
.case-results span{
  display:inline-flex;
  border:1px solid rgba(14,165,233,.18);
  background:rgba(14,165,233,.07);
  color:var(--white);
  border-radius:999px;
  padding:.42rem .7rem;
  font-size:.75rem;
  font-weight:700;
}
.case-results--large span{font-size:.85rem;padding:.55rem .85rem;}
.case-study-list{
  display:grid;
  gap:1rem;
}
.case-study{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:1.5rem;
  align-items:start;
}
.case-study .case-meta{grid-column:1/-1;margin-bottom:0;}
.service-detail-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
}
.service-detail ul,
.contact-panel ul{
  list-style:none;
  margin-top:1.4rem;
}
.service-detail li,
.contact-panel li{
  color:var(--dim);
  font-size:.9rem;
  padding:.55rem 0 .55rem 1.4rem;
  border-top:1px solid rgba(255,255,255,.05);
  position:relative;
}
.service-detail li::before,
.contact-panel li::before{
  content:'';
  position:absolute;
  left:0;
  top:1.15rem;
  width:7px;
  height:7px;
  border-radius:50%;
  background:var(--accent);
}
.contact-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:1rem;
  align-items:start;
}
.contact-direct{
  margin-top:2rem;
  border-top:1px solid var(--border);
  padding-top:1.4rem;
}
.contact-form{
  display:grid;
  gap:1rem;
}
.contact-form label{
  display:grid;
  gap:.45rem;
  font-size:.82rem;
  color:var(--dim);
  font-weight:700;
}
.contact-form button{justify-content:center;}

#portfolio{padding:8rem 0;}
.port-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:3rem;}
.port-card{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:16px;
  padding:2rem 1.4rem;
  text-align:center;
  transition:transform .3s,border-color .3s,box-shadow .3s;
  cursor:default;
}
.port-card:hover{transform:translateY(-7px);border-color:rgba(14,165,233,.35);box-shadow:0 24px 60px rgba(0,0,0,.4),0 0 40px rgba(14,165,233,.08);}
.port-logo{
  width:58px;
  height:58px;
  border-radius:15px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.1rem;
  font-family:var(--font-head);
  font-size:.62rem;
  font-weight:900;
  color:var(--accent);
  text-align:center;
  line-height:1.3;
}
.port-name{font-family:var(--font-head);font-size:.9rem;font-weight:700;color:var(--white);margin-bottom:.35rem;}
.port-type{font-size:.72rem;color:var(--muted);font-weight:500;}

#why{padding:8rem 0;}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;margin-top:3.5rem;}
.why-card{
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:18px;
  padding:2.4rem;
  display:flex;
  gap:1.6rem;
  transition:border-color .3s,background .3s;
}
.why-card:hover{border-color:rgba(14,165,233,.25);background:rgba(14,165,233,.04);}
.why-n{
  font-family:var(--font-head);
  font-size:2.8rem;
  font-weight:900;
  color:rgba(14,165,233,.1);
  line-height:1;
  flex-shrink:0;
  width:2.8rem;
  font-style:italic;
}
.why-title{font-family:var(--font-head);font-size:1.05rem;font-weight:700;color:var(--white);margin-bottom:.6rem;}
.why-desc{font-size:.875rem;color:var(--muted);line-height:1.8;}

#network{padding:8rem 0;}
.net-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;margin-top:2.5rem;}
.net-card{
  background:rgba(255,255,255,.04);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.4rem .8rem .9rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.7rem;
  cursor:default;
  transition:transform .25s,border-color .25s,background .25s;
}
.net-card:hover{transform:translateY(-4px);border-color:rgba(14,165,233,.3);background:rgba(14,165,233,.06);}
.net-card-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;}
.net-card-icon svg{width:100%;height:100%;}
.net-card-name{font-size:.72rem;font-weight:600;color:var(--dim);text-align:center;line-height:1.3;letter-spacing:.02em;}
.net-card:hover .net-card-name{color:var(--white);}

#approach{padding:8rem 0;}
.approach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:4.5rem;position:relative;}
.approach-line{position:absolute;top:1.85rem;left:calc(12.5% + 2rem);right:calc(12.5% + 2rem);height:1px;background:linear-gradient(90deg,transparent,rgba(14,165,233,.4) 15%,rgba(14,165,233,.4) 85%,transparent);}
.approach-step{text-align:center;padding:0 1.8rem;position:relative;}
.approach-dot{
  width:3.8rem;
  height:3.8rem;
  border-radius:50%;
  background:var(--deep);
  border:2px solid var(--accent);
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 1.5rem;
  font-family:var(--font-head);
  font-size:.85rem;
  font-weight:900;
  color:var(--accent);
  box-shadow:0 0 24px rgba(14,165,233,.2);
  position:relative;
  z-index:1;
  font-style:italic;
}
.approach-title{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--white);margin-bottom:.6rem;}
.approach-desc{font-size:.82rem;color:var(--muted);line-height:1.78;}

#cta{padding:8rem 0;}
.cta-box{
  background:linear-gradient(135deg,rgba(14,165,233,.07) 0%,rgba(15,52,96,.35) 100%);
  border:1px solid rgba(14,165,233,.2);
  border-radius:26px;
  padding:5.5rem 4rem;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-box::before{display:none;}
.cta-title{font-family:var(--font-head);font-size:clamp(2rem,4.2vw,3.1rem);font-weight:900;line-height:1.12;margin-bottom:1.2rem;font-style:italic;}
.cta-desc{font-size:1rem;color:var(--dim);margin-bottom:2.6rem;max-width:460px;margin-left:auto;margin-right:auto;line-height:1.82;}
.cta-acts{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.cta-note{font-size:.82rem;color:var(--muted);margin-top:1.4rem;}
.cta-note a{color:var(--accent);text-decoration:none;}
.cta-note a:hover{text-decoration:underline;}

.site-footer{border-top:1px solid var(--border);padding:4.5rem 0 2.5rem;}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:4rem;margin-bottom:3rem;}
.foot-logo{font-family:var(--font-head);font-size:1.25rem;font-weight:800;margin-bottom:.8rem;}
.foot-desc{font-size:.875rem;color:var(--muted);line-height:1.75;margin-bottom:1.5rem;}
.foot-ci{display:flex;align-items:flex-start;gap:.7rem;font-size:.8rem;color:var(--muted);margin-bottom:.65rem;}
.foot-ci svg{flex-shrink:0;margin-top:2px;}
.foot-col-h{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin-bottom:1.2rem;}
.foot-links{list-style:none;}
.foot-links li{margin-bottom:.55rem;}
.foot-links a{font-size:.875rem;color:var(--muted);text-decoration:none;transition:color .2s;}
.foot-links a:hover{color:var(--white);}
.foot-bottom{border-top:1px solid var(--border);padding-top:2rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;}
.foot-copy{font-size:.78rem;color:var(--muted);}
.foot-bar{width:36px;height:3px;background:var(--accent);border-radius:2px;}

/* bottom mobile navigation */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:120;display:flex;justify-content:center;padding:6px 10px;background:linear-gradient(180deg,rgba(6,14,26,0.02),rgba(6,14,26,0.6));backdrop-filter:blur(6px);border-top:1px solid rgba(255,255,255,0.03);}
.bottom-nav-list{display:flex;gap:8px;list-style:none;padding:6px 8px;margin:0;max-width:720px;width:100%;justify-content:space-between}
.bottom-nav-list li{flex:1}
.bn-link{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;color:var(--muted);font-size:.72rem;padding:8px 6px;border-radius:10px;min-height:48px}
.bn-link i{width:22px;height:22px;display:inline-block;margin-bottom:6px}
.bn-link:focus,.bn-link:hover{color:var(--white);background:rgba(255,255,255,0.02)}

/* hide by default on larger viewports; show on mobile */
@media(min-width:769px){
  .bottom-nav{display:none}
}

/* utilities */
@keyframes blink{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.5;transform:scale(1.4);}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:translateY(0);}}
.reveal{opacity:0;transform:translateY(32px);transition:opacity .75s ease,transform .75s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.d1{transition-delay:.12s;}
.d2{transition-delay:.22s;}
.d3{transition-delay:.32s;}
.d4{transition-delay:.42s;}

.menu-open{overflow:hidden;}

@media(max-width:1024px){
  .svc-grid{grid-template-columns:repeat(2,1fr);}
  .port-grid{grid-template-columns:repeat(3,1fr);}
  .approach-grid{grid-template-columns:repeat(2,1fr);gap:2.5rem;}
  .approach-line{display:none;}
  .about-grid{grid-template-columns:1fr;gap:3rem;}
  .services-head{grid-template-columns:1fr;gap:1.2rem;}
  .hero-form{grid-template-columns:1fr 1fr;}
  .hero-form button{justify-content:center;}
  .outcome-grid,.case-grid{grid-template-columns:1fr 1fr;}
  .testimonial-grid{grid-template-columns:1fr;}
  .client-logo-grid{grid-template-columns:repeat(3,1fr);}
  .product-grid,.product-list{grid-template-columns:1fr 1fr;}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:768px){
  .nav-links{display:none;}
  .nav-hamburger{display:flex;}
  .hero-stats{gap:1.8rem;}
  .svc-grid{grid-template-columns:1fr;}
  .hero-form,.outcome-grid,.case-grid,.service-detail-grid,.product-grid,.product-list{grid-template-columns:1fr;}
  .case-study{grid-template-columns:1fr;}
  .port-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;gap:2.2rem;}
  .cta-box{padding:3.5rem 1.8rem;}
  .approach-grid{grid-template-columns:1fr 1fr;}
  .page-hero{padding:8.5rem 0 4rem;}
  .container{padding:0 1.25rem;}
  .founder-card{flex-direction:column;text-align:center;padding:1.5rem;}
  .founder-card--featured .founder-avatar{width:104px;height:104px;}
  .founder-avatar{width:88px;height:88px;margin:0 auto;}
}
@media(max-width:480px){
  .port-grid{grid-template-columns:1fr 1fr;}
  .client-logo-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;}
  .client-logo-card{min-height:76px;padding:.85rem .65rem;}
  .client-logo-card img{height:28px;}
  .hero-stats{flex-direction:column;gap:1.2rem;}
  .approach-grid{grid-template-columns:1fr;}
}
