/* ============================================================
   styles.css — Clevaminds
   Aligned with Brand & Design Guidelines v2.0 (2026)
   Changes vs prior: fonts + colours only. Layout, spacing,
   shadows, animations, and selectors are unchanged.
   ============================================================ */

/* Fonts — Space Grotesk (display), IBM Plex Sans (body), IBM Plex Mono (technical) */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=IBM+Plex+Mono:wght@400;500;600;700&display=swap');

:root {
  /* ── Brand palette (v2.0) ───────────────────────────────── */
  --navy:#0B1F66;        /* Deep Navy — primary / dark fields */
  --blue:#1E6FFF;        /* Electric Blue — links, secondary, focus */
  --amber:#FFB020;       /* Signal Amber — accent & primary CTA */

  /* ── Surfaces & text ────────────────────────────────────── */
  --bg:#F4F7FF;          /* Ice Blue — body / alternating sections */
  --bg2:#FFFFFF;         /* White — alt sections / cards */
  --surface:#F4F7FF;     /* Light tint for hovers / fills */
  --border:#DCE4F5;      /* Divider — borders, rules, table lines */
  --ink:#0B1F66;         /* Headings / dark backgrounds / logo */
  --ink2:#1A1F2E;        /* Dark Text — body on light */
  --muted:#8C94A6;       /* Mid Grey — captions, metadata */

  /* ── Retired-name aliases ───────────────────────────────────
     These variable names are referenced throughout the file.
     Repointed to brand-approved values so existing selectors
     still work without renames. (Per v2.0, cyan/teal/green/
     indigo are no longer brand colours.)                       */
  --teal:#1E6FFF;        /* was teal  → Electric Blue */
  --green:#FFB020;       /* was green → Signal Amber (status/highlight) */
  --bluelt:#1E6FFF;      /* was light blue → Electric Blue */
  --indigo:#0B1F66;      /* was indigo → Deep Navy */

  /* ── Type system ────────────────────────────────────────── */
  --display:'Space Grotesk','Helvetica Neue',Arial,sans-serif;
  --body:'IBM Plex Sans','Helvetica Neue',Arial,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink2);font-family:var(--body);font-size:16px;line-height:1.6;overflow-x:hidden;}
::-webkit-scrollbar{width:6px;}::-webkit-scrollbar-track{background:var(--bg);}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px;}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:200;height:62px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);}
.logo{font-family:var(--display);font-weight:700;font-size:1.15rem;letter-spacing:-.03em;color:var(--ink);text-decoration:none;display:flex;align-items:center;white-space:nowrap;flex-shrink:0;}
.logo-icon{width:26px;height:26px;background:var(--navy);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:3px;}
.logo-icon svg{width:15px;height:15px;fill:none;stroke:#fff;stroke-width:2;}
.logo-img{height:30px;width:auto;display:block;flex-shrink:0;margin-right:8px;}
.logo span{color:var(--blue);}
.nav-desktop{list-style:none;display:flex;align-items:center;gap:.15rem;flex:1;justify-content:center;}
.nav-desktop a{color:var(--muted);text-decoration:none;font-size:.84rem;font-weight:500;padding:.38rem .8rem;border-radius:6px;white-space:nowrap;transition:color .15s,background .15s;}
.nav-desktop a:hover{color:var(--ink);background:var(--surface);}
.nav-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0;}
/* Primary CTA — Amber fill + Navy text per v2.0 */
.nav-cta-btn{background:var(--amber);color:var(--navy);text-decoration:none;font-family:var(--display);font-size:.83rem;font-weight:600;padding:.42rem 1.05rem;border-radius:6px;white-space:nowrap;transition:background .15s;}
.nav-cta-btn:hover{background:#E89E10;}
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:21px;height:2px;background:var(--ink);border-radius:2px;transition:transform .22s,opacity .22s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.drawer{position:fixed;inset:0;z-index:199;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);padding:80px 6% 3rem;display:flex;flex-direction:column;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .22s ease,transform .22s ease;}
.drawer.open{opacity:1;pointer-events:all;transform:translateY(0);}
.drawer-links{display:flex;flex-direction:column;gap:.3rem;}
.drawer-links a{color:var(--ink);text-decoration:none;font-family:var(--display);font-weight:700;font-size:1.4rem;letter-spacing:-.02em;padding:1rem 1.2rem;border-radius:12px;transition:background .15s;}
.drawer-links a:hover{background:var(--surface);}
.drawer-links .drawer-cta{background:var(--amber);color:var(--navy);margin-top:.8rem;text-align:center;}
.drawer-links .drawer-cta:hover{background:#E89E10;color:var(--navy);}
.drawer-links .drawer-jump-in{color:var(--blue);}
.drawer-links .drawer-jump-in:hover{background:rgba(30,111,255,.07);}

/* HERO */
.hero{padding:7.5rem 5% 5rem;display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;min-height:100vh;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 30% 40%,rgba(11,31,102,.05) 0%,transparent 65%),radial-gradient(ellipse 50% 50% at 80% 20%,rgba(30,111,255,.05) 0%,transparent 60%);}
.hero::after{content:'';position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(11,31,102,.06) 1px,transparent 1px);background-size:32px 32px;mask-image:radial-gradient(ellipse 90% 90% at 50% 50%,black 30%,transparent 80%);}
.hero-left{position:relative;z-index:1;}
.badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(30,111,255,.07);border:1px solid rgba(30,111,255,.18);color:var(--blue);font-family:var(--mono);font-size:.73rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:.3rem .85rem;border-radius:100px;margin-bottom:1.6rem;animation:fadeUp .5s ease both;}
.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);animation:pulse 2s infinite;}
h1{font-family:var(--display);font-weight:700;font-size:clamp(2.4rem,4.2vw,3.6rem);line-height:1.1;letter-spacing:-.025em;color:var(--ink);margin-bottom:1rem;animation:fadeUp .6s .06s ease both;}
h1 .accent{color:var(--blue);}
.hero-tag{display:inline-block;font-family:var(--mono);font-size:.8rem;color:var(--blue);background:rgba(30,111,255,.07);border:1px solid rgba(30,111,255,.18);border-radius:6px;padding:.28rem .7rem;margin-bottom:1.4rem;animation:fadeUp .6s .1s ease both;}
.hero-sub{font-size:1rem;color:var(--muted);max-width:460px;font-weight:300;line-height:1.78;margin-bottom:2.4rem;animation:fadeUp .6s .16s ease both;}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .6s .22s ease both;}
.hero-card-wrap{position:relative;z-index:1;animation:fadeUp .7s .28s ease both;}
.hero-card{background:var(--bg2);border:1.5px solid var(--border);border-radius:14px;padding:1.5rem;box-shadow:0 20px 60px rgba(11,31,102,.09),0 6px 20px rgba(0,0,0,.05);position:relative;}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--amber));border-radius:14px 14px 0 0;}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.2rem;}
.card-title{font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--ink);}
.card-sub{font-size:.73rem;color:var(--muted);margin-top:.15rem;font-family:var(--mono);}
.card-badge{display:flex;align-items:center;gap:.35rem;background:rgba(255,176,32,.12);border:1px solid rgba(255,176,32,.35);color:var(--navy);font-family:var(--mono);font-size:.69rem;font-weight:700;padding:.2rem .58rem;border-radius:100px;}
.card-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--amber);animation:pulse 1.8s infinite;}
.card-rows{display:flex;flex-direction:column;gap:.5rem;}
.card-row{display:flex;justify-content:space-between;align-items:center;padding:.48rem .72rem;background:var(--bg);border-radius:7px;border:1px solid var(--border);}
.card-label{font-size:.76rem;color:var(--muted);font-family:var(--mono);}
.card-value{font-family:var(--mono);font-size:.78rem;font-weight:600;}
.val-green{color:var(--amber);}.val-blue{color:var(--blue);}.val-teal{color:var(--blue);}

/* BUTTONS
   Primary   — Amber fill + Navy text (THE hero CTA, e.g. "Talk to us")
   Ghost     — Navy outline on light
   White     — White fill, Navy text (on dark fields)
   Outline-W — White outline on dark fields                                */
.btn-primary{display:inline-flex;align-items:center;gap:.45rem;background:var(--amber);color:var(--navy);font-family:var(--display);font-size:.88rem;font-weight:600;padding:.78rem 1.7rem;border-radius:8px;border:none;cursor:pointer;text-decoration:none;transition:transform .18s,box-shadow .18s,background .18s;box-shadow:0 4px 16px rgba(255,176,32,.32);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,176,32,.42);background:#E89E10;}
.btn-ghost{display:inline-flex;align-items:center;gap:.45rem;background:transparent;color:var(--navy);font-family:var(--display);font-size:.88rem;font-weight:600;padding:.78rem 1.7rem;border-radius:8px;border:1.5px solid var(--navy);cursor:pointer;text-decoration:none;transition:border-color .18s,background .18s,color .18s;}
.btn-ghost:hover{background:var(--navy);color:#fff;}
.btn-white{display:inline-flex;align-items:center;gap:.45rem;background:#fff;color:var(--navy);font-family:var(--display);font-size:.88rem;font-weight:600;padding:.78rem 1.7rem;border-radius:8px;text-decoration:none;transition:transform .18s,box-shadow .18s;box-shadow:0 4px 16px rgba(0,0,0,.12);}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.18);}
.btn-outline-white{display:inline-flex;align-items:center;gap:.45rem;background:transparent;color:#fff;font-family:var(--display);font-size:.88rem;font-weight:600;padding:.78rem 1.7rem;border-radius:8px;border:1.5px solid rgba(255,255,255,.32);text-decoration:none;transition:border-color .18s,background .18s;}
.btn-outline-white:hover{border-color:#fff;background:rgba(255,255,255,.1);}

/* STATS */
.stats-strip{display:flex;justify-content:center;flex-wrap:wrap;background:var(--navy);padding:2.4rem 5%;border-top:3px solid var(--amber);}
.stat-item{text-align:center;padding:0 3rem;border-right:1px solid rgba(255,255,255,.08);}
.stat-item:last-child{border-right:none;}
.stat-num{font-family:var(--display);font-size:2.4rem;font-weight:700;color:#fff;letter-spacing:-.04em;}
.stat-num sup{color:var(--amber);font-size:1.2rem;vertical-align:super;}
.stat-label{color:rgba(255,255,255,.38);font-size:.75rem;margin-top:.12rem;font-family:var(--mono);letter-spacing:.04em;}

/* SECTIONS */
section{position:relative;padding:6rem 5%;}
.section-tag{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:.69rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:.85rem;}
.section-tag::before{content:'';width:14px;height:2px;background:var(--blue);border-radius:2px;}
h2{font-family:var(--display);font-size:clamp(1.8rem,3.2vw,2.65rem);font-weight:700;line-height:1.12;letter-spacing:-.02em;color:var(--ink);margin-bottom:.85rem;}
h2 .accent{color:var(--blue);}
.section-desc{color:var(--muted);max-width:500px;font-size:.98rem;font-weight:300;line-height:1.78;}

/* SERVICES */
#services{background:var(--bg2);}
.services-header{margin-bottom:3rem;}
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;align-items:stretch;}
.service-card{
  background:var(--bg2);border:1.5px solid var(--border);border-radius:16px;
  padding:1.6rem 1.4rem;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
/* coloured top bar — slides in on hover */
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--card-line,var(--border));
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;border-radius:16px 16px 0 0;
}
.service-card:hover::before{transform:scaleX(1);}
.service-card:hover{border-color:rgba(30,111,255,.25);transform:translateY(-4px);box-shadow:0 14px 36px rgba(11,31,102,.08);}
/* Service-card icon tints — all now sit inside the v2.0 palette */
.icon-blue  {--card-line:var(--blue);  background:rgba(30,111,255,.09);}
.icon-teal  {--card-line:var(--blue);  background:rgba(30,111,255,.09);}   /* alias */
.icon-indigo{--card-line:var(--navy);  background:rgba(11,31,102,.09);}
.icon-green {--card-line:var(--amber); background:rgba(255,176,32,.10);}   /* alias */
.icon-amber {--card-line:var(--amber); background:rgba(255,176,32,.12);}

/* HOT card — Signal Amber accent (was burnt-orange) */
.service-card-hot{
  border-color:rgba(255,176,32,.45);
  background:linear-gradient(170deg,#FFF7E6 0%,var(--bg2) 55%);
  box-shadow:0 0 0 0 rgba(255,176,32,0);
}
.service-card-hot::before{transform:scaleX(1);background:var(--amber);}
.service-card-hot:hover{border-color:var(--amber);box-shadow:0 14px 36px rgba(255,176,32,.22);transform:translateY(-4px);}

/* HOT badge pill */
.sc-hot-badge{
  display:inline-flex;align-items:center;gap:.3rem;
  background:var(--amber);
  color:var(--navy);font-family:var(--mono);font-size:.62rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.25rem .7rem;border-radius:100px;
  margin-top:1rem;
  box-shadow:0 2px 8px rgba(255,176,32,.38);
  width:fit-content;
}

.service-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:1rem;}
.service-card h3{font-family:var(--display);font-size:.96rem;font-weight:600;margin-bottom:.45rem;color:var(--ink);letter-spacing:-.02em;line-height:1.3;}
.service-card p{color:var(--muted);font-size:.82rem;line-height:1.7;flex:1;}
.service-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:1.1rem;}
.tag{font-family:var(--mono);font-size:.63rem;font-weight:500;padding:.22rem .58rem;border-radius:6px;background:var(--surface);color:var(--ink2);border:1px solid var(--border);white-space:nowrap;}

/* HOW WE WORK */
#teamwork{background:var(--bg);}
.teamwork-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.pillars-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.pillar{background:var(--bg2);border:1.5px solid var(--border);border-radius:12px;padding:1.4rem;transition:border-color .2s,box-shadow .2s;}
.pillar:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(30,111,255,.09);}
.pillar-icon{font-size:1.4rem;margin-bottom:.65rem;}
.pillar h4{font-family:var(--display);font-weight:600;font-size:.9rem;margin-bottom:.3rem;color:var(--ink);}
.pillar p{color:var(--muted);font-size:.82rem;line-height:1.65;}

/* AI */
#ai{background:var(--bg2);}
.ai-section{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;}
.ai-visual{position:relative;height:360px;border-radius:16px;border:1.5px solid var(--border);overflow:hidden;background:linear-gradient(145deg,var(--bg2) 0%,var(--surface) 100%);box-shadow:0 14px 42px rgba(11,31,102,.07);}
.ai-visual::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(30,111,255,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(30,111,255,.055) 1px,transparent 1px);background-size:34px 34px;}
.ai-nodes{position:absolute;inset:0;}
.node{position:absolute;width:11px;height:11px;border-radius:50%;background:var(--blue);}
.node::after{content:'';position:absolute;inset:-5px;border-radius:50%;border:1.5px solid rgba(30,111,255,.22);animation:ripple 2.5s infinite;}
.node:nth-child(1){top:22%;left:18%;animation:float1 4s ease-in-out infinite;}
.node:nth-child(2){top:18%;right:24%;background:var(--amber);animation:float2 5s ease-in-out infinite;}
.node:nth-child(2)::after{border-color:rgba(255,176,32,.28);}
.node:nth-child(3){bottom:28%;left:28%;background:var(--navy);animation:float1 3.5s ease-in-out infinite reverse;}
.node:nth-child(3)::after{border-color:rgba(11,31,102,.22);}
.node:nth-child(4){bottom:22%;right:20%;background:var(--blue);animation:float2 4.5s ease-in-out infinite;}
.node:nth-child(4)::after{border-color:rgba(30,111,255,.22);}
.node:nth-child(5){top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background:var(--navy);box-shadow:0 0 0 5px rgba(30,111,255,.12);}
.node:nth-child(5)::after{border-color:rgba(11,31,102,.18);}
.ai-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;}
.ai-svg line{stroke:var(--border);stroke-width:1;stroke-dasharray:4 4;}
.ai-label{position:absolute;bottom:1.1rem;left:1.1rem;right:1.1rem;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:9px;padding:.65rem .95rem;font-size:.76rem;color:var(--muted);display:flex;justify-content:space-between;align-items:center;}
.ai-label strong{color:var(--ink);font-family:var(--display);font-size:.85rem;display:block;}
.ai-label-sub{font-size:.7rem;margin-top:.08rem;font-family:var(--mono);}
.ai-ping{display:flex;align-items:center;gap:.32rem;font-size:.7rem;color:var(--navy);font-weight:600;font-family:var(--mono);}
.ai-ping-dot{width:6px;height:6px;border-radius:50%;background:var(--amber);animation:pulse 1.5s infinite;}
.ai-features{display:flex;flex-direction:column;gap:.9rem;margin-top:2rem;}
.ai-feature{display:flex;align-items:flex-start;gap:.9rem;padding:1rem 1.2rem;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;transition:border-color .2s,box-shadow .2s;}
.ai-feature:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(30,111,255,.07);}
.af-icon{font-size:1.15rem;flex-shrink:0;margin-top:.08rem;}
.af-text h4{font-family:var(--display);font-weight:600;font-size:.88rem;margin-bottom:.16rem;color:var(--ink);}
.af-text p{color:var(--muted);font-size:.81rem;line-height:1.62;}

/* TEAM */
#team{background:var(--navy);}
#team .section-tag{color:var(--amber);}
#team .section-tag::before{background:var(--amber);}
#team h2{color:#fff;}
#team h2 .accent{color:var(--amber);}
#team .section-desc{color:rgba(255,255,255,.55);}
.team-header{text-align:center;margin-bottom:2.8rem;}
.team-header .section-desc{margin:0 auto;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;}
.team-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:1.5rem;text-align:center;transition:transform .25s,border-color .25s,background .25s;position:relative;overflow:hidden;}
.team-card::before{content:'';position:absolute;top:0;left:10%;right:10%;height:2px;background:var(--stripe);border-radius:0 0 3px 3px;}
.team-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.2);background:rgba(255,255,255,.07);}
.card-dennis{--stripe:var(--blue);}.card-adnan{--stripe:var(--amber);}.card-zack{--stripe:#fff;}
.member-photo-wrap{position:relative;width:160px;height:160px;border-radius:50%;overflow:hidden;margin:0 auto 1.1rem auto;background:rgba(255,255,255,.06);border:3px solid rgba(255,255,255,.12);}
.photo-slot{position:absolute;inset:0;transition:opacity .8s ease;}
.photo-slot.photo-a{opacity:1;z-index:2;}.photo-slot.photo-b{opacity:0;z-index:1;}
.member-photo-wrap.show-b .photo-a{opacity:0;}
.member-photo-wrap.show-b .photo-b{opacity:1;z-index:2;}
.photo-slot img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;}
.photo-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;background:rgba(255,255,255,.04);border-radius:50%;}
.ph-icon{font-size:1.5rem;opacity:.45;}.ph-file{display:none;}
.ph-label{display:none;}
.photo-counter{position:absolute;bottom:.45rem;right:.45rem;z-index:10;background:rgba(0,0,0,.45);color:rgba(255,255,255,.7);font-family:var(--mono);font-size:.62rem;padding:.16rem .4rem;border-radius:3px;}
.member-name{font-family:var(--display);font-size:1.1rem;font-weight:700;letter-spacing:-.025em;color:#fff;margin-bottom:.15rem;}
.member-role{font-family:var(--mono);font-size:.67rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;margin-bottom:.8rem;}
.role-blue{color:var(--blue);}.role-teal{color:var(--amber);}.role-green{color:#fff;}
.member-bio{color:rgba(255,255,255,.55);font-size:.82rem;line-height:1.68;}
.member-skills{display:flex;flex-wrap:wrap;gap:.3rem;justify-content:center;margin-top:1rem;}
.tag-light{font-family:var(--mono);font-size:.63rem;font-weight:500;padding:.18rem .55rem;border-radius:4px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.08);}

/* LOCATIONS */
#locations{background:var(--navy);overflow:hidden;position:relative;}
#locations::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(30,111,255,.22),transparent 65%);top:-200px;right:-100px;pointer-events:none;}
#locations::after{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(255,176,32,.14),transparent 65%);bottom:-100px;left:5%;pointer-events:none;}
#locations .section-tag{color:var(--amber);}
#locations .section-tag::before{background:var(--amber);}
#locations h2{color:#fff;}
#locations h2 .accent{color:var(--amber);}
#locations .section-desc{color:rgba(255,255,255,.55);}
.locations-inner{position:relative;z-index:1;}
.locations-top{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;margin-bottom:4rem;}
.locations-visual{display:flex;align-items:center;justify-content:center;}
.globe-wrap{position:relative;width:240px;height:240px;display:flex;align-items:center;justify-content:center;}
.globe-ring{position:absolute;border-radius:50%;border:1px solid rgba(30,111,255,.3);animation:globe-spin linear infinite;}
.globe-ring:nth-child(1){width:100%;height:100%;animation-duration:18s;}
.globe-ring:nth-child(2){width:70%;height:70%;animation-duration:13s;animation-direction:reverse;border-color:rgba(255,176,32,.28);}
.globe-ring:nth-child(3){width:44%;height:44%;animation-duration:9s;border-color:rgba(255,255,255,.18);}
@keyframes globe-spin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.globe-dot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--blue);border:2px solid rgba(255,255,255,.7);box-shadow:0 0 6px var(--blue);}
.globe-dot:nth-child(4){top:0;left:50%;transform:translateX(-50%);background:var(--amber);box-shadow:0 0 6px var(--amber);}
.globe-dot:nth-child(5){bottom:0;left:50%;transform:translateX(-50%);}
.globe-dot:nth-child(6){top:50%;left:0;transform:translateY(-50%);background:#fff;box-shadow:0 0 6px rgba(255,255,255,.6);}
.globe-dot:nth-child(7){top:50%;right:0;transform:translateY(-50%);background:var(--blue);box-shadow:0 0 6px var(--blue);}
.globe-dot:nth-child(8){top:16%;left:16%;background:var(--amber);width:6px;height:6px;}
.globe-dot:nth-child(9){bottom:18%;right:14%;background:#fff;width:6px;height:6px;}
.globe-emoji{font-size:3.2rem;position:relative;z-index:1;filter:drop-shadow(0 0 20px rgba(30,111,255,.35));}
.globe-tagline{margin-top:1rem;text-align:center;font-family:var(--mono);font-size:.7rem;font-weight:600;color:rgba(255,255,255,.35);letter-spacing:.1em;text-transform:uppercase;}
.locations-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:3.5rem;}
.loc-pillar{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.3rem;transition:border-color .2s,background .2s;}
.loc-pillar:hover{border-color:rgba(255,176,32,.4);background:rgba(255,255,255,.07);}
.loc-pillar-icon{font-size:1.25rem;margin-bottom:.55rem;}
.loc-pillar h4{font-family:var(--display);font-weight:600;font-size:.88rem;color:#fff;margin-bottom:.3rem;}
.loc-pillar p{color:rgba(255,255,255,.55);font-size:.8rem;line-height:1.65;}
.locations-bases-label{font-family:var(--mono);font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:.9rem;}
.pin-list{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.pin-item{display:flex;flex-direction:column;align-items:flex-start;gap:.45rem;padding:1.1rem 1rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);border-radius:12px;transition:border-color .2s,background .2s,transform .2s;}
.pin-item:hover{border-color:rgba(255,176,32,.45);background:rgba(255,255,255,.08);transform:translateY(-2px);}
.pin-flag{font-size:1.5rem;line-height:1;}
.pin-name{font-family:var(--display);font-weight:600;font-size:.86rem;color:#fff;}
.pin-detail{font-size:.7rem;color:rgba(255,255,255,.45);font-family:var(--mono);}

/* PROCESS */
#process{background:var(--bg);}
.process-header{text-align:center;margin-bottom:3.5rem;position:relative;z-index:10;}
.process-header .section-desc{margin:0 auto;}
.process-timeline-wrap{position:relative;}
.process-timeline-wrap::before{content:'';position:absolute;top:30px;left:calc(12.5% + 15px);right:calc(12.5% + 15px);height:2px;background:linear-gradient(90deg,var(--navy),var(--amber));z-index:0;}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;position:relative;z-index:1;}
.process-step{padding:1.8rem;border-radius:12px;border:1.5px solid var(--border);background:var(--bg2);transition:border-color .25s,box-shadow .25s,transform .25s;}
.process-step:hover{border-color:var(--blue);box-shadow:0 8px 26px rgba(30,111,255,.10);transform:translateY(-3px);}
.step-num-circle{width:30px;height:30px;border-radius:50%;background:var(--bg2);border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:.7rem;font-weight:700;color:var(--blue);margin-bottom:.85rem;position:relative;z-index:2;box-shadow:0 0 0 4px var(--bg);}
.process-step:hover .step-num-circle{background:var(--blue);color:#fff;box-shadow:0 0 0 4px var(--bg),0 0 12px rgba(30,111,255,.35);}
.step-icon{font-size:1.45rem;margin-bottom:.7rem;}
.process-step h3{font-family:var(--display);font-size:.95rem;font-weight:600;margin-bottom:.4rem;color:var(--ink);}
.process-step p{color:var(--muted);font-size:.82rem;line-height:1.65;}

/* PRICING */
.pf-icon{font-size:1.35rem;margin-bottom:.6rem;}
.philosophy-widget{margin-bottom:2.5rem;background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:2.5rem 2.5rem 2rem;overflow:hidden;}
@media(max-width:720px){
  }

/* CTA */
.cta-section{background:linear-gradient(135deg,var(--navy) 0%,#0A1A56 50%,#06123F 100%);text-align:center;padding:7rem 5%;position:relative;overflow:hidden;}
.cta-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:28px 28px;}
.cta-section::after{content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,176,32,.18),transparent 70%);bottom:-180px;right:-80px;pointer-events:none;}
.cta-section .section-tag{color:var(--amber);}
.cta-section .section-tag::before{background:var(--amber);}
.cta-section h2{color:#fff;position:relative;z-index:1;}
.cta-section h2 .accent{color:var(--amber);}
.cta-section .section-desc{color:rgba(255,255,255,.7);margin:0 auto 2.6rem;text-align:center;position:relative;z-index:1;}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;position:relative;z-index:1;}

/* FOOTER */
footer{padding:2.4rem 5%;background:var(--bg);border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;}
.footer-left{display:flex;flex-direction:column;gap:.2rem;}
.footer-logo{font-family:var(--display);font-weight:700;font-size:1.05rem;color:var(--ink);}
.footer-logo span{color:var(--blue);}
.footer-tagline{font-family:var(--mono);font-size:.66rem;color:var(--muted);letter-spacing:.07em;}
.footer-links{list-style:none;display:flex;gap:1.6rem;flex-wrap:wrap;}
.footer-links a{color:var(--muted);text-decoration:none;font-size:.8rem;transition:color .2s;}
.footer-links a:hover{color:var(--ink);}
.footer-copy{color:var(--muted);font-size:.75rem;font-family:var(--mono);}

/* LINKEDIN — brand colour #0a66c2 is LinkedIn's own, kept intentionally */
.li-icon{width:16px;height:16px;flex-shrink:0;}
.nav-li-btn{display:inline-flex;align-items:center;gap:.42rem;color:var(--muted);text-decoration:none;font-size:.82rem;font-weight:500;padding:.38rem .7rem;border-radius:6px;border:1px solid var(--border);transition:color .18s,border-color .18s,background .18s;white-space:nowrap;}
.nav-li-btn:hover{color:#0a66c2;border-color:#0a66c2;background:rgba(10,102,194,.06);}
.nav-li-btn .li-icon{width:15px;height:15px;color:currentColor;}
.nav-li-label{font-size:.8rem;}
.footer-li{display:inline-flex;align-items:center;gap:.5rem;margin-top:.6rem;color:var(--muted);text-decoration:none;font-size:.82rem;font-weight:500;transition:color .18s;}
.footer-li:hover{color:#0a66c2;}
.footer-li .li-icon{width:15px;height:15px;color:currentColor;transition:color .18s;}
.footer-li:hover .li-icon{color:#0a66c2;}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .5s ease,transform .5s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* Accessibility — 2px Electric Blue focus ring per v2.0 digital guidelines */
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:6px;}

/* KEYFRAMES */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.35;transform:scale(.75);}}
@keyframes ripple{0%{transform:scale(1);opacity:.55;}100%{transform:scale(3.5);opacity:0;}}
@keyframes float1{0%,100%{transform:translate(0,0);}50%{transform:translate(6px,-9px);}}
@keyframes float2{0%,100%{transform:translate(0,0);}50%{transform:translate(-7px,8px);}}

/* RESPONSIVE */
@media(max-width:1200px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .process-timeline-wrap::before{display:none;}
  }
@media(max-width:860px){
  .services-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:960px){
  .hero{grid-template-columns:1fr;gap:3rem;min-height:auto;padding-top:6rem;}
  .teamwork-layout{grid-template-columns:1fr;gap:2.5rem;}
  .ai-section{grid-template-columns:1fr;gap:2.5rem;}
  .locations-top{grid-template-columns:1fr;gap:2.5rem;}
  .locations-pillars{grid-template-columns:1fr 1fr;}
  .pin-list{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:860px){
  .nav-desktop{display:none;}
  .hamburger{display:flex;}
  .stat-item{padding:0 1.2rem;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .nav-li-btn{display:none;}
}
@media(max-width:600px){
  .services-grid{grid-template-columns:1fr;}
  .process-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr;}
  .pillars-grid{grid-template-columns:1fr;}
  .pin-list{grid-template-columns:1fr;}
  .locations-pillars{grid-template-columns:1fr;}
  }

/* ── UTILITY CLASSES (replacing inline styles) ──────────────── */
.section-desc--flush{margin-bottom:0;}
.proc-info-icon{flex-shrink:0;}
.qm-btn-back--hidden{visibility:hidden;}
.qm-title--complete{margin-top:1.1rem;}
.qm-hint--complete{margin-bottom:1.2rem;}
.q-num--optional{color:var(--amber);}

/* ── QUALIFY MODAL ──────────────────────────────────────────── */
.qm-overlay{position:fixed;inset:0;z-index:400;background:rgba(11,31,102,.55);backdrop-filter:blur(7px);display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .28s ease;}
.qm-overlay.open{opacity:1;pointer-events:all;}
.qm-card{background:#fff;border-radius:20px;width:100%;max-width:520px;box-shadow:0 32px 80px rgba(11,31,102,.28);overflow:hidden;transform:translateY(20px) scale(.97);transition:transform .35s cubic-bezier(.34,1.56,.64,1);display:flex;flex-direction:column;max-height:92vh;}
.qm-overlay.open .qm-card{transform:translateY(0) scale(1);}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-7px)}40%{transform:translateX(7px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.qm-card.shake{animation:shake .38s ease;}
.qm-close{width:30px;height:30px;flex-shrink:0;border-radius:50%;background:var(--surface);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:background .15s,color .15s;}
.qm-close:hover{background:var(--border);color:var(--ink);}
.qm-progress-wrap{padding:1.1rem 1.5rem .9rem;display:flex;align-items:center;gap:.75rem;}
.qm-progress-track{flex:1;height:5px;background:var(--surface);border-radius:100px;overflow:hidden;}
.qm-progress-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--amber));border-radius:100px;transition:width .55s cubic-bezier(.34,1.56,.64,1);}
.qm-progress-label{font-family:var(--mono);font-size:.68rem;font-weight:600;color:var(--muted);white-space:nowrap;letter-spacing:.04em;}
.qm-body{padding:.4rem 1.8rem 1rem;overflow-y:auto;flex:1;}
@keyframes qmOutL{to{opacity:0;transform:translateX(-30px)}}
@keyframes qmOutR{to{opacity:0;transform:translateX(30px)}}
@keyframes qmInL{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes qmInR{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:none}}
.qm-out-left{animation:qmOutL .26s cubic-bezier(.4,0,1,1) both;}
.qm-out-right{animation:qmOutR .26s cubic-bezier(.4,0,1,1) both;}
.qm-in-left{animation:qmInL .38s cubic-bezier(.22,1,.36,1) both;}
.qm-in-right{animation:qmInR .38s cubic-bezier(.22,1,.36,1) both;}
.qm-eyebrow{font-family:var(--mono);font-size:.64rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:.45rem;display:flex;align-items:center;gap:.4rem;}
.qm-eyebrow::before{content:'';width:10px;height:2px;background:var(--blue);border-radius:2px;}
.qm-title{font-family:var(--display);font-weight:700;font-size:1.16rem;color:var(--ink);margin-bottom:.5rem;line-height:1.3;letter-spacing:-.02em;}
.qm-hint{font-size:.8rem;color:var(--muted);margin-bottom:.9rem;font-style:italic;}
.qm-tag-row{display:flex;flex-wrap:wrap;gap:.35rem;min-height:26px;margin-bottom:.8rem;align-items:center;}
.qm-tag-placeholder{color:var(--muted);font-size:.79rem;font-style:italic;}
.qm-tag{display:inline-flex;align-items:center;gap:.28rem;background:rgba(30,111,255,.08);color:var(--blue);border:1px solid rgba(30,111,255,.18);font-family:var(--mono);font-size:.65rem;font-weight:600;padding:.18rem .58rem;border-radius:100px;}
.qm-tag-rm{cursor:pointer;opacity:.5;font-size:.66rem;background:none;border:none;color:inherit;padding:0;margin-left:2px;transition:opacity .12s;}
.qm-tag-rm:hover{opacity:1;}
.qm-ms-dropdown{display:flex;flex-direction:column;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;overflow-y:auto;max-height:230px;}
.qm-ms-option{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s;}
.qm-ms-option:last-child{border-bottom:none;}
.qm-ms-option:hover{background:var(--surface);}
.qm-ms-check{width:17px;height:17px;flex-shrink:0;border:1.5px solid var(--border);border-radius:4px;background:#fff;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;}
.qm-ms-option.selected .qm-ms-check{background:var(--blue);border-color:var(--blue);}
.qm-ms-check svg{width:10px;height:7px;opacity:0;transform:scale(.5);transition:opacity .14s,transform .14s;}
.qm-ms-option.selected .qm-ms-check svg{opacity:1;transform:scale(1);}
.qm-ms-icon{font-size:.93rem;flex-shrink:0;}
.qm-ms-label{font-size:.87rem;color:var(--ink2);line-height:1.3;}
.qm-ms-option.selected .qm-ms-label{color:var(--ink);font-weight:500;}
.qm-options{display:flex;flex-direction:column;gap:.5rem;}
.qm-option{display:flex;align-items:center;gap:.85rem;padding:.85rem 1.1rem;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;background:var(--bg);transition:border-color .22s,background .22s,box-shadow .22s,transform .2s;}
.qm-option:hover{border-color:rgba(30,111,255,.3);background:var(--surface);}
.qm-option.selected{border-color:var(--blue);background:rgba(30,111,255,.05);box-shadow:0 0 0 3px rgba(30,111,255,.08);}
.qm-option.qm-opt-confirming{transform:scale(.988);opacity:.85;transition:all .12s ease;}
.qm-opt-icon{font-size:1.1rem;flex-shrink:0;}
.qm-opt-label{flex:1;font-size:.9rem;color:var(--ink2);font-weight:500;}
.qm-option.selected .qm-opt-label{color:var(--blue);font-weight:600;}
.qm-opt-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s;color:transparent;}
.qm-option.selected .qm-opt-check{background:var(--blue);border-color:var(--blue);color:#fff;}
.qm-opt-check svg{width:9px;height:7px;}
.qm-cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.45rem;margin-bottom:.9rem;}
.qm-cal-day{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.5rem .3rem;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;background:var(--bg);transition:border-color .18s,background .18s,box-shadow .18s;text-align:center;}
.qm-cal-day:hover{border-color:rgba(30,111,255,.3);background:var(--surface);}
.qm-cal-day.selected{border-color:var(--blue);background:rgba(30,111,255,.07);box-shadow:0 0 0 3px rgba(30,111,255,.08);}
.qm-cal-dn{font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.qm-cal-day.selected .qm-cal-dn{color:var(--blue);}
.qm-cal-dd{font-family:var(--display);font-size:1.25rem;font-weight:700;color:var(--ink);line-height:1;}
.qm-cal-day.selected .qm-cal-dd{color:var(--blue);}
.qm-cal-dm{font-family:var(--mono);font-size:.6rem;color:var(--muted);}
.qm-time-wrap{margin-bottom:.6rem;}
.qm-time-wrap.hidden{display:none;}
.qm-time-label{font-family:var(--mono);font-size:.65rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;}
.qm-times-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;}
.qm-time-slot{padding:.52rem .4rem;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;background:var(--bg);font-family:var(--mono);font-size:.75rem;font-weight:600;color:var(--ink2);text-align:center;transition:border-color .18s,background .18s,color .18s;}
.qm-time-slot:hover{border-color:rgba(30,111,255,.3);background:var(--surface);}
.qm-time-slot.selected{border-color:var(--blue);background:rgba(30,111,255,.07);color:var(--blue);}
.qm-complete{text-align:center;padding:.4rem 0 .2rem;}
.qm-complete-icon{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--amber));display:flex;align-items:center;justify-content:center;margin:0 auto .4rem;box-shadow:0 8px 24px rgba(11,31,102,.32);}
.qm-textarea{width:100%;resize:vertical;min-height:78px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:.75rem .9rem;font-family:var(--body);font-size:.87rem;color:var(--ink2);line-height:1.6;outline:none;transition:border-color .18s,box-shadow .18s;}
.qm-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,111,255,.10);}
.qm-textarea::placeholder{color:var(--muted);}
/* Primary email-send CTA — Amber on Navy text per v2.0 */
.qm-email-btn{display:flex;align-items:center;justify-content:center;gap:.55rem;width:100%;margin-top:1rem;background:var(--amber);color:var(--navy);font-family:var(--display);font-size:.95rem;font-weight:600;padding:1rem;border-radius:10px;text-decoration:none;box-shadow:0 6px 22px rgba(255,176,32,.35);transition:transform .2s,box-shadow .2s,background .2s;}
.qm-email-btn:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(255,176,32,.45);background:#E89E10;}
.qm-email-note{margin-top:.55rem;font-family:var(--mono);font-size:.68rem;color:var(--muted);text-align:center;}
.qm-footer{padding:.75rem 1.8rem 1.3rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;border-top:1px solid var(--border);}
.qm-btn-back{display:inline-flex;align-items:center;gap:.4rem;background:none;border:none;color:var(--muted);font-size:.85rem;font-weight:500;cursor:pointer;padding:.45rem .7rem;border-radius:7px;transition:color .15s,background .15s;}
.qm-btn-back:hover{color:var(--ink);background:var(--surface);}
/* Primary next button — Amber on Navy per v2.0 */
.qm-btn-next{display:inline-flex;align-items:center;gap:.4rem;background:var(--amber);color:var(--navy);border:none;font-family:var(--display);font-size:.875rem;font-weight:600;cursor:pointer;padding:.55rem 1.3rem;border-radius:8px;transition:background .15s,transform .15s,opacity .25s;box-shadow:0 3px 12px rgba(255,176,32,.32);}
.qm-btn-next:hover{background:#E89E10;transform:translateY(-1px);}
.qm-btn-next.hidden{opacity:0;pointer-events:none;}

/* ── PROCESS PRICING PILL & TOOLTIP ────────────────────────── */
.process-hdr-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;}
.proc-info-icon{flex-shrink:0;}
.qm-disclaimer{width:100%;margin-top:.65rem;padding-top:.65rem;border-top:1px solid var(--border);font-family:var(--mono);font-size:.62rem;color:var(--muted);line-height:1.55;text-align:center;letter-spacing:.01em;}