/* ═══════════════════════════════════════════════════════════════════════════
   AGILE INDUSTRIES — FINAL CSS
   Playfair Display headings · Fira Sans 400 body · -0.01em letter-spacing
   Tight spacing · White navbar · Navy text · Industrial imagery
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── FONTS ─────────────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,700&family=Fira+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400&display=swap');

/* ── DESIGN TOKENS ─────────────────────────────────────────────────────────── */
:root {
  /* === LIGHT PALETTE === */
  --white:         #FFFFFF;
  --offwhite:      #F4F4F1;
  --border:        #E2E2DC;
  --border-2:      #CACAC2;

  /* === NAVY TEXT SCALE === */
  --navy:          #0D1B2A;
  --navy-75:       rgba(13,27,42,0.75);
  --navy-55:       rgba(13,27,42,0.55);
  --navy-35:       rgba(13,27,42,0.35);
  --navy-18:       rgba(13,27,42,0.18);

  /* === DARK SECTION PALETTE === */
  --dark:          #0A0A0A;
  --dark-border:   rgba(255,255,255,0.09);
  --dark-bmd:      rgba(255,255,255,0.16);
  --dw:            #FFFFFF;
  --dw-80:         rgba(255,255,255,0.80);
  --dw-60:         rgba(255,255,255,0.60);
  --dw-40:         rgba(255,255,255,0.40);
  --dw-22:         rgba(255,255,255,0.22);

  /* === BRAND === */
  --accent:        #E85D26;
  --accent-h:      #D04A18;
  --accent-lt:     #FF7A42;
  --accent-glow:   rgba(232,93,38,0.14);
  --blue:          #1D4ED8;
  --green:         #059669;

  /* === TYPOGRAPHY === */
  --f-head: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --f-body: 'Fira Sans', -apple-system, BlinkMacSystemFont, sans-serif;

  /* === SPACING — TIGHT SYSTEM === */
  --nav-h:     100px;
  --wrap:      1280px;
  --pad:       clamp(16px, 4vw, 40px);
  /* Section padding: top = 56px desktop, 40px mobile */
  --sy:        clamp(40px, 5.5vw, 64px);
  /* Header groups inside sections */
  --sh:        32px;   /* section-header bottom margin */
  --sg:        24px;   /* standard grid gap */
  --si:        20px;   /* item gap */

  /* === RADII === */
  --r-sm: 6px; --r-md: 10px; --r-lg: 14px; --r-xl: 18px; --r-2xl: 24px;

  /* === MOTION === */
  --ease: cubic-bezier(0.22,1,0.36,1);
  --t:    0.22s ease;
  --ts:   0.42s var(--ease);
}

/* ── RESET ─────────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html {
  scroll-behavior:smooth;
  scrollbar-width:thin;
  scrollbar-color:#444 #111;
  -webkit-text-size-adjust:100%;
}
::-webkit-scrollbar       { width:4px; }
::-webkit-scrollbar-track { background:#111; }
::-webkit-scrollbar-thumb { background:#444; border-radius:2px; }

body {
  font-family: var(--f-body);
  font-weight: 400;
  font-size: 15px;
  line-height: 1.65;
  letter-spacing: -0.01em;
  color: var(--navy-75);
  background: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* All headings → Playfair Display */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--f-head);
  letter-spacing: -0.01em;
  line-height: 1.12;
  color: var(--navy);
}

img  { max-width:100%; height:auto; display:block; }
a    { text-decoration:none; color:inherit; transition:color var(--t); }
ul, ol { list-style:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }

/* ── LAYOUT ─────────────────────────────────────────────────────────────────── */
.wrap {
  max-width: var(--wrap);
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.section {
  padding-top: var(--sy);
  padding-bottom: var(--sy);
}
.section--light    { background:var(--white);    border-top:1px solid var(--border); }
.section--offwhite { background:var(--offwhite); border-top:1px solid var(--border); }
.section--dark-cta { background:var(--dark); }

/* Hero → first light section: no double border */
.hero + .section { border-top:none; }

/* ── TYPOGRAPHY SYSTEM ─────────────────────────────────────────────────────── */
.eyebrow {
  font-family: var(--f-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
  display: block;
}

/* Section headings */
.section-h2 {
  font-size: clamp(26px, 3.5vw, 44px);
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 12px;
  line-height: 1.1;
  letter-spacing: -0.01em;
}
.section-intro {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.7;
  color: var(--navy-55);
  margin-bottom: var(--sh);
  max-width: 520px;
  letter-spacing: -0.01em;
}

.section-label          { margin-bottom: var(--sh); }
.section-header-split   {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: var(--sh);
}

/* ── BUTTONS ─────────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--f-body);
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  border-radius: var(--r-md);
  transition: all var(--ts);
  cursor: pointer;
  border: 1.5px solid transparent;
  white-space: nowrap;
  text-decoration: none;
}
.btn-sm   { padding: 11px 24px; font-size:14px; }
.btn-md   { padding: 13px 28px; font-size:14.5px; }
.btn-xl   { padding: 17px 38px; font-size:16px; }
.btn-hero { padding: 16px 36px; font-size:16px; font-weight:700; }
.btn-full { width:100%; justify-content:center; }

.btn-accent { background:var(--accent); color:#FFF; border-color:var(--accent); }
.btn-accent:hover { background:var(--accent-h); border-color:var(--accent-h); transform:translateY(-1px); box-shadow:0 6px 24px rgba(232,93,38,0.3); color:#FFF; }
.btn-accent:active { transform:scale(0.97); }

.btn-outline-white { background:transparent; color:#FFF; border-color:rgba(255,255,255,0.35); }
.btn-outline-white:hover { background:rgba(255,255,255,0.10); border-color:rgba(255,255,255,0.7); color:#FFF; transform:translateY(-1px); }

.btn-outline-dark { background:transparent; color:var(--navy); border-color:var(--border-2); }
.btn-outline-dark:hover { border-color:var(--accent); color:var(--accent); transform:translateY(-1px); }

.btn svg { flex-shrink:0; transition:transform var(--t); }
.btn:hover svg { transform:translateX(2px); }

/* ═══════════════════════════════════════════════════════════════════════════
   NAVIGATION — white bg, bigger logo, navy text
   ═══════════════════════════════════════════════════════════════════════════ */
.skip-link {
  position:absolute; top:-40px; left:16px;
  background:var(--accent); color:#FFF;
  padding:8px 16px; border-radius:4px; z-index:9999;
  font-family:var(--f-body); font-size:13px; font-weight:600;
}
.skip-link:focus { top:16px; }

.site-header {
  position: fixed; top:0; left:0; right:0; z-index:900;
  background: #FFFFFF;
  border-bottom: 1.5px solid var(--border);
  box-shadow: 0 1px 0 var(--navy-18);
  transition: box-shadow 0.3s ease;
}
.site-header.scrolled {
  box-shadow: 0 2px 16px rgba(13,27,42,0.10);
}

.nav-wrap {
  max-width: var(--wrap);
  margin: 0 auto;
  padding: 0 var(--pad);
  height: var(--nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

/* Logo — double size, white bg so full colour shows */
.nav-logo { display:flex; align-items:center; flex-shrink:0; }
.nav-logo__img,
.nav-logo .custom-logo {
  height: 120px;
  width: auto;
  object-fit: contain;
}

/* Nav links — navy */
.nav-primary { display:flex; }
.nav-menu { display:flex; align-items:center; gap:30px; }
.nav-menu li a {
  font-family: var(--f-body);
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--navy);
  transition: color var(--t);
  position: relative;
  padding-bottom: 2px;
}
.nav-menu li a::after {
  content:'';
  position:absolute; bottom:-2px; left:0; right:0;
  height:2px; background:var(--accent);
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--ts);
}
.nav-menu li a:hover,
.nav-menu .current-menu-item > a { color:var(--accent); }
.nav-menu li a:hover::after,
.nav-menu .current-menu-item > a::after { transform:scaleX(1); }

.nav-right { display:flex; align-items:center; gap:10px; flex-shrink:0; }
.nav-cta   { font-size:13px !important; padding:7px 16px !important; }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; justify-content:center;
  gap:5px; width:38px; height:38px; border-radius:var(--r-sm);
  background:var(--offwhite); border:1.5px solid var(--border);
}
.hamburger span { display:block; width:18px; height:1.5px; background:var(--navy); margin:0 auto; transition:all 0.28s; transform-origin:center; }
.hamburger.open span:nth-child(1) { transform:translateY(6.5px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-6.5px) rotate(-45deg); }

/* Mobile nav */
.mobile-nav {
  position:fixed; top:var(--nav-h); left:0; right:0; z-index:899;
  background:#FFF; border-bottom:1.5px solid var(--border);
  box-shadow:0 8px 28px rgba(13,27,42,0.10);
  /* Slide-down animation via max-height + opacity — CSS transition only */
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  transition: max-height 0.35s cubic-bezier(0.22,1,0.36,1),
              opacity 0.28s ease,
              box-shadow 0.3s ease;
}
.mobile-nav.is-open {
  max-height: 600px;
  opacity: 1;
  pointer-events: all;
}
.mobile-nav-inner { padding:20px var(--pad) 28px; }
.mobile-menu li a {
  display:block; color:var(--navy);
  padding:12px 0; font-family:var(--f-body);
  font-size:17px; font-weight:600; letter-spacing:-0.01em;
  border-bottom:1px solid var(--border);
}
.mobile-menu li a:hover { color:var(--accent); }

/* ═══════════════════════════════════════════════════════════════════════════
   HERO — dark cinematic, tight internal spacing
   ═══════════════════════════════════════════════════════════════════════════ */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center;
  overflow:hidden; background:var(--dark);
}
.hero__img {
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center 40%;
  transform:scale(1.04); transition:transform 8s ease-out;
}
.hero:hover .hero__img { transform:scale(1.0); }
.hero__overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(135deg,
    rgba(10,10,10,0.93) 0%,rgba(10,10,10,0.80) 40%,
    rgba(10,10,10,0.68) 65%,rgba(10,10,10,0.92) 100%);
}
.hero__grid {
  position:absolute; inset:0; z-index:2; opacity:0.035; pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,1) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,1) 1px,transparent 1px);
  background-size:80px 80px;
}
.hero__glow-a {
  position:absolute; top:15%; right:5%; width:480px; height:480px; z-index:2;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle,rgba(232,93,38,0.13) 0%,transparent 65%);
  animation:glowPulse 5s ease-in-out infinite;
}
.hero__glow-b {
  position:absolute; bottom:10%; left:5%; width:340px; height:340px; z-index:2;
  border-radius:50%; pointer-events:none;
  background:radial-gradient(circle,rgba(29,78,216,0.07) 0%,transparent 65%);
  animation:glowPulse 5s ease-in-out infinite; animation-delay:-2.5s;
}
@keyframes glowPulse { 0%,100%{opacity:.6;transform:scale(1)} 50%{opacity:1;transform:scale(1.1)} }

.hero__wrap {
  position:relative; z-index:3;
  display:grid; grid-template-columns:1fr auto; gap:40px; align-items:center;
  padding-top:calc(var(--nav-h) + 48px); padding-bottom:64px;
}

/* Hero badge */
.hero__badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:5px 14px; border-radius:999px;
  border:1px solid var(--dark-bmd);
  background:rgba(255,255,255,0.06);
  margin-bottom:22px;
  font-family:var(--f-body);
  font-size:11px; letter-spacing:0.08em; font-weight:600;
  text-transform:uppercase; color:var(--dw-60);
}
.hero__dot { width:6px; height:6px; border-radius:50%; background:#4ADE80; flex-shrink:0; animation:dotPulse 1.8s ease-in-out infinite; box-shadow:0 0 8px rgba(74,222,128,0.5); }
@keyframes dotPulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.6)} }

/* Hero headline — Playfair */
.hero__h1 {
  font-family: var(--f-head);
  font-size: clamp(40px, 6.5vw, 82px);
  font-weight: 800;
  line-height: 1.02;
  letter-spacing: -0.01em;
  color: var(--dw);
  margin-bottom: 20px;
  display:block;
}
.hero__h1-line   { display:block; }
.hero__h1-accent {
  display:block;
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-lt) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero__h1-sub {
  display:block; color:rgba(255,255,255,0.44);
  font-family:var(--f-body); font-weight:300;
  font-size:clamp(14px,1.8vw,20px); letter-spacing:0; margin-top:10px;
}

.hero__body {
  font-family:var(--f-body); font-size:16px; line-height:1.72;
  color:var(--dw-60); max-width:520px; margin-bottom:32px; letter-spacing:-0.01em;
}
.hero__ctas { display:flex; gap:12px; flex-wrap:wrap; }
.hero__scroll { margin-top:52px; display:flex; align-items:center; gap:10px; }
.hero__scroll-line { width:1px; height:40px; background:linear-gradient(var(--accent),transparent); animation:scrollLine 1.8s ease-in-out infinite; }
@keyframes scrollLine { 0%,100%{opacity:.4} 50%{opacity:1} }
.hero__scroll span { font-family:var(--f-body); color:var(--dw-22); font-size:10.5px; letter-spacing:0.1em; text-transform:uppercase; }

/* Stats card */
.hero__stats {
  background:rgba(8,8,8,0.76); border:1px solid var(--dark-bmd);
  border-radius:var(--r-xl); padding:22px; min-width:210px;
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
}
.hero__stats-label { font-family:var(--f-body); color:var(--dw-22); font-size:10.5px; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; margin-bottom:16px; }
.hero__stat { padding:11px 0; }
.hero__stat--border { border-bottom:1px solid var(--dark-border); }
.hero__stat strong { display:block; font-family:var(--f-head); font-size:22px; font-weight:700; color:var(--dw); letter-spacing:-0.01em; line-height:1.1; }
.hero__stat span   { display:block; font-family:var(--f-body); font-size:11.5px; color:var(--dw-40); margin-top:2px; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   INDUSTRIES — tight image cards
   ═══════════════════════════════════════════════════════════════════════════ */
.industries-grid {
  display:grid; grid-template-columns:repeat(5,1fr); gap:14px;
}
.ind-card {
  border-radius:var(--r-lg); overflow:hidden;
  border:1.5px solid var(--border); background:var(--white);
  box-shadow:0 1px 8px rgba(13,27,42,0.07);
  transition:all var(--ts); cursor:pointer;
}
.ind-card:hover {
  transform:translateY(-5px);
  box-shadow:0 10px 32px rgba(13,27,42,0.13);
  border-color:rgba(232,93,38,0.3);
}
.ind-card__img { position:relative; aspect-ratio:4/3; overflow:hidden; background:var(--offwhite); }
.ind-card__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.55s var(--ease),filter 0.35s; filter:brightness(0.8) saturate(0.85); }
.ind-card:hover .ind-card__img img { transform:scale(1.06); filter:brightness(0.9) saturate(1.05); }
.ind-card__img-overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(13,27,42,0.52) 0%,transparent 55%); }
.ind-card__emoji { position:absolute; bottom:10px; left:12px; font-size:20px; }
.ind-card__body { padding:13px 15px 16px; }
.ind-card__body h3 { font-family:var(--f-head); font-size:14px; font-weight:700; color:var(--navy); margin-bottom:4px; letter-spacing:-0.01em; }
.ind-card__body p  { font-family:var(--f-body); font-size:12px; color:var(--navy-55); line-height:1.55; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   SERVICES — image-topped cards, tight
   ═══════════════════════════════════════════════════════════════════════════ */
.services-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:20px; }

.svc-card {
  border-radius:var(--r-2xl); overflow:hidden; background:var(--white);
  border:1.5px solid var(--border);
  box-shadow:0 1px 12px rgba(13,27,42,0.06);
  transition:all var(--ts); display:flex; flex-direction:column;
}
.svc-card:hover {
  transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(13,27,42,0.12);
  border-color:color-mix(in srgb,var(--sc,var(--accent)) 35%,transparent);
}
.svc-card__img { height:180px; overflow:hidden; position:relative; background:var(--offwhite); }
.svc-card__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.65s var(--ease),filter 0.35s; filter:brightness(0.76) saturate(0.8); }
.svc-card:hover .svc-card__img img { transform:scale(1.07); filter:brightness(0.88) saturate(1.05); }
.svc-card__img::after { content:''; position:absolute; bottom:0; left:0; right:0; height:50px; background:linear-gradient(0deg,rgba(13,27,42,0.28),transparent); }

.svc-card__body { padding:22px 22px 18px; display:flex; flex-direction:column; flex:1; }
.svc-card__top  { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }
.svc-card__icon { width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; background:color-mix(in srgb,var(--sc,var(--accent)) 12%,transparent); color:var(--sc,var(--accent)); flex-shrink:0; }
.svc-card__tag  { font-family:var(--f-body); font-size:10.5px; padding:3px 9px; border-radius:999px; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; background:color-mix(in srgb,var(--sc,var(--accent)) 10%,transparent); color:var(--sc,var(--accent)); }
.svc-card__title { font-family:var(--f-head); font-size:18px; font-weight:700; color:var(--navy); margin-bottom:8px; letter-spacing:-0.01em; line-height:1.15; }
.svc-card__desc  { font-family:var(--f-body); font-size:13.5px; color:var(--navy-55); line-height:1.65; letter-spacing:-0.01em; flex:1; margin-bottom:18px; }
.svc-card__foot  { display:flex; justify-content:space-between; align-items:center; gap:10px; padding-top:14px; border-top:1.5px solid var(--border); }
.svc-card__spec  { font-family:var(--f-body); font-size:11.5px; color:var(--navy-35); padding:3px 9px; border-radius:5px; background:var(--offwhite); border:1px solid var(--border); font-weight:500; letter-spacing:-0.01em; }
.svc-card__link  { display:flex; align-items:center; gap:5px; font-family:var(--f-body); font-size:12.5px; font-weight:700; color:var(--navy-35); transition:all var(--t); white-space:nowrap; letter-spacing:-0.01em; }
.svc-card:hover .svc-card__link { color:var(--sc,var(--accent)); gap:9px; }

/* ═══════════════════════════════════════════════════════════════════════════
   WHY AGILE — image strip + bento
   ═══════════════════════════════════════════════════════════════════════════ */
.why-section { padding-top:0; }

.why-strip { position:relative; width:100%; height:200px; overflow:hidden; }
.why-strip img { width:100%; height:100%; object-fit:cover; object-position:center 55%; filter:brightness(0.52) saturate(0.78); }
.why-strip__overlay { position:absolute; inset:0; background:linear-gradient(0deg,rgba(13,27,42,0.58) 0%,rgba(13,27,42,0.12) 65%,transparent 100%); }
.why-strip__text { position:absolute; bottom:22px; left:var(--pad); right:var(--pad); max-width:var(--wrap); margin:0 auto; }
.why-strip__text span { font-family:var(--f-head); font-size:clamp(17px,2.2vw,26px); font-weight:700; letter-spacing:-0.01em; color:#FFFFFF; }

/* Bento */
.bento { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.bento__card--span-1 { grid-column:span 1; }
.bento__card--span-2 { grid-column:span 2; }
.bento__card {
  padding:26px 24px; border-radius:var(--r-2xl);
  background:var(--white); border:1.5px solid var(--border);
  box-shadow:0 1px 10px rgba(13,27,42,0.05);
  min-height:190px; transition:all var(--ts); position:relative; overflow:hidden;
}
.bento__card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--bc,var(--accent)); transform:scaleX(0); transform-origin:left; transition:transform var(--ts); }
.bento__card:hover { transform:translateY(-3px); box-shadow:0 10px 32px rgba(13,27,42,0.10); border-color:color-mix(in srgb,var(--bc,var(--accent)) 28%,transparent); }
.bento__card:hover::before { transform:scaleX(1); }
.bento__icon { width:36px; height:36px; border-radius:9px; display:flex; align-items:center; justify-content:center; background:color-mix(in srgb,var(--bc,var(--accent)) 12%,transparent); color:var(--bc,var(--accent)); margin-bottom:14px; }
.bento__metric { margin-bottom:10px; }
.bento__metric strong { display:block; font-family:var(--f-head); font-size:clamp(28px,3.5vw,42px); font-weight:800; color:var(--bc,var(--accent)); letter-spacing:-0.01em; line-height:1; }
.bento__metric span   { display:block; font-family:var(--f-body); font-size:10.5px; color:var(--navy-35); text-transform:uppercase; letter-spacing:0.08em; margin-top:3px; }
.bento__card h3 { font-family:var(--f-head); font-size:16px; font-weight:700; color:var(--navy); margin-bottom:8px; letter-spacing:-0.01em; }
.bento__card p  { font-family:var(--f-body); font-size:13.5px; color:var(--navy-55); line-height:1.62; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   PROCESS — tight timeline
   ═══════════════════════════════════════════════════════════════════════════ */
.process-grid {
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:0; position:relative; margin-top:var(--sh);
}
.process-grid::before {
  content:''; position:absolute; top:23px; left:24px; right:24px; height:1px;
  background:linear-gradient(90deg,var(--accent),rgba(232,93,38,0.06));
  pointer-events:none;
}
.process-step { padding:0 16px 0 0; }
.process-step:last-child { padding-right:0; }
.process-step__num {
  width:46px; height:46px; border-radius:13px;
  border:1.5px solid var(--border); background:var(--white);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--f-body); font-size:12px; font-weight:700;
  color:var(--navy-35); margin-bottom:14px;
  box-shadow:0 1px 6px rgba(13,27,42,0.06); transition:all var(--t);
}
.process-step--active .process-step__num { background:var(--accent); border-color:var(--accent); color:#FFF; box-shadow:0 4px 18px rgba(232,93,38,0.38); }
.process-step__icon-wrap { width:24px; height:24px; border-radius:6px; display:flex; align-items:center; justify-content:center; color:var(--navy-35); margin-bottom:10px; margin-top:-6px; }
.process-step--active .process-step__icon-wrap { color:var(--accent); }
.process-step__title { font-family:var(--f-head); font-size:14px; font-weight:700; color:var(--navy); margin-bottom:6px; line-height:1.3; letter-spacing:-0.01em; }
.process-step__desc  { font-family:var(--f-body); font-size:12.5px; color:var(--navy-55); line-height:1.62; letter-spacing:-0.01em; }

/* Process bottom CTA strip */
.process-cta {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:14px;
  margin-top:32px; padding:22px 28px;
  background:var(--white); border-radius:var(--r-xl);
  border:1.5px solid var(--border);
  box-shadow:0 1px 8px rgba(13,27,42,0.05);
}
.process-cta p { font-family:var(--f-head); font-size:17px; font-weight:700; color:var(--navy); letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   ABOUT — editorial split
   ═══════════════════════════════════════════════════════════════════════════ */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:start; }
.about-visual { display:flex; flex-direction:column; gap:0; }

.about-body { font-family:var(--f-body); color:var(--navy-55); font-size:14.5px; line-height:1.8; margin-bottom:16px; letter-spacing:-0.01em; }
.about-checks { margin-top:14px; display:flex; flex-direction:column; gap:10px; }
.about-checks li { display:flex; align-items:center; gap:10px; font-family:var(--f-body); font-size:13.5px; color:var(--navy-55); letter-spacing:-0.01em; }
.about-check-icon { width:22px; height:22px; border-radius:6px; background:rgba(232,93,38,0.10); display:flex; align-items:center; justify-content:center; color:var(--accent); flex-shrink:0; }

.about-img-wrap { border-radius:var(--r-2xl); overflow:hidden; aspect-ratio:4/3; margin-bottom:16px; box-shadow:0 6px 40px rgba(13,27,42,0.16); background:var(--offwhite); }
.about-img-wrap img { width:100%; height:100%; object-fit:cover; transition:transform 0.8s var(--ease); filter:brightness(0.9) saturate(0.88); }
.about-img-wrap:hover img { transform:scale(1.03); filter:brightness(0.96) saturate(1); }

/* Spec card */
.about-spec-float { background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; box-shadow:0 2px 18px rgba(13,27,42,0.08); }
.spec-float__header { padding:11px 18px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:9px; background:var(--offwhite); }
.spec-float__dots { display:flex; gap:5px; }
.spec-float__dots span { width:9px; height:9px; border-radius:50%; display:block; }
.spec-float__file { font-family:'Fira Mono','DM Mono',monospace; font-size:11px; color:var(--navy-35); letter-spacing:-0.01em; }
.spec-float__row { display:grid; grid-template-columns:1fr 1.5fr; padding:9px 18px; align-items:baseline; }
.spec-float__row--border { border-bottom:1px solid var(--border); }
.spec-float__row span   { font-family:var(--f-body); color:var(--navy-35); font-size:10.5px; font-weight:600; text-transform:uppercase; letter-spacing:0.05em; }
.spec-float__row strong { font-family:var(--f-body); color:var(--navy-75); font-weight:500; font-size:12.5px; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   TESTIMONIALS — trust pills + cards
   ═══════════════════════════════════════════════════════════════════════════ */
.testi-sectors { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.testi-sector-pill { font-family:var(--f-body); font-size:11.5px; font-weight:600; letter-spacing:-0.01em; padding:5px 13px; border-radius:999px; background:var(--white); color:var(--navy-55); border:1.5px solid var(--border); box-shadow:0 1px 4px rgba(13,27,42,0.05); }

.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.testi-card {
  padding:24px; border-radius:var(--r-2xl);
  background:var(--white); border:1.5px solid var(--border);
  box-shadow:0 1px 12px rgba(13,27,42,0.06);
  transition:all var(--ts); height:100%; display:flex; flex-direction:column;
}
.testi-card:hover { transform:translateY(-4px); box-shadow:0 10px 32px rgba(13,27,42,0.10); border-color:rgba(232,93,38,0.28); }
.testi-stars { display:flex; gap:3px; margin-bottom:14px; }
.testi-star  { color:var(--accent); }
.testi-card blockquote { flex:1; }
.testi-card blockquote p { font-family:var(--f-body); font-size:13.5px; color:var(--navy-75); line-height:1.78; margin-bottom:20px; font-style:italic; letter-spacing:-0.01em; }
.testi-author { display:flex; align-items:center; gap:10px; padding-top:16px; border-top:1.5px solid var(--border); }
.testi-avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,rgba(232,93,38,0.75),rgba(29,78,216,0.75)); display:flex; align-items:center; justify-content:center; font-family:var(--f-head); font-size:14px; font-weight:700; color:#FFF; flex-shrink:0; }
.testi-author strong { display:block; font-family:var(--f-head); font-size:13.5px; font-weight:700; color:var(--navy); letter-spacing:-0.01em; }
.testi-author span   { display:block; font-family:var(--f-body); font-size:11.5px; color:var(--navy-35); margin-top:1px; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   CTA — dark closing, tight
   ═══════════════════════════════════════════════════════════════════════════ */
.cta-inner { max-width:680px; margin:0 auto; text-align:center; position:relative; }
.cta-inner::before { content:''; position:absolute; inset:-40px -80px; background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(232,93,38,0.08) 0%,transparent 65%); pointer-events:none; z-index:0; }

.cta-badge { display:inline-block; padding:5px 14px; border-radius:999px; border:1px solid rgba(255,255,255,0.16); background:rgba(232,93,38,0.10); color:var(--accent-lt); font-family:var(--f-body); font-size:11px; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; margin-bottom:20px; position:relative; z-index:1; }
.cta-h2 { font-family:var(--f-head); font-size:clamp(34px,5.5vw,68px); font-weight:800; letter-spacing:-0.01em; color:var(--dw); line-height:1.04; margin-bottom:16px; position:relative; z-index:1; }
.cta-h2__accent { display:block; background:linear-gradient(135deg,var(--accent) 0%,var(--accent-lt) 100%); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cta-body { font-family:var(--f-body); color:var(--dw-60); font-size:16px; line-height:1.72; margin-bottom:32px; max-width:460px; margin-left:auto; margin-right:auto; letter-spacing:-0.01em; position:relative; z-index:1; }
.cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-bottom:28px; position:relative; z-index:1; }
.cta-trust { display:flex; gap:24px; justify-content:center; flex-wrap:wrap; position:relative; z-index:1; }
.cta-trust span { display:flex; align-items:center; gap:6px; font-family:var(--f-body); font-size:12.5px; color:var(--dw-40); letter-spacing:-0.01em; }
.cta-trust span svg { color:var(--green); }

/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER — dark, tight
   ═══════════════════════════════════════════════════════════════════════════ */
.site-footer { background:#0C0C0C; }
.footer-top { padding:48px 0 36px; border-top:1px solid var(--dark-border); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }

.footer-brand img { height:34px; width:auto; margin-bottom:14px; }
.footer-brand p { font-family:var(--f-body); color:var(--dw-40); font-size:13px; line-height:1.72; max-width:260px; margin-bottom:18px; letter-spacing:-0.01em; }
.footer-contact-list { display:flex; flex-direction:column; gap:9px; }
.footer-contact-list a,
.footer-contact-list span { display:flex; align-items:center; gap:8px; font-family:var(--f-body); font-size:13px; color:var(--dw-40); transition:color var(--t); letter-spacing:-0.01em; }
.footer-contact-list a:hover { color:var(--dw); }
.footer-contact-list svg { flex-shrink:0; color:var(--dw-22); }

.footer-col h4 { font-family:var(--f-body); font-size:10.5px; font-weight:700; color:var(--dw); letter-spacing:0.1em; text-transform:uppercase; margin-bottom:14px; }
.footer-col ul li { margin-bottom:8px; }
.footer-col ul a { font-family:var(--f-body); font-size:13px; color:var(--dw-40); transition:color var(--t); letter-spacing:-0.01em; }
.footer-col ul a:hover { color:var(--dw); }

.footer-bottom { border-top:1px solid var(--dark-border); padding:16px 0; }
.footer-bottom .wrap { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.footer-bottom span { font-family:var(--f-body); font-size:11.5px; color:var(--dw-22); letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE HERO (inner pages)
   ═══════════════════════════════════════════════════════════════════════════ */
.page-hero { padding:calc(var(--nav-h) + 56px) 0 52px; position:relative; overflow:hidden; background:var(--dark); }
.page-hero--contact  { background-image:url('https://images.pexels.com/photos/2760343/pexels-photo-2760343.jpeg?auto=compress&cs=tinysrgb&w=1920&fit=crop'); background-size:cover; background-position:center; }
.page-hero--services { background-image:url('https://images.pexels.com/photos/29386087/pexels-photo-29386087.jpeg?auto=compress&cs=tinysrgb&w=1920&fit=crop'); background-size:cover; background-position:center 30%; }
.page-hero--projects { background-image:url('https://images.pexels.com/photos/8973680/pexels-photo-8973680.jpeg?auto=compress&cs=tinysrgb&w=1920&fit=crop'); background-size:cover; background-position:center; }
.page-hero--about    { background-image:url('https://images.pexels.com/photos/32845683/pexels-photo-32845683.jpeg?auto=compress&cs=tinysrgb&w=1920&fit=crop'); background-size:cover; background-position:center 40%; }
.page-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(10,10,10,0.93) 0%,rgba(10,10,10,0.78) 50%,rgba(10,10,10,0.93) 100%); z-index:1; }
.page-hero::after  { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 30% 50%,rgba(232,93,38,0.06) 0%,transparent 60%); z-index:1; pointer-events:none; }
.page-hero .wrap   { position:relative; z-index:2; }
.page-hero__eyebrow { font-family:var(--f-body); color:var(--accent-lt); font-size:11px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; margin-bottom:10px; display:block; }
.page-hero__title { font-family:var(--f-head); font-size:clamp(32px,4.5vw,60px); font-weight:800; letter-spacing:-0.01em; color:var(--dw); margin-bottom:14px; line-height:1.06; }
.page-hero__sub   { font-family:var(--f-body); color:var(--dw-60); font-size:16px; line-height:1.72; max-width:540px; letter-spacing:-0.01em; }

/* ═══════════════════════════════════════════════════════════════════════════
   CONTACT PAGE — light
   ═══════════════════════════════════════════════════════════════════════════ */
.contact-form-section { background:var(--white); padding-top:52px; padding-bottom:52px; }
.contact-wrap { display:grid; grid-template-columns:1fr 340px; gap:52px; align-items:start; }

.form-row    { display:flex; gap:16px; margin-bottom:18px; }
.form-row--2 {}
.form-group  { flex:1; display:flex; flex-direction:column; gap:6px; }
.form-label  { font-family:var(--f-body); font-size:12.5px; font-weight:600; color:var(--navy); letter-spacing:-0.01em; }
.form-label sup { color:var(--accent); }

.form-input, .form-select, .form-textarea {
  background:var(--white); border:1.5px solid var(--border-2);
  border-radius:var(--r-md); padding:10px 14px;
  font-family:var(--f-body); font-size:13.5px;
  color:var(--navy); letter-spacing:-0.01em;
  transition:border-color var(--t),box-shadow var(--t);
  outline:none; width:100%; -webkit-appearance:none;
}
.form-input::placeholder, .form-textarea::placeholder { color:var(--navy-18); }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(232,93,38,0.08); }
.form-select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%230D1B2A' stroke-width='2' opacity='0.35'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 12px center; padding-right:36px; cursor:pointer; }
.form-select option { background:var(--white); color:var(--navy); }
.form-textarea { resize:vertical; min-height:108px; }
.form-response { padding:12px 16px; border-radius:var(--r-md); margin-bottom:18px; font-family:var(--f-body); font-size:13px; font-weight:600; letter-spacing:-0.01em; }
.form-response--success { background:#ECFDF5; border:1.5px solid #A7F3D0; color:#065F46; }
.form-response--error   { background:#FFF7ED; border:1.5px solid #FED7AA; color:#9A3412; }
.form-privacy { margin-top:12px; font-family:var(--f-body); font-size:11.5px; color:var(--navy-35); text-align:center; line-height:1.55; letter-spacing:-0.01em; }
.btn-loading { display:none; }
.btn.is-loading .btn-text    { display:none; }
.btn.is-loading .btn-loading { display:block; }

.contact-sidebar { position:sticky; top:calc(var(--nav-h) + 20px); display:flex; flex-direction:column; gap:16px; }
.contact-info-card { background:var(--offwhite); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:22px; }
.contact-info-card h3 { font-family:var(--f-head); font-size:15px; font-weight:700; color:var(--navy); margin-bottom:16px; letter-spacing:-0.01em; }
.contact-info-list li { display:flex; align-items:flex-start; gap:10px; margin-bottom:14px; }
.contact-info-list li:last-child { margin-bottom:0; }
.contact-info-list svg { color:var(--accent); flex-shrink:0; margin-top:2px; }
.ci-label { display:block; font-family:var(--f-body); font-size:10.5px; font-weight:700; color:var(--navy-35); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:2px; }
.ci-val   { font-family:var(--f-body); color:var(--navy-75); font-size:13px; letter-spacing:-0.01em; }
.ci-val a { color:var(--navy-75); } .ci-val a:hover { color:var(--accent); }
.next-steps li { display:flex; align-items:flex-start; gap:10px; margin-bottom:12px; font-family:var(--f-body); font-size:13px; color:var(--navy-55); line-height:1.52; letter-spacing:-0.01em; }
.ns-num { font-family:var(--f-body); font-size:11.5px; font-weight:800; color:var(--accent); letter-spacing:0.04em; flex-shrink:0; min-width:20px; padding-top:1px; }

/* ═══════════════════════════════════════════════════════════════════════════
   SINGLE CPT PAGES
   ═══════════════════════════════════════════════════════════════════════════ */
.single-grid    { display:grid; grid-template-columns:1fr 290px; gap:48px; align-items:start; }
.single-sidebar { position:sticky; top:calc(var(--nav-h) + 20px); background:var(--offwhite); border:1.5px solid var(--border); border-radius:var(--r-xl); padding:22px; }
.single-sidebar__title { font-family:var(--f-body); font-size:10.5px; font-weight:700; color:var(--navy-35); text-transform:uppercase; letter-spacing:0.1em; margin-bottom:14px; }
.single-detail { display:flex; justify-content:space-between; gap:10px; padding:8px 0; border-bottom:1px solid var(--border); font-size:12.5px; }
.single-detail:last-of-type { border-bottom:none; }
.single-detail span:first-child { font-family:var(--f-body); color:var(--navy-35); font-weight:600; font-size:10.5px; text-transform:uppercase; letter-spacing:0.06em; }
.single-detail span:last-child  { font-family:var(--f-body); color:var(--navy-75); text-align:right; font-weight:500; letter-spacing:-0.01em; }

/* Post body content */
.post-content { font-family:var(--f-body); font-size:14.5px; line-height:1.8; color:var(--navy-75); letter-spacing:-0.01em; }
.post-content h2, .post-content h3 { font-family:var(--f-head); color:var(--navy); font-weight:700; margin:28px 0 12px; letter-spacing:-0.01em; }
.post-content h2 { font-size:1.5em; }
.post-content h3 { font-size:1.25em; }
.post-content p  { margin-bottom:16px; }
.post-content a  { color:var(--accent); } .post-content a:hover { text-decoration:underline; }
.post-content strong { color:var(--navy); font-weight:700; }
.post-content ul { list-style:disc; padding-left:18px; margin-bottom:16px; }
.post-content ul li { margin-bottom:6px; }

/* ═══════════════════════════════════════════════════════════════════════════
   ARCHIVE / PAGINATION
   ═══════════════════════════════════════════════════════════════════════════ */
.archive-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:20px; }
.nav-links { display:flex; gap:6px; justify-content:center; margin-top:36px; flex-wrap:wrap; }
.nav-links a, .nav-links span { padding:7px 14px; border-radius:var(--r-sm); font-family:var(--f-body); font-size:13px; font-weight:600; border:1.5px solid var(--border); color:var(--navy); transition:all var(--t); letter-spacing:-0.01em; }
.nav-links a:hover { border-color:var(--accent); color:var(--accent); }
.nav-links .current { background:var(--accent); border-color:var(--accent); color:#FFF; }

/* ═══════════════════════════════════════════════════════════════════════════
   ACCESSIBILITY
   ═══════════════════════════════════════════════════════════════════════════ */
:focus-visible { outline:2px solid var(--accent); outline-offset:3px; border-radius:4px; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .hero__wrap { grid-template-columns:1fr; }
  .hero__stats { display:none; }
  .bento { grid-template-columns:1fr 1fr; }
  .bento__card--span-2 { grid-column:span 2; }
  .about-grid { grid-template-columns:1fr; gap:36px; }
}
@media (max-width:900px) {
  .nav-primary  { display:none; }
  .hamburger    { display:flex; }
  .industries-grid { grid-template-columns:repeat(3,1fr); }
  .testi-grid   { grid-template-columns:1fr 1fr; }
  .contact-wrap { grid-template-columns:1fr; }
  .contact-sidebar { position:static; }
  .footer-grid  { grid-template-columns:1fr 1fr; gap:28px; }
  .process-grid { grid-template-columns:1fr 1fr; }
  .process-grid::before { display:none; }
  .process-step { padding-right:0; margin-bottom:20px; }
  .single-grid  { grid-template-columns:1fr; }
  .single-sidebar { position:static; }
  .why-strip { height:160px; }
}
@media (max-width:640px) {
  :root { --nav-h:68px; --sy:clamp(32px,5vw,48px); --sh:24px; }
  .nav-logo__img, .nav-logo .custom-logo { height:72px; }
  .industries-grid { grid-template-columns:1fr 1fr; }
  .bento { grid-template-columns:1fr; }
  .bento__card--span-2 { grid-column:span 1; }
  .services-grid { grid-template-columns:1fr; }
  .testi-grid { grid-template-columns:1fr; }
  .section-header-split { flex-direction:column; align-items:flex-start; }
  .footer-grid  { grid-template-columns:1fr; gap:24px; }
  .hero__ctas, .cta-btns { flex-direction:column; align-items:stretch; }
  .process-grid { grid-template-columns:1fr; }
  .form-row { flex-direction:column; }
  .footer-bottom .wrap { flex-direction:column; gap:6px; text-align:center; }
  .cta-trust { flex-direction:column; align-items:center; gap:10px; }
  .why-strip { height:120px; }
  .why-strip__text span { font-size:15px; }
  .testi-sectors { gap:6px; }
  .testi-sector-pill { font-size:11px; padding:4px 10px; }
  .process-cta { flex-direction:column; text-align:center; }
}
@media (max-width:420px) {
  .industries-grid { grid-template-columns:1fr; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   NAV DROPDOWN
   ═══════════════════════════════════════════════════════════════════════════ */
.nav-has-dropdown { position:relative; }
.nav-dropdown {
  position:absolute; top:calc(100% + 10px); left:50%;
  transform:translateX(-50%) translateY(-4px);
  background:#FFF; border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:6px 0;
  min-width:220px;
  box-shadow:0 8px 32px rgba(13,27,42,0.12);
  opacity:0; pointer-events:none;
  transition:opacity 0.2s ease,transform 0.22s var(--ease);
  z-index:200;
}
.nav-has-dropdown:hover .nav-dropdown,
.nav-has-dropdown:focus-within .nav-dropdown {
  opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
}
.nav-dropdown li a {
  display:block; padding:10px 18px;
  font-family:var(--f-body); font-size:13.5px;
  font-weight:500; color:var(--navy);
  letter-spacing:-0.01em;
  transition:color var(--t),background var(--t);
}
.nav-dropdown li a:hover { color:var(--accent); background:var(--offwhite); }
.nav-dropdown li a::after { display:none; }

/* ═══════════════════════════════════════════════════════════════════════════
   SERVICE DETAIL PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.svc-hero-img {
  border-radius:var(--r-2xl); overflow:hidden;
  aspect-ratio:16/6; margin-bottom:44px;
  border:1.5px solid var(--border);
  box-shadow:0 4px 28px rgba(13,27,42,0.10);
}
.svc-hero-img img { width:100%; height:100%; object-fit:cover; filter:brightness(0.85); }

.svc-detail-block { margin-bottom:32px; }
.svc-detail-h3 {
  font-family:var(--f-head); font-size:18px; font-weight:700;
  color:var(--navy); margin-bottom:16px; letter-spacing:-0.01em;
}
.svc-feature-list { display:flex; flex-direction:column; gap:10px; }
.svc-feature-list li {
  display:flex; align-items:flex-start; gap:10px;
  font-family:var(--f-body); font-size:14px;
  color:var(--navy-75); letter-spacing:-0.01em; line-height:1.55;
}
.svc-feature-list li svg { color:var(--accent); flex-shrink:0; margin-top:2px; }

.svc-app-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.svc-app-item {
  padding:14px 16px; border-radius:var(--r-md);
  background:var(--offwhite); border:1px solid var(--border);
}
.svc-app-item strong {
  display:block; font-family:var(--f-head);
  font-size:13.5px; font-weight:700; color:var(--navy);
  margin-bottom:4px; letter-spacing:-0.01em;
}
.svc-app-item span {
  font-family:var(--f-body); font-size:12.5px;
  color:var(--navy-55); letter-spacing:-0.01em;
}

.svc-cta-strip {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:16px; margin-top:36px; padding:22px 24px;
  background:var(--offwhite); border-radius:var(--r-xl);
  border:1.5px solid var(--border);
}
.svc-cta-strip p {
  font-family:var(--f-head); font-size:17px;
  font-weight:700; color:var(--navy); letter-spacing:-0.01em;
}

/* Sidebar service links */
.sidebar-contact {
  margin-top:18px; padding-top:16px;
  border-top:1px solid var(--border);
  display:flex; flex-direction:column; gap:10px;
}
.sidebar-contact a {
  display:flex; align-items:center; gap:8px;
  font-family:var(--f-body); font-size:12.5px;
  color:var(--navy-55); transition:color var(--t); letter-spacing:-0.01em;
}
.sidebar-contact a:hover { color:var(--accent); }
.sidebar-contact svg { color:var(--accent); flex-shrink:0; }

.sidebar-other-services { display:flex; flex-direction:column; gap:4px; }
.sidebar-svc-link {
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px; border-radius:var(--r-sm);
  font-family:var(--f-body); font-size:13px;
  font-weight:500; color:var(--navy-55);
  background:var(--offwhite); border:1px solid var(--border);
  transition:all var(--t); letter-spacing:-0.01em;
}
.sidebar-svc-link:hover { color:var(--sc,var(--accent)); border-color:color-mix(in srgb,var(--sc,var(--accent)) 30%,transparent); background:color-mix(in srgb,var(--sc,var(--accent)) 6%,transparent); }
.sidebar-svc-icon { display:flex; align-items:center; gap:8px; color:var(--sc,var(--accent)); }

/* ═══════════════════════════════════════════════════════════════════════════
   ABOUT PAGE EXTRAS
   ═══════════════════════════════════════════════════════════════════════════ */
.about-pillars {
  display:flex; flex-direction:column; gap:10px; margin:18px 0 24px;
}
.about-pillar {
  display:flex; align-items:center; gap:10px;
  font-family:var(--f-body); font-size:14px; font-weight:600;
  color:var(--navy); letter-spacing:-0.01em;
}
.about-pillar .about-check-icon { flex-shrink:0; }

.about-vision-mission { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:24px; }
.avm-card {
  padding:18px 20px; border-radius:var(--r-lg);
  background:var(--offwhite); border:1.5px solid var(--border);
}
.avm-card h3 {
  font-family:var(--f-head); font-size:14px; font-weight:700;
  color:var(--accent); margin-bottom:8px; letter-spacing:-0.01em;
  text-transform:uppercase; font-size:11px; letter-spacing:0.08em;
}
.avm-card p {
  font-family:var(--f-body); font-size:13px;
  color:var(--navy-55); line-height:1.65; letter-spacing:-0.01em;
}

.about-stats-row {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:12px; margin-top:16px;
}
.about-stat {
  padding:14px; text-align:center;
  background:var(--offwhite); border-radius:var(--r-md);
  border:1.5px solid var(--border);
}
.about-stat strong {
  display:block; font-family:var(--f-head);
  font-size:20px; font-weight:800; color:var(--accent);
  letter-spacing:-0.02em; line-height:1;
}
.about-stat span {
  display:block; font-family:var(--f-body);
  font-size:11px; color:var(--navy-40);
  text-transform:uppercase; letter-spacing:0.06em;
  margin-top:4px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE ADDITIONS
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:900px) {
  .svc-app-grid { grid-template-columns:1fr; }
  .about-vision-mission { grid-template-columns:1fr; }
  .about-stats-row { grid-template-columns:repeat(2,1fr); }
  .svc-cta-strip { flex-direction:column; }
}
@media (max-width:640px) {
  .about-stats-row { grid-template-columns:repeat(2,1fr); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTON THROB — Subtle breathing pulse on all accent + CTA buttons
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes btnThrob {
  0%   { box-shadow: 0 0 0 0 rgba(232,93,38,0.0),  0 4px 14px rgba(232,93,38,0.25); transform:scale(1); }
  35%  { box-shadow: 0 0 0 6px rgba(232,93,38,0.14), 0 6px 20px rgba(232,93,38,0.30); transform:scale(1.018); }
  70%  { box-shadow: 0 0 0 10px rgba(232,93,38,0.05), 0 4px 14px rgba(232,93,38,0.22); transform:scale(1.008); }
  100% { box-shadow: 0 0 0 0 rgba(232,93,38,0.0),  0 4px 14px rgba(232,93,38,0.25); transform:scale(1); }
}

/* Apply to every accent button automatically */
.btn-accent {
  animation: btnThrob 2.8s ease-in-out infinite;
}

/* Pause throb on hover — hover has its own lift effect */
.btn-accent:hover,
.btn-accent:focus-visible {
  animation-play-state: paused;
}

/* Explicit .btn-throb class for any non-accent button that needs it */
.btn-throb {
  animation: btnThrob 2.8s ease-in-out infinite;
}
.btn-throb:hover,
.btn-throb:focus-visible {
  animation-play-state: paused;
}

/* Nav CTA — slightly calmer throb (doesn't fight the nav) */
.nav-cta.btn-accent {
  animation-duration: 3.5s;
}

/* ── NAV HEIGHT ADJUSTMENT for bigger logo ── */
.nav-wrap {
  height: var(--nav-h);
}

/* ── PROCESS CTA STRIP button — make it xl ── */
.process-cta .btn {
  font-size: 15px !important;
  padding: 15px 32px !important;
}
