/* ========================================================
   ABAJ ARISE — Global Design System
   Fonts : Outfit (headings) + Plus Jakarta Sans (body)
   ======================================================== */

:root {
  /* Brand colours */
  --navy:       #0d1f3c;
  --navy-mid:   #1a3464;
  --navy-lt:    #1e4080;
  --amber:      #f59e0b;
  --amber-dk:   #d97706;
  --gold:       #d4a017;

  /* Backgrounds */
  --bg:         #f8f9ff;
  --bg-2:       #eef1f8;
  --white:      #ffffff;
  --dark:       #060f1e;

  /* Text */
  --text:       #1e293b;
  --text-2:     #475569;
  --text-3:     #94a3b8;
  --border:     #e2e8f0;

  /* Fonts */
  --fd: 'Outfit', sans-serif;
  --fb: 'Plus Jakarta Sans', sans-serif;

  /* Shadows */
  --sh-sm: 0 1px 3px rgba(13,31,60,.07);
  --sh-md: 0 4px 16px rgba(13,31,60,.10);
  --sh-lg: 0 12px 40px rgba(13,31,60,.14);
  --sh-xl: 0 24px 64px rgba(13,31,60,.18);

  /* Radii */
  --rs: 6px;
  --rm: 12px;
  --rl: 20px;
  --rxl: 32px;

  /* Transition */
  --t: 0.25s ease;
}

/* ── Reset ──────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--text);background:#fff;line-height:1.65;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit;border:none;background:none}

/* ── Typography ─────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{font-family:var(--fd);line-height:1.2;color:var(--navy)}

.text-gradient{
  background:linear-gradient(120deg,#d4a017 0%,#f59e0b 55%,#fbbf24 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* ── Layout ─────────────────────────────────────────────── */
.container{max-width:1380px;margin-inline:auto;padding-inline:2.5rem}
section{padding-block:6rem}

.section-badge{
  display:inline-flex;align-items:center;gap:.375rem;
  padding:.375rem .875rem;
  background:rgba(212,160,23,.1);border:1px solid rgba(212,160,23,.25);
  border-radius:100px;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--gold);
  margin-bottom:1rem;
}
.section-badge.light{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:rgba(255,255,255,.8)}

.section-title{
  font-family:var(--fd);font-size:clamp(1.75rem,3.5vw,2.75rem);
  font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:.875rem;
}
.section-title.light{color:#fff}

.section-desc{color:var(--text-2);font-size:1.05rem;max-width:580px;line-height:1.75}

.section-head{margin-bottom:4rem}
.section-head.center{text-align:center}
.section-head.center .section-desc{margin-inline:auto}

/* ── Buttons ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.875rem 1.875rem;border-radius:var(--rs);
  font-family:var(--fb);font-size:.9375rem;font-weight:700;
  letter-spacing:.01em;border:2px solid transparent;
  cursor:pointer;transition:all var(--t);white-space:nowrap;
}
.btn-primary{background:var(--amber);color:var(--navy);border-color:var(--amber)}
.btn-primary:hover{background:var(--amber-dk);border-color:var(--amber-dk);transform:translateY(-2px);box-shadow:0 8px 24px rgba(245,158,11,.35)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-mid);border-color:var(--navy-mid);transform:translateY(-2px);box-shadow:0 8px 24px rgba(13,31,60,.3)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.8)}
.btn-outline-navy{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-outline-navy:hover{background:var(--navy);color:#fff}
.btn-sm{padding:.625rem 1.25rem;font-size:.875rem}
.btn-lg{padding:1.0625rem 2.25rem;font-size:1rem}
.btn-full{width:100%;justify-content:center}
.btn-arrow{transition:transform var(--t)}
.btn:hover .btn-arrow{transform:translateX(3px)}

/* ── Navbar ──────────────────────────────────────────────── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:1rem 0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(16px);
  box-shadow:0 1px 0 var(--border);
  transition:box-shadow var(--t),padding var(--t);
}
.navbar.scrolled{
  box-shadow:0 1px 0 var(--border),var(--sh-md);
  padding:.75rem 0;
}
.nav-inner{
  display:flex;align-items:center;gap:2rem;
  max-width:1240px;margin-inline:auto;padding-inline:2rem;
}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:55px;width:auto}

.nav-links{display:flex;align-items:center;gap:.25rem;margin-left:auto}
.nav-link{
  padding:.5rem 1rem;font-size:.9rem;font-weight:600;
  border-radius:var(--rs);color:var(--text-2);transition:all var(--t);
}
.nav-link:hover{color:var(--navy);background:var(--bg)}
.nav-link.active{color:var(--navy);font-weight:700}
.nav-actions{display:flex;align-items:center;gap:.75rem}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.hamburger span{display:block;width:24px;height:2px;background:var(--navy);border-radius:2px;transition:all var(--t)}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile overlay */
.mobile-menu{
  display:none;position:fixed;inset:0;z-index:490;
  background:var(--navy);flex-direction:column;
  padding:7rem 2rem 3rem;gap:0;
}
.mobile-menu.open{display:flex}
.mobile-link{
  font-family:var(--fd);font-size:1.625rem;font-weight:800;
  color:rgba(255,255,255,.7);padding:1rem 0;
  border-bottom:1px solid rgba(255,255,255,.07);transition:color var(--t);
}
.mobile-link:hover,.mobile-link.active{color:var(--amber)}
.mobile-link:last-of-type{border-bottom:none}
.mobile-menu .btn{margin-top:2rem;align-self:flex-start}

/* ── Page Header (inner pages) ───────────────────────────── */
.page-header{
  background:linear-gradient(135deg,#060f1e 0%,#0d1f3c 45%,#1a3464 100%);
  padding:10rem 0 5.5rem;position:relative;overflow:hidden;
}
/* layered bg decorations */
.page-header::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 65% 80% at 100% 50%,rgba(245,158,11,.07) 0%,transparent 65%),
    radial-gradient(ellipse 50% 60% at 0% 100%,rgba(30,64,128,.5) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 55% 10%,rgba(255,255,255,.03) 0%,transparent 70%);
}
.page-header::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:64px 64px;
}
/* text animations */
@keyframes phFadeUp{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes phFadeIn{
  from{opacity:0}
  to{opacity:1}
}
.page-header-colossal{
  position:absolute;inset:0;z-index:0;
  display:flex;flex-direction:column;justify-content:center;
  gap:0;overflow:hidden;pointer-events:none;
  padding-left:2%;
}
.page-header-colossal span{
  display:block;
  font-family:var(--fd);font-size:clamp(4rem,9vw,8.5rem);
  font-weight:800;letter-spacing:-.03em;line-height:1;
  color:rgba(255,255,255,.04);white-space:nowrap;
  animation:phFadeIn 1s ease .05s both;
}
/* ── Building image page headers ─────────────────────────── */
@keyframes kenBurns{
  0%  {transform:scale(1)    translateX(0)}
  50% {transform:scale(1.06) translateX(-1%)}
  100%{transform:scale(1)    translateX(0)}
}

.page-header--services,
.page-header--whyus,
.page-header--about{
  background:none;
  isolation:isolate;
}

/* photo layer */
.page-header--services::before,
.page-header--whyus::before,
.page-header--about::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background-size:cover;background-position:center;
  animation:kenBurns 14s ease-in-out infinite;
}
.page-header--services::before{ background-image:url('building.png'); }
.page-header--whyus::before{    background-image:url('building-1.png'); }
.page-header--about::before{    background-image:url('office.png'); }

/* dark gradient overlay */
.page-header--services::after,
.page-header--whyus::after,
.page-header--about::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(135deg,rgba(6,15,30,.88) 0%,rgba(13,31,60,.78) 50%,rgba(26,52,100,.65) 100%),
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px) 0 0/64px 64px,
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px) 0 0/64px 64px;
}

/* colossal text brighter on image bg */
.page-header--services .page-header-colossal span,
.page-header--whyus .page-header-colossal span,
.page-header--about .page-header-colossal span{
  color:rgba(255,255,255,.06);
}

.page-header-content{position:relative;z-index:1}
.page-header .breadcrumb{
  animation:phFadeIn .5s ease .1s both;
}
.page-header h1{
  font-size:clamp(2.25rem,5vw,3.75rem);font-weight:800;color:#fff;margin-bottom:1rem;
  animation:phFadeUp .65s cubic-bezier(.22,1,.36,1) .25s both;
}
.page-header p{
  animation:phFadeUp .65s cubic-bezier(.22,1,.36,1) .4s both;
}
.page-header-subhead{
  font-size:clamp(1.1rem,2vw,1.375rem);font-weight:600;color:var(--amber);
  margin-bottom:.875rem;letter-spacing:-.01em;
  animation:phFadeUp .65s cubic-bezier(.22,1,.36,1) .38s both;
}
.page-header-desc{
  color:rgba(255,255,255,.6);font-size:1rem;
  max-width:600px;line-height:1.75;margin-bottom:1.75rem;
  animation:phFadeUp .65s cubic-bezier(.22,1,.36,1) .48s both;
}
.page-header-pills{
  display:flex;flex-wrap:wrap;gap:.75rem;
  animation:phFadeUp .65s cubic-bezier(.22,1,.36,1) .58s both;
}
.page-header-pill{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.4rem 1rem;
  border:1px solid rgba(255,255,255,.2);border-radius:100px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(6px);
  color:rgba(255,255,255,.8);font-size:.875rem;font-weight:500;
}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgba(255,255,255,.5)}
.breadcrumb a{color:rgba(255,255,255,.5);transition:color var(--t)}
.breadcrumb a:hover{color:var(--amber)}
.bc-sep{color:rgba(255,255,255,.25)}

/* ── Hero (home) ─────────────────────────────────────────── */
@keyframes graphDrift{
  0%  {transform:scale(1.08) translate(0,0)}
  33% {transform:scale(1.13) translate(-1%,-0.8%)}
  66% {transform:scale(1.1)  translate(1.2%,0.6%)}
  100%{transform:scale(1.08) translate(0,0)}
}
.hero{
  min-height:100dvh;
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  isolation:isolate;
}
/* graph.png photo layer */
.hero::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('graph.png') center/cover no-repeat;
  animation:graphDrift 20s ease-in-out infinite;
  pointer-events:none;
}
/* deep navy overlay preserving brand colours */
.hero::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(135deg,rgba(4,10,22,.95) 0%,rgba(10,25,52,.88) 45%,rgba(20,42,86,.80) 100%),
    radial-gradient(ellipse 60% 70% at 90% 40%,rgba(245,158,11,.07) 0%,transparent 65%),
    radial-gradient(ellipse 50% 60% at 5%  80%,rgba(30,64,128,.35) 0%,transparent 60%);
  pointer-events:none;
}
.hero-inner{flex:1;display:flex;align-items:center;position:relative;z-index:1;padding:7rem 0 4rem}
.hero-glow{position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.hero-glow-1{top:-200px;right:-100px;width:700px;height:700px;background:radial-gradient(circle,rgba(245,158,11,.07),transparent 65%)}
.hero-glow-2{bottom:-100px;left:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(30,64,128,.4),transparent 65%)}
.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:4rem;align-items:center}
.hero-content{position:relative;z-index:1}
.hero-region-badge{
  display:inline-flex;align-items:center;gap:.75rem;
  padding:.5rem 1.125rem;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:100px;font-size:.8125rem;font-weight:600;
  color:rgba(255,255,255,.75);margin-bottom:2rem;
}
.badge-dot{color:rgba(255,255,255,.25)}
.hero-title{
  font-family:var(--fd);font-size:clamp(2.5rem,5.5vw,4.75rem);
  font-weight:800;color:#fff;line-height:1.1;
  margin-bottom:1.5rem;letter-spacing:-.02em;
}
.hero-title em{font-style:normal;display:block}
@keyframes heroSlideUp{
  from{opacity:0;transform:translateY(32px)}
  to{opacity:1;transform:translateY(0)}
}
.hero-title-line1{
  display:block;
  opacity:0;
  animation:heroSlideUp .7s cubic-bezier(.22,1,.36,1) .15s forwards;
}
.hero-title-line2{
  opacity:0;
  animation:heroSlideUp .7s cubic-bezier(.22,1,.36,1) .4s forwards;
}
.hero-desc{font-size:1.125rem;color:rgba(255,255,255,.6);max-width:520px;line-height:1.75;margin-bottom:2.5rem}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3rem}
.hero-trust{display:flex;align-items:center;gap:1.75rem;flex-wrap:wrap}
.trust-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:rgba(255,255,255,.45);font-weight:500}
.trust-item svg{color:var(--amber);flex-shrink:0}
.hero-visual{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.75rem;overflow:hidden;min-width:0}
/* ── Hero Dashboard Card ─────────────────────────────────── */
@keyframes heroFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
/* ── Hero marquee stack ───────────────────────────────────── */
@keyframes hmLtr{
  0%  {transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
@keyframes hmRtl{
  0%  {transform:translateX(-50%)}
  100%{transform:translateX(0)}
}
.hero-marquee-stack{
  display:flex;flex-direction:column;justify-content:center;
  gap:1.1rem;overflow:hidden;width:100%;max-width:100%;
}
.hm-row{overflow:hidden;border-radius:6px;padding:.55rem 0}
.hm-row--outline{
  border-top:1px solid rgba(255,255,255,.1);
  border-bottom:1px solid rgba(255,255,255,.1);
}
.hm-row--filled{
  background:var(--amber);
}
.hm-row--ghost{
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.hm-track{
  display:flex;align-items:center;gap:1.5rem;
  white-space:nowrap;width:max-content;
}
.hm-ltr{animation:hmLtr 18s linear infinite}
.hm-rtl{animation:hmRtl 18s linear infinite}
.hm-slow{animation-duration:26s}

.hm-row--outline .hm-track span{
  font-family:var(--fd);font-size:clamp(1.1rem,2vw,1.6rem);
  font-weight:800;letter-spacing:-.01em;
  color:rgba(255,255,255,.9);
}
.hm-row--outline .hm-track em{
  font-style:normal;font-size:.6rem;color:rgba(255,255,255,.5);
}
.hm-row--filled .hm-track span{
  font-family:var(--fd);font-size:clamp(1.1rem,2vw,1.6rem);
  font-weight:800;letter-spacing:-.01em;
  color:var(--navy);
}
.hm-row--filled .hm-track em{
  font-style:normal;font-size:.6rem;color:rgba(13,31,60,.35);
}
.hm-row--ghost .hm-track span{
  font-family:var(--fd);font-size:clamp(1rem,1.8vw,1.4rem);
  font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.15);
}
.hm-row--ghost .hm-track em{
  font-style:normal;font-size:.5rem;color:rgba(255,255,255,.1);
}

/* ── Tools & Software section ────────────────────────────── */
@keyframes bg1Drift{
  0%  {transform:scale(1.08) translate(0,0)}
  33% {transform:scale(1.12) translate(-1%,-0.6%)}
  66% {transform:scale(1.1)  translate(0.8%,0.5%)}
  100%{transform:scale(1.08) translate(0,0)}
}
.tools-section{
  position:relative;overflow:hidden;padding-bottom:0;
  isolation:isolate;
}
/* bg-1 photo layer */
.tools-section::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('bg-1.png') center/cover no-repeat;
  animation:bg1Drift 18s ease-in-out infinite;
  pointer-events:none;
}
/* dark overlay */
.tools-section::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(135deg,rgba(6,15,30,.93) 0%,rgba(13,31,60,.87) 50%,rgba(26,52,100,.82) 100%),
    radial-gradient(ellipse 60% 50% at 50% 0%,rgba(245,158,11,.07) 0%,transparent 65%);
  pointer-events:none;
}
.tools-head{
  position:relative;z-index:1;
  text-align:center;padding-bottom:3rem;
}
.tools-logo-grid{position:relative;z-index:1}
.tools-single-ticker,.tools-marquee-stack{position:relative;z-index:1}
.tools-section .section-badge{background:rgba(245,158,11,.15);color:var(--amber);border-color:rgba(245,158,11,.25)}
.tools-section .section-title{color:#fff}
.tools-section .section-desc{color:rgba(255,255,255,.55);text-align:center;margin-inline:auto}
.tools-marquee-stack{display:flex;flex-direction:column;gap:0}
.tools-row{border-radius:0 !important;padding:.65rem 0}

/* override ghost text colour for light-on-dark context */
.tools-section .hm-row--ghost .hm-track span{color:rgba(255,255,255,.18)}
.tools-section .hm-row--outline .hm-track span{color:rgba(255,255,255,.9)}
.tools-section .hm-row--outline{
  border-color:rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
}
.tools-section .hm-row--ghost{
  border-color:rgba(255,255,255,.05);
}
.tools-single-ticker{
  border-radius:0 !important;
  padding:.7rem 0;
  margin-top:0;
}

/* tools logo grid */
.tools-logo-grid{
  display:grid;
  grid-template-columns:repeat(8,1fr);
  gap:1rem;
  margin-bottom:3rem;
}
.tool-logo-card{
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--rl);
  padding:1.5rem 1rem;
  transition:transform .3s cubic-bezier(.22,1,.36,1),
             background .3s ease,
             border-color .3s ease;
}
.tool-logo-card:hover{
  transform:translateY(-6px) scale(1.05);
  background:rgba(255,255,255,.12);
  border-color:rgba(245,158,11,.35);
}
.tool-logo-card img{
  width:40px;height:40px;object-fit:contain;
  filter:brightness(0) invert(1);
  opacity:.85;
  transition:opacity .3s ease,filter .3s ease;
}
.tool-logo-card:hover img{
  opacity:1;
  filter:none;
}
.tool-logo-card span{
  font-size:.72rem;font-weight:700;letter-spacing:.04em;
  color:rgba(255,255,255,.5);text-align:center;
  transition:color .3s ease;
}
.tool-logo-card:hover span{color:var(--amber)}
.tool-abbr{
  width:40px;height:40px;border-radius:8px;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;font-weight:800;letter-spacing:.04em;
  color:rgba(255,255,255,.7);transition:background .3s ease,color .3s ease;
}
.tool-logo-card:hover .tool-abbr{background:rgba(245,158,11,.2);color:var(--amber)}

@media(max-width:900px){
  .tools-logo-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:520px){
  .tools-logo-grid{grid-template-columns:repeat(3,1fr)}
}

.hero-card-logo img{width:130px;margin-inline:auto;margin-bottom:1.5rem;background:#fff;border-radius:var(--rm);padding:.75rem 1rem}
.hero-card-tagline{
  font-family:var(--fd);font-size:.75rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.35);margin-bottom:2rem;
}
.hero-flags{display:flex;gap:.625rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem}
.hero-flag{
  display:flex;align-items:center;gap:.4rem;
  padding:.375rem .875rem;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:100px;
  font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.7);
}
.hero-stat-row{
  display:flex;gap:0;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:1.5rem;
}
.hero-stat{flex:1;text-align:center}
.hero-stat + .hero-stat{border-left:1px solid rgba(255,255,255,.08)}
.hero-stat-num{
  display:block;font-family:var(--fd);font-size:1.625rem;font-weight:800;
  color:var(--amber);line-height:1;
}
.hero-stat-lbl{font-size:.7rem;color:rgba(255,255,255,.4);font-weight:600;text-transform:uppercase;letter-spacing:.07em;margin-top:.25rem;display:block}

/* Stats strip */
.stats-strip{background:#f4f6f9;padding:2.5rem 0;border-top:1px solid #e2e6ed}
.stats-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap}
.stat-item{text-align:center;padding:.875rem 3rem;flex:1;min-width:140px}
.stat-item+.stat-item{border-left:1px solid #d5dae3}
.stat-num{display:block;font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);font-weight:800;color:#b8860b;line-height:1}
.stat-lbl{font-size:.72rem;font-weight:700;color:#444;text-transform:uppercase;letter-spacing:.08em;margin-top:.35rem;display:block}

/* ── About Preview (home) ────────────────────────────────── */
.about-preview{background:var(--bg)}
.about-2col{display:grid;grid-template-columns:1fr 1.45fr;gap:5rem;align-items:center}

/* about-visual animations */
@keyframes aboutFadeUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes aboutPop{
  0%{opacity:0;transform:scale(.78)}
  70%{transform:scale(1.06)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes aboutSlideIn{
  from{opacity:0;transform:translateX(-16px)}
  to{opacity:1;transform:translateX(0)}
}
.about-visual.visible .about-visual-card{
  animation:aboutFadeUp .65s cubic-bezier(.22,1,.36,1) forwards;
}
.about-visual.visible .about-visual-card img{
  animation:aboutPop .7s cubic-bezier(.34,1.56,.64,1) .25s both;
}
.about-visual.visible .about-card-tagline{
  animation:aboutFadeUp .55s cubic-bezier(.22,1,.36,1) .45s both;
}
.about-visual.visible .flag-badge:nth-child(1){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) .55s both}
.about-visual.visible .flag-badge:nth-child(2){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) .65s both}
.about-visual.visible .flag-badge:nth-child(3){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) .75s both}
.about-visual.visible .flag-badge:nth-child(4){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) .85s both}
.about-visual.visible .flag-badge:nth-child(5){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) .95s both}
.about-visual.visible .flag-badge:nth-child(6){animation:aboutSlideIn .45s cubic-bezier(.22,1,.36,1) 1.05s both}

.about-visual-card{
  background:linear-gradient(145deg,var(--navy) 0%,var(--navy-lt) 100%);
  border-radius:var(--rl);padding:3rem 2.5rem;text-align:center;
  box-shadow:var(--sh-xl);
  opacity:0;
}
.about-visual-card img{width:120px;margin-inline:auto;margin-bottom:1.5rem;background:#fff;border-radius:var(--rm);padding:.75rem 1rem;opacity:0}
.about-card-tagline{
  font-family:var(--fd);font-size:.72rem;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
  opacity:0;
}
.about-flags{display:flex;gap:.625rem;justify-content:center;margin-top:1.75rem;flex-wrap:wrap}
.flag-badge{
  display:flex;align-items:center;gap:.375rem;
  padding:.375rem .875rem;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  border-radius:100px;font-size:.8125rem;font-weight:600;color:rgba(255,255,255,.7);
  opacity:0;
}
.about-pillars{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:1.75rem 0}
.pillar-item{display:flex;align-items:center;gap:.625rem;font-size:.9rem;font-weight:600;color:var(--navy)}
.pillar-check{
  width:20px;height:20px;border-radius:50%;
  background:rgba(245,158,11,.15);color:var(--amber);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.625rem;
}

/* ── Services grid (home preview) ────────────────────────── */
@keyframes building3Drift{
  0%  {transform:scale(1.08) translate(0,0)}
  33% {transform:scale(1.12) translate(-1%,-0.5%)}
  66% {transform:scale(1.1)  translate(0.8%, 0.5%)}
  100%{transform:scale(1.08) translate(0,0)}
}
.services-preview{
  position:relative;overflow:hidden;
  isolation:isolate;
}
/* building-3 photo layer */
.services-preview::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('building-3.png') center/cover no-repeat;
  animation:building3Drift 18s ease-in-out infinite;
  pointer-events:none;
}
/* dark navy overlay + grid texture */
.services-preview::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(135deg,rgba(6,15,30,.92) 0%,rgba(13,31,60,.85) 50%,rgba(26,52,100,.78) 100%),
    radial-gradient(ellipse 70% 60% at 80% 40%,rgba(245,158,11,.09) 0%,transparent 65%),
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px) 0 0/64px 64px,
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px) 0 0/64px 64px;
  pointer-events:none;
}
.services-preview .section-badge{background:rgba(245,158,11,.2);color:var(--amber);border-color:rgba(245,158,11,.3)}
.services-preview .section-title{color:#fff}
.services-preview .section-desc{color:rgba(255,255,255,.75)}
.svc-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.svc-card{
  background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--rl);padding:1.875rem 1.625rem;
  position:relative;overflow:hidden;transition:all var(--t);
}
.svc-card::after{
  content:'';position:absolute;top:0;left:0;
  width:100%;height:3px;
  background:linear-gradient(90deg,var(--amber),var(--gold));
  transform:scaleX(0);transform-origin:left;transition:transform var(--t);
}
.svc-card:hover::after{transform:scaleX(1)}
.svc-card:hover{transform:translateY(-5px);box-shadow:0 12px 36px rgba(0,0,0,.4);border-color:rgba(245,158,11,.35);background:rgba(0,0,0,.58)}
.svc-num{
  font-family:var(--fd);font-size:2.75rem;font-weight:800;
  color:rgba(245,158,11,.45);line-height:1;margin-bottom:.5rem;
}
.svc-icon{width:40px;height:40px;margin-bottom:1rem}
.svc-icon svg{width:100%;height:100%}
.svc-card h3{font-size:.9375rem;font-weight:700;color:#fff;margin-bottom:.5rem;line-height:1.3}
.svc-card p{font-size:.8125rem;color:rgba(255,255,255,.92);line-height:1.65}
.services-preview .btn-outline-navy{color:#fff;border-color:rgba(255,255,255,.35)}
.services-preview .btn-outline-navy:hover{background:#fff;color:var(--navy)}

/* ── Services page grid (full) ──────────────────────────── */
.svc-full-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.svc-full-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2.25rem;
  display:flex;gap:1.75rem;align-items:flex-start;
  transition:all var(--t);
}
.svc-full-card:hover{box-shadow:var(--sh-lg);border-color:rgba(245,158,11,.2)}
.svc-full-card > div:last-child{flex:1;min-width:0}
.svc-icon-wrap{
  width:56px;height:56px;border-radius:var(--rm);
  background:rgba(245,158,11,.1);color:var(--amber);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.svc-icon-wrap svg{width:26px;height:26px}
.svc-full-card h3{font-size:1.0625rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.svc-full-card > div > p{font-size:.9rem;color:var(--text-2);line-height:1.7;margin-bottom:0}
.svc-bullet-groups{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:.875rem 1.75rem;
  max-height:0;overflow:hidden;margin-top:0;
  transition:max-height .4s ease, margin-top .3s ease;
}
.svc-bullet-groups.open{max-height:3000px;margin-top:1.25rem}
.svc-toggle{
  display:flex;align-items:center;gap:.5rem;
  width:100%;margin-top:1.125rem;padding:.625rem 0 0;
  background:none;border:none;border-top:1px solid var(--border);
  color:var(--amber);font-size:.875rem;font-weight:600;
  cursor:pointer;text-align:left;font-family:inherit;
  transition:color var(--t);
}
.svc-toggle:hover{color:var(--amber-dk)}
.svc-toggle svg{margin-left:auto;transition:transform .3s ease;flex-shrink:0}
.svc-toggle.open svg{transform:rotate(180deg)}
.svc-bullet-head{
  font-size:.7rem;font-weight:700;color:var(--navy);
  text-transform:uppercase;letter-spacing:.06em;
  margin-bottom:.5rem;padding-bottom:.375rem;
  border-bottom:1px solid var(--border);
}
.svc-full-card ul{display:flex;flex-direction:column;gap:.35rem}
.svc-full-card ul li{
  font-size:.825rem;color:var(--text-2);
  display:flex;align-items:flex-start;gap:.5rem;line-height:1.6;
}
.svc-full-card ul li::before{content:'→';color:var(--amber);flex-shrink:0;font-weight:700;margin-top:.05em}
.svc-flag-list li::before{content:none}
.svc-bullet-group--wide{grid-column:1/-1}
.svc-ul-2col{display:grid;grid-template-columns:repeat(2,1fr);gap:.35rem 1.5rem}

/* ── Testimonials / Client Stories ───────────────────────── */
.testimonials-bg{background:var(--bg)}
.testi-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}
.testi-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2rem;box-shadow:var(--sh-sm);
  transition:all var(--t);flex:0 1 calc(33.333% - 1rem);min-width:260px;
}
.testi-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.testi-stars{display:flex;gap:2px;margin-bottom:1.125rem;color:var(--amber);font-size:1rem}
.testi-text{
  font-size:.9375rem;color:var(--text-2);line-height:1.75;
  margin-bottom:0;font-style:normal;
}
.testi-author{display:flex;align-items:center;gap:.875rem}
.testi-avatar{
  width:44px;height:44px;border-radius:50%;background:var(--navy);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:1rem;font-weight:700;flex-shrink:0;
}
.testi-name{font-size:.9375rem;font-weight:700;color:var(--navy)}
.testi-role{font-size:.8125rem;color:var(--text-3);margin-top:1px}
/* Story card elements */
.story-country{
  font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.5rem;
}
.story-meta{
  font-size:.8125rem;font-weight:600;color:var(--amber);
  text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:1rem;padding-bottom:.75rem;
  border-bottom:1px solid var(--border);
}

/* ── CTA Banner ──────────────────────────────────────────── */
@keyframes bokehDrift{
  0%  {transform:scale(1.08) translateX(0)   translateY(0)}
  33% {transform:scale(1.12) translateX(-1%) translateY(-1%)}
  66% {transform:scale(1.08) translateX(1%)  translateY(.5%)}
  100%{transform:scale(1.08) translateX(0)   translateY(0)}
}
.cta-banner{
  padding:5rem 0;text-align:center;position:relative;overflow:hidden;
  isolation:isolate;
}
/* bokeh photo layer */
.cta-banner::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('bokeh.png') center/cover no-repeat;
  animation:bokehDrift 16s ease-in-out infinite;
}
/* dark amber-navy overlay */
.cta-banner::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,rgba(6,12,26,.92) 0%,rgba(13,31,60,.85) 50%,rgba(26,52,100,.78) 100%);
}
.cta-content{position:relative;z-index:1;max-width:1000px;margin:0 auto}
.cta-banner h2{font-size:clamp(1.75rem,3.5vw,2.75rem);color:#fff;margin-bottom:.875rem}
.cta-banner p{
  color:rgba(255,255,255,.6);font-size:1rem;
  max-width:900px;margin:0 auto 1.25rem;line-height:1.7;
}
.cta-badges{
  display:flex;align-items:center;justify-content:center;
  flex-wrap:wrap;gap:0;margin-bottom:1.75rem;
}
.cta-badge-item{
  color:rgba(255,255,255,.72);font-size:.875rem;font-weight:500;
  padding:.25rem 1.25rem;
}
.cta-badge-item+.cta-badge-item{
  border-left:1px solid rgba(255,255,255,.2);
}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.cta-footer-note{
  color:rgba(255,255,255,.35);font-size:.8rem;
  max-width:900px;margin:0 auto 1.75rem;line-height:1.7;
}

/* ── Onboarding Process Section ─────────────────────────── */
.process-section{
  position:relative;overflow:hidden;isolation:isolate;
}
.process-section::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('bokeh.png') center/cover no-repeat;
  animation:bokehDrift 18s ease-in-out infinite;
  pointer-events:none;
}
.process-section::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,rgba(6,12,26,.93) 0%,rgba(13,31,60,.87) 50%,rgba(26,52,100,.80) 100%);
  pointer-events:none;
}
.process-section .container{position:relative;z-index:1}
.process-section .section-badge{
  background:rgba(245,158,11,.18);color:var(--amber);
  border:1px solid rgba(245,158,11,.3);
}
.process-section .section-title{color:#fff}
.process-section .section-desc{color:rgba(255,255,255,.65)}
/* process step cards on dark bg */
.process-section .process-step{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:1rem;
  padding:2rem 1.75rem;
}
.process-section .process-step:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(245,158,11,.35);
}
.process-section .process-step h3{color:#fff}
.process-section .process-step p{color:rgba(255,255,255,.62)}

/* ── Mission & Vision — connection overlay ───────────────── */
@keyframes connDrift{
  0%  {transform:scale(1.08) translate(0,0)}
  33% {transform:scale(1.12) translate(-1.5%,-1%)}
  66% {transform:scale(1.1)  translate(1%,.5%)}
  100%{transform:scale(1.08) translate(0,0)}
}
.mv-section{
  position:relative;overflow:hidden;
  background:var(--navy);
  isolation:isolate;
}
.mv-section-bg{
  position:absolute;inset:0;z-index:0;
  background:url('connection.png') center/cover no-repeat;
  opacity:.18;
  mix-blend-mode:screen;
  animation:connDrift 18s ease-in-out infinite;
}
/* dark gradient over the blend layer for depth */
.mv-section::after{
  content:'';position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 70% 60% at 50% 50%,rgba(13,31,60,.3) 0%,transparent 80%),
    linear-gradient(180deg,rgba(13,31,60,.55) 0%,rgba(13,31,60,.2) 50%,rgba(13,31,60,.55) 100%);
  pointer-events:none;
}
.mv-title{color:#fff !important}
.mv-section .section-badge{
  background:rgba(245,158,11,.2);color:var(--amber);border-color:rgba(245,158,11,.3);
}
/* glassmorphism cards */
.mv-card-glass{
  background:rgba(255,255,255,.07) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  backdrop-filter:blur(12px);
  box-shadow:0 8px 32px rgba(0,0,0,.25) !important;
  transition:transform .35s cubic-bezier(.22,1,.36,1),
             box-shadow .35s ease,
             background .35s ease,
             border-color .35s ease !important;
  cursor:default;
  position:relative;overflow:hidden;
}
/* shimmer sweep on hover */
.mv-card-glass::before{
  content:'';position:absolute;top:0;left:-75%;
  width:50%;height:100%;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);
  transform:skewX(-20deg);
  transition:left .55s ease;
  pointer-events:none;
}
.mv-card-glass:hover::before{left:130%}
.mv-card-glass:hover{
  transform:translateY(-8px) scale(1.02) !important;
  box-shadow:0 24px 56px rgba(0,0,0,.4),0 0 0 1px rgba(245,158,11,.3) !important;
  background:rgba(255,255,255,.12) !important;
  border-color:rgba(245,158,11,.4) !important;
}
.mv-card-glass h3{color:#fff !important}
.mv-card-glass p{color:rgba(255,255,255,.72) !important}
.mv-card-glass.navy{background:rgba(245,158,11,.1) !important;border-color:rgba(245,158,11,.25) !important}
.mv-card-glass.navy:hover{background:rgba(245,158,11,.18) !important}

/* icon pulse on card hover */
.mv-card-glass:hover .mv-icon{
  transform:scale(1.15) rotate(-6deg);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.mv-icon{
  width:48px;height:48px;border-radius:var(--rm);margin-bottom:1.25rem;
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s ease;
}

/* ── Why Us page cards ───────────────────────────────────── */
.why-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.why-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2.25rem;
  transition:all var(--t);
}
.why-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.why-card-navy{background:var(--navy);border-color:var(--navy);color:#fff}
.why-card-navy h3{color:#fff}
.why-card-navy p{color:rgba(255,255,255,.7)}
.why-icon{width:52px;height:52px;border-radius:var(--rm);margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center}
.why-icon-amber{background:rgba(245,158,11,.12);color:var(--amber)}
.why-icon-white{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9)}
.why-icon svg{width:26px;height:26px}
.why-card h3{font-size:1.0625rem;font-weight:700;margin-bottom:.625rem}
.why-card p{font-size:.9rem;color:var(--text-2);line-height:1.7}
.why-card-navy p{color:rgba(255,255,255,.7)}

/* Process steps */
.process-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:2rem;position:relative}
.process-grid .process-step{grid-column:span 2}
.process-grid .process-step:nth-child(4){grid-column:2/4}
.process-grid .process-step:nth-child(5){grid-column:4/6}
.process-grid::before{display:none}
.process-step{text-align:center;position:relative;z-index:1}
.process-dot{
  width:52px;height:52px;border-radius:50%;
  background:var(--amber);color:var(--navy);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:1.125rem;font-weight:800;
  margin:0 auto 1.25rem;box-shadow:0 0 0 6px rgba(245,158,11,.12);
}
.process-step h3{font-size:.9375rem;font-weight:700;margin-bottom:.5rem}
.process-step p{font-size:.85rem;color:var(--text-2);line-height:1.65}

/* Engagement Models */
.engage-group{margin-bottom:3.5rem}
.engage-group-label{
  display:flex;align-items:center;justify-content:center;gap:.75rem;
  font-size:1.1875rem;font-weight:800;color:var(--navy);
  margin-bottom:1.75rem;
  padding:1rem 2rem;
  background:var(--navy);color:#fff;
  border-radius:var(--rl);
  border-left:4px solid var(--amber);
  letter-spacing:-.01em;
}
.engage-group .why-grid-3{grid-template-columns:repeat(2,1fr)}
.engage-group-icon{font-size:1.375rem;line-height:1}
.engage-tag{
  display:inline-block;font-size:.6875rem;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;background:var(--amber);color:var(--navy);
  border-radius:4px;
  padding:.2em .6em;margin-left:.375rem;vertical-align:middle;
}
.engage-footnote{
  text-align:center;font-size:.9375rem;color:var(--text-2);line-height:1.7;
  max-width:680px;margin:2rem auto 0;
  padding:1.25rem 1.75rem;
  background:var(--bg);border:1px solid var(--border);border-radius:var(--rl);
}

/* Industries */
.industry-tags{display:flex;gap:.625rem;flex-wrap:wrap}
.industry-tag{
  padding:.5rem 1.125rem;background:var(--bg);border:1px solid var(--border);
  border-radius:100px;font-size:.875rem;font-weight:600;color:var(--navy);
  transition:all var(--t);
}
.industry-tag:hover{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  padding:1.375rem 0;cursor:pointer;
  font-size:1.0625rem;font-weight:600;color:var(--navy);
  transition:color var(--t);background:none;border:none;width:100%;
  text-align:left;font-family:var(--fd);
}
.faq-q:hover{color:var(--amber)}
.faq-q svg{flex-shrink:0;width:20px;height:20px;transition:transform var(--t);color:var(--text-3)}
.faq-item.open .faq-q{color:var(--amber)}
.faq-item.open .faq-q svg{transform:rotate(45deg);color:var(--amber)}
.faq-a{display:none;padding:0 0 1.375rem;font-size:.9375rem;color:var(--text-2);line-height:1.75}
.faq-item.open .faq-a{display:block}

/* ── Contact page ────────────────────────────────────────── */
.contact-2col{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start}
.contact-info-list{display:flex;flex-direction:column;gap:1.5rem}
.contact-info-item{display:flex;gap:1rem;align-items:flex-start}
.contact-icon{
  width:44px;height:44px;border-radius:var(--rm);
  background:rgba(245,158,11,.1);color:var(--amber);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.contact-icon svg{width:20px;height:20px}
.contact-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:.25rem}
.contact-value{font-size:.9375rem;font-weight:500;color:var(--text);line-height:1.55}
.contact-value a{color:var(--amber);transition:color var(--t)}
.contact-value a:hover{color:var(--amber-dk)}

.contact-form-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2.5rem;box-shadow:var(--sh-md);
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.5rem}
.form-label{font-size:.8125rem;font-weight:700;color:var(--text);letter-spacing:.02em}
.form-input,.form-select,.form-textarea{
  padding:.875rem 1rem;border:2px solid var(--border);border-radius:var(--rs);
  font-family:var(--fb);font-size:.9375rem;color:var(--text);background:var(--white);
  outline:none;transition:border-color var(--t),box-shadow var(--t);width:100%;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.12);
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-3)}
.form-textarea{resize:vertical;min-height:130px}
.form-note{margin-top:.75rem;font-size:.75rem;color:var(--text-3);text-align:center}
.form-success{
  display:none;align-items:flex-start;gap:1rem;
  padding:1.5rem;border-radius:var(--rl);
  background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.25);
  color:#166534;margin-top:1rem;
}
.form-success svg{color:#16a34a;flex-shrink:0;margin-top:2px}
.form-success strong{display:block;font-weight:700;margin-bottom:.25rem}
.form-success p{font-size:.9rem;color:#166534;margin:0}
.form-error{
  display:none;align-items:flex-start;gap:1rem;
  padding:1.5rem;border-radius:var(--rl);
  background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.25);
  color:#991b1b;margin-top:1rem;
}
.form-error svg{color:#dc2626;flex-shrink:0;margin-top:2px}
.form-error strong{display:block;font-weight:700;margin-bottom:.25rem}
.form-error p{font-size:.9rem;color:#991b1b;margin:0}
.form-error a{color:#dc2626;text-decoration:underline}

/* ── About page ──────────────────────────────────────────── */
/* ── Story Hero ─────────────────────────────────────────── */
.story-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,#ffffff 0%,#f0f4ff 60%,#e8edf8 100%);
  padding:6rem 0;
  border-top:4px solid var(--amber);
}
.story-hero-bg{position:absolute;inset:0;pointer-events:none}
.story-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.25}
.story-orb-1{width:520px;height:520px;background:rgba(26,52,100,.15);top:-120px;right:-180px}
.story-orb-2{width:380px;height:380px;background:rgba(245,158,11,.1);bottom:-60px;left:-5%}
.story-orb-3{width:260px;height:260px;background:rgba(26,52,100,.08);top:40%;left:45%}
.story-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(26,52,100,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(26,52,100,.04) 1px,transparent 1px);
  background-size:60px 60px;
}

.story-hero-2col{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1fr 1.15fr;gap:5rem;align-items:center;
}

/* left image column */
.story-img-col{
  display:flex;align-items:center;justify-content:center;
  animation:storyFadeUp .75s cubic-bezier(.22,1,.36,1) .1s both;
}
.story-stock-img{
  width:100%;max-width:460px;
  filter:drop-shadow(0 20px 48px rgba(13,31,60,.18));
  animation:storyImgFloat 5s ease-in-out infinite;
}
@keyframes storyImgFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-16px)}
}

/* right text column */
.story-text-col{
  display:flex;flex-direction:column;gap:1.5rem;text-align:left;
}

/* entrance keyframes */
@keyframes storyFadeUp{
  from{opacity:0;transform:translateY(30px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes storyFadeIn{
  from{opacity:0}
  to{opacity:1}
}
@keyframes storyScaleIn{
  from{opacity:0;transform:scale(.85)}
  to{opacity:1;transform:scale(1)}
}

.story-badge-row{
  display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
  animation:storyFadeUp .6s cubic-bezier(.22,1,.36,1) .2s both;
}
.story-hero-logo{
  height:56px;background:#fff;border-radius:var(--rm);padding:.5rem .875rem;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.founded-badge{
  display:inline-block;
  padding:.5rem 1.25rem;
  background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);
  border-radius:100px;font-size:.8125rem;font-weight:700;color:var(--amber);
}
.story-hero-title{
  font-family:var(--fd);font-size:clamp(1.75rem,3vw,2.75rem);font-weight:800;
  color:var(--navy);line-height:1.15;letter-spacing:-.02em;margin:0;
  animation:storyFadeUp .7s cubic-bezier(.22,1,.36,1) .25s both;
}
.story-hero-title em{
  font-style:normal;
  background:linear-gradient(90deg,var(--amber),#d97706);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.story-hero-tagline{
  font-family:var(--fd);font-size:.8rem;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:rgba(13,31,60,.35);margin:0;
  animation:storyFadeIn .6s ease .4s both;
}
.story-hero-body{
  max-width:720px;
  animation:storyFadeUp .7s cubic-bezier(.22,1,.36,1) .45s both;
}
.story-hero-body p{
  font-size:1rem;line-height:1.85;color:var(--text-2);margin-bottom:1rem;
}
.story-hero-body p:last-child{margin-bottom:0}
.story-hero-body strong{color:var(--navy)}

.story-hero-stats{
  display:flex;gap:3rem;flex-wrap:wrap;
  padding:1.75rem 3rem;
  background:rgba(13,31,60,.04);border:1px solid rgba(13,31,60,.1);
  border-radius:var(--rl);
  animation:storyScaleIn .65s cubic-bezier(.22,1,.36,1) .6s both;
}
.story-stat{text-align:center}
.story-stat-num{
  display:block;font-family:var(--fd);font-size:2.25rem;font-weight:800;
  color:var(--amber);line-height:1;
}
.story-stat-lbl{
  display:block;font-size:.72rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:rgba(13,31,60,.45);margin-top:.35rem;
}
.story-hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;
  animation:storyFadeUp .6s cubic-bezier(.22,1,.36,1) .75s both;
}
.mv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.mv-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2.5rem;box-shadow:var(--sh-sm);
}
.mv-card.navy{background:var(--navy);border-color:var(--navy)}
.mv-card.navy h3{color:#fff}
.mv-card.navy p{color:rgba(255,255,255,.7)}
.mv-icon-amber{background:rgba(245,158,11,.12);color:var(--amber)}
.mv-icon-white{background:rgba(255,255,255,.12);color:rgba(255,255,255,.8)}
.mv-card h3{font-size:1.125rem;font-weight:700;margin-bottom:.625rem}
.mv-card p{font-size:.9375rem;color:var(--text-2);line-height:1.7}

.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.value-card{
  background:var(--bg);border:1px solid var(--border);
  border-radius:var(--rl);padding:2rem;text-align:center;
  transition:all var(--t);
}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);background:var(--white);border-color:rgba(245,158,11,.2)}
.value-icon{
  width:52px;height:52px;border-radius:var(--rm);
  background:rgba(245,158,11,.1);color:var(--amber);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.125rem;transition:background var(--t);
}
.value-card:hover .value-icon{background:rgba(245,158,11,.18)}
.value-icon svg{width:22px;height:22px}
.value-card h3{font-size:.9375rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.value-card p{font-size:.8125rem;color:var(--text-2);line-height:1.65}

/* ── Countries We Serve ─────────────────────────────────── */
@keyframes bokeh2Pan{
  0%  {transform:scale(1.1) translate(0,0)}
  33% {transform:scale(1.14) translate(-1.5%,-1%)}
  66% {transform:scale(1.1)  translate(1%,.8%)}
  100%{transform:scale(1.1) translate(0,0)}
}
@keyframes flagBounce{
  0%,100%{transform:translateY(0) scale(1)}
  40%    {transform:translateY(-10px) scale(1.15)}
  60%    {transform:translateY(-6px) scale(1.1)}
}
.countries-section{
  position:relative;overflow:hidden;isolation:isolate;
}
/* bokeh-2 photo layer */
.countries-section::before{
  content:'';position:absolute;inset:0;z-index:-2;
  background:url('bokeh-2.png') center/cover no-repeat;
  animation:bokeh2Pan 20s ease-in-out infinite;
  pointer-events:none;
}
/* overlay: dark navy gradient so cards stay readable */
.countries-section::after{
  content:'';position:absolute;inset:0;z-index:-1;
  background:linear-gradient(135deg,rgba(6,15,30,.9) 0%,rgba(13,31,60,.82) 50%,rgba(26,52,100,.75) 100%);
  pointer-events:none;
}
.countries-section .section-badge{
  background:rgba(245,158,11,.2);color:var(--amber);border-color:rgba(245,158,11,.3);
}
.countries-section .section-title{color:#fff}
.countries-section .section-desc{color:rgba(255,255,255,.65)}

.countries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.country-card{
  background:rgba(0,0,0,.48);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--rl);padding:2rem;text-align:center;
  backdrop-filter:blur(10px);
  box-shadow:0 8px 28px rgba(0,0,0,.35);
  transition:transform .35s cubic-bezier(.22,1,.36,1),
             box-shadow .35s ease,
             background .35s ease,
             border-color .35s ease;
  position:relative;overflow:hidden;
}
/* shimmer on hover */
.country-card::before{
  content:'';position:absolute;top:0;left:-75%;width:50%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.08),transparent);
  transform:skewX(-20deg);transition:left .5s ease;pointer-events:none;
}
.country-card:hover::before{left:130%}
.country-card:hover{
  transform:translateY(-8px) scale(1.03);
  background:rgba(0,0,0,.62);
  border-color:rgba(245,158,11,.4);
  box-shadow:0 20px 48px rgba(0,0,0,.5),0 0 0 1px rgba(245,158,11,.25);
}
.country-card:hover .country-flag{
  animation:flagBounce .6s cubic-bezier(.34,1.56,.64,1) forwards;
}
.country-flag{font-size:2.5rem;margin-bottom:.75rem;display:block;transition:transform .3s ease}
.country-card h3{font-size:1.0625rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.country-card p{font-size:.875rem;color:rgba(255,255,255,.92);line-height:1.65}
.country-auth{
  font-size:.7rem;font-weight:700;color:var(--amber);
  letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:.875rem;padding-bottom:.625rem;
  border-bottom:1px solid rgba(255,255,255,.1);
}
.country-items{
  text-align:left;list-style:none;
  display:flex;flex-direction:column;gap:.4rem;
}
.country-items li{
  font-size:.775rem;color:rgba(255,255,255,.72);line-height:1.5;
  padding-left:1rem;position:relative;
}
.country-items li::before{
  content:'→';position:absolute;left:0;
  color:var(--amber);font-size:.7rem;font-weight:700;top:.05em;
}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.team-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:2.25rem;text-align:center;
  box-shadow:var(--sh-sm);transition:all var(--t);
}
.team-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.team-avatar{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-lt) 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-family:var(--fd);font-size:1.5rem;font-weight:800;
  margin:0 auto 1rem;
}
.team-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}
.team-role{font-size:.875rem;color:var(--amber);font-weight:600;margin-bottom:.625rem}
.team-card p{font-size:.85rem;color:var(--text-2);line-height:1.65}

/* Brochure section */
.brochure-section{background:var(--bg)}
.brochure-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--rl);padding:3rem;
  display:flex;align-items:center;gap:3rem;
  box-shadow:var(--sh-md);
}
.brochure-icon{
  width:72px;height:72px;border-radius:var(--rl);
  background:rgba(245,158,11,.1);color:var(--amber);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.brochure-icon svg{width:36px;height:36px}
.brochure-text h3{font-size:1.375rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}
.brochure-text p{font-size:.9375rem;color:var(--text-2);line-height:1.7}
.brochure-actions{margin-top:1.25rem;display:flex;gap:1rem;flex-wrap:wrap}

/* ── Footer ──────────────────────────────────────────────── */
.footer{background:#f0f2f5;color:#333;font-family:var(--fb)}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;
  gap:4rem;padding:5rem 0 4rem;
  border-bottom:1px solid #d5dae3;
}
.footer-logo img{height:64px;margin-bottom:1rem;border-radius:var(--rs);padding:.375rem .75rem}
.footer-desc{font-family:var(--fb);font-size:.9rem;line-height:1.75;color:#555;max-width:280px;margin-bottom:1.5rem}
.footer-social{display:flex;gap:.625rem}
.footer-social a{
  width:36px;height:36px;border-radius:var(--rs);
  background:#e2e6ed;border:1px solid #cdd2da;
  display:flex;align-items:center;justify-content:center;
  color:#555;font-size:.875rem;transition:all var(--t);
  text-decoration:none;
}
.footer-social a:hover{background:var(--amber);border-color:var(--amber);color:#fff}
.footer-col-head{
  font-family:var(--fb);font-size:.75rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:#888;margin-bottom:1.25rem;
}
.footer-links{display:flex;flex-direction:column;gap:.75rem}
.footer-link{
  font-family:var(--fb);font-size:.9rem;
  color:#444;transition:color var(--t);
}
.footer-link:hover{color:var(--amber)}
.footer-contact-item{
  display:flex;gap:.75rem;align-items:flex-start;
  font-family:var(--fb);font-size:.9rem;
  color:#444;margin-bottom:.875rem;line-height:1.5;
}
.footer-contact-icon{color:var(--amber);flex-shrink:0;margin-top:1px}
.footer-bottom{
  font-family:var(--fb);display:flex;align-items:center;
  justify-content:space-between;flex-wrap:wrap;gap:.75rem;
  padding:1.5rem 0;font-size:.8125rem;color:#777;
}

/* ── Scroll Reveal ───────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.reveal.visible{opacity:1;transform:none}

/* ── Responsive ──────────────────────────────────────────── */
@media(max-width:1100px){
  .svc-grid-4{grid-template-columns:repeat(2,1fr)}
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{display:none}
  .process-grid{grid-template-columns:repeat(4,1fr)}
  .process-grid .process-step{grid-column:span 2}
  .process-grid .process-step:nth-child(4){grid-column:2/4}
  .process-grid .process-step:nth-child(5){grid-column:2/4}
  .values-grid{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:900px){
  .story-hero-2col{grid-template-columns:1fr;gap:2.5rem}
  .story-img-col{order:-1}
  .about-2col,.contact-2col{grid-template-columns:1fr;gap:3rem}
  .mv-grid,.why-grid-3,.team-grid{grid-template-columns:1fr 1fr}
  .testi-grid .testi-card{flex:0 1 calc(50% - .75rem)}
  .countries-grid{grid-template-columns:repeat(2,1fr)}
  .svc-full-grid{grid-template-columns:1fr}
  section{padding-block:4.5rem}
  .brochure-card{flex-direction:column;gap:1.5rem;text-align:center}
  .brochure-actions{justify-content:center}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
}

@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .stat-item+.stat-item{border-left:none;border-top:1px solid rgba(255,255,255,.08)}
  .stats-row{flex-direction:column}
  .why-grid-3,.mv-grid,.team-grid{grid-template-columns:1fr}
  .testi-grid .testi-card{flex:0 1 100%}
  .countries-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .svc-grid-4{grid-template-columns:1fr}
  .values-grid{grid-template-columns:repeat(2,1fr)}
  .process-grid{grid-template-columns:1fr}
  .process-grid .process-step,.process-grid .process-step:nth-child(4),.process-grid .process-step:nth-child(5){grid-column:1/-1}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .form-grid{grid-template-columns:1fr}
}

@media(max-width:600px){
  .container{padding-inline:1.25rem}
  section{padding-block:3.5rem}
  .values-grid{grid-template-columns:1fr}
  .hero-trust{gap:1rem}
  .hero-region-badge{font-size:.75rem}
}
