:root {
  --ink: #0d1418;
  --ink-2: #121b21;
  --ink-3: #1b262d;
  --paper: #f7f6f2;
  --paper-2: #efece3;
  --paper-3: #e6e2d6;
  --text: #15201f;
  --muted: #5b6a6b;
  --muted-2: #7c8889;
  --line: rgba(13, 20, 24, .12);
  --line-2: rgba(13, 20, 24, .07);
  --green: #3d900a;
  --green-br: #85c712;
  --green-dk: #2c6b07;
  --gold: #c9a227;
  --gold-br: #e2c65a;
  --gold-dk: #9a7c1a;
  --blue: #064c8e;
  --blue-br: #40ace3;
  --blue-dk: #053c70;
  --fire: #ba5214;
  --fire-br: #e2641a;
  --sil-1: #eceee7;
  --sil-2: #b6b9b1;
  --sil-3: #7f8379;
  --r: 1rem;
  --maxw: 75rem;
  --shadow: 0 1px 2px rgba(13, 20, 24, .04), 0 16px 40px -20px rgba(13, 20, 24, .22);
  --shadow-lg: 0 30px 70px -30px rgba(13, 20, 24, .4);
}

* {
  box-sizing: border-box
}

html {
  scroll-behavior: smooth
}

body {
  margin: 0;
  font-family: "Hanken Grotesk", system-ui, sans-serif;
  color: var(--text);
  background: var(--paper);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden
}

h1,
h2,
h3,
h4 {
  font-family: "Saira", sans-serif;
  line-height: 1.04;
  margin: 0;
  letter-spacing: -.01em;
  font-weight: 800;
  overflow-wrap: break-word
}

a {
  color: inherit;
  text-decoration: none
}

img {
  max-width: 100%;
  display: block
}

section {
  scroll-margin-top: 5.25rem
}

.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 1.5rem
}

.ey {
  font-family: "Spline Sans Mono", monospace;
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .22em;
  text-transform: uppercase
}

.skip {
  position: absolute;
  left: -999px;
  top: 0;
  background: var(--ink);
  color: #fff;
  padding: .625rem 1rem;
  z-index: 1000;
  border-radius: 0 0 .5rem 0
}

.skip:focus {
  left: 0
}

.pip {
  width: .6875rem;
  height: .6875rem;
  border-radius: 50%;
  flex: none;
  display: inline-block
}

.pip.c {
  background: var(--green)
}

.pip.p {
  background: var(--gold)
}

.pip.r {
  background: var(--blue)
}

/* buttons */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5625rem;
  font-family: "Saira", sans-serif;
  font-weight: 700;
  font-size: .9375rem;
  letter-spacing: .01em;
  padding: .8125rem 1.375rem;
  border-radius: 999px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform .25s, box-shadow .25s, background .25s, color .25s;
  white-space: nowrap
}

.btn:hover {
  transform: translateY(-2px)
}

.btn svg {
  width: 1.0625rem;
  height: 1.0625rem
}

.btn-pri {
  background: linear-gradient(180deg, var(--green-br), var(--green));
  color: #fff;
  box-shadow: 0 12px 26px -12px rgba(61, 144, 10, .7)
}

.btn-pri:hover {
  box-shadow: 0 18px 34px -12px rgba(61, 144, 10, .8)
}

.btn-iq {
  background: var(--ink);
  color: #fff;
  border-color: rgba(255, 255, 255, .1)
}

.btn-iq:hover {
  background: #000
}

.btn-iq .iqdot {
  width: .4375rem;
  height: .4375rem;
  border-radius: 50%;
  background: var(--green-br)
}

.btn-ghost {
  background: transparent;
  color: var(--text);
  border-color: var(--line)
}

.btn-ghost:hover {
  border-color: var(--text);
  background: rgba(13, 20, 24, .03)
}

.btn-ghost-l {
  background: transparent;
  color: #fff;
  border-color: rgba(255, 255, 255, .28)
}

.btn-ghost-l:hover {
  border-color: #fff;
  background: rgba(255, 255, 255, .07)
}

/* header */
header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(247, 246, 242, .82);
  backdrop-filter: blur(.875rem);
  border-bottom: 1px solid var(--line-2);
  transition: box-shadow .3s
}

header.scrolled {
  box-shadow: 0 10px 30px -22px rgba(13, 20, 24, .4)
}

.nav {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  height: 4.625rem
}

.brand {
  display: flex;
  align-items: center;
  gap: .6875rem;
  margin-right: auto
}

.brand img {
  height: 2.875rem;
  width: auto
}

.brand .gtag {
  font-family: "Spline Sans Mono", monospace;
  font-size: .625rem;
  letter-spacing: .2em;
  color: var(--muted);
  border-left: 1px solid var(--line);
  padding-left: .6875rem;
  text-transform: uppercase;
  line-height: 1.3
}

.navlinks {
  display: flex;
  gap: 1.375rem;
  align-items: center
}

.navlinks>a,
.has-drop>a {
  font-weight: 600;
  font-size: .9375rem;
  color: #2a3636;
  position: relative;
  padding: .25rem 0;
  display: inline-flex;
  align-items: center;
  gap: .3125rem
}

.navlinks>a::after,
.has-drop>a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -.125rem;
  height: .125rem;
  width: 0;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--blue));
  transition: width .3s
}

.navlinks>a:hover::after,
.has-drop:hover>a::after,
.navlinks>a.active::after,
.has-drop.active>a::after {
  width: 100%
}

.has-drop {
  position: relative
}

.has-drop .caret {
  width: .8125rem;
  height: .8125rem;
  transition: transform .25s
}

.has-drop:hover .caret {
  transform: rotate(180deg)
}

.drop {
  position: absolute;
  top: calc(100% + .5rem);
  left: -.75rem;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: .8125rem;
  padding: .5rem;
  min-width: 15.5rem;
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateY(.5rem);
  transition: .2s
}

.has-drop:hover .drop {
  opacity: 1;
  visibility: visible;
  transform: none
}

.drop a {
  display: flex;
  align-items: center;
  gap: .6875rem;
  padding: .6875rem .8125rem;
  border-radius: .5625rem;
  font-size: .9375rem;
  font-weight: 600;
  color: #243030
}

.drop a:hover {
  background: var(--paper-2)
}

.drop a span.sub {
  display: block;
  font-family: "Spline Sans Mono";
  font-size: .625rem;
  letter-spacing: .12em;
  color: var(--muted-2);
  font-weight: 500;
  text-transform: uppercase
}

.navcta {
  display: flex;
  align-items: center;
  gap: .8125rem
}

.phone {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: "Saira";
  font-weight: 700;
  font-size: .9375rem;
  color: var(--text)
}

.phone .dot {
  width: .5rem;
  height: .5rem;
  border-radius: 50%;
  background: var(--green-br);
  box-shadow: 0 0 0 0 rgba(133, 199, 18, .6);
  animation: pulse 2.4s infinite
}

@keyframes pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(133, 199, 18, .55)
  }

  70% {
    box-shadow: 0 0 0 .5625rem rgba(133, 199, 18, 0)
  }

  100% {
    box-shadow: 0 0 0 0 rgba(133, 199, 18, 0)
  }
}

.burger {
  display: none;
  flex-direction: column;
  gap: .3125rem;
  background: none;
  border: 0;
  cursor: pointer;
  padding: .5rem
}

.burger span {
  width: 1.5rem;
  height: .125rem;
  background: var(--text);
  transition: .3s
}

.mobile {
  display: none
}

/* hero */
.hero {
  position: relative;
  background: var(--ink);
  color: #fff;
  overflow: hidden;
  padding: 96px 0 92px
}

.hero .grid-bg {
  position: absolute;
  inset: 0;
  opacity: .5;
  background-image: linear-gradient(rgba(255, 255, 255, .045) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .045) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(ellipse 80% 70% at 70% 20%, #000, transparent 90%)
}

.hero .glow {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px)
}

.hero .g1 {
  width: 520px;
  height: 520px;
  background: var(--green);
  left: -160px;
  top: -120px;
  opacity: .32
}

.hero .g2 {
  width: 460px;
  height: 460px;
  background: var(--blue-br);
  right: -120px;
  top: 40px;
  opacity: .28
}

.hero .g3 {
  width: 420px;
  height: 420px;
  background: var(--gold);
  right: 160px;
  bottom: -200px;
  opacity: .22
}

.hero .wrap {
  position: relative;
  z-index: 2
}

.hero-ey {
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap
}

.hero-ey::before {
  content: "";
  width: 34px;
  height: 1px;
  background: currentColor;
  opacity: .6
}

.hero h1 {
  font-size: clamp(40px, 6.6vw, 82px);
  font-weight: 900;
  letter-spacing: -.025em;
  max-width: 16ch
}

.hero h1 .c {
  color: var(--green-br)
}

.hero h1 .p {
  color: var(--gold-br)
}

.hero h1 .r {
  color: var(--blue-br)
}

.hero p.lead {
  font-size: clamp(17px, 1.9vw, 21px);
  color: #c6cfcf;
  max-width: 62ch;
  margin: 26px 0 34px
}

.hero-cta {
  display: flex;
  gap: 14px;
  flex-wrap: wrap
}

.trust {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 28px;
  margin-top: 46px;
  padding-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, .1)
}

.trust span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 14px;
  color: #aeb8b8;
  font-weight: 500
}

.trust svg {
  width: 17px;
  height: 17px;
  flex: none
}

.hero h1,
.hero p.lead,
.hero-cta,
.trust {
  opacity: 0;
  animation: rise .85s cubic-bezier(.2, .7, .2, 1) forwards
}

.hero p.lead {
  animation-delay: .12s
}

.hero-cta {
  animation-delay: .22s
}

.trust {
  animation-delay: .34s
}

@keyframes rise {
  from {
    opacity: 0;
    transform: translateY(26px)
  }

  to {
    opacity: 1;
    transform: none
  }
}

/* division hero accents */
.hero.c .hero-ey,
.hero.c h1 em {
  color: var(--green-br);
  font-style: normal
}

.hero.p .hero-ey,
.hero.p h1 em {
  color: var(--gold-br);
  font-style: normal
}

.hero.r .hero-ey,
.hero.r h1 em {
  color: var(--blue-br);
  font-style: normal
}

.hero.c .g1 {
  opacity: .4
}

.hero.p .g3 {
  opacity: .4;
  right: -120px;
  top: -80px;
  width: 520px;
  height: 520px
}

.hero.r .g2 {
  opacity: .4;
  width: 560px;
  height: 560px
}

/* workflow strip */
.flow {
  background: var(--ink-2);
  color: #fff
}

.flow-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid rgba(255, 255, 255, .08)
}

.flow-step {
  padding: 30px 26px;
  border-right: 1px solid rgba(255, 255, 255, .08)
}

.flow-step:last-child {
  border-right: 0
}

.flow-step .n {
  font-family: "Spline Sans Mono";
  font-size: 12px;
  letter-spacing: .2em;
  color: var(--muted-2)
}

.flow-step h4 {
  font-size: 19px;
  margin: 10px 0 6px;
  font-weight: 700
}

.flow-step p {
  font-size: 14px;
  color: #9aa6a6;
  margin: 0
}

.flow-step .bar {
  height: 3px;
  width: 34px;
  border-radius: 3px;
  margin-bottom: 18px
}

/* section heads */
.shead {
  max-width: 64ch
}

.shead .ey {
  color: var(--green-dk)
}

.shead.p .ey {
  color: var(--gold-dk)
}

.shead.r .ey {
  color: var(--blue)
}

.shead h2 {
  font-size: clamp(30px, 4.4vw, 52px);
  font-weight: 800;
  margin: 14px 0 0;
  letter-spacing: -.02em
}

.shead p {
  color: var(--muted);
  font-size: 18px;
  margin: 18px 0 0
}

.pad {
  padding: 96px 0
}

.center {
  text-align: center;
  margin-left: auto;
  margin-right: auto
}

/* companies cards */
.firms {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 54px
}

.firm {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 34px 30px 30px;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform .3s, box-shadow .3s
}

.firm::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 5px
}

.firm:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg)
}

.firm.c::before {
  background: linear-gradient(90deg, var(--green-dk), var(--green-br))
}

.firm.p::before {
  background: linear-gradient(90deg, var(--gold-dk), var(--gold-br))
}

.firm.r::before {
  background: linear-gradient(90deg, var(--blue), var(--blue-br))
}

.firm .toprow {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px
}

.firm .icon {
  width: 54px;
  height: 54px;
  border-radius: 13px;
  display: grid;
  place-items: center
}

.firm.c .icon {
  background: rgba(61, 144, 10, .12)
}

.firm.p .icon {
  background: rgba(201, 162, 39, .14)
}

.firm.r .icon {
  background: rgba(6, 76, 142, .1)
}

.firm .icon svg {
  width: 28px;
  height: 28px
}

.firm .num {
  font-family: "Spline Sans Mono";
  font-size: 13px;
  color: var(--muted-2);
  letter-spacing: .15em
}

.firm h3 {
  font-size: 25px;
  font-weight: 800
}

.firm .tag {
  font-family: "Spline Sans Mono";
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  margin-top: 4px
}

.firm.c .tag {
  color: var(--green-dk)
}

.firm.p .tag {
  color: var(--gold-dk)
}

.firm.r .tag {
  color: var(--blue)
}

.firm p.desc {
  font-size: 15px;
  color: var(--muted);
  margin: 14px 0 18px
}

.firm ul {
  list-style: none;
  padding: 0;
  margin: 0 0 22px;
  display: grid;
  gap: 9px
}

.firm li {
  font-size: 14.5px;
  font-weight: 500;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: #2c3838
}

.firm li svg {
  width: 16px;
  height: 16px;
  flex: none;
  margin-top: 3px
}

.firm .more {
  font-family: "Saira";
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px
}

.firm.c .more {
  color: var(--green-dk)
}

.firm.p .more {
  color: var(--gold-dk)
}

.firm.r .more {
  color: var(--blue)
}

.firm .more svg {
  width: 16px;
  height: 16px;
  transition: transform .25s
}

.firm:hover .more svg {
  transform: translateX(4px)
}

/* services grid */
.svc {
  background: var(--paper-2)
}

.svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 50px
}

.svc-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 13px;
  padding: 24px;
  transition: transform .25s, box-shadow .25s
}

.svc-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow)
}

.svc-card .ic {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  margin-bottom: 14px
}

.svc-card .ic.c {
  background: rgba(61, 144, 10, .12)
}

.svc-card .ic.p {
  background: rgba(201, 162, 39, .14)
}

.svc-card .ic.r {
  background: rgba(6, 76, 142, .1)
}

.svc-card .ic svg {
  width: 21px;
  height: 21px
}

.svc-card.row {
  display: flex;
  gap: 14px;
  align-items: flex-start
}

.svc-card.row .pip {
  margin-top: 6px
}

.svc-card h4 {
  font-size: 17px;
  font-weight: 700;
  margin: 0 0 4px
}

.svc-card p {
  font-size: 13.5px;
  color: var(--muted);
  margin: 0
}

.legend {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  margin-top: 34px;
  font-size: 13px;
  font-weight: 600
}

.legend span {
  display: inline-flex;
  align-items: center;
  gap: 8px
}

/* why / process */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  margin-top: 54px
}

.why-card {
  padding: 30px 26px;
  border: 1px solid var(--line);
  border-radius: var(--r);
  background: #fff
}

.why-card .ic {
  width: 46px;
  height: 46px;
  border-radius: 11px;
  background: var(--ink);
  display: grid;
  place-items: center;
  margin-bottom: 18px
}

.why-card .ic svg {
  width: 23px;
  height: 23px
}

.why-card h4 {
  font-size: 19px;
  font-weight: 700;
  margin: 0 0 8px
}

.why-card p {
  font-size: 14.5px;
  color: var(--muted);
  margin: 0
}

.steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 54px;
  counter-reset: s
}

.step {
  position: relative;
  padding-top: 30px
}

.step::before {
  counter-increment: s;
  content: "0" counter(s);
  font-family: "Saira";
  font-weight: 900;
  font-size: 46px;
  position: absolute;
  top: -14px;
  left: 0;
  opacity: .13
}

.step h4 {
  font-size: 19px;
  font-weight: 700;
  margin: 0 0 7px
}

.step p {
  font-size: 14.5px;
  color: var(--muted);
  margin: 0
}

.step .ln {
  height: 3px;
  width: 40px;
  border-radius: 3px;
  margin-bottom: 10px
}

/* stats */
.stats {
  background: var(--ink);
  color: #fff;
  position: relative;
  overflow: hidden
}

.stats .grid-bg {
  position: absolute;
  inset: 0;
  opacity: .4;
  background-image: linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
  background-size: 50px 50px;
  mask-image: radial-gradient(ellipse 70% 100% at 50% 0%, #000, transparent)
}

.stats-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  text-align: center
}

.stat .num {
  font-family: "Saira";
  font-weight: 900;
  font-size: clamp(36px, 5vw, 58px);
  letter-spacing: -.02em
}

.stat .lab {
  font-size: 14px;
  color: #9aa6a6;
  font-weight: 500;
  margin-top: 4px
}

.stat:nth-child(1) .num {
  background: linear-gradient(180deg, var(--green-br), var(--green));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent
}

.stat:nth-child(2) .num {
  background: linear-gradient(180deg, var(--gold-br), var(--gold));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent
}

.stat:nth-child(3) .num {
  background: linear-gradient(180deg, var(--blue-br), var(--blue));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent
}

.stat:nth-child(4) .num {
  background: linear-gradient(180deg, var(--sil-1), var(--sil-3));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent
}

/* coverage */
.cover {
  background: var(--paper-2)
}

.cover-flex {
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 54px;
  align-items: center;
  margin-top: 30px
}

.chips {
  display: flex;
  flex-wrap: wrap;
  gap: 11px;
  margin-top: 26px
}

.chip {
  background: #fff;
  border: 1px solid var(--line);
  padding: 9px 16px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  transition: transform .2s
}

.chip:hover {
  transform: translateY(-2px)
}

.chip.hq {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink)
}

.loc-cards {
  display: grid;
  gap: 16px;
  margin-top: 8px
}

.loc-card {
  background: var(--ink);
  color: #fff;
  border-radius: var(--r);
  padding: 30px 30px;
  position: relative;
  overflow: hidden
}

.loc-card .glow {
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  filter: blur(70px);
  background: var(--blue-br);
  opacity: .22;
  right: -80px;
  top: -60px
}

.loc-card .badge {
  font-family: "Spline Sans Mono";
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  display: inline-block;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .12);
  position: relative
}

.loc-card h3 {
  font-size: 23px;
  margin: 12px 0 0;
  position: relative
}

.loc-card .addr {
  font-size: 15px;
  color: #c6cfcf;
  margin: 10px 0 0;
  position: relative;
  line-height: 1.7
}

.loc-card a {
  color: var(--gold-br);
  font-weight: 600
}

/* ===== where-we-are ===== */
.wwa-hero {
  background: var(--ink);
  color: #fff;
  position: relative;
  overflow: hidden;
  padding: 90px 0 70px
}

.wwa-hero .glow {
  position: absolute;
  width: 600px;
  height: 400px;
  border-radius: 50%;
  filter: blur(90px);
  right: -100px;
  top: -120px;
  background: linear-gradient(90deg, var(--green), var(--gold), var(--blue));
  opacity: .22
}

.wwa-hero .wrap {
  position: relative
}

.wwa-hero h1 {
  font-size: clamp(34px, 5.4vw, 64px);
  font-weight: 900;
  max-width: 18ch;
  letter-spacing: -.025em
}

.wwa-hero p {
  font-size: clamp(17px, 1.9vw, 21px);
  color: #c6cfcf;
  max-width: 60ch;
  margin: 22px 0 0
}

.wwa-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 30px;
  margin-top: 34px
}

.wwa-actions a {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: "Saira";
  font-weight: 700;
  font-size: 15px;
  color: #fff
}

.wwa-actions a svg {
  width: 18px;
  height: 18px;
  transition: transform .25s
}

.wwa-actions a:hover svg {
  transform: translateX(4px)
}

.prov {
  border-bottom: 1px solid var(--line)
}

.prov-head {
  width: 100%;
  background: none;
  border: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 30px 0;
  font-family: "Saira";
  font-weight: 800;
  font-size: clamp(24px, 3vw, 34px);
  color: var(--text);
  letter-spacing: -.02em
}

.prov-head .meta {
  display: flex;
  align-items: center;
  gap: 16px
}

.prov-head .cnt {
  font-family: "Spline Sans Mono";
  font-size: 13px;
  font-weight: 600;
  color: var(--muted-2);
  letter-spacing: .1em
}

.prov-head .pm {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  transition: .3s
}

.prov-head[aria-expanded="true"] .pm {
  background: var(--green);
  border-color: var(--green);
  transform: rotate(45deg)
}

.prov-head .pm svg {
  width: 15px;
  height: 15px
}

.prov-head[aria-expanded="true"] .pm svg {
  stroke: #fff
}

.prov-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s ease
}

.branches {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  padding: 6px 0 36px
}

.branch {
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 26px;
  background: #fff;
  transition: transform .25s, box-shadow .25s
}

.branch:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow)
}

.branch .bt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px
}

.branch h3 {
  font-size: 21px;
  font-weight: 800
}

.branch .tag {
  font-family: "Spline Sans Mono";
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 600
}

.branch .tag.hq {
  background: var(--ink);
  color: #fff
}

.branch .tag.br {
  background: rgba(64, 172, 227, .14);
  color: var(--blue)
}

.branch .addr {
  font-size: 15px;
  color: var(--muted);
  margin: 12px 0 18px;
  line-height: 1.6
}

.branch .blinks {
  display: flex;
  gap: 10px;
  flex-wrap: wrap
}

.branch .blinks a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-weight: 700;
  font-size: 13.5px;
  font-family: "Saira";
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 8px 15px;
  transition: .2s
}

.branch .blinks a:hover {
  border-color: var(--text)
}

.branch .blinks svg {
  width: 15px;
  height: 15px
}

.branch .hrs {
  font-size: 13px;
  color: var(--muted-2);
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 8px
}

/* ===== Bremara IQ portal ===== */
.iq-head {
  background: var(--ink)
}

.iq-head .nav {
  height: 70px
}

.iq-head .brand .gtag {
  color: #8b9797;
  border-color: rgba(255, 255, 255, .18)
}

.iq-head .back {
  color: #cdd5d5;
  font-weight: 600;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 7px
}

.iq-head .back:hover {
  color: #fff
}

.iq-head .back svg {
  width: 16px;
  height: 16px
}

.iq-wrap {
  min-height: calc(100vh - 70px);
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  background: var(--ink);
  color: #fff
}

.iq-left {
  padding: 70px 6vw;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center
}

.iq-left .grid-bg {
  position: absolute;
  inset: 0;
  opacity: .4;
  background-image: linear-gradient(rgba(255, 255, 255, .05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, .05) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(ellipse 90% 80% at 30% 30%, #000, transparent)
}

.iq-left .glow {
  position: absolute;
  width: 480px;
  height: 480px;
  border-radius: 50%;
  filter: blur(90px);
  left: -120px;
  bottom: -160px;
  background: linear-gradient(90deg, var(--green), var(--blue));
  opacity: .25
}

.iq-left .inner {
  position: relative;
  max-width: 520px
}

.iq-badge {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: "Spline Sans Mono";
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--green-br);
  border: 1px solid rgba(133, 199, 18, .4);
  padding: 6px 13px;
  border-radius: 999px
}

.iq-left h1 {
  font-size: clamp(34px, 4.6vw, 56px);
  font-weight: 900;
  letter-spacing: -.025em;
  margin: 24px 0 0
}

.iq-left h1 .sil {
  background: linear-gradient(180deg, var(--sil-1), var(--sil-2) 55%, var(--sil-3));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent
}

.iq-left p.lead {
  font-size: 19px;
  color: #c6cfcf;
  margin: 22px 0 30px;
  max-width: 48ch
}

.iq-feat {
  display: grid;
  gap: 14px
}

.iq-feat .f {
  display: flex;
  gap: 13px;
  align-items: flex-start
}

.iq-feat .f .d {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  flex: none;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, .07)
}

.iq-feat .f .d svg {
  width: 18px;
  height: 18px
}

.iq-feat .f h4 {
  font-size: 16px;
  font-weight: 700;
  margin: 0
}

.iq-feat .f p {
  font-size: 13.5px;
  color: #9aa6a6;
  margin: 2px 0 0
}

.iq-right {
  background: var(--paper);
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 5vw
}

.iq-card {
  width: 100%;
  max-width: 400px
}

.iq-card h2 {
  font-size: 28px;
  font-weight: 800
}

.iq-card .sub {
  color: var(--muted);
  font-size: 15px;
  margin: 8px 0 28px
}

.iq-card .field {
  margin-bottom: 16px
}

.iq-card label {
  font-size: 13px;
  font-weight: 600;
  display: block;
  margin-bottom: 6px
}

.iq-card input {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 13px 15px;
  font-family: inherit;
  font-size: 15px;
  background: #fff;
  transition: .2s
}

.iq-card input:focus {
  outline: 0;
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(61, 144, 10, .12)
}

.iq-card .rowflex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px;
  font-size: 13.5px
}

.iq-card .rowflex a {
  color: var(--green-dk);
  font-weight: 600
}

.iq-card .btn {
  width: 100%;
  justify-content: center
}

.iq-card .req {
  text-align: center;
  font-size: 14px;
  color: var(--muted);
  margin-top: 22px
}

.iq-card .req a {
  color: var(--green-dk);
  font-weight: 700
}

.iq-note {
  font-size: 12px;
  color: var(--muted-2);
  text-align: center;
  margin-top: 26px;
  padding-top: 18px;
  border-top: 1px solid var(--line)
}

/* faq */
.faq-list {
  margin-top: 46px;
  border-top: 1px solid var(--line)
}

.faq-item {
  border-bottom: 1px solid var(--line)
}

.faq-q {
  width: 100%;
  background: none;
  border: 0;
  text-align: left;
  padding: 24px 0;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  font-family: "Saira";
  font-weight: 700;
  font-size: 19px;
  color: var(--text)
}

.faq-q .pm {
  flex: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid var(--line);
  display: grid;
  place-items: center;
  transition: .3s
}

.faq-q[aria-expanded="true"] .pm {
  background: var(--green);
  border-color: var(--green);
  transform: rotate(45deg)
}

.faq-q .pm svg {
  width: 14px;
  height: 14px;
  transition: .3s
}

.faq-q[aria-expanded="true"] .pm svg {
  stroke: #fff
}

.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease
}

.faq-a p {
  padding: 0 0 24px;
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  max-width: 80ch
}

/* cta band */
.cband {
  background: linear-gradient(120deg, var(--ink), var(--ink-3));
  color: #fff;
  text-align: center;
  position: relative;
  overflow: hidden
}

.cband .glow {
  position: absolute;
  width: 600px;
  height: 300px;
  border-radius: 50%;
  filter: blur(90px);
  left: 50%;
  top: -60px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, var(--green), var(--gold), var(--blue));
  opacity: .3
}

.cband h2 {
  font-size: clamp(28px, 4.4vw, 48px);
  font-weight: 900;
  position: relative;
  max-width: 20ch;
  margin: 0 auto;
  letter-spacing: -.02em
}

.cband p {
  color: #c6cfcf;
  font-size: 18px;
  margin: 18px auto 30px;
  max-width: 54ch;
  position: relative
}

.cband .hero-cta {
  justify-content: center;
  position: relative
}

/* contact */
.contact-grid {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: 54px;
  margin-top: 30px
}

.nap {
  display: grid;
  gap: 22px;
  margin-top: 28px
}

.nap .row {
  display: flex;
  gap: 16px;
  align-items: flex-start
}

.nap .ic {
  width: 44px;
  height: 44px;
  border-radius: 11px;
  background: var(--paper-2);
  display: grid;
  place-items: center;
  flex: none
}

.nap .ic svg {
  width: 21px;
  height: 21px
}

.nap .row h4 {
  font-family: "Spline Sans Mono";
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted-2);
  font-weight: 600;
  margin: 0 0 4px
}

.nap .row p {
  margin: 0;
  font-size: 16px;
  font-weight: 500
}

.nap .row a {
  font-weight: 600
}

.form {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 32px;
  box-shadow: var(--shadow)
}

.form .frow {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px
}

.field {
  margin-bottom: 14px
}

.field label {
  font-size: 13px;
  font-weight: 600;
  display: block;
  margin-bottom: 6px;
  color: #2c3838
}

.field input,
.field select,
.field textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 15px;
  background: var(--paper);
  color: var(--text);
  transition: .2s
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: 0;
  border-color: var(--green);
  box-shadow: 0 0 0 3px rgba(61, 144, 10, .12)
}

.field textarea {
  resize: vertical;
  min-height: 104px
}

.form .btn {
  width: 100%;
  justify-content: center;
  margin-top: 6px
}

.form .note {
  font-size: 12.5px;
  color: var(--muted-2);
  text-align: center;
  margin: 14px 0 0
}

/* footer */
footer {
  background: var(--ink);
  color: #cdd5d5;
  padding: 64px 0 26px
}

.fgrid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 40px
}

.fbrand img {
  height: 54px;
  margin-bottom: 16px
}

.fbrand p {
  font-size: 14px;
  color: #9aa6a6;
  max-width: 34ch
}

.fcol h4 {
  font-family: "Spline Sans Mono";
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #fff;
  margin: 0 0 16px;
  font-weight: 600
}

.fcol a,
.fcol p {
  display: block;
  font-size: 14.5px;
  color: #9aa6a6;
  margin-bottom: 10px;
  transition: color .2s
}

.fcol a:hover {
  color: #fff
}

.fcol .pipd {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 8px;
  vertical-align: middle
}

.fbot {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 46px;
  padding-top: 24px;
  border-top: 1px solid rgba(255, 255, 255, .1);
  font-size: 13px;
  color: #8b9797
}

.fbot a {
  color: #8b9797
}

.fbot a:hover {
  color: #fff
}

/* group band */
.gband {
  background: var(--paper-2)
}

.gband-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
  margin-top: 44px
}

.gcard {
  display: flex;
  gap: 16px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 24px 26px;
  transition: transform .25s, box-shadow .25s
}

.gcard:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow)
}

.gcard .ic {
  width: 50px;
  height: 50px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex: none
}

.gcard.c .ic {
  background: rgba(61, 144, 10, .12)
}

.gcard.p .ic {
  background: rgba(201, 162, 39, .14)
}

.gcard.r .ic {
  background: rgba(6, 76, 142, .1)
}

.gcard .ic svg {
  width: 25px;
  height: 25px
}

.gcard h4 {
  font-size: 19px;
  font-weight: 800;
  margin: 0
}

.gcard p {
  font-size: 13.5px;
  color: var(--muted);
  margin: 2px 0 0
}

.gcard .ar {
  margin-left: auto;
  transition: transform .25s
}

.gcard:hover .ar {
  transform: translateX(4px)
}

.gcard .ar svg {
  width: 18px;
  height: 18px
}

/* reveal */
.rv {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s, transform .7s
}

.rv.in {
  opacity: 1;
  transform: none
}

/* ---------- responsive ---------- */
/* prevent long content from forcing overflow inside grid/flex items */
.firm,
.svc-card,
.why-card,
.branch,
.gcard,
.stat,
.flow-step,
.step,
.loc-card,
.cover-card,
.form,
.faq-q,
.shead {
  min-width: 0
}

.faq-q span,
.prov-head span {
  min-width: 0;
  overflow-wrap: break-word
}

/* small desktop / large laptop: tighten the header so it never crowds */
@media(max-width:1080px) {
  .nav {
    gap: 18px
  }

  .navlinks {
    gap: 18px
  }

  .navcta {
    gap: 10px
  }

  .navcta .btn {
    padding: 11px 15px;
    font-size: 14px
  }
}

/* tablet landscape: nav collapses to the menu button, grids go 2-up */
@media(max-width:940px) {

  .navlinks,
  .navcta .btn-pri,
  .navcta .btn-iq {
    display: none
  }

  .burger {
    display: flex
  }

  .mobile.open {
    display: block;
    position: fixed;
    top: 4.625rem;
    left: 0;
    right: 0;
    height: calc(100dvh - 4.625rem);
    background: var(--paper);
    z-index: 99;
    padding: 1.5rem;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch
  }

  .mobile.open a {
    display: block;
    font-family: "Saira";
    font-weight: 700;
    font-size: 1.3125rem;
    padding: .9375rem 0;
    border-bottom: 1px solid var(--line)
  }

  .mobile.open a.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center
  }

  .mobile.open .btn {
    margin-top: 1.125rem;
    width: 100%;
    justify-content: center;
    font-size: 1.0625rem
  }

  body.lock {
    overflow: hidden
  }

  .firms,
  .svc-grid,
  .why-grid,
  .stats-grid,
  .flow-inner,
  .fgrid,
  .steps,
  .branches,
  .gband-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .cover-flex,
  .contact-grid,
  .iq-wrap {
    grid-template-columns: 1fr
  }

  .iq-wrap {
    min-height: 0
  }

  .iq-left {
    padding: 64px 28px
  }

  .iq-right {
    padding: 48px 28px
  }

  .flow-step {
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .08)
  }

  .fgrid {
    gap: 34px
  }
}

/* tablet portrait: most grids go single column */
@media(max-width:760px) {

  .firms,
  .svc-grid,
  .why-grid,
  .fgrid,
  .form .frow,
  .steps,
  .branches,
  .flow-inner,
  .gband-grid {
    grid-template-columns: 1fr
  }

  .pad {
    padding: 60px 0
  }

  .hero {
    padding: 60px 0 56px
  }

  .hero h1 {
    font-size: clamp(32px, 8.4vw, 56px)
  }

  .shead h2 {
    font-size: clamp(26px, 6.4vw, 40px)
  }

  .wwa-hero h1 {
    font-size: clamp(30px, 7.8vw, 48px)
  }

  .iq-left h1 {
    font-size: clamp(30px, 7.8vw, 44px)
  }

  .prov-head {
    font-size: clamp(22px, 6vw, 30px)
  }

  .stats-grid {
    gap: 30px 16px
  }
}

/* large phone */
@media(max-width:560px) {
  .wrap {
    padding: 0 18px
  }

  .phone .txt {
    display: none
  }

  .hero h1 {
    font-size: clamp(28px, 9vw, 46px);
    letter-spacing: -.02em
  }

  .hero p.lead,
  .iq-left p.lead,
  .shead p {
    font-size: 16px
  }

  .firm {
    padding: 28px 22px
  }

  .trust {
    gap: 10px 18px
  }

  .wwa-actions {
    gap: 14px 20px
  }

  .branch .blinks a {
    padding: 8px 12px;
    font-size: 13px
  }

  .prov-head .cnt {
    display: none
  }

  .fbot {
    justify-content: flex-start
  }
}

/* small phone */
@media(max-width:400px) {
  .brand .gtag {
    display: none
  }

  .brand img {
    height: 40px
  }

  .hero h1 {
    font-size: 26px
  }

  .shead h2,
  .cband h2,
  .wwa-hero h1 {
    font-size: 23px
  }

  .stat .num {
    font-size: 38px
  }

  .btn {
    font-size: 13.5px;
    padding: 11px 16px
  }

  .firm h3,
  .branch h3 {
    font-size: 20px
  }
}