:root {
  --navy-950: #041117;
  --navy-900: #071922;
  --navy-850: #0a202a;
  --navy-800: #0e2a35;
  --navy-700: #173844;
  --ink: #0a1d24;
  --slate: #4c6269;
  --mist: #eaf4f3;
  --paper: #f6faf9;
  --white: #f4ffff;
  --cyan: #48d8ff;
  --teal: #23d7b0;
  --emerald: #16815f;
  --violet: #8e7dff;
  --gold: #c9a85b;
  --line: rgba(39, 88, 100, 0.18);
  --shadow: 0 24px 70px rgba(3, 21, 28, 0.12);
  --shadow-soft: 0 14px 40px rgba(3, 21, 28, 0.08);
  --radius-sm: 12px;
  --radius: 22px;
  --radius-lg: 34px;
  --container: min(1180px, calc(100% - 40px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  overflow-x: hidden;
  color: var(--ink);
  background: var(--paper);
  font-family: Inter, Aptos, "Segoe UI", Arial, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  text-rendering: optimizeLegibility;
}
body.nav-open { overflow: hidden; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
.container { width: var(--container); margin-inline: auto; }
.skip-link {
  position: fixed; z-index: 100; left: 20px; top: -60px;
  padding: 10px 16px; color: var(--navy-950); background: var(--cyan);
  border-radius: 0 0 8px 8px;
}
.skip-link:focus { top: 0; }

.site-header {
  position: fixed; inset: 0 0 auto; z-index: 50; height: 76px;
  display: grid; grid-template-columns: 210px 1fr auto; align-items: center; gap: 22px;
  padding: 0 max(24px, calc((100vw - 1400px) / 2));
  color: var(--white);
  border-bottom: 1px solid rgba(151, 224, 232, .12);
  transition: background .25s ease, height .25s ease, backdrop-filter .25s ease;
}
.site-header.is-scrolled { height: 66px; background: rgba(4, 17, 23, .94); backdrop-filter: blur(18px); }
.brand-link img { width: 190px; height: auto; }
.site-nav { display: flex; justify-content: center; gap: clamp(12px, 1.35vw, 23px); }
.site-nav a {
  position: relative; color: #afc9ce; font-size: 11px; font-weight: 700; letter-spacing: .02em;
  transition: color .2s ease;
}
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--white); }
.site-nav a[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -12px; height: 1px;
  background: linear-gradient(90deg, var(--teal), var(--cyan));
}
.header-cta { display: flex; align-items: center; gap: 7px; color: var(--cyan); font-size: 11px; font-weight: 800; }
.header-cta svg, .button svg, .capability-card a svg { width: 17px; transition: transform .2s ease; }
.header-cta:hover svg, .button:hover svg, .capability-card a:hover svg { transform: translateX(4px); }
.nav-toggle { display: none; }

.hero {
  position: relative; overflow: hidden; min-height: 710px; display: grid; align-items: center;
  padding: 128px 0 72px; color: var(--white); background:
  radial-gradient(circle at 82% 18%, rgba(142, 125, 255, .20), transparent 31%),
  radial-gradient(circle at 24% 92%, rgba(35, 215, 176, .13), transparent 38%),
  linear-gradient(145deg, var(--navy-950), var(--navy-900) 52%, #0b2630);
}
.hero--compact { min-height: 620px; padding-block: 116px 62px; }
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .23;
  background-image: linear-gradient(rgba(72, 216, 255, .10) 1px, transparent 1px), linear-gradient(90deg, rgba(72, 216, 255, .10) 1px, transparent 1px);
  background-size: 70px 70px; mask-image: linear-gradient(90deg, black, transparent 70%);
}
.hero__glow { position: absolute; width: 460px; height: 460px; border: 1px solid rgba(72,216,255,.14); border-radius: 50%; top: 4%; right: -13%; box-shadow: 0 0 0 80px rgba(72,216,255,.018), 0 0 0 160px rgba(35,215,176,.014); }
.hero__layout { position: relative; display: grid; grid-template-columns: minmax(0, 1.03fr) minmax(400px, .97fr); align-items: center; gap: clamp(45px, 6vw, 82px); }
.hero--compact .hero__layout { grid-template-columns: minmax(0, 1.08fr) minmax(370px, .82fr); }
.hero__content, .hero__aside { min-width: 0; }
.eyebrow { display: flex; align-items: center; gap: 11px; margin: 0 0 18px; color: var(--cyan); font-size: 11px; font-weight: 850; letter-spacing: .15em; text-transform: uppercase; }
.eyebrow span { width: 28px; height: 1px; background: linear-gradient(90deg, var(--teal), var(--cyan)); }
.eyebrow--dark { color: var(--emerald); }
.hero h1 {
  max-width: 720px; margin: 0; color: var(--white); font-size: clamp(50px, 5.2vw, 76px);
  font-weight: 730; letter-spacing: -.058em; line-height: 1;
}
.hero--compact h1 { max-width: 660px; font-size: clamp(46px, 4.7vw, 66px); }
.hero h1 em { color: var(--cyan); font-style: normal; }
.hero__text { max-width: 650px; margin: 24px 0 0; color: #b2ccd1; font-size: clamp(16px, 1.35vw, 18px); line-height: 1.7; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 14px; min-height: 50px;
  padding: 0 21px; border: 1px solid transparent; border-radius: 999px;
  font-size: 12px; font-weight: 850; letter-spacing: .015em; transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.button:hover { transform: translateY(-2px); }
.button--primary { color: var(--navy-950); background: linear-gradient(100deg, var(--teal), var(--cyan)); box-shadow: 0 14px 34px rgba(35,215,176,.20); }
.button--ghost { color: #d9f2f4; border-color: rgba(190, 235, 239, .22); background: rgba(255,255,255,.025); }
.button--light { color: var(--navy-950); background: var(--white); }
.hero__note { display: flex; align-items: center; gap: 8px; margin-top: 24px; color: #88a9b0; font-size: 11px; letter-spacing: .035em; }
.hero__note i { width: 7px; height: 7px; border: 1px solid var(--teal); border-radius: 50%; box-shadow: 0 0 0 4px rgba(35,215,176,.08); }

.narrative-visual { position: relative; min-height: 470px; display: grid; place-items: center; isolation: isolate; }
.hero--compact .narrative-visual { min-height: 400px; }
.visual-orbit { position: absolute; z-index: -1; border: 1px solid rgba(72,216,255,.15); border-radius: 50%; }
.visual-orbit::before, .visual-orbit::after { content: ""; position: absolute; width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); box-shadow: 0 0 20px var(--cyan); }
.visual-orbit::before { left: 15%; top: 6%; }.visual-orbit::after { right: 5%; bottom: 22%; background: var(--gold); box-shadow: 0 0 20px var(--gold); }
.visual-orbit--outer { width: 450px; height: 450px; animation: rotate 32s linear infinite; }
.visual-orbit--inner { width: 335px; height: 335px; border-color: rgba(35,215,176,.13); animation: rotate 23s linear infinite reverse; }
.visual-panel {
  position: relative; width: min(100%, 480px); padding: 22px;
  border: 1px solid rgba(125,203,214,.23); border-radius: 28px;
  background: linear-gradient(145deg, rgba(12,38,49,.91), rgba(5,24,32,.88));
  box-shadow: 0 30px 90px rgba(0,0,0,.28), inset 0 1px rgba(255,255,255,.035);
  backdrop-filter: blur(18px);
}
.visual-panel::after { content: ""; position: absolute; inset: auto 18px 0; height: 2px; background: linear-gradient(90deg, transparent, rgba(72,216,255,.45), rgba(142,125,255,.35), transparent); }
.visual-panel__top { display: flex; justify-content: space-between; gap: 20px; color: #a8c4c9; font-size: 10px; font-weight: 850; letter-spacing: .11em; text-transform: uppercase; }
.visual-panel__top i { color: var(--teal); font-style: normal; white-space: nowrap; }.visual-panel__top i::before { content: ""; display: inline-block; width: 6px; height: 6px; margin-right: 6px; border-radius: 50%; background: var(--teal); box-shadow: 0 0 12px var(--teal); }
.visual-art { width: 100%; height: auto; margin-top: 8px; overflow: visible; }
.visual-art text { fill: #d9f7f8; font-size: 14px; font-weight: 850; text-anchor: middle; dominant-baseline: middle; }
.visual-line { fill: none; stroke: rgba(137,180,189,.27); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.visual-line--bright { stroke: url(#visual-gradient); stroke: var(--cyan); stroke-width: 3.5; filter: drop-shadow(0 0 7px rgba(72,216,255,.28)); }
.visual-area { fill: rgba(35,215,176,.07); stroke: none; }
.visual-dot { stroke: #08242d; stroke-width: 4; }.visual-dot--teal { fill: var(--teal); }.visual-dot--cyan { fill: var(--cyan); }.visual-dot--violet { fill: var(--violet); }.visual-dot--gold { fill: var(--gold); }
.visual-ring { fill: rgba(35,215,176,.045); stroke: rgba(35,215,176,.7); stroke-width: 2; }.visual-ring--violet { fill: rgba(142,125,255,.05); stroke: rgba(142,125,255,.72); }.visual-ring--gold { fill: rgba(201,168,91,.05); stroke: rgba(201,168,91,.72); }.visual-ring--large { fill: none; stroke: rgba(72,216,255,.32); }
.visual-hub { fill: rgba(72,216,255,.08); stroke: var(--cyan); stroke-width: 2; }
.visual-check { fill: none; stroke: var(--teal); stroke-width: 4; stroke-linecap: round; stroke-linejoin: round; }.visual-check--large { stroke-width: 6; }
.visual-sheet { fill: rgba(255,255,255,.025); stroke: rgba(72,216,255,.42); stroke-width: 2; }
.visual-stage { fill: rgba(35,215,176,.07); stroke: var(--teal); stroke-width: 2; }.visual-stage--violet { fill: rgba(142,125,255,.08); stroke: var(--violet); }.visual-stage--gold { fill: rgba(201,168,91,.07); stroke: var(--gold); }
.visual-pulse { fill: none; stroke: var(--cyan); stroke-width: 3; stroke-linecap: round; stroke-linejoin: round; }
.visual-zone { fill: rgba(35,215,176,.04); stroke: rgba(35,215,176,.55); stroke-width: 2; stroke-dasharray: 5 7; }.visual-zone--violet { fill: rgba(142,125,255,.04); stroke: rgba(142,125,255,.55); }
.visual-node { fill: rgba(72,216,255,.11); stroke: var(--cyan); stroke-width: 2; }
.visual-shield { fill: rgba(35,215,176,.08); stroke: var(--teal); stroke-width: 2.5; }
.visual-bar { fill: rgba(35,215,176,.18); stroke: rgba(35,215,176,.55); }.visual-bar--cyan { fill: rgba(72,216,255,.2); stroke: rgba(72,216,255,.6); }.visual-bar--violet { fill: rgba(142,125,255,.18); stroke: rgba(142,125,255,.58); }.visual-bar--gold { fill: rgba(201,168,91,.18); stroke: rgba(201,168,91,.58); }
.visual-axis { stroke: rgba(137,180,189,.18); stroke-width: 1; }.visual-compass { fill: rgba(72,216,255,.12); stroke: var(--cyan); stroke-width: 2.5; }
.visual-labels { display: grid; grid-template-columns: repeat(3, 1fr); gap: 9px; padding-top: 12px; border-top: 1px solid rgba(137,180,189,.12); }
.visual-labels span { color: #86a6ad; font-size: 9px; font-weight: 800; letter-spacing: .045em; text-transform: uppercase; }

.credibility-strip { position: relative; color: #bfd9dd; border-top: 1px solid rgba(137,180,189,.12); border-bottom: 1px solid rgba(137,180,189,.12); background: linear-gradient(90deg, var(--navy-950), var(--navy-850), var(--navy-950)); }
.credibility-strip__layout { display: grid; grid-template-columns: repeat(4, 1fr); }
.credibility-strip span { padding: 19px 20px; border-left: 1px solid rgba(137,180,189,.12); font-size: 11px; letter-spacing: .025em; }.credibility-strip span:last-child { border-right: 1px solid rgba(137,180,189,.12); }
.credibility-strip b { display: block; margin-bottom: 2px; color: var(--cyan); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }

.section-heading { max-width: 720px; margin-bottom: 40px; }
.section-heading--center { margin-inline: auto; text-align: center; }.section-heading--center .eyebrow { justify-content: center; }
.section-heading h2, .cta-band h2 {
  margin: 0; font-size: clamp(34px, 3.8vw, 52px); font-weight: 720; letter-spacing: -.047em; line-height: 1.07;
}
.section-heading p:not(.eyebrow) { max-width: 660px; margin: 16px 0 0; color: var(--slate); font-size: 16px; line-height: 1.72; }
.section-heading--center p:not(.eyebrow) { margin-inline: auto; }
.section { position: relative; padding: 94px 0; }.section--tight { padding: 72px 0; }.section--dark { color: var(--white); background: var(--navy-900); }.section--mist { background: linear-gradient(145deg, var(--mist), #f1f7f5); }
.section--mist::before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: .25; background-image: linear-gradient(rgba(22,129,95,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(22,129,95,.08) 1px, transparent 1px); background-size: 64px 64px; mask-image: linear-gradient(90deg, transparent, black 55%, transparent); }
.section > .container { position: relative; }

.capability-grid { display: grid; grid-template-columns: 1.08fr 1fr .96fr; gap: 14px; }
.capability-card { position: relative; overflow: hidden; min-height: 350px; display: flex; flex-direction: column; padding: 30px; border: 1px solid var(--line); border-radius: var(--radius); background: #fff; box-shadow: var(--shadow-soft); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.capability-card::before { content: ""; position: absolute; inset: 0 0 auto; height: 3px; background: linear-gradient(90deg, var(--teal), var(--cyan)); }.capability-card--violet::before { background: linear-gradient(90deg, var(--violet), var(--cyan)); }.capability-card--emerald::before { background: linear-gradient(90deg, var(--emerald), var(--gold)); }
.capability-card:hover { transform: translateY(-5px); border-color: rgba(72,216,255,.34); box-shadow: var(--shadow); }
.capability-card--cyan { color: var(--white); background: radial-gradient(circle at 0 100%, rgba(35,215,176,.16), transparent 42%), var(--navy-900); }.capability-card--violet { color: var(--white); background: radial-gradient(circle at 100% 0, rgba(142,125,255,.25), transparent 42%), #111a27; }.capability-card--emerald { background: linear-gradient(145deg, #f6fbf8, #eaf5ef); }
.capability-card__meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: auto; color: var(--slate); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.capability-card--cyan .capability-card__meta, .capability-card--violet .capability-card__meta { color: #84a8af; }
.capability-card__meta b { color: var(--cyan); font-size: 11px; }.capability-card--violet .capability-card__meta b { color: #b8acff; }.capability-card--emerald .capability-card__meta b { color: var(--emerald); }
.capability-card h3 { margin: 65px 0 15px; font-size: clamp(24px, 2.3vw, 31px); letter-spacing: -.038em; line-height: 1.1; }
.capability-card p { margin: 0; color: var(--slate); font-size: 15px; line-height: 1.65; }.capability-card--cyan p, .capability-card--violet p { color: #a6c1c6; }
.capability-card a { display: flex; align-items: center; gap: 8px; margin-top: 30px; color: var(--emerald); font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }.capability-card--cyan a { color: var(--cyan); }.capability-card--violet a { color: #b8acff; }.capability-card a svg { width: 18px; }

.info-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.info-card { min-height: 235px; padding: 25px; border: 1px solid var(--line); border-radius: var(--radius); background: rgba(255,255,255,.8); box-shadow: 0 10px 30px rgba(3,21,28,.04); transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease; }
.info-card:hover { transform: translateY(-4px); border-color: rgba(22,129,95,.32); box-shadow: var(--shadow-soft); }
.info-card__number { color: var(--emerald); font-size: 10px; letter-spacing: .12em; }.info-card__tag { margin: 22px 0 -10px; color: var(--emerald); font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.info-card h3 { margin: 42px 0 12px; font-size: 21px; line-height: 1.16; letter-spacing: -.03em; }.info-card p { margin: 0; color: var(--slate); font-size: 14px; line-height: 1.65; }
.info-card__tag + h3 { margin-top: 22px; }
.process-grid { border-top: 1px solid var(--line); }
.process-step { display: grid; grid-template-columns: 74px 1fr; gap: 25px; padding: 25px 0; border-bottom: 1px solid var(--line); }
.process-step b { color: var(--emerald); font-size: 11px; letter-spacing: .13em; }.process-step h3 { margin: 0; font-size: 22px; letter-spacing: -.03em; }.process-step p { max-width: 650px; margin: 7px 0 0; color: var(--slate); font-size: 15px; }
.service-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.service-list div { display: flex; gap: 15px; padding: 19px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: rgba(255,255,255,.78); box-shadow: 0 8px 24px rgba(3,21,28,.035); }
.service-list span { flex: 0 0 auto; width: 9px; height: 9px; margin-top: 8px; border: 2px solid var(--cyan); border-radius: 50%; box-shadow: 0 0 0 4px rgba(72,216,255,.08); }.service-list--emerald span { border-color: var(--teal); }.service-list--violet span { border-color: var(--violet); }
.service-list p { margin: 0; font-size: 15px; font-weight: 680; line-height: 1.55; }
.pill-list { display: flex; flex-wrap: wrap; gap: 9px; }.pill-list span { padding: 10px 14px; color: #315b64; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.72); font-size: 12px; font-weight: 760; }

.contact-signal { display: grid; gap: 10px; width: min(100%, 430px); padding: 35px; border: 1px solid rgba(125,203,214,.18); border-radius: var(--radius-lg); background: rgba(7,25,34,.72); box-shadow: var(--shadow); }
.contact-signal p { margin: 0; padding: 16px 0; color: #bad2d6; border-bottom: 1px solid rgba(137,180,189,.12); font-size: 15px; }
.contact-signal p::before { content: ""; display: inline-block; width: 8px; height: 8px; margin-right: 12px; border: 2px solid var(--cyan); border-radius: 50%; box-shadow: 0 0 0 5px rgba(72,216,255,.07); }
.contact-signal strong { margin-top: 20px; color: var(--gold); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; }
.contact-layout { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(260px, .65fr); gap: 70px; align-items: start; }
.enquiry-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.enquiry-form label { display: grid; gap: 7px; color: #355b64; font-size: 11px; font-weight: 800; letter-spacing: .04em; }
.enquiry-form input, .enquiry-form select, .enquiry-form textarea { width: 100%; color: var(--ink); border: 1px solid var(--line); border-radius: 12px; background: #fff; font: inherit; outline: none; }
.enquiry-form input, .enquiry-form select { min-height: 49px; padding: 0 13px; }.enquiry-form textarea { padding: 13px; resize: vertical; }
.enquiry-form input:focus, .enquiry-form select:focus, .enquiry-form textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 4px rgba(35,215,176,.09); }
.enquiry-form__wide { grid-column: 1 / -1; }.enquiry-form button { justify-self: start; cursor: pointer; }
.contact-aside { position: sticky; top: 115px; padding: 25px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--mist); }
.contact-email { display: grid; gap: 3px; padding: 17px 0; border-bottom: 1px solid var(--line); }.contact-email span { color: var(--emerald); font-size: 9px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }.contact-email strong { font-size: 12px; }
.contact-note { margin-top: 28px; padding: 18px; color: #9fbabf; border-radius: 13px; background: var(--navy-900); }.contact-note strong { color: var(--white); font-size: 13px; }.contact-note p { margin: 6px 0 0; font-size: 11px; }

.cta-band { position: relative; overflow: hidden; padding: 90px 0; color: var(--white); background: linear-gradient(120deg, var(--navy-950), var(--navy-800)); }
.cta-band::before { content: ""; position: absolute; inset: 0; opacity: .18; background-image: linear-gradient(rgba(72,216,255,.15) 1px, transparent 1px), linear-gradient(90deg, rgba(72,216,255,.15) 1px, transparent 1px); background-size: 52px 52px; mask-image: linear-gradient(90deg, black, transparent); }
.cta-band__signal { position: absolute; right: -120px; top: -180px; width: 520px; height: 520px; border: 1px solid rgba(72,216,255,.18); border-radius: 50%; box-shadow: 0 0 0 70px rgba(72,216,255,.025), 0 0 0 140px rgba(35,215,176,.018); }
.cta-band__layout { position: relative; display: grid; grid-template-columns: 1fr auto; align-items: end; gap: 60px; }.cta-band h2 { max-width: 760px; }.cta-band p:not(.eyebrow) { max-width: 670px; color: #9ebac0; }

.site-footer { padding: 70px 0 25px; color: #a3bec3; background: var(--navy-950); }
.footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 70px; }.footer__brand img { width: 240px; }.footer__brand p { max-width: 430px; color: #718f96; font-size: 13px; }
.site-footer h2 { margin: 0 0 18px; color: var(--white); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; }.site-footer a { display: block; margin: 9px 0; color: #89a6ac; font-size: 12px; }.site-footer a:hover { color: var(--cyan); }
.footer__bottom { display: flex; justify-content: space-between; gap: 20px; margin-top: 55px; padding-top: 20px; border-top: 1px solid rgba(137,180,189,.12); color: #536f76; font-size: 10px; letter-spacing: .04em; text-transform: uppercase; }

[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity .65s ease, transform .65s ease; }
[data-reveal].is-visible { opacity: 1; transform: none; }
@keyframes rotate { to { transform: rotate(360deg); } }

@media (max-width: 1180px) {
  .site-header { grid-template-columns: 190px 1fr auto; padding-inline: 20px; }.site-nav { gap: 13px; }.site-nav a { font-size: 10px; }.header-cta { display: none; }
  .hero__layout, .hero--compact .hero__layout { grid-template-columns: minmax(0, 1fr) minmax(350px, .82fr); gap: 35px; }
  .narrative-visual { min-height: 420px; }.visual-orbit--outer { width: 390px; height: 390px; }.visual-orbit--inner { width: 290px; height: 290px; }
  .info-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1024px) {
  :root { --container: min(calc(100% - 40px), 920px); }
  .site-header { height: 68px; display: flex; justify-content: space-between; padding: 0 20px; background: rgba(4,17,23,.91); backdrop-filter: blur(16px); }.brand-link img { width: 182px; }
  .nav-toggle { position: relative; z-index: 52; width: 46px; height: 42px; display: grid; align-content: center; gap: 5px; padding: 0 11px; color: var(--white); border: 1px solid rgba(137,180,189,.22); border-radius: 12px; background: rgba(255,255,255,.02); }.nav-toggle span { display: block; height: 1px; background: var(--white); }.nav-toggle b { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
  .site-nav { position: fixed; z-index: 51; inset: 0; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 20px; opacity: 0; pointer-events: none; background: rgba(4,17,23,.985); transition: opacity .2s ease; }.site-nav.is-open { opacity: 1; pointer-events: auto; }.site-nav a { font-size: 19px; }.site-nav a[aria-current="page"]::after { bottom: -5px; }
  .hero { min-height: 660px; padding-top: 108px; }.hero--compact { min-height: 570px; padding-top: 100px; }
  .hero h1 { font-size: clamp(47px, 6.4vw, 64px); }.hero--compact h1 { font-size: clamp(43px, 5.7vw, 57px); }
  .capability-grid { grid-template-columns: repeat(2, 1fr); }.capability-card:last-child { grid-column: 1 / -1; }.capability-card { min-height: 315px; }
  .credibility-strip__layout { grid-template-columns: repeat(2, 1fr); }.credibility-strip span:nth-child(3) { border-top: 1px solid rgba(137,180,189,.12); }.credibility-strip span:nth-child(4) { border-top: 1px solid rgba(137,180,189,.12); }
}

@media (max-width: 840px) {
  :root { --container: min(calc(100% - 34px), 700px); }
  .hero, .hero--compact { min-height: auto; padding: 112px 0 66px; }
  .hero__layout, .hero--compact .hero__layout { grid-template-columns: minmax(0, 1fr); }
  .hero__content { max-width: 680px; }.hero__aside { margin-top: 14px; }
  .narrative-visual, .hero--compact .narrative-visual { min-height: 390px; }.visual-panel { width: min(100%, 500px); }
  .section { padding: 78px 0; }.capability-grid { grid-template-columns: 1fr; }.capability-card:last-child { grid-column: auto; }.capability-card { min-height: 290px; }.capability-card h3 { margin-top: 48px; }
  .service-list { grid-template-columns: 1fr; }.contact-layout { grid-template-columns: 1fr; }.contact-aside { position: static; }
  .cta-band__layout, .footer__top { grid-template-columns: 1fr; }.cta-band__layout { align-items: start; }.footer__top { gap: 38px; }
}

@media (max-width: 720px) {
  :root { --container: min(calc(100% - 28px), 620px); }
  .site-header { padding-inline: 14px; }.brand-link img { width: 170px; }
  .hero, .hero--compact { padding: 102px 0 56px; }
  .hero h1, .hero--compact h1 { max-width: 100%; font-size: clamp(38px, 11.5vw, 50px); line-height: 1.03; letter-spacing: -.048em; overflow-wrap: anywhere; }
  .hero__text { font-size: 16px; line-height: 1.68; }.hero__actions { flex-direction: column; align-items: stretch; }.button { width: 100%; padding-inline: 17px; text-align: center; }
  .eyebrow { max-width: 100%; font-size: 9px; letter-spacing: .13em; line-height: 1.45; }.eyebrow span { flex: 0 0 20px; }
  .narrative-visual, .hero--compact .narrative-visual { min-height: 335px; width: 100%; }.visual-orbit--outer { width: 310px; height: 310px; }.visual-orbit--inner { width: 235px; height: 235px; }.visual-panel { width: 100%; padding: 15px; border-radius: 20px; }.visual-panel__top { font-size: 8px; }.visual-labels { display: none; }
  .credibility-strip__layout { grid-template-columns: 1fr 1fr; }.credibility-strip span { padding: 15px 13px; font-size: 10px; }
  .section { padding: 65px 0; }.section-heading { margin-bottom: 32px; }.section-heading h2, .cta-band h2 { font-size: clamp(31px, 9.5vw, 40px); line-height: 1.1; }.section-heading p:not(.eyebrow) { font-size: 15px; }
  .info-grid { grid-template-columns: 1fr; }.info-card { min-height: 205px; }.process-step { grid-template-columns: 38px 1fr; gap: 14px; }
  .enquiry-form { grid-template-columns: 1fr; }.enquiry-form__wide { grid-column: auto; }.footer__bottom { flex-direction: column; }
}

@media (max-width: 420px) {
  :root { --container: min(calc(100% - 24px), 390px); }
  .hero h1, .hero--compact h1 { font-size: clamp(35px, 10.8vw, 44px); }
  .credibility-strip__layout { grid-template-columns: 1fr; }.credibility-strip span { border-right: 1px solid rgba(137,180,189,.12); border-top: 1px solid rgba(137,180,189,.12); }.credibility-strip span:first-child { border-top: 0; }
  .narrative-visual, .hero--compact .narrative-visual { min-height: 305px; }.visual-orbit--outer { width: 275px; height: 275px; }.visual-orbit--inner { width: 205px; height: 205px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  [data-reveal] { opacity: 1; transform: none; }
}
