/* ============================================================
   BANJO TECH LTD — DESIGN SYSTEM v2
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&display=swap');

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
img,svg{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}

/* ── TOKENS ── */
:root{
  --navy:#0B1526;--navy-mid:#0F1E3C;
  --blue:#1D4ED8;--blue-hover:#1A43C0;--blue-light:#EFF6FF;--blue-mid:#3B82F6;
  --teal:#0EA5E9;--white:#FFFFFF;--off-white:#F9FAFB;
  --gray-50:#F8FAFC;--gray-100:#F1F5F9;--gray-200:#E2E8F0;--gray-300:#CBD5E1;
  --gray-400:#94A3B8;--gray-500:#64748B;--gray-600:#475569;
  --gray-700:#334155;--gray-800:#1E293B;--gray-900:#0F172A;
  --green:#16A34A;--green-light:#F0FDF4;--red:#DC2626;--red-light:#FEF2F2;
  --font-head:'Sora',sans-serif;--font-body:'DM Sans',sans-serif;
  --max-w:1200px;--pad-x:clamp(16px,4vw,60px);--section-y:clamp(56px,8vw,104px);
  --radius-sm:4px;--radius:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.07),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.09),0 4px 8px rgba(0,0,0,.04);
  --shadow-xl:0 24px 56px rgba(0,0,0,.12);
  --shadow-blue:0 8px 32px rgba(29,78,216,.22);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-in-out:cubic-bezier(0.4,0,0.2,1);
  --transition:200ms var(--ease-in-out);
  --transition-md:320ms var(--ease-out);
  --transition-slow:500ms var(--ease-out);
}

/* ── KEYFRAMES ── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-28px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:translateX(0)}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes gradMove{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes countUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}

/* ── BASE ── */
body{font-family:var(--font-body);font-size:16px;font-weight:300;line-height:1.7;color:var(--gray-800);background:var(--white);-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.2;color:var(--gray-900)}
h1{font-size:clamp(28px,5.5vw,64px);letter-spacing:-1.5px}
h2{font-size:clamp(22px,3.5vw,44px);letter-spacing:-0.8px}
h3{font-size:clamp(18px,2vw,26px);letter-spacing:-0.4px}
h4{font-size:clamp(15px,1.5vw,18px);letter-spacing:-0.2px}
h5{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;font-weight:700}
p{color:var(--gray-600)}
strong{font-weight:600;color:var(--gray-800)}

/* ── LAYOUT ── */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:var(--section-y) 0}
.section-label{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.section-label::before{content:'';display:block;width:20px;height:2px;background:var(--blue);border-radius:1px}
.section-intro{max-width:560px}
.section-intro p{font-size:17px;margin-top:14px;line-height:1.75}
.text-center{text-align:center}
.text-center .section-intro{margin:0 auto}
.text-center .section-label{margin:0 auto 14px}
.text-center .section-label::before{display:none}

/* ── RESPONSIVE GRID ── */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--radius);font-family:var(--font-head);font-size:14px;font-weight:600;letter-spacing:.2px;cursor:pointer;border:2px solid transparent;transition:all var(--transition-md);white-space:nowrap;position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent}
.btn:active{transform:scale(0.97)!important}
.btn-primary{background:var(--blue);color:var(--white);border-color:var(--blue);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.btn-primary:hover{background:var(--blue-hover);border-color:var(--blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-blue)}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.3)}
.btn-outline:hover{border-color:var(--white);background:rgba(255,255,255,.1);transform:translateY(-1px)}
.btn-outline-dark{background:transparent;color:var(--gray-800);border-color:var(--gray-300)}
.btn-outline-dark:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light);transform:translateY(-1px)}
.btn-sm{padding:9px 18px;font-size:13px}
.btn-lg{padding:16px 36px;font-size:16px}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--gray-200);transition:box-shadow var(--transition)}
.nav.scrolled{box-shadow:var(--shadow-md)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.nav-logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-logo:hover{opacity:.8}
.nav-logo-mark{width:34px;height:34px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;color:white;font-size:15px;font-weight:800;font-family:var(--font-head);letter-spacing:-1px;flex-shrink:0;transition:transform var(--transition)}
.nav-logo:hover .nav-logo-mark{transform:rotate(-5deg) scale(1.05)}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links>a{font-family:var(--font-head);font-size:14px;font-weight:500;color:var(--gray-600);padding:8px 14px;border-radius:var(--radius);transition:all var(--transition);position:relative}
.nav-links>a::after{content:'';position:absolute;bottom:4px;left:14px;right:14px;height:2px;background:var(--blue);border-radius:1px;transform:scaleX(0);transition:transform var(--transition-md)}
.nav-links>a:hover{color:var(--gray-900);background:var(--gray-100)}
.nav-links>a:hover::after,.nav-links>a.active::after{transform:scaleX(1)}
.nav-links>a.active{color:var(--gray-900)}

/* ── NAV DROPDOWN ── */













.ndi-icon{width:36px;height:36px;border-radius:8px;background:var(--gray-100);color:var(--gray-500);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-md)}
.ndi-text{flex:1;min-width:0}
.ndi-label{font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--gray-800);display:block;transition:color var(--transition)}
.ndi-sub{font-size:11px;color:var(--gray-400);margin-top:1px;display:block}

/* ── HAMBURGER ── */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;border-radius:var(--radius);transition:background var(--transition)}
.nav-hamburger:hover{background:var(--gray-100)}
.nav-hamburger span{width:22px;height:2px;background:var(--gray-800);border-radius:1px;display:block;transition:all .3s ease}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE MENU ── */
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;bottom:0;background:white;z-index:999;padding:16px var(--pad-x) 32px;flex-direction:column;overflow-y:auto;border-top:1px solid var(--gray-100)}
.mobile-menu.open{display:flex;animation:slideDown .25s ease}
.mobile-menu>a{font-family:var(--font-head);font-size:17px;font-weight:600;color:var(--gray-800);padding:14px 0;border-bottom:1px solid var(--gray-100);transition:color var(--transition)}
.mobile-menu>a:last-child{border-bottom:none}
.mobile-menu>a:hover{color:var(--blue)}
.mobile-dropdown-toggle{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:var(--font-head);font-size:17px;font-weight:600;color:var(--gray-800);padding:14px 0;border-bottom:1px solid var(--gray-100);display:flex;justify-content:space-between;align-items:center}
.mobile-sub-links{display:none;flex-direction:column;padding:8px 0 12px 16px;gap:2px}
.mobile-sub-links.open{display:flex}
.mobile-sub-links a{font-size:15px!important;font-weight:500!important;color:var(--gray-600)!important;padding:10px 12px!important;border-bottom:none!important;border-radius:var(--radius);transition:all var(--transition)!important}
.mobile-sub-links a:hover{background:var(--blue-light)!important;color:var(--blue)!important}

/* ── SITE BANNER ── */
.site-banner{background:var(--blue);color:white;text-align:center;padding:10px var(--pad-x);font-size:13px;font-family:var(--font-head);font-weight:500;position:relative;z-index:1001;top:0}
.site-banner a{color:white;text-decoration:underline}
.site-banner-close{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:none;border:none;color:white;cursor:pointer;font-size:18px;opacity:.7;line-height:1}
.site-banner-close:hover{opacity:1}
body.has-banner .nav{top:40px}
body.has-banner{padding-top:108px}

/* ── HERO ── */
.hero{background:var(--navy);padding:calc(68px + clamp(48px,8vw,112px)) 0 clamp(48px,8vw,112px);position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-200px;right:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(29,78,216,.2) 0%,transparent 65%);pointer-events:none;animation:float 8s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-100px;left:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(14,165,233,.1) 0%,transparent 65%);pointer-events:none}
.hero-content{position:relative;z-index:1;max-width:860px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(29,78,216,.2);border:1px solid rgba(59,130,246,.3);border-radius:20px;padding:5px 14px;font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);margin-bottom:24px;animation:fadeIn .6s ease both}
.hero h1{color:var(--white);margin-bottom:20px;animation:fadeInUp .7s .1s ease both}
.hero h1 em{font-style:normal;color:var(--teal)}
.hero-desc{font-size:clamp(15px,1.8vw,19px);color:rgba(255,255,255,.65);max-width:600px;margin-bottom:40px;line-height:1.75;font-weight:300;animation:fadeInUp .7s .2s ease both}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;animation:fadeInUp .7s .3s ease both}
.hero-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px;padding-top:36px;border-top:1px solid rgba(255,255,255,.1);animation:fadeInUp .7s .4s ease both}
.hero-stat-num{font-family:var(--font-head);font-size:clamp(22px,3vw,36px);font-weight:800;color:var(--white);letter-spacing:-1px;line-height:1}
.hero-stat-label{font-size:12px;color:rgba(255,255,255,.5);margin-top:6px}

/* ── PAGE HEADER ── */
.page-header{background:var(--navy);padding:calc(68px + clamp(36px,6vw,72px)) 0 clamp(36px,5vw,64px);position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;top:-150px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(29,78,216,.15) 0%,transparent 70%)}
.page-header-label{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal);margin-bottom:12px}
.page-header h1{color:var(--white);max-width:700px;margin-bottom:14px}
.page-header p{color:rgba(255,255,255,.6);font-size:clamp(14px,1.8vw,17px);max-width:600px}
.breadcrumb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.4);margin-bottom:16px}
.breadcrumb a{color:rgba(255,255,255,.5);transition:color var(--transition)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb span{color:rgba(255,255,255,.25)}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:32px;transition:all var(--transition-md);position:relative;overflow:hidden}
.card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(29,78,216,.05) 0%,rgba(14,165,233,.02) 100%);opacity:0;transition:opacity var(--transition-md)}
.card:hover{border-color:rgba(29,78,216,.35);box-shadow:0 8px 32px rgba(29,78,216,.1),0 2px 8px rgba(0,0,0,.04);transform:translateY(-5px)}
.card:hover::before{opacity:1}
.card-icon{width:48px;height:48px;border-radius:var(--radius);background:var(--blue-light);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--blue);transition:all var(--transition-md)}
.card:hover .card-icon{background:var(--blue);color:white;transform:scale(1.12) rotate(-6deg);box-shadow:0 4px 16px rgba(29,78,216,.3)}
.card h3{margin-bottom:10px;position:relative}
.card p{font-size:15px;line-height:1.65;position:relative}
.card-link{display:inline-flex;align-items:center;gap:6px;margin-top:20px;font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--blue);transition:all var(--transition);position:relative}
.card-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--blue);transition:width var(--transition-md)}
.card-link:hover{gap:10px}
.card-link:hover::after{width:100%}

/* ── STATS STRIP ── */
.stats-strip{background:var(--gray-50);border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);padding:clamp(24px,4vw,48px) 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-num{font-family:var(--font-head);font-size:clamp(26px,3.5vw,40px);font-weight:800;color:var(--gray-900);letter-spacing:-1px;line-height:1;transition:color var(--transition-md)}
.stat-label{font-size:13px;color:var(--gray-500);margin-top:6px}

/* ── LOGOS STRIP ── */
.logos-strip{background:var(--navy);padding:28px 0;border-top:1px solid rgba(255,255,255,.06)}
.logos-label{text-align:center;font-size:11px;font-family:var(--font-head);font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:20px}
.logos-row{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;padding:0 var(--pad-x)}
.logo-pill{font-family:var(--font-head);font-size:12px;font-weight:700;letter-spacing:.5px;color:rgba(255,255,255,.4);padding:7px 14px;border:1px solid rgba(255,255,255,.1);border-radius:20px;transition:all var(--transition-md);cursor:default}
.logo-pill:hover{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.06);transform:translateY(-2px)}

/* ── DIVIDERS ── */
.divider{height:1px;background:var(--gray-200)}
.divider-dashed{border:none;border-top:1px dashed var(--gray-200);margin:32px 0}

/* ── TESTIMONIAL ── */
.testimonial{background:var(--gray-50);border-left:3px solid var(--blue);border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:24px 28px}
.testimonial-quote{font-size:16px;font-style:italic;color:var(--gray-700);line-height:1.75;margin-bottom:16px}
.testimonial-author{font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--gray-800)}
.testimonial-role{font-size:12px;color:var(--gray-400);margin-top:2px}

/* ── TAGS ── */
.tag{display:inline-block;font-family:var(--font-head);font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;border-radius:20px;background:var(--blue-light);color:var(--blue);transition:all var(--transition)}
.tag:hover{background:var(--blue);color:white}
.tag-green{background:var(--green-light);color:var(--green)}
.tag-green:hover{background:var(--green);color:white}
.tag-gray{background:var(--gray-100);color:var(--gray-600)}
.tag-gray:hover{background:var(--gray-200)}

/* ── PERSON CARD ── */
.person-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-md)}
.person-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:rgba(29,78,216,.2)}
.person-photo{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--navy-mid),var(--blue));display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:32px;font-weight:800;color:rgba(255,255,255,.3);letter-spacing:-1px;transition:transform var(--transition-slow);overflow:hidden}
.person-card:hover .person-photo{transform:scale(1.04)}
.person-info{padding:20px}
.person-name{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--gray-900)}
.person-role{font-size:13px;color:var(--blue);margin-top:2px;font-weight:500}
.person-bio{font-size:13px;color:var(--gray-500);margin-top:8px;line-height:1.6}

/* ── OFFICES GRID ── */
.offices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.office-card{border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;transition:all var(--transition-md);background:white}
.office-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);background:var(--blue-light);transform:translateY(-3px)}
.office-flag{font-size:22px;margin-bottom:10px}
.office-country{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--gray-900);margin-bottom:6px}
.office-addr{font-size:13px;color:var(--gray-500);line-height:1.6}
.office-hq-badge{display:inline-block;font-size:10px;font-weight:700;font-family:var(--font-head);letter-spacing:1px;text-transform:uppercase;background:var(--blue-light);color:var(--blue);border-radius:20px;padding:2px 8px;margin-left:8px}

/* ── CASE CARDS ── */
.case-card{border:1px solid var(--gray-200);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-md);background:white}
.case-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-6px);border-color:transparent}
.case-banner{height:160px;display:flex;align-items:flex-end;padding:20px;position:relative;overflow:hidden}
.case-banner-bg{position:absolute;inset:0;background:linear-gradient(135deg,#0B1526 0%,#1D4ED8 100%);transition:transform var(--transition-slow)}
.case-card:hover .case-banner-bg{transform:scale(1.06)}
.case-banner-bg.variant-2{background:linear-gradient(135deg,#0B1526 0%,#059669 100%)}
.case-banner-bg.variant-3{background:linear-gradient(135deg,#0B1526 0%,#7C3AED 100%)}
.case-tag{position:relative;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.25);border-radius:20px;padding:4px 10px;backdrop-filter:blur(8px);background:rgba(255,255,255,.08)}
.case-body{padding:24px 28px}
.case-client{font-size:11px;color:var(--gray-400);margin-bottom:6px;font-weight:600;font-family:var(--font-head);letter-spacing:.5px;text-transform:uppercase}
.case-title{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--gray-900);margin-bottom:10px;line-height:1.35}
.case-desc{font-size:13px;color:var(--gray-500);line-height:1.65;margin-bottom:20px}
.case-outcomes{display:flex;gap:20px;flex-wrap:wrap}
.case-outcome-val{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--gray-900);line-height:1}
.case-outcome-lab{font-size:11px;color:var(--gray-400);margin-top:3px}

/* ── JOB LISTINGS ── */
.job-item{border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;transition:all var(--transition-md);background:white}
.job-item:hover{border-color:var(--blue);box-shadow:var(--shadow-md);background:var(--blue-light);transform:translateX(4px)}
.job-title{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:8px}
.job-meta{display:flex;gap:12px;flex-wrap:wrap}
.job-meta-item{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--gray-500)}
.job-actions{flex-shrink:0}

/* ── FORMS ── */
.form-group{margin-bottom:20px}
.form-label{display:block;font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--gray-700);margin-bottom:7px}
.form-label .req{color:var(--red);margin-left:2px}
.form-control{width:100%;padding:12px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius);font-size:15px;color:var(--gray-800);background:var(--white);transition:all var(--transition);outline:none;-webkit-appearance:none}
.form-control:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(29,78,216,.1)}
.form-control:hover:not(:focus){border-color:var(--gray-300)}
.form-control::placeholder{color:var(--gray-400)}
textarea.form-control{resize:vertical;min-height:120px}
select.form-control{cursor:pointer}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-hint{font-size:12px;color:var(--gray-400);margin-top:5px}
.form-success{background:var(--green-light);border:1px solid rgba(22,163,74,.2);border-radius:var(--radius);padding:16px 20px;color:var(--green);font-size:14px;font-family:var(--font-head);font-weight:500;display:none;margin-top:16px}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease}
.modal{background:var(--white);border-radius:var(--radius-2xl);padding:clamp(24px,4vw,40px);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;position:relative;animation:scaleIn .25s var(--ease-out)}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:12px}
.modal-header h3{margin:0}
.modal-close{width:32px;height:32px;border:none;background:var(--gray-100);border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition)}
.modal-close:hover{background:var(--gray-200);transform:rotate(90deg)}

/* ── ALERT ── */
.alert{padding:14px 18px;border-radius:var(--radius);font-size:14px;display:flex;gap:10px;align-items:flex-start}
.alert-info{background:var(--blue-light);color:var(--blue);border:1px solid rgba(29,78,216,.15)}
.alert-success{background:var(--green-light);color:var(--green);border:1px solid rgba(22,163,74,.15)}
.alert-error{background:var(--red-light);color:var(--red);border:1px solid rgba(220,38,38,.15)}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--gray-200)}
table{width:100%;border-collapse:collapse}
thead th{background:var(--gray-50);padding:12px 16px;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--gray-500);text-align:left;border-bottom:1px solid var(--gray-200)}
tbody td{padding:14px 16px;font-size:14px;color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:top}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--gray-50)}

/* ── CTA SECTION ── */
.cta-section{background:var(--navy);padding:var(--section-y) 0;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 60%,rgba(29,78,216,.15) 0%,transparent 60%)}
.cta-section>*{position:relative}
.cta-section h2{color:var(--white);max-width:600px;margin:0 auto 16px}
.cta-section p{color:rgba(255,255,255,.55);max-width:480px;margin:0 auto 36px;font-size:clamp(14px,1.5vw,17px)}
.cta-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* ── FOOTER ── */
.footer{background:var(--gray-900);padding:0;color:rgba(255,255,255,.55)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:clamp(20px,4vw,48px)}
.footer-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--white);margin-bottom:14px;transition:opacity var(--transition)}
.footer-logo:hover{opacity:.8}
.footer-logo-mark{width:32px;height:32px;background:var(--blue);border-radius:7px;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:14px;font-weight:800;color:white;letter-spacing:-1px}
.footer-desc{font-size:14px;line-height:1.7;max-width:280px;color:rgba(255,255,255,.4)}
.footer-reg{font-size:12px;color:rgba(255,255,255,.22);margin-top:12px}
.footer-col h5{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.5);transition:all var(--transition)}
.footer-col ul a:hover{color:var(--white);padding-left:4px}
.footer-offices{display:flex;flex-direction:column;gap:14px}
.footer-office-name{font-size:12px;font-family:var(--font-head);font-weight:600;color:rgba(255,255,255,.45);margin-bottom:2px}
.footer-office-addr{font-size:13px;color:rgba(255,255,255,.28);line-height:1.5}
.footer-bottom{margin-top:clamp(32px,4vw,52px);padding:20px 0;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.25);gap:16px;flex-wrap:wrap}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{color:rgba(255,255,255,.25);transition:color var(--transition)}
.footer-bottom-links a:hover{color:rgba(255,255,255,.6)}

/* ── SERVICE LAYOUT ── */
.service-layout{display:grid;grid-template-columns:220px 1fr;gap:clamp(24px,4vw,56px);align-items:start}
.service-sidebar{position:sticky;top:88px}
.service-sidebar-label{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-400);margin-bottom:10px}
.service-sidebar ul{display:flex;flex-direction:column;gap:2px}
.service-sidebar ul a{font-family:var(--font-head);font-size:13px;font-weight:500;color:var(--gray-600);padding:9px 14px;border-radius:var(--radius);display:block;transition:all var(--transition);border-left:2px solid transparent}
.service-sidebar ul a:hover{color:var(--blue);background:var(--blue-light);border-left-color:rgba(29,78,216,.3)}
.service-sidebar ul a.active{color:var(--blue);background:var(--blue-light);border-left-color:var(--blue);font-weight:600}
.service-body{min-width:0}

/* ── PROCESS STEPS ── */
.process-steps{display:flex;flex-direction:column}
.process-step{display:flex;gap:20px;padding-bottom:32px}
.process-step:last-child{padding-bottom:0}
.process-step-line{display:flex;flex-direction:column;align-items:center;flex-shrink:0}
.process-step-num{width:40px;height:40px;border-radius:50%;background:var(--blue);color:white;font-family:var(--font-head);font-weight:800;font-size:15px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-md);box-shadow:0 2px 8px rgba(29,78,216,.2)}
.process-step:hover .process-step-num{transform:scale(1.1);box-shadow:0 4px 16px rgba(29,78,216,.3)}
.process-step-connector{width:2px;flex:1;background:var(--gray-200);margin-top:8px;min-height:20px}
.process-step:last-child .process-step-connector{display:none}
.process-step-body{padding-top:8px}
.process-step-body h4{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:6px}
.process-step-body p{font-size:14px;color:var(--gray-500);line-height:1.75}

/* ── DELIVERABLES ── */
.deliverables-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.deliverable-item{display:flex;gap:12px;align-items:flex-start;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:16px;transition:all var(--transition-md)}
.deliverable-item:hover{border-color:rgba(29,78,216,.3);background:var(--blue-light);transform:translateX(3px)}
.deliverable-check{width:22px;height:22px;border-radius:50%;background:var(--green-light);color:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;transition:all var(--transition)}
.deliverable-item:hover .deliverable-check{background:var(--green);color:white;transform:scale(1.1)}
.deliverable-text h5{font-size:13px;font-weight:700;font-family:var(--font-head);color:var(--gray-900);text-transform:none;letter-spacing:0}
.deliverable-text p{font-size:12px;color:var(--gray-400);margin-top:2px}

/* ── FAQ ── */
.faq-item{border-top:1px solid var(--gray-200)}
.faq-item:last-child{border-bottom:1px solid var(--gray-200)}
.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 0;background:none;border:none;cursor:pointer;text-align:left;gap:12px;transition:color var(--transition)}
.faq-question:hover span{color:var(--blue)}
.faq-question span{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--gray-900);transition:color var(--transition)}
.faq-question svg{flex-shrink:0;transition:transform .3s var(--ease-out);color:var(--gray-400)}
.faq-item.open .faq-question svg{transform:rotate(45deg);color:var(--blue)}
.faq-item.open .faq-question span{color:var(--blue)}
.faq-answer{display:none;padding:0 0 20px;font-size:14px;color:var(--gray-600);line-height:1.8}
.faq-item.open .faq-answer{display:block;animation:fadeInUp .25s ease}

/* ── CS CALLOUT ── */
.cs-callout{background:var(--navy);border-radius:var(--radius-xl);padding:clamp(24px,3vw,40px);color:white;display:flex;gap:32px;align-items:center;transition:box-shadow var(--transition-md)}
.cs-callout:hover{box-shadow:0 16px 48px rgba(11,21,38,.4)}
.cs-callout-body{flex:1;min-width:0}
.cs-callout-tag{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal);margin-bottom:10px}
.cs-callout h3{color:white;font-size:clamp(16px,2vw,22px);margin-bottom:10px}
.cs-callout p{color:rgba(255,255,255,.55);font-size:14px;line-height:1.7}
.cs-callout-metrics{display:flex;gap:24px;flex-wrap:wrap;flex-shrink:0}
.cs-metric-val{font-family:var(--font-head);font-size:clamp(22px,2.5vw,32px);font-weight:800;color:white;line-height:1}
.cs-metric-lab{font-size:11px;color:rgba(255,255,255,.4);margin-top:4px}

/* ── ADMIN INLINE ── */
.admin-panel{background:var(--gray-900);border-radius:var(--radius-xl);padding:clamp(20px,3vw,32px);color:var(--white);margin-top:56px}
.admin-lock{background:rgba(29,78,216,.12);border:1px solid rgba(29,78,216,.2);border-radius:var(--radius-lg);padding:32px;max-width:380px}
.admin-lock h3{color:white;margin-bottom:6px}
.admin-tools-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}
.admin-jobs-list{display:flex;flex-direction:column;gap:10px}
.admin-job-row{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background var(--transition)}
.admin-job-row:hover{background:rgba(255,255,255,.07)}
.admin-job-title{font-family:var(--font-head);font-size:14px;font-weight:600;color:var(--white)}
.admin-job-sub{font-size:12px;color:rgba(255,255,255,.4);margin-top:2px}
.admin-job-actions{display:flex;gap:8px;flex-shrink:0}
.btn-admin{padding:6px 14px;border-radius:var(--radius-sm);font-size:12px;font-family:var(--font-head);font-weight:600;border:none;cursor:pointer;transition:all var(--transition)}
.btn-edit{background:rgba(59,130,246,.2);color:#60A5FA}
.btn-edit:hover{background:rgba(59,130,246,.35);transform:scale(1.05)}
.btn-delete{background:rgba(220,38,38,.2);color:#F87171}
.btn-delete:hover{background:rgba(220,38,38,.35);transform:scale(1.05)}
.btn-save{background:var(--blue);color:white;padding:10px 20px;font-size:13px;border-radius:var(--radius);border:none;cursor:pointer;font-family:var(--font-head);font-weight:600;transition:all var(--transition)}
.btn-save:hover{background:var(--blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-blue)}
.admin-control .form-control{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);color:var(--white)}
.admin-control .form-control:focus{border-color:var(--blue-mid);background:rgba(255,255,255,.09)}
.admin-control .form-label{color:rgba(255,255,255,.6)}

/* ── SCROLL REVEAL ── */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
[data-reveal].revealed{opacity:1;transform:translateY(0)}
[data-reveal-left]{opacity:0;transform:translateX(-28px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
[data-reveal-left].revealed{opacity:1;transform:translateX(0)}
[data-reveal-right]{opacity:0;transform:translateX(28px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
[data-reveal-right].revealed{opacity:1;transform:translateX(0)}
[data-stagger]>*{opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease-out),transform .5s var(--ease-out)}
[data-stagger].revealed>*:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
[data-stagger].revealed>*:nth-child(2){opacity:1;transform:none;transition-delay:.12s}
[data-stagger].revealed>*:nth-child(3){opacity:1;transform:none;transition-delay:.19s}
[data-stagger].revealed>*:nth-child(4){opacity:1;transform:none;transition-delay:.26s}
[data-stagger].revealed>*:nth-child(5){opacity:1;transform:none;transition-delay:.33s}
[data-stagger].revealed>*:nth-child(6){opacity:1;transform:none;transition-delay:.40s}

/* ── UTILITIES ── */
.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}.mt-48{margin-top:48px}.mt-56{margin-top:56px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.mb-32{margin-bottom:32px}.mb-40{margin-bottom:40px}.mb-48{margin-bottom:48px}.mb-56{margin-bottom:56px}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-32{gap:32px}
.flex{display:flex;align-items:center}.flex-col{flex-direction:column;align-items:flex-start}
.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.justify-center{justify-content:center}
.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.w-full{width:100%}.text-blue{color:var(--blue)}

/* ── RESPONSIVE 480px ── */
@media(max-width:480px){
  h1{font-size:26px;letter-spacing:-1px}h2{font-size:21px}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:16px;margin-top:36px}
  .hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .deliverables-grid{grid-template-columns:1fr}
  .offices-grid{grid-template-columns:1fr}
  .cs-callout{flex-direction:column}
  .logos-row{gap:6px}.logo-pill{font-size:11px;padding:5px 10px}
  .modal{padding:20px;border-radius:var(--radius-xl)}
  .admin-panel{padding:16px}
  .admin-job-row{flex-direction:column;align-items:flex-start}
  .footer-bottom{flex-direction:column;text-align:center}
  .footer-bottom-links{justify-content:center}
  .cta-actions{flex-direction:column;align-items:center}
  .cta-actions .btn{width:100%;max-width:300px;justify-content:center}
  .page-header h1{font-size:24px}
}

/* ── RESPONSIVE 768px ── */
@media(max-width:768px){
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .service-layout{grid-template-columns:1fr!important}
  .service-sidebar{position:static;background:var(--gray-50);border-radius:var(--radius-lg);padding:16px}
  div[style*="grid-template-columns: 1fr 1fr"]{display:block!important}
  div[style*="grid-template-columns:1fr 1fr"]{display:block!important}
  div[style*="grid-template-columns: 1fr 1.4fr"]{display:block!important}
  div[style*="grid-template-columns: 2fr 1fr"]{display:block!important}
  div[style*="grid-template-columns: 240px"]{display:block!important}
  div[style*="grid-template-columns: 1fr 1.2fr"]{display:block!important}
  div[style*="grid-template-columns"] > div{margin-bottom:28px}
  div[style*="grid-template-columns"] > div:last-child{margin-bottom:0}
  div[style*="grid-template-columns"] > aside{margin-bottom:24px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .hero-meta{grid-template-columns:repeat(2,1fr);gap:20px}
  .hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}
  .offices-grid{grid-template-columns:repeat(2,1fr)}
  .job-item{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .cs-callout{flex-direction:column}
  .deliverables-grid{grid-template-columns:1fr}
  .cta-actions{flex-direction:column;align-items:center}
  .cta-actions .btn{width:100%;max-width:320px;justify-content:center}
  [style*="order: 2"],[style*="order:2"]{order:unset!important}
  [style*="order: 1"],[style*="order:1"]{order:unset!important}
  .two-col{grid-template-columns:1fr!important}
  .modal{max-width:100%}
}

/* ── RESPONSIVE 1024px ── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .offices-grid{grid-template-columns:repeat(2,1fr)}
  .service-layout{grid-template-columns:190px 1fr}
}

/* ── TWO-COL responsive class ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,80px);align-items:center}
.case-feature-grid{display:grid;grid-template-columns:1fr 1fr;min-height:420px}
@media(max-width:768px){
  .two-col{grid-template-columns:1fr!important;gap:32px}
  .case-feature-grid{grid-template-columns:1fr!important;min-height:auto}
}

/* ── NAV DROPDOWN (matching HTML class names) ── */




.nav-dropdown a{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);
  font-family:var(--font-head);font-size:13px;font-weight:500;color:var(--gray-700);
  transition:all var(--transition);text-decoration:none;
}
.nav-dropdown a:hover{background:var(--blue-light);color:var(--blue)}
.nav-dropdown a:hover 


/* ── SECTION ANIMATIONS ── */
.section-anim{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out)}
.section-anim.in{opacity:1;transform:none}

/* ── CARD COLOR TINTS per service ── */
.card-it:hover{border-color:rgba(29,78,216,.4);background:linear-gradient(145deg,#EFF6FF 0%,white 60%)}
.card-sw:hover{border-color:rgba(124,58,237,.4);background:linear-gradient(145deg,#F5F3FF 0%,white 60%)}
.card-ai:hover{border-color:rgba(14,165,233,.4);background:linear-gradient(145deg,#F0F9FF 0%,white 60%)}
.card-cl:hover{border-color:rgba(5,150,105,.4);background:linear-gradient(145deg,#F0FDF4 0%,white 60%)}
.card-cy:hover{border-color:rgba(220,38,38,.4);background:linear-gradient(145deg,#FEF2F2 0%,white 60%)}
.card-ui:hover{border-color:rgba(217,119,6,.4);background:linear-gradient(145deg,#FFFBEB 0%,white 60%)}

/* ── ADDITIONAL MICRO-INTERACTIONS ── */
/* Value proposition icons */
.value-icon{width:52px;height:52px;border-radius:var(--radius-lg);background:var(--blue-light);display:flex;align-items:center;justify-content:center;color:var(--blue);margin-bottom:16px;transition:all var(--transition-md)}
.value-card:hover .value-icon{background:var(--blue);color:white;transform:rotate(-8deg) scale(1.1)}

/* Number stats hover */
.stat-item:hover .stat-num{color:var(--blue);transform:scale(1.05)}
.stat-num{transition:all var(--transition-md);display:inline-block}

/* Timeline */
.timeline-item{position:relative;padding-left:28px;padding-bottom:28px}
.timeline-item::before{content:'';position:absolute;left:8px;top:6px;bottom:0;width:2px;background:var(--gray-200)}
.timeline-item:last-child::before{display:none}
.timeline-dot{width:18px;height:18px;border-radius:50%;background:var(--blue);position:absolute;left:0;top:4px;transition:all var(--transition-md);box-shadow:0 0 0 4px var(--blue-light)}
.timeline-item:hover .timeline-dot{transform:scale(1.3);box-shadow:0 0 0 6px var(--blue-light)}
.timeline-year{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--blue);margin-bottom:4px}
.timeline-text{font-size:14px;color:var(--gray-600);line-height:1.6}

/* Contact info icons */
.contact-icon{width:44px;height:44px;border-radius:var(--radius);background:var(--blue-light);display:flex;align-items:center;justify-content:center;color:var(--blue);flex-shrink:0;transition:all var(--transition-md)}
.contact-item:hover .contact-icon{background:var(--blue);color:white;transform:scale(1.08)}
.contact-item{display:flex;gap:16px;align-items:flex-start;padding:16px 0;border-bottom:1px solid var(--gray-100)}
.contact-item:last-child{border-bottom:none}

/* Filter pills */
.filter-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px}
.filter-pill{padding:8px 18px;border:1.5px solid var(--gray-200);border-radius:20px;font-family:var(--font-head);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);background:white;color:var(--gray-600)}
.filter-pill:hover,.filter-pill.active{background:var(--blue);color:white;border-color:var(--blue);transform:translateY(-1px);box-shadow:0 4px 12px rgba(29,78,216,.2)}

/* Section bg alternation */
.bg-light{background:var(--gray-50)}
.bg-navy{background:var(--navy);color:white}

/* Smooth image placeholders */
.img-placeholder{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,var(--gray-100),var(--gray-200));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--gray-300);font-size:48px}

/* ── CAREERS PAGE LAYOUT FIX ── */
.careers-layout{display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:start}
@media(max-width:1024px){.careers-layout{grid-template-columns:1fr;gap:32px}}

/* ── FLOATING LABELS on forms ── */
.form-control:focus+.form-label{color:var(--blue)}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}

/* ── ADDITIONAL MOBILE FIXES ── */
@media(max-width:768px){
  /* Careers layout */
  .careers-layout{grid-template-columns:1fr}
  /* Form row */
  .form-row{grid-template-columns:1fr}
  /* Section padding reduction */
  .section{padding:clamp(40px,8vw,56px) 0}
  /* Page header smaller */
  .page-header{padding:calc(68px + 32px) 0 40px}
  /* Card padding */
  .card{padding:24px}
  /* case-feature two col */
  .case-feature-grid{grid-template-columns:1fr!important;min-height:auto}
  /* hide decorative blobs */
  .hero::before,.hero::after,.page-header::before{opacity:.5}
  /* offices */
  .offices-grid{grid-template-columns:1fr 1fr}
  /* footer - stack properly */
  .footer-grid{grid-template-columns:1fr}
  .footer-desc{max-width:100%}
  /* Nav CTA hide on medium mobile */
  .nav-cta{display:none}
}
@media(max-width:480px){
  .offices-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .filter-pills{gap:6px}
  .filter-pill{padding:7px 14px;font-size:12px}
  .career-page-grid{grid-template-columns:1fr!important}
}

/* ================================================================
   V2 ELEGANT LAYER v2 — Animations · Scroll FX · AI Hero
   ================================================================ */

/* ── KEYFRAMES ─────────────────────────────────────────────────── */
@keyframes gridDrift1  { to { transform: translateY(-40px) translateX(-20px); } }
@keyframes gridDrift2  { to { transform: translateY(30px) translateX(15px); } }
@keyframes gridDrift3  { to { transform: translateY(-20px) translateX(25px); } }
@keyframes orbPulse    { 0%,100%{opacity:0;transform:scale(.82)} 30%{opacity:.95;transform:scale(1)} 70%{opacity:.95;transform:scale(1.04) translateY(-14px)} }
@keyframes lineFade    { 0%,100%{opacity:.05} 50%{opacity:.22} }
@keyframes nodePing    { 0%,100%{transform:scale(0);opacity:0} 40%{transform:scale(1.6);opacity:1} 70%{transform:scale(1);opacity:.6} }
@keyframes tagDrift    { 0%,100%{opacity:0;transform:translateY(7px)} 20%,80%{opacity:1;transform:translateY(0)} }
@keyframes pulsRing    { 0%{transform:scale(.4);opacity:.9} 100%{transform:scale(2.8);opacity:0} }
@keyframes hsvgNode    { 0%,100%{r:3;opacity:.5} 50%{r:5;opacity:1} }
@keyframes revealUp    { from{opacity:0;transform:translateY(28px)} to{opacity:1;transform:none} }
@keyframes footerSlide { 0%{background-position:0% 50%} 100%{background-position:300% 50%} }
@keyframes svcPulse    { 0%,100%{opacity:.07} 50%{opacity:.16} }
@keyframes gradMove    { 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }

/* ── HERO CANVAS ─────────────────────────────────────────────── */
.hero { position: relative; overflow: hidden; }

.hero-canvas {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

/* Layer 1: fine fast dot grid */
.hero-canvas::before {
  content: '';
  position: absolute; inset: -8%;
  background-image: radial-gradient(circle, rgba(59,130,246,.22) 1px, transparent 1px);
  background-size: 36px 36px;
  animation: gridDrift1 18s linear infinite;
}
/* Layer 2: medium slower grid */
.hero-canvas::after {
  content: '';
  position: absolute; inset: -8%;
  background-image: radial-gradient(circle, rgba(14,165,233,.14) 1.5px, transparent 1.5px);
  background-size: 72px 72px;
  background-position: 18px 18px;
  animation: gridDrift2 30s linear infinite;
}
/* Layer 3: large coarse grid (slowest) */
.hero-dots-3 {
  position: absolute; inset: -8%;
  background-image: radial-gradient(circle, rgba(99,102,241,.10) 2px, transparent 2px);
  background-size: 120px 120px;
  background-position: 40px 30px;
  animation: gridDrift3 50s linear infinite;
}

/* Glowing orbs — blurred depth layers */
.hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0;
  animation: orbPulse var(--dur,14s) var(--delay,0s) ease-in-out infinite;
}
.hero-orb-1 {
  width: 520px; height: 520px;
  top: -20%; right: -12%;
  background: radial-gradient(circle, rgba(29,78,216,.28) 0%, transparent 65%);
  --dur:12s; --delay:0s;
}
.hero-orb-2 {
  width: 340px; height: 340px;
  bottom: -10%; left: 1%;
  background: radial-gradient(circle, rgba(14,165,233,.2) 0%, transparent 65%);
  --dur:18s; --delay:-6s;
}
.hero-orb-3 {
  width: 220px; height: 220px;
  top: 35%; right: 20%;
  background: radial-gradient(circle, rgba(99,102,241,.18) 0%, transparent 65%);
  --dur:11s; --delay:-9s;
}
.hero-orb-4 {
  width: 160px; height: 160px;
  top: 60%; right: 5%;
  background: radial-gradient(circle, rgba(14,165,233,.15) 0%, transparent 65%);
  --dur:14s; --delay:-4s;
}

/* SVG network overlay */
.hero-svg {
  position: absolute;
  top: 0; right: 0;
  width: 65%; height: 100%;
  opacity: 1;
}
.hsvg-line { stroke-dasharray: 6 4; stroke-dashoffset: 0; animation: lineFade 5s ease-in-out infinite; }
.hsvg-line:nth-child(2)  { animation-delay: -.8s; }
.hsvg-line:nth-child(3)  { animation-delay: -1.6s; }
.hsvg-line:nth-child(4)  { animation-delay: -2.4s; }
.hsvg-line:nth-child(5)  { animation-delay: -3.2s; }
.hsvg-line:nth-child(6)  { animation-delay: -0.4s; }
.hsvg-line:nth-child(7)  { animation-delay: -1.2s; }
.hsvg-line:nth-child(8)  { animation-delay: -2.0s; }
.hsvg-line:nth-child(9)  { animation-delay: -2.8s; }
.hsvg-line:nth-child(10) { animation-delay: -3.6s; }
.hsvg-node { animation: hsvgNode 3s ease-in-out infinite; }
.hsvg-node:nth-child(even) { animation-delay: -1.5s; }

/* Pulse rings — background glow dots that expand and fade */
.hero-pulse {
  position: absolute;
  border-radius: 50%;
  border: 1.5px solid rgba(59,130,246,.4);
  animation: pulsRing var(--pr-dur,4s) var(--pr-delay,0s) ease-out infinite;
}
.hp1 { width:16px;height:16px; top:28%; right:22%; --pr-dur:3.5s;--pr-delay:0s; }
.hp2 { width:12px;height:12px; top:52%; right:14%; --pr-dur:4.2s;--pr-delay:-1.4s; }
.hp3 { width:20px;height:20px; top:38%; right:38%; --pr-dur:5.0s;--pr-delay:-2.5s; }
.hp4 { width:10px;height:10px; top:70%; right:28%; --pr-dur:3.2s;--pr-delay:-0.8s; }

/* Circuit lines (CSS) */
.hero-line {
  position: absolute;
  background: rgba(59,130,246,.18);
  border-radius: 1px;
  animation: lineFade var(--ld,7s) var(--ll,0s) ease-in-out infinite;
}
.hl1{width:180px;height:1px;top:22%;right:10%; --ld:8s;--ll:0s}
.hl2{width:1px;height:110px;top:18%;right:10%; --ld:9s;--ll:-1s}
.hl3{width:80px;height:1px;top:22%;right:calc(10% + 180px); --ld:6s;--ll:-2s}
.hl4{width:1px;height:80px;top:35%;right:25%;  --ld:7s;--ll:-3s}
.hl5{width:130px;height:1px;top:35%;right:18%; --ld:10s;--ll:-4s}
.hl6{width:220px;height:1px;top:62%;right:16%; --ld:12s;--ll:-2s}
.hl7{width:1px;height:95px;top:57%;right:16%;  --ld:8s;--ll:-5s}

/* Node dots */
.hero-node {
  position: absolute;
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(59,130,246,.55);
  box-shadow: 0 0 8px 2px rgba(59,130,246,.3);
  animation: nodePing var(--nd,5s) var(--nl,0s) ease-in-out infinite;
}
.hn1{top:22%;right:10%;            --nd:5s;--nl:0s}
.hn2{top:22%;right:calc(10% + 180px); --nd:6s;--nl:-.5s}
.hn3{top:35%;right:25%;            --nd:5.5s;--nl:-2s}
.hn4{top:62%;right:16%;            --nd:7s;--nl:-3s}
.hn5{top:calc(62% + 95px);right:16%; --nd:8s;--nl:-4s}

/* Floating tech tags */





.hero-content { position: relative; z-index: 1; }

/* ── SERVICES SECTION — AI feel ──────────────────────────────── */
/* Override the plain service card with a techy glass-morphism style */
#services .card,
#servicesGrid .card {
  background: var(--white);
  border: 1px solid rgba(29,78,216,.12);
  position: relative;
  overflow: hidden;
  transition: all .3s cubic-bezier(.16,1,.3,1);
}
/* Subtle grid texture inside each service card */
#services .card::after,
#servicesGrid .card::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(59,130,246,.08) 1px, transparent 1px);
  background-size: 20px 20px;
  opacity: 0;
  transition: opacity .4s ease;
  pointer-events: none;
  z-index: 0;
}
#services .card:hover::after,
#servicesGrid .card:hover::after {
  opacity: 1;
  animation: svcPulse 3s ease-in-out infinite;
}
/* Animated top accent line per card on hover */
#services .card::before,
#servicesGrid .card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--teal));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s cubic-bezier(.16,1,.3,1);
  z-index: 2;
}
#services .card:hover::before,
#servicesGrid .card:hover::before {
  transform: scaleX(1);
}
#services .card > *,
#servicesGrid .card > * { position: relative; z-index: 1; }

/* Service card icon — techy ring effect */
#services .card-icon,
#servicesGrid .card-icon {
  position: relative;
}
#services .card-icon::before,
#servicesGrid .card-icon::before {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 12px;
  border: 1.5px solid rgba(29,78,216,.15);
  opacity: 0;
  transform: scale(.8);
  transition: all .3s ease;
}
#services .card:hover .card-icon::before,
#servicesGrid .card:hover .card-icon::before {
  opacity: 1;
  transform: scale(1);
}

/* Services section bg — subtle gradient */
.section#services,
section#services {
  background: linear-gradient(180deg, #fff 0%, #F5F8FF 50%, #fff 100%);
  position: relative;
}
section#services::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(29,78,216,.05) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
  animation: svcPulse 6s ease-in-out infinite;
}
section#services .container { position: relative; z-index: 1; }

/* ── ANIMATED FOOTER GRADIENT LINE ──────────────────────────── */
.footer {
  padding-top: 0;
}
.footer::before {
  content: '';
  display: block;
  height: 3px;
  width: 100%;
  margin: 0; padding: 0;
  background: linear-gradient(
    90deg,
    #0EA5E9 0%,
    #1D4ED8 15%,
    #3B82F6 30%,
    #60A5FA 45%,
    #0EA5E9 55%,
    #6366F1 70%,
    #1D4ED8 82%,
    #0EA5E9 100%
  );
  background-size: 300% 100%;
  animation: footerSlide 4s linear infinite;
  box-shadow: 0 0 14px rgba(59,130,246,.65), 0 0 4px rgba(14,165,233,.9);
}
/* Footer inner content padding */
.footer > .container {
  padding-top: clamp(40px, 5vw, 64px);
}
/* Remove any double-before issue */
.footer-top-bar { display: none; }

/* ── SCROLL REVEAL ───────────────────────────────────────────── */
[data-reveal] {
  opacity: 1; transform: none;
  transition: opacity .65s cubic-bezier(.16,1,.3,1),
              transform .65s cubic-bezier(.16,1,.3,1);
}
[data-reveal].revealed { opacity: 1; transform: none; }

[data-reveal-left] {
  opacity: 0; transform: translateX(-28px);
  transition: opacity .65s cubic-bezier(.16,1,.3,1),
              transform .65s cubic-bezier(.16,1,.3,1);
}
[data-reveal-left].revealed { opacity: 1; transform: none; }

[data-reveal-right] {
  opacity: 0; transform: translateX(28px);
  transition: opacity .65s cubic-bezier(.16,1,.3,1),
              transform .65s cubic-bezier(.16,1,.3,1);
}
[data-reveal-right].revealed { opacity: 1; transform: none; }

[data-stagger] > * {
  opacity: 0; transform: translateY(22px);
  transition: opacity .55s cubic-bezier(.16,1,.3,1),
              transform .55s cubic-bezier(.16,1,.3,1);
}
[data-stagger].revealed > *:nth-child(1){opacity:1;transform:none;transition-delay:.04s}
[data-stagger].revealed > *:nth-child(2){opacity:1;transform:none;transition-delay:.10s}
[data-stagger].revealed > *:nth-child(3){opacity:1;transform:none;transition-delay:.16s}
[data-stagger].revealed > *:nth-child(4){opacity:1;transform:none;transition-delay:.22s}
[data-stagger].revealed > *:nth-child(5){opacity:1;transform:none;transition-delay:.28s}
[data-stagger].revealed > *:nth-child(6){opacity:1;transform:none;transition-delay:.34s}
[data-stagger].revealed > *:nth-child(7){opacity:1;transform:none;transition-delay:.40s}
[data-stagger].revealed > *:nth-child(8){opacity:1;transform:none;transition-delay:.46s}

/* ── PARALLAX SECTION ───────────────────────────────────────── */
.section-para { position: relative; overflow: hidden; }
.section-para-bg {
  position: absolute; inset: -25%;
  background: radial-gradient(ellipse at 55% 40%, rgba(29,78,216,.06) 0%, transparent 60%),
              radial-gradient(ellipse at 20% 75%, rgba(14,165,233,.04) 0%, transparent 50%);
  will-change: transform; pointer-events: none; z-index: 0;
}
.section-para > .container { position: relative; z-index: 1; }
.bg-tint-blue  { background: linear-gradient(180deg,#fff 0%,#F5F8FF 55%,#fff 100%); }
.bg-tint-light { background: linear-gradient(180deg,#fff 0%,var(--gray-50) 50%,#fff 100%); }

/* ── CASE STUDY ENHANCEMENTS ───────────────────────────────── */
.cs-featured {
  background: var(--navy); border-radius: 18px;
  padding: clamp(28px,5vw,52px);
  position: relative; overflow: hidden; margin-bottom: 44px;
}
.cs-featured::before {
  content:'';position:absolute;top:-120px;right:-80px;
  width:380px;height:380px;
  background:radial-gradient(circle,rgba(29,78,216,.28) 0%,transparent 65%);
}
.cs-featured::after {
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue) 0%,var(--teal) 40%,transparent 100%);
}
.cs-featured-eyebrow {
  font-family:var(--font-head);font-size:10px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;color:var(--teal);
  margin-bottom:14px;display:block;position:relative;z-index:1;
}
.cs-featured h2 { color:white;max-width:540px;margin-bottom:12px;position:relative;z-index:1; }
.cs-featured p  { color:rgba(255,255,255,.56);font-size:15px;line-height:1.75;max-width:560px;margin-bottom:28px;position:relative;z-index:1; }
.cs-featured-link { position:relative;z-index:1; }
.cs-featured-metrics {
  display:flex;gap:28px;flex-wrap:wrap;
  padding-top:24px;border-top:1px solid rgba(255,255,255,.1);position:relative;z-index:1;
}
.cfm-val { font-family:var(--font-head);font-size:clamp(22px,3vw,34px);font-weight:800;color:white;letter-spacing:-1px;line-height:1; }
.cfm-lab { font-size:11px;color:rgba(255,255,255,.42);margin-top:5px; }
.cs-featured-icon {
  position:absolute;top:20px;right:20px;z-index:1;
  width:52px;height:52px;border-radius:12px;
  background:rgba(29,78,216,.22);border:1px solid rgba(59,130,246,.25);
  display:flex;align-items:center;justify-content:center;font-size:24px;
  transition:transform .3s ease;
}
.cs-featured:hover .cs-featured-icon { transform:scale(1.08) rotate(-4deg); }

.cs-sectors {
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:36px;
}
.cs-sector {
  display:flex;align-items:center;gap:8px;
  background:var(--gray-50);border:1px solid var(--gray-200);
  border-radius:9px;padding:9px 14px;
  font-family:var(--font-head);font-size:12px;font-weight:600;color:var(--gray-700);
  transition:all .25s ease;
}
.cs-sector svg { color:var(--blue);flex-shrink:0; }
.cs-sector:hover { background:var(--blue-light);border-color:rgba(29,78,216,.2);color:var(--blue);transform:translateY(-2px); }

.case-outcome-bar {
  display:flex;gap:6px;margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-100);
}
.cob-item {
  flex:1;background:var(--gray-50);border:1px solid var(--gray-100);
  border-radius:7px;padding:8px 10px;text-align:center;transition:all .25s ease;
}
.case-card:hover .cob-item { background:var(--blue-light);border-color:rgba(29,78,216,.14); }
.cob-val { font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--blue);line-height:1; }
.cob-lab { font-size:10px;color:var(--gray-500);margin-top:3px;font-weight:500; }

/* ── REDUCED MOTION ─────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;}
  [data-reveal],[data-reveal-left],[data-reveal-right],[data-stagger]>*{opacity:1!important;transform:none!important;}
}

/* ══ ROBOT & HERO EXTRAS ════════════════════════════════════ */

50%{transform:translateY(calc(-50% - 10px))}





/* ══ HERO TAGS ═══════════════════════════════════════════════ */
.hero-ripple{position:absolute;border-radius:50%;border:1.5px solid rgba(59,130,246,.3);animation:rippleDrop var(--rd,6s) var(--rl,0s) ease-out infinite;pointer-events:none;opacity:0}
.hp1{width:120px;height:120px;--rd:7s;--rl:0s;left:20%;top:20%}
.hp2{width:80px;height:80px;--rd:9s;--rl:-3s;left:55%;top:60%}
.hp3{width:160px;height:160px;--rd:11s;--rl:-5s;left:72%;top:15%}
.hp4{width:60px;height:60px;--rd:8s;--rl:-7s;left:38%;top:75%}
@keyframes rippleDrop{0%{transform:scale(.4);opacity:.7}60%{opacity:.15}100%{transform:scale(2.5);opacity:0}}

.ht8{right:4%;bottom:35%;--td:10s;--tl:-5s}

/* ══ CASE STUDY CARDS ════════════════════════════════════════ */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case-card{border:1px solid var(--gray-200);border-radius:16px;overflow:hidden;background:#fff;transition:all .3s ease}
.case-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.1);border-color:rgba(29,78,216,.2)}
.case-banner{height:140px;display:flex;align-items:flex-end;justify-content:space-between;padding:16px 18px;overflow:hidden}
.case-banner-blue{background:linear-gradient(135deg,#1E3A8A,#1D4ED8)}
.case-banner-purple{background:linear-gradient(135deg,#4C1D95,#7C3AED)}
.case-banner-green{background:linear-gradient(135deg,#064E3B,#059669)}
.case-banner-red{background:linear-gradient(135deg,#7F1D1D,#DC2626)}
.case-banner-orange{background:linear-gradient(135deg,#7C2D12,#EA580C)}
.case-banner-teal{background:linear-gradient(135deg,#0C4A6E,#0EA5E9)}
.case-category{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.8);background:rgba(255,255,255,.15);padding:3px 10px;border-radius:20px}
.case-icon{font-size:32px;line-height:1;margin-left:auto}
.case-body{padding:18px}
.case-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.case-tag{font-family:var(--font-head);font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;background:var(--blue-light);color:var(--blue);border:1px solid rgba(29,78,216,.15)}
.case-body h3{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--gray-900);margin-bottom:8px;line-height:1.4}
.case-body p{font-size:13px;color:var(--gray-500);line-height:1.7;margin-bottom:14px}
.case-outcomes{display:flex;border-top:1px solid var(--gray-100);padding-top:12px}
.case-outcome{flex:1;text-align:center;padding:0 6px}
.case-outcome:not(:last-child){border-right:1px solid var(--gray-100)}
.case-outcome-val{display:block;font-family:var(--font-head);font-size:18px;font-weight:800;color:var(--blue);letter-spacing:-0.5px}
.case-outcome-lab{display:block;font-size:10px;color:var(--gray-400);margin-top:2px;line-height:1.3}
@media(max-width:1024px){.case-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.case-grid{grid-template-columns:1fr}}

/* ══ OFFICE CARDS ════════════════════════════════════════════ */
.offices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.office-card-v2{position:relative;border:1px solid var(--gray-200);border-radius:14px;padding:22px 20px 20px;background:#fff;overflow:hidden;transition:all .3s ease}
.office-card-v2:hover{border-color:rgba(29,78,216,.25);box-shadow:0 10px 32px rgba(29,78,216,.1);transform:translateY(-4px)}
.office-card-v2:hover .office-gradient-bar{transform:scaleX(1)}
.office-gradient-bar{position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:left;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.office-flag-svg{margin-bottom:10px;display:inline-block;border-radius:3px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.15);line-height:0}
.office-country-name{font-family:var(--font-head);font-size:15px;font-weight:700;color:var(--gray-900);margin-bottom:4px}
.office-hq-badge{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.8px;padding:2px 8px;border-radius:20px;background:var(--blue);color:#fff;margin-left:8px;vertical-align:middle}
.office-city{font-size:12px;font-weight:600;color:var(--blue);margin-bottom:8px}
.office-address{font-size:13px;color:var(--gray-500);line-height:1.65}
.office-note{font-size:11px;color:var(--gray-400);margin-top:6px}
@media(max-width:900px){.offices-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.offices-grid{grid-template-columns:1fr}}

/* ══ JOB CARDS ═══════════════════════════════════════════════ */
.job-card{border:1px solid var(--gray-200);border-radius:12px;padding:20px 22px;background:#fff;transition:all .25s ease}
.job-card:hover{border-color:rgba(29,78,216,.22);box-shadow:0 6px 20px rgba(29,78,216,.08);transform:translateY(-2px)}
.job-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:10px}
.job-title{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--gray-900);margin-bottom:8px}
.job-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--gray-500)}
.job-salary{color:var(--green);font-weight:600}
.job-desc{font-size:14px;color:var(--gray-500);line-height:1.7;margin-top:6px}
@media(max-width:600px){.job-card-header{flex-direction:column}.job-card-header .btn{align-self:flex-start}}

/* ══ LOGO TICKER ══════════════════════════════════════════════ */
.logos-ticker-section{padding:20px 0;background:#fff;overflow:hidden;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}
.logos-ticker-label{text-align:center;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--gray-400);margin-bottom:16px}
.logos-ticker-wrap{overflow:hidden;position:relative;height:52px;display:flex;align-items:center;mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%)}
.logos-ticker{display:flex;gap:14px;width:max-content;animation:tickerScroll 28s linear infinite;will-change:transform}
.logos-ticker:hover{animation-play-state:paused}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.logo-chip{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:9px 18px;border:1px solid var(--gray-200);border-radius:10px;background:white;font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--gray-500);white-space:nowrap;filter:grayscale(1);opacity:.55;transition:all .3s ease;cursor:default}
.logo-chip:hover{filter:grayscale(0);opacity:1;border-color:var(--blue);color:var(--blue);transform:translateY(-2px);box-shadow:0 4px 16px rgba(29,78,216,.08)}

/* ══ SITE-WIDE BANNER ════════════════════════════════════════ */
.bt-site-banner{background:var(--blue);color:white;text-align:center;padding:10px 20px;font-size:13px;font-family:var(--font-head);font-weight:600;position:sticky;top:0;z-index:999}
.bt-site-banner a{color:rgba(255,255,255,.85);text-decoration:underline}
.bt-site-banner .bn-close{float:right;cursor:pointer;opacity:.7;font-size:16px;line-height:1}

/* ══ RESPONSIVE FINAL ════════════════════════════════════════ */
.nav-logo-img{height:36px;width:auto;max-width:180px;object-fit:contain;display:block}
@media(max-width:900px){}
@media(max-width:680px){}
@media(max-width:480px){.hero-actions{flex-direction:column}.hero-meta{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.form-row{grid-template-columns:1fr}}
h1{font-size:clamp(28px,5vw,60px)}
h2{font-size:clamp(22px,3.5vw,42px)}
h3{font-size:clamp(16px,2vw,24px)}
/* ══ HERO LAYOUT ════════════════════════════════════════════ */
.hero{
  position:relative;overflow:hidden;
  min-height:calc(100vh - 68px);
  display:flex;align-items:center;
  background:linear-gradient(135deg,var(--navy) 0%,#0B1E3C 60%,#091629 100%);
  color:white;
}
.hero-inner{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(24px,4vw,60px);
  align-items:center;
  padding-top:40px;
  padding-bottom:40px;
  position:relative;z-index:2;
}

/* ── Robot side (LEFT) ─────────────────────────────── */
.hero-robot-side{
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
.robot-wrap{
  position:relative;
  width:100%;
  max-width:460px;
  animation:robotFloat 8s ease-in-out infinite;
}
@keyframes robotFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-12px)}
}
.robot-img{
  display:block;width:100%;height:auto;
  opacity:0.55;
  -webkit-mask-image:radial-gradient(ellipse 80% 82% at 52% 46%,black 30%,rgba(0,0,0,.7) 55%,transparent 82%);
  mask-image:radial-gradient(ellipse 80% 82% at 52% 46%,black 30%,rgba(0,0,0,.7) 55%,transparent 82%);
  filter:drop-shadow(0 0 30px rgba(14,165,233,.25));
}

/* ── Service tags around robot ─────────────────────── */
.svc-tag{
  position:absolute;
  display:inline-flex;align-items:center;
  font-family:var(--font-head);font-size:10px;font-weight:700;
  letter-spacing:1px;text-transform:uppercase;
  color:rgba(147,219,253,.85);
  border:1px solid rgba(59,130,246,.25);border-radius:20px;
  padding:5px 12px;
  background:rgba(11,21,38,.65);
  backdrop-filter:blur(8px);
  white-space:nowrap;
  animation:tagFloat var(--tf-d,8s) var(--tf-l,0s) ease-in-out infinite;
}
/* All tags same pill shape - positioned around robot */
.st1{top:4%;left:-8%;--tf-d:7s;--tf-l:0s}
.st2{top:18%;right:-12%;--tf-d:9s;--tf-l:-2s}
.st3{top:38%;right:-16%;--tf-d:8s;--tf-l:-4s}
.st4{top:62%;right:-10%;--tf-d:10s;--tf-l:-1s}
.st5{bottom:8%;right:-5%;--tf-d:8s;--tf-l:-3s}
.st6{bottom:4%;left:2%;--tf-d:11s;--tf-l:-5s}
.st7{top:52%;left:-14%;--tf-d:9s;--tf-l:-2s}
.st8{top:22%;left:-2%;--tf-d:7s;--tf-l:-6s}
@keyframes tagFloat{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}

/* ── Text side (RIGHT) ─────────────────────────────── */
.hero-text-side{
  position:relative;z-index:2;
}
.hero-rotating-line{
  font-family:var(--font-head);font-size:clamp(14px,1.4vw,16px);
  color:rgba(255,255,255,.5);margin-bottom:16px;font-weight:500;
}
.hero-service-text{
  color:var(--teal);font-weight:700;display:inline-block;
  transition:opacity .28s ease,transform .28s ease;
}

/* ── Ripple drops ──────────────────────────────────── */
.hero-ripple{
  position:absolute;border-radius:50%;
  border:1.5px solid rgba(59,130,246,.25);
  animation:rippleDrop var(--rd,6s) var(--rl,0s) ease-out infinite;
  pointer-events:none;opacity:0;
}
.hp1{width:140px;height:140px;--rd:7s;--rl:0s;left:8%;top:15%}
.hp2{width:90px;height:90px;--rd:9s;--rl:-3s;left:42%;top:65%}
.hp3{width:180px;height:180px;--rd:11s;--rl:-5s;right:10%;top:10%}
.hp4{width:70px;height:70px;--rd:8s;--rl:-7s;left:25%;bottom:15%}
@keyframes rippleDrop{
  0%{transform:scale(.4);opacity:.6}
  70%{opacity:.1}
  100%{transform:scale(2.2);opacity:0}
}

/* ── Responsive ────────────────────────────────────── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-robot-side{order:2;max-width:340px;margin:0 auto}
  .hero-text-side{order:1}
  .hero-actions{justify-content:center}
  .hero-meta{justify-content:center}
  .svc-tag{font-size:9px;padding:4px 10px}
  .st1,.st6,.st7,.st8{display:none} /* fewer tags on tablet */
}
@media(max-width:600px){
  /* Mobile: hide robot, keep service animation only */
  .hero-robot-side{display:none}
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-text-side{order:1}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-actions .btn{width:100%;max-width:320px;justify-content:center}
  .hero-meta{justify-content:center;grid-template-columns:repeat(2,1fr)}
  .hero{min-height:auto;padding:80px 0 48px}
}
