:root{
  --bg:#ffffff;
  --content:#0f172a;
  --muted:#64748b;
  --brand:#068bd8;
  --accent:#f97316;
  --ok:#10b981;
  --radius:16px;

  --border: rgba(13,15,15,.22);
  --shadow: 0 8px 24px rgba(13,15,15,.15);

  /* logo sizing (bigger + responsive) */
  --logo-size: clamp(170px, 14vw, 220px);   /* desktop */
  --logo-size-md: 150px; /* tablet */
  --logo-size-sm: 120px; /* mobile */

  /* wordmark sizing */
  --brand-name-desktop: 2.4rem;
  --brand-name-md: 1.9rem;
  --brand-name-sm: 1.4rem;

  /* headings gradient */
  --heading-green-start:#064e3b;
  --heading-green-end:#10b981;

  /* background logo (watermark) — centered & bigger */
  --bg-logo-size: clamp(880px, 115vw, 1680px);
  --bg-logo-opacity: .08; /* desktop base */
  --bg-logo-base: -140px;
  --bg-logo-scroll: 0px;

  /* dynamic navbar height (JS updates) */
  --nav-h: 96px;

  --black:#000;
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color:var(--content);
  background:linear-gradient(180deg, rgba(6,139,216,.08) 0%, rgba(255,255,255,1) 28%, rgba(248,250,252,1) 82%);
  line-height:1.55;
  padding-top:var(--nav-h);
}
a{color:var(--brand); text-decoration:none}
.container{width:min(1100px,92%); margin-inline:auto}

/* helpers */
.text-brand{color:var(--brand)!important}
.text-content{color:var(--content)!important}
.text-muted{color:var(--muted)!important}

/* background logo (fixed watermark) — IMPORTANT: use path relative to CSS file */
.bg-logo{
  position:fixed; inset:0;
  background-image: url("../img/manki-logo-512.png");
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: var(--bg-logo-size);
  opacity: var(--bg-logo-opacity);
  mix-blend-mode: multiply;               /* looks good on white */
  pointer-events:none;
  transform: translate3d(0, calc(var(--bg-logo-base, -140px) + var(--bg-logo-scroll, 0px)), 0);
  z-index:0;                              /* behind page content */
}

/* NAV */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  backdrop-filter:saturate(1.2) blur(14px);
  background:rgba(255,255,255,.9);
  border-bottom:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 40px rgba(15,23,42,.08);
}
.nav .row{
  display:grid;
  grid-template-columns:auto 1fr;
  align-items:center;
  column-gap:20px;
  padding:6px 20px;
  position:relative;
}

/* Logo + wordmark */
.logo{display:flex; align-items:center; gap:16px; font-weight:900; padding:0; margin:0;}
.logo-mark{
  width:var(--logo-size);
  height:var(--logo-size);
  object-fit:cover;
  border-radius:0;
  display:block;
}
.nav .logo-mark{
  width:clamp(88px, 6.4vw, 120px);
  height:clamp(88px, 6.4vw, 120px);
  box-shadow:none;
}
.logo-text{
  letter-spacing:.5px;
  font-size: var(--brand-name-desktop);
  font-weight: 900;
  line-height:1;
  color:var(--brand)
}
.nav .logo-text{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
}
.logo-text .logo-ai { color: var(--accent); }

/* Menu */
.menu{display:flex; align-items:center; gap:16px; justify-content:flex-end}
.menu a,
.menu .menu-link{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  font-size:1.05rem;
  opacity:.92; font-weight:600; letter-spacing:.18px;
  padding:6px 12px; border-radius:8px;
  transition:color .2s ease, background .2s ease, box-shadow .2s ease;
}
.menu a:hover,
.menu a:focus-visible{background:rgba(6,139,216,.12); color:var(--brand); box-shadow:0 10px 22px rgba(6,139,216,.18); outline:none;}
.btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; border-radius:999px;
  background:linear-gradient(135deg, var(--brand), var(--accent));
  color:#ffffff; font-weight:700; box-shadow:0 16px 28px rgba(6,139,216,.24); border:none;
  transition:transform .18s ease, box-shadow .18s ease;
}
.btn:hover,
.btn:focus-visible{transform:translateY(-2px); box-shadow:0 22px 36px rgba(6,139,216,.28); outline:none;}
.btn-cta{ margin-left:6px; }
.btn.btn-ghost{background:transparent; color:var(--brand); box-shadow:none; border:1px solid rgba(6,139,216,.28);}
.btn.btn-ghost:hover,
.btn.btn-ghost:focus-visible{background:rgba(6,139,216,.12);}
.btn-small{padding:8px 14px; font-size:.9rem; box-shadow:none;}
.btn-small:hover,.btn-small:focus-visible{box-shadow:0 6px 20px rgba(6,139,216,.28);}

@media (min-width: 901px){
  .nav .row{ align-items:center; }
}

.menu a,
.menu .menu-link{
  color: var(--black);
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, text-decoration .2s;
}
.menu a:hover,
.menu a:focus-visible,
.menu .menu-link:hover,
.menu .menu-link:focus-visible{
  background: var(--brand);
  color: var(--accent);
  text-decoration:none;
  box-shadow:0 2px 8px rgba(6,139,216,.25);
  outline:none;
}

/* Services dropdown */
.menu-item{ position:relative }
.has-submenu > .menu-link{ position:relative; padding-right:24px; }
.has-submenu > .menu-link::after{
  content:""; position:absolute; right:6px; top:50%; width:6px; height:6px;
  border-right:2px solid currentColor; border-bottom:2px solid currentColor;
  transform: translateY(-60%) rotate(45deg); opacity:.8;
}
.has-submenu::before{ content:""; position:absolute; left:0; right:0; top:100%; height:12px; }
.has-submenu .submenu{
  position:absolute; top:calc(100% + 8px); left:0; display:none;
  background:#fff; border:1px solid var(--border); border-radius:14px;
  box-shadow:0 16px 40px rgba(13,15,15,.18);
  min-width:280px; overflow:hidden; z-index:1100;
}
.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu{ display:block }
.submenu-inner{ padding:10px; border-top:4px solid var(--brand) }
.submenu-item{
  display:flex; flex-direction:column; gap:2px;
  padding:10px 12px; border-radius:10px; color:var(--content);
}
.submenu-item strong{ color:#0b1220 }
.submenu-item span{ color:var(--muted); font-size:.9rem }
.submenu-item:hover{
  background:linear-gradient(135deg, rgba(6,139,216,.10), rgba(249,115,22,.10));
  box-shadow: inset 0 0 0 1px rgba(6,139,216,.25);
}
.submenu-item.active{
  background:linear-gradient(135deg, rgba(6,139,216,.18), rgba(249,115,22,.16));
  box-shadow: inset 0 0 0 1px rgba(6,139,216,.32);
}
.submenu-item[aria-current="page"]{
  background:linear-gradient(135deg, rgba(6,139,216,.22), rgba(249,115,22,.18));
  box-shadow: inset 0 0 0 1px rgba(6,139,216,.36);
}
.submenu-item[aria-current="page"] strong{ color:var(--brand); }

/* Mobile toggle */
.nav-toggle{
  display:none; position:relative; width:44px; height:40px;
  border:0; background:transparent; padding:0; cursor:pointer; z-index:1200;
}
.nav-toggle span{
  position:absolute; left:10px; right:10px; height:2px; background:#111; border-radius:2px;
}
.nav-toggle span:nth-child(1){ top:11px }
.nav-toggle span:nth-child(2){ top:19px }
.nav-toggle span:nth-child(3){ top:27px }

/* HERO & SECTIONS */

.hero{padding:24px 0 40px; position:relative; overflow:hidden;}
.hero::before{content:""; position:absolute; inset:0; background:radial-gradient(circle at -10% -10%, rgba(6,139,216,.25) 0%, rgba(6,139,216,0) 55%), radial-gradient(circle at 80% 20%, rgba(249,115,22,.18) 0%, rgba(249,115,22,0) 52%); opacity:.65; pointer-events:none;}
.hero .wrap{position:relative; display:grid; grid-template-columns: 1.05fr .95fr; gap:34px; align-items:center;}
.hero .wrap > div:first-child{backdrop-filter:blur(0px);}
.hero h1{font-size: clamp(28px, 3.6vw, 35px); line-height:1.12; margin:10px 0 12px; color:var(--brand)}
.t-ai{ color: var(--accent); }
.hero p{margin:0 0 22px; color:var(--content)}
.hero-card{background:rgba(255,255,255,.94); border:1px solid rgba(15,23,42,.08); border-radius:24px; padding:26px; box-shadow:0 24px 48px rgba(15,23,42,.14);}
.hero-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:10px}
.stat{background:#ffffff; border:1px solid var(--border); border-radius:14px; padding:16px; text-align:center}
.stat h3{margin:0; font-size:22px; color:var(--accent)}
.stat p{margin:6px 0 0; color:var(--brand); font-size:14px}
.hero-trust{
  margin-top:18px; display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}

/* About page */
.page-about{background:linear-gradient(180deg, rgba(6,139,216,.04) 0%, rgba(255,255,255,0) 55%);} 
.about-hero{padding:calc(var(--nav-h) + 4px) 0 34px;}
.about-hero-inner{display:grid; grid-template-columns:minmax(0, 1.05fr) minmax(0, .95fr); gap:40px; align-items:center;}
.about-hero-copy h1{margin:16px 0; font-size:clamp(26px, 3vw, 40px); color:var(--brand);}
.about-hero-copy p{margin:14px 0; max-width:64ch;}
.about-meta{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px;}
.about-hero-media{display:flex; justify-content:flex-end;}
.about-hero-media img{width:100%; max-width:480px; border-radius:24px; box-shadow:0 18px 38px rgba(15,23,42,.18); object-fit:cover;}
.about-stats-band{padding:56px 0; background:rgba(6,139,216,.05);}
.about-stats-grid{display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:22px;}
.about-stats-grid .stat{text-align:left; box-shadow:none; border-radius:18px; display:flex; flex-direction:column; gap:6px; border:1px solid rgba(6,139,216,.16); background:rgba(255,255,255,.92);}
.about-stats-grid .stat h2{margin:0; font-size:2rem; color:var(--brand);}
.about-panel{display:flex; flex-direction:column; overflow:hidden; padding:0;}
.about-panel img{width:100%; height:220px; object-fit:cover;}
.about-panel-body{padding:20px 20px 22px; display:flex; flex-direction:column; gap:12px;}
.about-panel-body h2{margin:0; font-size:1.24rem;}
.about-panel-body p{margin:0;}
.about-panel-body ul{list-style:none; padding:0; margin:0; display:grid; gap:8px;}
.about-panel-body ul li{position:relative; padding-left:18px; font-weight:600; color:var(--brand);}
.about-panel-body ul li::before{content:""; position:absolute; top:6px; left:0; width:8px; height:8px; border-radius:50%; background:var(--accent);}
.about-panels-section{padding:56px 0;}
.about-panels{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:24px;}
.section-subtitle{font-size:1.2rem; font-weight:700; color:var(--brand); margin:0 0 18px; letter-spacing:.2px;}
.about-timeline{padding:56px 0 32px;}
.timeline{list-style:none; margin:0; padding-left:28px; border-left:2px solid rgba(15,23,42,.18); display:grid; gap:26px;}
.timeline li{position:relative; padding-left:6px;}
.timeline li::before{content:""; position:absolute; left:-31px; top:4px; width:12px; height:12px; border-radius:50%; background:var(--brand); box-shadow:0 0 0 4px rgba(6,139,216,.15);}
.timeline-year{font-weight:800; font-size:1rem; color:var(--brand); letter-spacing:.3px; text-transform:uppercase;}
.timeline-body strong{display:block; margin:6px 0 4px; font-size:1.05rem;}
.timeline-body p{margin:0;}
.about-values{padding:48px 0 32px;}
.values-grid{display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:20px;}
.value h3,.value h4{margin:0 0 8px; font-size:1.08rem;}
.value p{margin:0;}
.about-cta{padding:54px 0; background:linear-gradient(135deg, rgba(6,139,216,.12), rgba(249,115,22,.10));}
.about-cta-inner{display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between;}
.about-cta-inner h2{margin:0 0 6px; font-size:clamp(22px, 2.6vw, 30px);}

/* Careers */
.careers{padding:60px 0; background:linear-gradient(135deg, rgba(6,139,216,.05), rgba(249,115,22,.06));}
.careers-inner{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);
  gap:32px;
  align-items:start;
}
.careers-intro h2{margin:12px 0 16px; font-size:clamp(24px, 2.8vw, 34px); color:var(--brand);}
.career-tags{display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 0; padding:0; list-style:none;}
.career-tags li{background:rgba(15,23,42,.08); border:1px solid rgba(15,23,42,.12); padding:6px 12px; border-radius:999px; font-weight:600; letter-spacing:.18px; color:var(--content);}
.careers-highlight{display:flex; flex-direction:column; gap:14px; padding:24px; background:#ffffff; border-radius:20px;}
.careers-highlight h3{margin:0; font-size:1.2rem; color:var(--content);}
.careers-highlight ul{margin:0; padding-left:18px; display:grid; gap:10px; color:var(--content);}
.careers-highlight li{line-height:1.5;}
.careers-grid{
  margin-top:40px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
}
.role-card{
  background:#ffffff;
  border:1px solid rgba(15,23,42,.14);
  border-radius:20px;
  padding:26px;
  display:flex; flex-direction:column; gap:18px;
  box-shadow:0 20px 40px rgba(15,23,42,.08);
}
.role-card header{display:flex; flex-direction:column; gap:6px;}
.role-type{font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); font-weight:700;}
.role-card h3{margin:0; font-size:1.35rem; color:var(--content);}
.role-card ul{margin:0; padding-left:18px; display:grid; gap:8px; color:var(--content);}
.role-card footer{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;}
.role-meta{font-size:.92rem; color:var(--muted); font-weight:600;}
.role-card-secondary{background:linear-gradient(135deg, rgba(6,139,216,.12), rgba(249,115,22,.10)); border-color:rgba(6,139,216,.22);}


/* Service pages */
.page-service{background:linear-gradient(180deg, rgba(6,139,216,.035) 0%, rgba(255,255,255,0) 60%);} 
.service-hero{padding:56px 0 36px;}
.service-hero-inner{display:grid; grid-template-columns:minmax(0, 1.05fr) minmax(0, .95fr); gap:40px; align-items:center;}
.service-hero-copy h1{margin:16px 0; font-size:clamp(26px, 3vw, 38px); color:var(--brand);}
.service-hero-copy p{margin:12px 0; max-width:62ch;}
.service-meta{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px;}
.service-hero-media{display:flex; justify-content:flex-end;}
.service-hero-media img{width:100%; max-width:460px; border-radius:24px; box-shadow:0 18px 38px rgba(15,23,42,.18); object-fit:cover;}
.service-highlights{padding:42px 0;}
.service-columns{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:32px;}
.service-list{list-style:none; padding:0; margin:0; display:grid; gap:10px;}
.service-list li{position:relative; padding-left:20px; font-weight:600; color:var(--brand);}
.service-list li::before{content:""; position:absolute; left:0; top:8px; width:8px; height:8px; border-radius:50%; background:var(--accent);}
.service-cases{padding:40px 0;}
.case-grid{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:22px;}
.case img{width:100%; height:220px; object-fit:cover; border-radius:18px 18px 0 0;}
.case figcaption{padding:18px; display:grid; gap:6px;}
.case strong{font-size:1.05rem; color:var(--content);}
.service-cta{padding:54px 0; background:linear-gradient(135deg, rgba(6,139,216,.12), rgba(249,115,22,.10));}
.service-cta-inner{display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between;}
.service-cta-inner h2{margin:0 0 6px; font-size:clamp(22px, 2.4vw, 30px);}
.service-cta-inner p{margin:0; max-width:46ch;}
.trust-label{font-weight:700; color:var(--content); letter-spacing:.2px}
.trust-logos{
  display:flex; gap:16px; flex-wrap:wrap; list-style:none; margin:0; padding:0;
  color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.12em; font-size:.78rem;
}
.trust-logos li{background:rgba(15,23,42,.06); border:1px solid rgba(15,23,42,.08); padding:6px 12px; border-radius:32px;}

/* Home enhancements */
.hero{padding:24px 0 40px; position:relative; overflow:hidden;}
.hero .wrap{grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr); gap:40px;}
.hero-card{display:none;}
.hero-copy{display:flex; flex-direction:column; gap:18px;}
.hero h1{margin:0; font-size:clamp(30px, 3.8vw, 35px);}
.hero p{margin:0;}
.hero-points{margin:0; padding:0; display:flex; flex-direction:column; gap:8px; list-style:none; font-weight:600; color:var(--content);}
.hero-points li{display:flex; align-items:center; gap:8px;}
.hero-points li::before{content:"•"; color:var(--accent); font-size:1.1em;}
.hero-visual{position:relative; margin:0; border-radius:32px; overflow:hidden; box-shadow:0 32px 60px rgba(15,23,42,.2);}
.hero-visual img{display:block; width:100%; height:100%; object-fit:cover;}
.hero-visual::after{content:""; position:absolute; inset:0; background:linear-gradient(120deg, rgba(15,23,42,.35), rgba(15,23,42,0) 70%);} 
.hero-visual figcaption{position:absolute; left:24px; right:24px; bottom:24px; background:rgba(15,23,42,.78); color:#fff; padding:16px 18px; border-radius:18px; display:flex; flex-direction:column; gap:6px; box-shadow:0 20px 40px rgba(15,23,42,.45);}
.hero-visual figcaption strong{font-size:1rem;}
.hero-proof{margin-top:18px; display:flex; align-items:center; gap:16px; flex-wrap:wrap; color:var(--muted); font-weight:600;}
.hero-proof ul{display:flex; gap:12px; flex-wrap:wrap; padding:0; margin:0; list-style:none; text-transform:uppercase; letter-spacing:.16em; font-size:.78rem;}
.hero-proof li{background:rgba(15,23,42,.06); border-radius:32px; padding:6px 12px; color:var(--brand);}
.hero-link{font-weight:700; color:var(--brand); text-decoration:none; padding:10px 0; display:inline-flex; align-items:center; gap:6px;}
.hero-link:hover,.hero-link:focus-visible{color:var(--accent); text-decoration:underline; outline:none;}

.home-capabilities{padding:64px 0; background:linear-gradient(180deg, rgba(6,139,216,.04) 0%, rgba(255,255,255,0) 80%);}
.home-capabilities .section-title{margin-bottom:6px;}
.capability-grid{margin-top:32px; display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:20px;}
.capability-card{background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:20px; padding:24px; display:flex; flex-direction:column; gap:12px; box-shadow:0 16px 36px rgba(15,23,42,.08); transition:transform .18s ease, box-shadow .18s ease;}
.capability-card:hover{transform:translateY(-4px); box-shadow:0 26px 44px rgba(15,23,42,.12);}
.capability-icon{width:48px; height:48px; border-radius:16px; display:grid; place-items:center; font-size:24px; background:linear-gradient(135deg, rgba(6,139,216,.18), rgba(249,115,22,.18));}

.home-case{padding:72px 0;}
.case-wrap{display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.1fr); gap:40px; align-items:center;}
.case-wrap figure{margin:0; border-radius:28px; overflow:hidden; box-shadow:0 24px 48px rgba(15,23,42,.18);}
.case-wrap img{width:100%; height:100%; object-fit:cover; display:block;}
.case-copy{display:flex; flex-direction:column; gap:18px;}
.case-copy ul{margin:0; padding-left:20px; display:flex; flex-direction:column; gap:10px;}
.case-metrics{display:flex; flex-wrap:wrap; gap:10px;}
.badge-outline{background:transparent; color:var(--brand); border:1px solid rgba(15,23,42,.24);}

.home-testimonials{padding:60px 0; background:linear-gradient(180deg, rgba(6,139,216,.05), rgba(249,115,22,.04));}
.testimonials-preview{margin-top:28px; display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px;}
.testimonials-preview article{background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:20px; padding:24px; box-shadow:0 18px 36px rgba(15,23,42,.08); display:flex; flex-direction:column; gap:12px;}
.testimonials-preview span{color:var(--muted); font-weight:600;}

.home-founders{padding:60px 0;}
.founder-grid{margin-top:28px; display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:24px;}
.founder-card{display:flex; gap:18px; background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:22px; padding:24px; align-items:center; box-shadow:0 16px 32px rgba(15,23,42,.08);}
.founder-card img{width:96px; height:96px; object-fit:cover; border-radius:24px; box-shadow:0 10px 24px rgba(15,23,42,.12);}
.founder-card h3{margin:0; font-size:1.2rem;}
.founder-card span{display:block; font-weight:600; color:var(--brand); margin-top:4px;}
.founder-card p{margin:10px 0 0;}

.home-insights{padding:64px 0;}
.insights-grid{display:grid; grid-template-columns:minmax(0,0.9fr) minmax(0,1.1fr); gap:32px; align-items:center;}
.insight-cards{display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:20px;}
.insight-card{background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:18px; padding:24px; display:flex; flex-direction:column; gap:12px; box-shadow:0 18px 36px rgba(15,23,42,.06);}
.insight-card small{font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--muted);}
.insight-card h3{margin:0; font-size:1.15rem;}

.process{background:linear-gradient(180deg, rgba(6,139,216,.04) 0%, rgba(255,255,255,0) 85%);}
.process-steps{margin-top:32px; display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:18px;}
.process-steps article{background:#fff; border:1px solid rgba(15,23,42,.12); border-radius:20px; padding:22px; display:flex; flex-direction:column; gap:10px; box-shadow:0 16px 32px rgba(15,23,42,.06);}
.step-icon{width:44px; height:44px; border-radius:14px; background:linear-gradient(135deg, rgba(6,139,216,.16), rgba(249,115,22,.16)); display:grid; place-items:center; font-size:20px;}

.home-case ul,
.process-steps p{color:var(--content);}

.home-cta{padding:70px 0; background:linear-gradient(120deg, rgba(6,139,216,.18), rgba(249,115,22,.18)); color:#fff;}
.cta-inner{display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap;}
.cta-inner h2{margin:0; font-size:clamp(26px, 3vw, 36px);}
.cta-inner .muted{color:rgba(255,255,255,.85); max-width:42ch;}
.cta-actions{display:flex; gap:16px; flex-wrap:wrap;}
.cta-proof{margin-top:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.75);}

.service-extras{padding:48px 0; background:linear-gradient(180deg, rgba(6,139,216,.04) 0%, rgba(255,255,255,0) 80%);}
.service-extras-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:20px;
}
.service-extra{display:flex; flex-direction:column; gap:12px; padding:24px; align-items:flex-start;}
.service-extra-icon{
  width:48px; height:48px; border-radius:16px;
  background:linear-gradient(135deg, rgba(6,139,216,.18), rgba(249,115,22,.18));
  display:grid; place-items:center; font-size:24px;
}
.service-extra h3{margin:0; font-size:1.18rem; color:var(--content);}
.service-extra p{margin:0;}

/* Sections */
section{padding:48px 0}
.section-title{
  font-size: clamp(22px, 2.6vw, 32px);
  margin:0 0 12px;
  color:var(--brand);
}

#services .section-title,
.work .section-title,
#blog .section-title,
#process .section-title,
#team .section-title,
#contact .section-title{
  color: transparent;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
}
.muted{color:var(--muted)}
.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.card{background:#ffffff; border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)}
.chip{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.2px;
  background:rgba(13,15,15,.10);
  border:1px solid rgba(13,15,15,.30);
  color:var(--brand);
}

.chip-hero{
  display: inline-flex;       /* never stretch full width */
  width: auto;                /* override any accidental 100% */
  max-width: max-content;     /* hug text */
  align-self: start;          /* avoid grid/flex stretching */
  padding: 6px 12px;          /* was 14px 24px */
  line-height: 1.05;          /* compact height */
  font-size: 16px;            /* slightly smaller to match */
  letter-spacing: .02em;      /* keep it crisp */
  border-radius: 999px;       /* keep the pill look */
}

/* Preloader */
.preloader{
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  background:#ffffff; z-index:2000;
  transition:opacity .45s ease, visibility .45s ease;
}
.preloader.preloader-hidden{opacity:0; visibility:hidden; pointer-events:none;}
.preloader-inner{display:flex; flex-direction:column; gap:18px; align-items:center; text-align:center; padding:32px;}
.preloader-inner img{
  width:clamp(150px, 14vw, 320px);
  height:auto;
  border-radius:24px;
  box-shadow:0 16px 32px rgba(15,23,42,.18);
}
.preloader-bar{width:140px; height:6px; border-radius:999px; background:rgba(15,23,42,.12); overflow:hidden; position:relative;}
.preloader-bar span{
  position:absolute; inset:0; width:40%; border-radius:999px;
  background:linear-gradient(135deg, var(--brand), var(--accent));
  animation: preloaderSlide 1.2s ease-in-out infinite;
}
.preloader-text{margin:0; font-weight:600; letter-spacing:.3px; color:var(--muted); text-transform:uppercase; font-size:.82rem;}

@keyframes preloaderSlide{
  0%{transform:translateX(-120%);} 50%{transform:translateX(40%);} 100%{transform:translateX(220%);}
}

/* Services section */
.services{padding:72px 0 40px; position:relative; background:linear-gradient(180deg, rgba(6,139,216,.05) 0%, rgba(255,255,255,1) 80%);} 
.services::before{
  content:"";
  position:absolute; inset:20px 0 auto; height:220px;
  background:linear-gradient(135deg, rgba(6,139,216,.12), rgba(249,115,22,.10));
  filter:blur(60px); opacity:.18; z-index:-1;
}
.services-header{display:flex; flex-direction:column; gap:6px; margin-bottom:24px; max-width:640px;}
.services-panel{display:grid; grid-template-columns:240px minmax(0,1fr); gap:24px; align-items:start;}
.services-tabs{display:flex; flex-direction:column; gap:10px; background:#ffffff; border:1px solid rgba(15,23,42,.12); border-radius:20px; padding:18px; box-shadow:0 20px 42px rgba(15,23,42,.10); position:sticky; top:calc(var(--nav-h) + 24px); touch-action:pan-y; cursor:grab;}
.services-tabs.is-dragging{cursor:grabbing;}
.service-tab{
  display:block; width:100%; text-align:left; border:1px solid transparent; border-radius:12px;
  padding:10px 12px; font-weight:700; letter-spacing:.2px; color:var(--content);
  background:transparent; cursor:pointer; transition:all .18s ease;
}
.service-tab:hover,
.service-tab:focus-visible{border-color:rgba(6,139,216,.3); box-shadow:0 8px 20px rgba(6,139,216,.12); outline:none;}
.service-tab.active{background:linear-gradient(135deg, rgba(6,139,216,.16), rgba(249,115,22,.18)); border-color:rgba(6,139,216,.36); color:var(--brand);}
.service-detail{display:flex; flex-direction:column; gap:18px;}
.service-detail header h3{margin:0; font-size:1.35rem; color:var(--content);}
.service-highlights{margin:0; padding-left:20px; display:flex; flex-direction:column; gap:8px; color:var(--content);}
.service-highlights li{line-height:1.5;}
.service-foot{display:flex; flex-direction:column; gap:6px; margin-top:4px;}
.service-stack{color:var(--brand); font-size:.95rem; letter-spacing:.3px;}
.service-outcome{color:var(--muted); font-size:.92rem;}
.service-foot .btn-small{align-self:flex-start; margin-top:6px;}

/* Work slider */
.work{ position:relative }
.work-slider{
  position:relative; z-index:20; margin-top:16px;
  background:#fff; border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow);
  overflow:hidden;
}
.work-track{
  display:flex; width:100%;
  transition: transform .4s ease; will-change: transform;
}
.work-slide{
  /* Lock each slide to the viewport width while keeping screenshots uncropped */
  flex: 0 0 100%;
  min-width:100%; position:relative;
  background:#ffffff;
  padding:clamp(12px, 3vw, 24px);
  display:flex; align-items:flex-end; justify-content:center;
  box-sizing:border-box;
  margin:0;
}
.work-slide img{
  display:block;
  width:100%;
  height:auto;
  max-width:100%;
}
.work-slide figcaption{
  position:absolute;
  left:clamp(16px, 3.4vw, 36px);
  right:clamp(16px, 3.4vw, 36px);
  bottom:clamp(16px, 3.4vw, 32px);
  background:rgba(17,24,39,.68); color:#fff; padding:10px 12px; border-radius:12px;
  display:flex; flex-direction:column; gap:2px;
}
.work-slide figcaption strong{ font-size:1rem }
.work-slide figcaption span{ font-size:.92rem; opacity:.95 }
.work-meta{display:flex; gap:8px; flex-wrap:wrap; margin-top:8px;}
.badge{
  display:inline-block; padding:6px 10px; border-radius:999px; font-size:.72rem;
  font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(255,255,255,.18); color:#f8fafc; border:1px solid rgba(255,255,255,.36);
}
.badge-light{
  background:rgba(6,139,216,.22);
  color:#f8fafc;
  border-color:rgba(6,139,216,.48);
}

.work-prev, .work-next{
  position:absolute; top:50%; transform:translateY(-50%);
  width:38px; height:38px; border-radius:999px; border:0;
  background:#fff; color:#111; box-shadow:0 6px 18px rgba(0,0,0,.25);
  cursor:pointer; font-size:22px; line-height:1;
}
.work-prev{ left:10px } .work-next{ right:10px }
.work-dots{
  display:flex; gap:8px; justify-content:center; align-items:center; padding:10px 0 12px;
  background:#fff; border-top:1px solid var(--border);
}
.work-dots button{
  width:9px; height:9px; border-radius:999px; border:0; background:#cbd5e1; cursor:pointer;
}
.work-dots button.active{ background:var(--brand) }

/* Blog */
.blog{
  background:linear-gradient(180deg, rgba(6,139,216,.04), rgba(248,250,252,1));
}
.blog-header{display:flex; flex-direction:column; gap:10px; max-width:620px;}
.blog-layout{
  display:grid;
  grid-template-columns:minmax(0, 2fr) minmax(0, 1fr);
  gap:32px;
  align-items:flex-start;
  margin-top:32px;
  position:relative;
  z-index:1; /* keep above watermark */
}
.blog-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:24px;
}
.post-card{
  display:flex; flex-direction:column;
  border-radius:22px; overflow:hidden;
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 32px rgba(15,23,42,.08); background:#fff;
}
.post-cover{
  display:block;
  position:relative;
  aspect-ratio:16/9;            /* keeps covers consistent on mobile */
  padding:32px 28px 80px;
  color:#fff;
  background:linear-gradient(135deg, rgba(6,139,216,.85), rgba(249,115,22,.75));
}
.post-cover h3{margin:12px 0 0; font-size:1.35rem; line-height:1.2;}
.post-tag{
  display:inline-block; padding:6px 10px; border-radius:12px;
  background:rgba(255,255,255,.2); font-weight:700; letter-spacing:.18em;
  font-size:.72rem; text-transform:uppercase;
}
.post-cover::after{
  content:"";
  position:absolute; inset:auto 0 0; height:4px;
  background:linear-gradient(90deg, rgba(255,255,255,.6), rgba(255,255,255,0));
}
.post-cover:focus-visible,
.post-cover:hover{outline:none; box-shadow:inset 0 0 0 2px rgba(255,255,255,.6);}
.post-body{padding:22px 24px 26px; display:flex; flex-direction:column; gap:12px;}
.post-meta{margin:0; font-size:.9rem; font-weight:600; letter-spacing:.18px; color:var(--brand);}
.post-link{font-weight:700; color:var(--brand); text-decoration:none;}
.post-link:hover,
.post-link:focus-visible{text-decoration:underline; outline:none;}
.blog-testimonials{
  background:#ffffff;
  border:1px solid rgba(15,23,42,.1);
  border-radius:22px;
  padding:24px;
  box-shadow:0 18px 32px rgba(15,23,42,.1);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.blog-testimonials-title{margin:0; font-size:1.35rem; color:var(--content);}
.blog-testimonials .muted{margin:0;}
.blog-testimonials .testimonials-slider{margin-top:6px;}

/* Steps */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:14px}
.step{background:#ffffff; border:1px solid var(--border); border-radius:var(--radius); padding:18px; box-shadow:var(--shadow)}
.step-num{width:34px; height:34px; border-radius:8px; display:grid; place-items:center; background:linear-gradient(135deg, var(--brand), var(--ok)); color:#ffffff; font-weight:800}

/* Footer */
footer{border-top:1px solid rgba(15,23,42,.12); padding:18px 0 24px; color:var(--brand)}
.foot{display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; text-align:center;}
.footer-note{color:var(--muted); font-size:.92rem; letter-spacing:.15px;}

/* Forms */
label{display:block; font-size:12px; color:var(--brand); margin:0 0 6px}
.input{
  width:100%; padding:12px 12px; border-radius:12px;
  border:1px solid rgba(13,15,15,.25); background:#ffffff;
  color:var(--content); outline:none
}
.input:focus{
  border-color: rgba(13,15,15,.8);
  box-shadow:0 0 0 4px rgba(13,15,15,.2)
}
.mt{margin-top:16px}
.mt-sm{margin-top:12px}
.form-row{display:flex; gap:10px; align-items:center; margin-top:14px}

/* Green gradient headings */

/* TEAM */
#team .section-title{
  color: transparent;
  background: linear-gradient(135deg, var(--brand), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
}
.team-grid{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; }
.team-card{
  position:relative; background:#ffffff; border:1px solid var(--border);
  border-radius:20px; padding:22px; box-shadow: var(--shadow);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.team-card:hover{ transform: translateY(-4px); box-shadow: 0 14px 36px rgba(13,15,15,.18); border-color: rgba(13,15,15,.28); }
.team-inner{ display:grid; grid-template-columns: 130px 1fr; gap:16px; align-items:center; }
.profile .vision{ margin-top:8px; }
.achievements{ margin:10px 0 0; padding-left:18px; color:var(--content); }
.achievements li{ margin:4px 0 }

.avatar{
  width:120px; height:120px; padding:2px; border-radius:50%;
  background:#000; box-shadow: 0 6px 18px rgba(13,15,15,.12);
  border:0; cursor:pointer;
}
.avatar img{ width:100%; height:100%; object-fit: cover; border-radius:50%; display:block; background:#f8fafc; }
.person-name{ margin:14px 0 4px; font-size:1.15rem; color:var(--content); }
.role{ margin:0 0 4px; font-weight:700; letter-spacing:.2px; color: var(--brand); }
.bio{ margin:8px 0 0; }
.vision{
  margin:8px 0 0; padding:10px 12px; font-style: italic; color: var(--content);
  background: linear-gradient(90deg, rgba(6,139,216,.08), rgba(6,139,216,0));
  border:1px solid rgba(6,139,216,.18); border-radius: 12px;
}

/* Testimonials */
.testimonials{
  background:linear-gradient(180deg, rgba(6,139,216,.05), rgba(249,115,22,.04));
  padding:60px 0;
}
.testimonials .muted{margin-bottom:20px;}
.testimonials-slider{
  position:relative; margin-top:28px; overflow:hidden;
  border-radius:24px; border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.92); box-shadow:0 14px 32px rgba(15,23,42,.08);
}
.testimonials-track{
  display:flex; width:100%; transition: transform .45s ease; will-change:transform;
  touch-action: pan-y;
}
.testimonial-slide{
  flex:0 0 100%; min-width:100%; padding:clamp(20px, 5vw, 36px);
  box-sizing:border-box; display:flex; justify-content:center;
}
.testimonial{
  background:#ffffff; border:1px solid rgba(15,23,42,.12); border-radius:18px;
  padding:clamp(18px, 4vw, 28px); box-shadow:0 12px 32px rgba(15,23,42,.08);
  display:flex; flex-direction:column; gap:18px; max-width:640px;
}
.testimonial p{margin:0; font-size:1rem; color:var(--content); line-height:1.6;}
.testimonial footer{display:flex; flex-direction:column; gap:4px;}
.testimonial footer strong{color:var(--brand); font-size:.95rem;}
.testimonial footer span{color:var(--muted); font-size:.85rem; letter-spacing:.2px;}
.testimonials-prev,
.testimonials-next{
  position:absolute; top:50%; transform:translateY(-50%);
  width:38px; height:38px; border-radius:999px; border:0;
  background:rgba(6,139,216,.18); color:var(--brand); box-shadow:0 6px 20px rgba(6,139,216,.18);
  cursor:pointer; font-size:22px; line-height:1; z-index:10;
}
.testimonials-prev{ left:12px; }
.testimonials-next{ right:12px; }
.testimonials-prev:focus-visible,
.testimonials-next:focus-visible{ outline:2px solid rgba(6,139,216,.8); outline-offset:2px; }
.testimonials-dots{
  display:flex; gap:8px; justify-content:center; align-items:center;
  padding:12px 0 16px; background:transparent;
}
.testimonials-dots button{
  width:9px; height:9px; border-radius:999px; border:0;
  background:rgba(148,163,184,.5); cursor:pointer;
}
.testimonials-dots button.active{ background:var(--brand); }

/* Lightbox */
.lightbox{ position:fixed; inset:0; display:none; z-index:1300; }
.lightbox.open{ display:block; }
.lightbox-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.62); backdrop-filter: blur(2px); }
.lightbox-content{
  position:absolute; inset:0; margin:auto; max-width:min(92vw,1000px); max-height:88vh;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:12px;
}
.lightbox-content img{
  max-width:100%; max-height:80vh; width:auto; height:auto; border-radius:14px;
  box-shadow:0 16px 48px rgba(0,0,0,.35); background:#fff;
}
.lightbox-content figcaption{ color:#fff; font-weight:600; text-align:center }
.lightbox-close{
  position:absolute; top:14px; right:18px; width:40px; height:40px;
  border-radius:999px; border:0; background:#ffffff; color:#111; font-size:28px;
  line-height:1; cursor:pointer; box-shadow:0 6px 18px rgba(0,0,0,.25);
}

/* Speech bubble (double-click/tap) */
.speech{
  position:absolute; bottom:18px; left:50%; transform:translateX(-50%);
  background:#111; color:#fff; padding:10px 14px; border-radius:14px;
  box-shadow:0 10px 28px rgba(0,0,0,.35);
  font-weight:700; letter-spacing:.2px; opacity:0; animation: bubbleIn .15s ease-out forwards;
}
.speech::after{
  content:""; position:absolute; bottom:-8px; left:50%; transform:translateX(-50%);
  width:0; height:0; border-left:8px solid transparent; border-right:8px solid transparent; border-top:8px solid #111;
}
@keyframes bubbleIn{ from{transform:translateX(-50%) translateY(6px); opacity:0} to{transform:translateX(-50%) translateY(0); opacity:1} }

/* RESPONSIVE */
@media (max-width: 900px){
  .nav-toggle{ display:block }
  .menu{
    position:fixed;
    top:calc(var(--nav-h) + 10px);
    right:16px;
    left:auto;
    width:min(320px, 88vw);
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    background:#fff;
    padding:16px;
    border:1px solid var(--border);
    border-radius:18px;
    box-shadow:0 18px 36px rgba(13,15,15,.18);
    max-height:calc(100vh - var(--nav-h) - 24px);
    overflow:auto;
    z-index:1050;
  }
  .menu.open{ display:flex }
  .menu a, .menu .menu-link{ font-size:.98rem; padding:6px 10px }
  .btn-cta{ align-self:flex-start; padding:8px 12px; font-size:.95rem }

  .has-submenu .submenu{
    position:static;
    display:none;
    width:100%;
    margin-top:10px;
    border-radius:18px;
    box-shadow:0 12px 30px rgba(15,23,42,.08);
    border:1px solid rgba(15,23,42,.12);
    background:#ffffff;
  }
  .has-submenu.open .submenu{ display:block }
  .has-submenu.open .submenu .submenu-inner{
    display:flex;
    flex-direction:column;
    gap:10px;
    border-top:0;
    padding:10px 12px;
  }
  .has-submenu.open .submenu .submenu-item{
    width:100%;
    background:linear-gradient(135deg, rgba(6,139,216,.08), rgba(249,115,22,.08));
    border:1px solid rgba(15,23,42,.12);
    border-radius:14px;
    padding:12px 16px;
  }
  .has-submenu > .menu-link{padding-right:40px;}
  .has-submenu > .menu-link::after{ right:16px; }
  .submenu-inner{ border-top-width:3px }
  .submenu-item{ padding:10px 10px }

  .hero .wrap{grid-template-columns:1fr}
  .hero-visual{order:-1; max-width:520px; justify-self:center;}
  .hero-proof{flex-direction:column; align-items:flex-start; gap:12px;}
  .hero-proof ul{gap:10px;}
  .hero-trust{flex-direction:column; align-items:flex-start; gap:10px;}
  .grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}

  .logo-mark{ width:var(--logo-size-md); height:var(--logo-size-md) }
  .nav .logo-mark{ width:var(--logo-size-md); height:var(--logo-size-md); }
  .logo-text{ font-size: var(--brand-name-md) }
  .nav .logo-text{ font-size: var(--brand-name-md); }

  .about-hero{padding:60px 0 28px;}
  .about-hero-inner{grid-template-columns:1fr; gap:28px; text-align:left;}
  .about-hero-media{justify-content:center;}
  .about-hero-media img{max-width:420px;}
  .about-stats-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
  .about-panels{grid-template-columns:repeat(2, minmax(0,1fr)); gap:20px;}
  .timeline{padding-left:22px;}
  .timeline li::before{left:-26px;}
  .values-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
  .about-cta-inner{flex-direction:column; align-items:flex-start;}
  .careers-inner{grid-template-columns:1fr;}
  .careers-highlight{order:2;}
  .careers-grid{grid-template-columns:1fr;}

  /* BLOG: stack and 2-up grid on tablets */
  .blog-layout{grid-template-columns:1fr; gap:28px;}
  .blog-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
  .blog-testimonials{padding:22px;}
  .post-cover{padding:28px 24px 72px;}

  .service-hero{padding:52px 0 30px;}
  .service-hero-inner{grid-template-columns:1fr; gap:28px;}
  .service-hero-media{justify-content:center;}
  .service-hero-media img{max-width:420px;}
  .service-columns{grid-template-columns:1fr;}
  .case-grid{grid-template-columns:1fr;}
  .service-cta-inner{flex-direction:column; align-items:flex-start;}
  .capability-grid{grid-template-columns:repeat(2, minmax(0,1fr));}
  .case-wrap{grid-template-columns:1fr; gap:28px;}
  .testimonials-preview{grid-template-columns:1fr;}
  .founder-grid{grid-template-columns:1fr;}
  .founder-card{flex-direction:column; align-items:flex-start; text-align:left;}
  .insights-grid{grid-template-columns:1fr;}
  .insight-cards{grid-template-columns:repeat(2, minmax(0,1fr));}
  .process-steps{grid-template-columns:repeat(2, minmax(0,1fr));}
  .cta-inner{flex-direction:column; align-items:flex-start;}
  .service-extras-grid{grid-template-columns:repeat(2, minmax(0,1fr));}

  .services-panel{grid-template-columns:1fr; gap:20px;}
  .services-tabs{position:relative; top:auto; flex-direction:row; overflow-x:auto; padding:12px;}
  .service-tab{flex:0 0 auto; white-space:nowrap;}

  .work-slide{
    padding:18px 18px 32px;
    gap:18px;
  }
  .work-slide figcaption{
    left:24px;
    right:24px;
    bottom:24px;
  }

  .team-grid{ grid-template-columns:1fr; }
  .team-inner{ grid-template-columns: 1fr; align-items:center; text-align:center; }
  .achievements{ padding-left:0; list-style-position: inside; text-align:left; margin-inline:auto; max-width:28rem; }
  .avatar{ width:110px; height:110px; }

  /* watermark: a bit brighter on tablets for visibility */
  :root{ --bg-logo-opacity: .1; --bg-logo-base: -110px; }

  .testimonials-slider{margin-top:24px;}
  .testimonial-slide{padding:24px;}
  .testimonial{padding:22px;}
}
@media (max-width: 560px){
  .menu a, .menu .menu-link{ font-size:.95rem; padding:6px }
  .btn-cta{ padding:8px 12px; font-size:.92rem }
  .menu{
    top:calc(var(--nav-h) + 6px);
    right:12px;
    width:min(88vw, 320px);
    padding:14px;
    border-radius:16px;
  }

  .nav .row{
    display:grid;
    grid-template-columns:minmax(0, 1fr) auto;
    grid-template-areas:
      "logo-img logo-img"
      "logo-text logo-text"
      "menu menu";
    align-items:center;
    column-gap:6px;
    row-gap:2px;
    padding:12px;
  }
  .nav .logo{ display:contents; }
  .logo-mark{
    grid-area:logo-img;
    justify-self:center;
    width:var(--logo-size-sm);
    height:var(--logo-size-sm);
  }
  .nav .logo-mark{ width:var(--logo-size-sm); height:var(--logo-size-sm); }
  .logo-text{
    grid-area:logo-text;
    text-align:center;
    justify-self:center;
    width:100%;
  }
  .nav .logo-text{ font-size: var(--brand-name-sm); }
  .nav-toggle{
    grid-column:2;
    grid-row:2;
    margin:0;
    justify-self:end;
    align-self:center;
  }
  .nav .menu{ grid-area:menu; }
  .logo-text{ font-size: var(--brand-name-sm); }
  .hero h1{ font-size: clamp(20px, 6.2vw, 30px); }
  .hero-visual{max-width:100%;}
  .steps{grid-template-columns:1fr}
  .avatar{ width:96px; height:96px; }

  .about-hero{padding:48px 0 24px;}
  .about-hero-inner{gap:24px;}
  .about-hero-media img{max-width:100%; height:220px;}
  .about-stats-grid{grid-template-columns:1fr;}
  .about-panels{grid-template-columns:1fr;}
  .about-panel img{height:200px;}
  .values-grid{grid-template-columns:1fr;}
  .about-cta-inner{gap:16px; align-items:flex-start;}
  .career-tags{gap:8px;}
  .careers-grid{gap:18px;}
  .role-card{padding:22px;}

  /* BLOG: phone single-column + tighter paddings */
  .blog-grid{grid-template-columns:1fr;}
  .home-insights{padding:48px 0;}
  .insights-grid{gap:24px;}
  .insight-cards{grid-template-columns:1fr; gap:16px;}
  .insight-card{padding:20px;}
  .insight-card h3{font-size:1.05rem;}
  .post-cover{
    aspect-ratio:16/9;
    padding:26px 22px 64px;
  }
  .post-body{padding:16px;}
  .blog-testimonials{padding:20px;}

  .service-hero{padding:44px 0 26px;}
  .service-hero-inner{gap:24px;}
  .service-hero-media img{max-width:100%; height:210px;}
  .case img{height:200px;}
  .capability-grid{grid-template-columns:1fr;}
  .insight-cards{grid-template-columns:1fr;}
  .process-steps{grid-template-columns:1fr;}
  .cta-actions{width:100%; display:flex; gap:12px;}

  .service-extras-grid{grid-template-columns:1fr;}

  .testimonials-prev,
  .testimonials-next{display:none;}
  .testimonial-slide{padding:18px;}
  .testimonial{padding:18px;}
  .testimonials-dots{padding:12px 0;}

  .services-tabs{padding:10px; gap:8px;}
  .service-tab{font-size:.95rem; padding:10px 12px;}

  .work-slide{
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    padding:16px 16px 26px;
    gap:18px;
  }
  .work-slide img{
    border-radius:16px;
  }
  .work-slide figcaption{
    position:static;
    width:100%;
    background:#0f172a;
    border-radius:16px;
    padding:16px;
    gap:8px;
    box-shadow:0 12px 28px rgba(15,23,42,.18);
  }
  .work-slide figcaption strong{font-size:1.05rem;}
  .work-meta{margin-top:10px;}

  /* watermark: large and visible on phones */
  :root{
    --bg-logo-size: clamp(720px, 180vw, 1600px);
    --bg-logo-opacity: .12;
    --bg-logo-base: -90px;
    --logo-size-sm: 140px;
    --brand-name-sm: 2.4rem;
  }

  footer{padding:14px 0 16px;}
  .foot{gap:4px;}
  .footer-note{font-size:.84rem;}
}

/* === Manki overrides (Orbitron + 45px brand + hero visual order on mobile) === */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@500;700;800;900&display=swap');

:root{
  --brand-font: "Orbitron", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --brand-name-all: 45px;
}

/* Apply Orbitron to brand everywhere */
.brand-name,
.logo-text,
.nav .logo-text,
.footer-brand{
  font-family: var(--brand-font) !important;
  font-size: var(--brand-name-all) !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: .01em !important;
}
.logo-text .logo-ai{ font-family: inherit !important; font-weight: inherit !important; }

/* Keep hamburger spacing & make sure it shows on mobile */
@media (max-width: 900px){
  .nav-toggle{ display:block !important; }
  .menu{ display:none; }
  .menu.open{ display:flex !important; }
  /* Move hero visual below copy on small screens */
  .hero .wrap{ grid-template-columns: 1fr !important; }
  .hero-visual{ order: 2 !important; }
}

/* --- BLOG: force a true mobile layout --- */
@media (max-width: 900px){
  /* Stack hero on blog (image below copy) */
  body.page-blog .service-hero-inner{
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  body.page-blog .service-hero-media{ justify-content: center !important; }
  body.page-blog .service-hero-media img{
    max-width: 100% !important;
    height: 220px !important;
    object-fit: cover !important;
    border-radius: 20px !important;
  }

  /* Blog list: one column */
  body.page-blog .blog-layout{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
    align-items: start !important;
  }
  body.page-blog .blog-grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* Keep container feeling mobile */
  body.page-blog .blog .container{
    width: 94% !important;
    max-width: 680px !important; /* prevents “desktop wide” feel */
  }

  /* Card paddings a bit tighter on small screens */
  body.page-blog .post-card{ border-radius: 18px !important; }
  body.page-blog .post-cover{ padding: 22px 18px 56px !important; }
  body.page-blog .post-body{ padding: 16px 16px 20px !important; }
}

@media (max-width: 560px){
  /* Even tighter on phones */
  body.page-blog .blog-layout{ gap: 18px !important; }
  body.page-blog .blog-grid{ gap: 14px !important; }

  body.page-blog .post-cover{
    aspect-ratio: 16/9 !important;
    padding: 18px 14px 50px !important;
  }
  body.page-blog .post-card{ border-radius: 16px !important; }
  body.page-blog .post-body{ padding: 14px !important; }
}

/* HERO */
.hero{
  position:relative;
  min-height:86vh;                 /* tall on mobile */
  display:grid;
  place-items:center;
  padding:16px;
  color:var(--white);
  background-image:
    url("/assets/hero-bg.jpg");    /* <- replace with your image path */
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

/* subtle dark-to-transparent wash so text stays readable */
.hero__overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.55));
}

/* floating card */
.hero__card{
  position:relative; z-index:1;
  width:100%;
  max-width:560px;
  padding:18px 18px 16px;
  border-radius:18px;
  background:rgba(255,255,255,.86);
  color:#0a0a0a;
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  box-shadow:0 10px 24px rgba(2,6,23,.2);
}

.hero__eyebrow{
  margin:0 0 8px 0;
  font:800 18px/1.2 "Orbitron", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing:.4px;
  color:#0b2a3d;
}

.hero__copy{
  margin:0 0 14px 0;
  font:500 14.5px/1.55 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.hero__cta{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--brand-orange);
  color:var(--white);
  text-decoration:none;
  font:700 14px/1 "Inter", system-ui;
  padding:12px 16px;
  border-radius:999px;
  box-shadow:0 6px 16px rgba(249,115,22,.35);
  transition:transform .12s ease, box-shadow .12s ease;
}
.hero__cta:active{ transform:translateY(1px); }
.hero__cta:hover{ box-shadow:0 8px 20px rgba(249,115,22,.42); }

/* ABOUT block */
.about{
  padding:28px 16px 44px;
  background:#fff;
  color:var(--text);
}
.about h3{
  font:800 18px/1.2 "Orbitron", system-ui;
  letter-spacing:.4px;
  margin:0 0 8px;
  color:#0b2a3d;
  position:relative;
}
.about h3::before,
.about h3::after{
  content:""; display:inline-block; width:14px; height:2px;
  background:var(--brand-orange); vertical-align:middle; margin:0 10px 5px 0;
}
.about h3::after{
  background:var(--brand-blue); margin:0 0 5px 10px;
}
.about p{ margin:0; font:500 14.5px/1.7 "Inter", system-ui; }

/* Tablet & up tweaks */
@media (min-width:768px){
  .hero{ min-height:78vh; padding:32px; }
  .hero__card{ padding:22px 22px 18px; }
  .hero__eyebrow{ font-size:22px; }
  .hero__copy{ font-size:16px; }
  .about{ padding:40px 24px 60px; }
  .about h3{ font-size:22px; }
}

/* MOBILE: bring the Services chevron in and center it */
@media (max-width: 900px){
  .has-submenu > .menu-link{
    position: relative;
    padding-right: 40px;     /* room for icon */
    min-height: 44px;
  }
  .has-submenu > .menu-link::after{
    right: 12px;             /* was ~16–18px; bring it inward */
    top: 50%;
    width: 8px; height: 8px; /* a bit smaller so it doesn’t feel cramped */
    transform: translateY(-50%) rotate(45deg);
  }
}

/* phones: nudge a bit more */
@media (max-width: 560px){
  .has-submenu > .menu-link{ padding-right: 36px; }
  .has-submenu > .menu-link::after{ right: 10px; width: 7px; height: 7px; }
}

/* --- BLOG: force a true mobile layout --- */
@media (max-width: 900px){
  /* Stack hero (image below copy) */
  body.page-blog .service-hero-inner{
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  body.page-blog .service-hero-media{ justify-content: center !important; }
  body.page-blog .service-hero-media img{
    max-width: 100% !important;
    height: 220px !important;
    object-fit: cover !important;
    border-radius: 20px !important;
  }

  /* Blog list: one column */
  body.page-blog .blog-layout{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 22px !important;
    align-items: start !important;
  }
  body.page-blog .blog-grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* Keep container feeling mobile */
  body.page-blog .blog .container{
    width: 94% !important;
    max-width: 680px !important;
  }
}

@media (max-width: 560px){
  /* Even tighter on phones */
  body.page-blog .blog-layout{ gap: 18px !important; }
  body.page-blog .blog-grid{ gap: 14px !important; }

  body.page-blog .post-cover{
    aspect-ratio: 16/9 !important;
    padding: 18px 14px 50px !important;
  }
  body.page-blog .post-card{ border-radius: 16px !important; }
  body.page-blog .post-body{ padding: 14px !important; }
}

/* --- NAV hover: keep only light blue on hover/focus --- */
.menu a,
.menu .menu-link{
  color: var(--black);
  transition: background .2s ease, color .2s ease, box-shadow .2s ease, text-decoration .2s;
}

/* Force the light-blue style and suppress the dark-blue override */
.menu a:hover,
.menu a:focus-visible,
.menu .menu-link:hover,
.menu .menu-link:focus-visible{
  background: rgba(6,139,216,.12) !important;  /* light blue wash */
  color: var(--brand) !important;               /* brand blue text */
  text-decoration: none;
  box-shadow: 0 2px 8px rgba(6,139,216,.25);
  outline: none;
}

/* can remove later Contact page: remove analytics image section */
.page-contact .contact-analytics,
.page-contact img[alt*="analytic" i],
.page-contact img[alt*="analytics" i] {
  display: none !important;
}

/* can remove later If layout was a 2-col grid, make it full width after removal */
.page-contact .contact.grid {
  grid-template-columns: 1fr !important;
}

/* can remove later If there was a gap reserved for the image, collapse it */
.page-contact .contact .right,
.page-contact .contact .media {
  display: none !important;
}

/* === Mobile tweaks: Home > Fintech section === */
@media (max-width: 640px) {
  /* Try the most likely IDs/classes first */
  #fintech,
  .section--fintech,
  .fintech-section {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }

  /* If it's inside a generic "hero" or "card" */
  #fintech .container,
  .section--fintech .container,
  .fintech-section .container {
    padding-left: 12px !important;
    padding-right: 12px !important;
    gap: 12px !important; /* if using CSS grid/flex gaps */
  }

  /* Fintech image sizing */
  #fintech img,
  .section--fintech img,
  .fintech-section img,
  img[alt*="fintech" i] {
    width: 100% !important;
    height: auto !important;
    max-height: 180px !important;   /* shrink visual depth */
    object-fit: cover;
    display: block;
    margin: 0 auto;
  }

  /* Trim headings & text spacing in that block */
  #fintech h1, #fintech h2, #fintech h3,
  .section--fintech h1, .section--fintech h2, .section--fintech h3,
  .fintech-section h1, .fintech-section h2, .fintech-section h3 {
    margin: 6px 0 !important;
    line-height: 1.15 !important;
  }
  #fintech p,
  .section--fintech p,
  .fintech-section p {
    margin: 6px 0 !important;
  }
}

/* ========= Founder Lightbox ========= */
#lightbox {
  border: none;
  padding: 0;
  width: min(95vw, 1200px);
  background: transparent;
}
#lightbox::backdrop {
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(2px);
}
#lightbox img {
  display: block;
  max-width: 95vw;
  max-height: 85vh;
  margin: 0 auto;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
#lightbox .lb-close {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 28px;
  line-height: 1;
  background: rgba(0,0,0,.6);
  color: #fff;
  border: 0;
  border-radius: 999px;
  width: 38px; height: 38px;
  cursor: pointer;
}
/* Thumbs look clickable */
.founder-thumb {
  cursor: zoom-in;
  border-radius: 12px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.founder-thumb:hover, .founder-thumb:focus {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.18);
  outline: none;
}
/* Screen reader only */
.sr-only {
  position: absolute !important;
  height: 1px; width: 1px;
  overflow: hidden; clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

