:root {
  /* Light theme — Highgate */
  --bg: #f7f8fa;
  --panel: #ffffff;
  --panel-2: #ffffff;
  --text: #1f2933;
  --muted: #4b5563;
  --faint: #6b7280;
  --line: #e5e7eb;
  --primary: #3f454b;
--primary-hover: #33383d;
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.08);


  --radius: 16px;
  --max: 980px;

  --h1: clamp(2.1rem, 4vw, 3.2rem);
  --h2: 1.05rem;
  --body: 1rem;
  --lh: 1.55;
}
* {
  box-sizing: border-box;
}
html,
body {
  height: 100%;
}
body {
  margin: 0;
  background:
    radial-gradient(
      1100px 600px at 20% -10%,
      rgba(255, 255, 255, 0.06),
      transparent 55%
    ),
    radial-gradient(
      900px 500px at 90% 10%,
      rgba(255, 255, 255, 0.05),
      transparent 60%
    ),
    var(--bg);
  color: var(--text);
  font:
    400 var(--body)/var(--lh) ui-sans-serif,
    system-ui,
    -apple-system,
    Segoe UI,
    Roboto,
    Helvetica,
    Arial;
  letter-spacing: 0.2px;
}

.container {
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
}

.site-header {
  position: sticky;
  top: 0;
  backdrop-filter: blur(6px);
  background: #ffffff;
  border-bottom: 1px solid var(--line);
  z-index: 10;
}

.header-inner {
  display: flex;
  align-items: center;
  padding: 18px 0;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  user-select: none;
}

.mark {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  display: grid;
  place-items: center;
}
.logo {
  width: 24px;
  height: 24px;
  object-fit: contain;
}
.mark-inner {
  font-weight: 700;
  letter-spacing: 1px;
  color: rgba(255, 255, 255, 0.86);
}

.wordmark-top {
  font-weight: 700;
  letter-spacing: 2.2px;
  font-size: 0.95rem;
}
.wordmark-top {
  color: #1f2933;
}
.wordmark-sub {
  color: #6b7280;
}

.wordmark-sub {
  font-size: 0.78rem;
  color: var(--muted);
  letter-spacing: 0.9px;
  margin-top: 2px;
}

.site-main {
  padding: 56px 0 28px;
}

.hero {
  padding: 34px 0 40px;
}
h1 {
  margin: 0 0 12px 0;
  font-size: var(--h1);
  line-height: 1.08;
  letter-spacing: -0.6px;
}
.subline {
  margin: 0;
  color: var(--muted);
  font-size: 1.05rem;
  max-width: 55ch;
}

.section {
  padding: 26px 0;
}
.section h2 {
  margin: 0 0 10px 0;
  font-size: var(--h2);
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: #6b7280;
}
.section p {
  margin: 0;
  color: var(--muted);
  max-width: 70ch;
}

.cards {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.card {
  border-radius: var(--radius);
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.06),
    rgba(255, 255, 255, 0.03)
  );
  border: 1px solid var(--line);
  padding: 16px 16px 14px;
  box-shadow: var(--shadow);
}

.card-link {
  display: block;
  color: inherit;
  text-decoration: none;
  transition:
    transform 140ms ease,
    box-shadow 140ms ease;
}

.card-link:hover {
  transform: translateY(-1px);
}

.card-link:focus-visible {
  outline: 3px solid rgba(37, 99, 235, 0.35);
  outline-offset: 3px;
}

.card-title {
  font-weight: 650;
  letter-spacing: 0.3px;
}
.card-meta {
  margin-top: 6px;
  color: var(--faint);
  font-size: 0.95rem;
}

.site-footer {
  border-top: 1px solid var(--line);
  padding: 22px 0;
  margin-top: 32px;
}
.footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 0.92rem;
}
.footer-note {
  color: var(--faint);
}

@media (max-width: 720px) {
  .cards {
    grid-template-columns: 1fr;
  }
  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .site-main {
    padding-top: 42px;
  }
}

.brand,
.brand:visited {
  color: inherit;
  text-decoration: none;
}

.brand:hover {
  text-decoration: none;
}

.page-cta {
  border-top: 1px solid var(--line);
  padding-top: 22px;
  margin-top: 8px;
}

.page-cta p {
  margin: 0 0 10px 0;
  color: var(--muted);
  max-width: 64ch;
}

.text-links {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--faint);
  font-size: 0.95rem;
}

.text-links a {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
}

.text-links a:hover {
  text-decoration: underline;
}

/* About/story page spacing */
.about-page .site-main {
  padding-top: 48px;
}

.about-page .hero {
  padding: 28px 0 30px;
}

.about-page .section {
  padding: 20px 0;
}

.about-page .section p + p {
  margin-top: 10px;
}

.about-page .page-cta {
  margin-top: 18px;
}

.cta-kicker {
  margin: 0 0 6px 0 !important;
  color: var(--faint) !important;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 1.6px;
  text-transform: uppercase;
}

.card-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  color: var(--faint);
  font-size: 0.92rem;
}

.card-actions a,
.inline-link a,
.footer-links a {
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
}

.card-actions a:hover,
.inline-link a:hover,
.footer-links a:hover {
  text-decoration: underline;
}

.inline-link {
  margin-top: 12px !important;
}

.footer-links {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.home-page .cards {
  max-width: 560px;
}

.home-page .card {
  background: rgba(255, 255, 255, 0.72);
}

.home-page .cards {
  grid-template-columns: 1fr;
}

.home-page .hero {
  position: relative;
  overflow: hidden;
  padding: 76px 0 92px;
  background-image:
    linear-gradient(
      180deg,
      rgba(247, 248, 250, 1) 0%,
      rgba(247, 248, 250, 0.72) 16%,
      rgba(247, 248, 250, 0.08) 42%,
      rgba(247, 248, 250, 0.08) 62%,
      rgba(247, 248, 250, 0.78) 88%,
      rgba(247, 248, 250, 1) 100%
    ),
    linear-gradient(
      90deg,
      rgba(247, 248, 250, 1) 0%,
      rgba(247, 248, 250, 0.94) 24%,
      rgba(247, 248, 250, 0.68) 44%,
      rgba(247, 248, 250, 0.22) 66%,
      rgba(247, 248, 250, 0) 100%
    ),
    radial-gradient(
      circle at 86% 50%,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.06) 55%,
      rgba(247, 248, 250, 0.4) 78%,
      rgba(247, 248, 250, 0.78) 100%
    ),
    url("./assets/highgate/hero-flow-bg.jpg");
  background-repeat: no-repeat;
  background-position:
    center center,
    left top,
    right center,
    right center;
  background-size:
    auto,
    auto,
    auto,
    72% auto;
}

.home-page .hero .container {
  position: relative;
  z-index: 2;
}

.home-page .hero h1 {
  max-width: 13ch;
  margin-bottom: 16px;
}

.home-page .hero .subline {
  max-width: 30ch;
  font-size: 1.08rem;
  line-height: 1.55;
}

.home-page .hero::before {
  content: "";
  position: absolute;
  inset: -24% -18%;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse at 68% 42%,
      rgba(255, 255, 255, 0.92) 0%,
      rgba(255, 255, 255, 0.56) 28%,
      rgba(255, 255, 255, 0) 62%
    ),
    radial-gradient(
      ellipse at 88% 58%,
      rgba(219, 234, 254, 0.78) 0%,
      rgba(219, 234, 254, 0.42) 32%,
      rgba(219, 234, 254, 0) 66%
    );
  filter: blur(22px);
  opacity: 0.95;
  transform: translate3d(-24px, -8px, 0) scale(1);
  animation: heroMistDrift 12s ease-in-out infinite alternate;
}

@keyframes heroMistDrift {
  from {
    transform: translate3d(-34px, -12px, 0) scale(1);
    opacity: 0.62;
  }

  to {
    transform: translate3d(34px, 14px, 0) scale(1.08);
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .home-page .hero::before {
    animation: none;
  }
}

@media (max-width: 720px) {
  .home-page .hero {
    padding: 56px 0 68px;
    background-size:
      auto,
      auto,
      auto,
      92% auto;
    background-position:
      center center,
      left top,
      right top,
      right top;
  }

  .home-page .hero::before {
    animation: none;
    opacity: 0.16;
  }
}

.header-inner {
  justify-content: space-between;
}

.site-nav {
  display: flex;
  align-items: center;
  gap: 28px;
  margin-left: auto;
}

.site-nav a,
.nav-cta {
  color: var(--text);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 600;
}

.site-nav a:hover {
  text-decoration: underline;
}

.nav-cta {
  margin-left: 28px;
  padding: 10px 16px;
  border-radius: 8px;
  background: var(--primary);
  color: #ffffff;
  box-shadow: 0 10px 24px rgba(17, 24, 39, 0.12);
}

.nav-cta:hover,
.button-primary:hover {
  background: var(--primary-hover);
  text-decoration: none;
  transform: translateY(-1px);
}

.hero-note {
  margin: 16px 0 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  max-width: 36ch;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 28px;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 8px;
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 700;
}

.button-primary {
  background: var(--primary);
  color: #ffffff;
  box-shadow: 0 12px 28px rgba(17, 24, 39, 0.14);
}

.button-secondary {
  background: rgba(255, 255, 255, 0.82);
  color: var(--text);
  border: 1px solid rgba(31, 41, 51, 0.18);
}

.button:hover {
  transform: translateY(-1px);
}

@media (max-width: 840px) {
  .site-nav,
  .nav-cta {
    display: none;
  }
}

.hero-proof {
  padding: 28px 0 34px;
  border-bottom: 1px solid rgba(229, 231, 235, 0.72);
}

.proof-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px;
}

.proof-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.proof-icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: var(--primary);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
}

.proof-title {
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 800;
}

.proof-meta {
  margin-top: 2px;
  color: var(--faint);
  font-size: 0.78rem;
}

@media (max-width: 840px) {
  .proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .proof-grid {
    grid-template-columns: 1fr;
  }
}

.product-section {
  padding: 56px 0;
  border-bottom: 1px solid rgba(229, 231, 235, 0.72);
}

.product-layout {
  display: grid;
  grid-template-columns: 0.85fr 1.75fr;
  gap: 48px;
  align-items: start;
}

.section-intro .eyebrow {
  margin: 0 0 12px 0;
  color: var(--faint);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 1.6px;
  text-transform: uppercase;
}

.section-intro h2 {
  margin: 0 0 14px 0;
  color: var(--text);
  font-size: clamp(1.55rem, 2.4vw, 2.15rem);
  line-height: 1.12;
  letter-spacing: -0.4px;
  text-transform: none;
}

.section-intro p {
  color: var(--muted);
  max-width: 34ch;
}

.product-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.product-card {
  min-height: 230px;
  border: 1px solid rgba(229, 231, 235, 0.9);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 18px 46px rgba(31, 41, 51, 0.08);
  padding: 22px;
}

.product-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 22px;
}

.product-icon {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--primary);
  color: #ffffff;
  font-weight: 800;
}

.muted-icon {
  background: rgba(255, 255, 255, 0.9);
  color: var(--muted);
  border: 1px solid var(--line);
}

.status-pill {
  padding: 4px 9px;
  border-radius: 999px;
  background: #dff3e7;
  color: #2f7d4f;
  font-size: 0.72rem;
  font-weight: 800;
}

@media (max-width: 840px) {
  .product-layout {
    grid-template-columns: 1fr;
  }

  .product-cards {
    grid-template-columns: 1fr;
  }
}

.services-section {
  padding: 56px 0;
  border-bottom: 1px solid rgba(229, 231, 235, 0.72);
}

.services-layout {
  display: grid;
  grid-template-columns: 0.85fr 1.75fr;
  gap: 48px;
  align-items: start;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px 34px;
}

.service-item {
  display: grid;
  grid-template-columns: 54px 1fr;
  gap: 16px;
  align-items: start;
}

.service-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(229, 231, 235, 0.9);
  box-shadow: 0 12px 28px rgba(31, 41, 51, 0.06);
  color: var(--primary);
  font-size: 1.05rem;
  font-weight: 800;
}

.service-title {
  color: var(--text);
  font-weight: 800;
  font-size: 0.95rem;
  margin-bottom: 4px;
}

.service-item p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  max-width: 34ch;
}

@media (max-width: 840px) {
  .services-layout {
    grid-template-columns: 1fr;
  }

  .service-grid {
    grid-template-columns: 1fr;
  }
}
.proof-icon svg,
.service-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.proof-icon {
  color: var(--primary);
  opacity: 0.9;
}

.service-icon {
  color: var(--primary);
}

.proof-icon {
  width: 30px;
  height: 30px;
  margin-top: -2px;
  color: var(--primary);
  opacity: 0.95;
}

.proof-icon svg {
  width: 19px;
  height: 19px;
}

.product-icon-image {
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(229, 231, 235, 0.95);
  box-shadow: 0 10px 24px rgba(31, 41, 51, 0.06);
  overflow: hidden;
  padding: 2px;
}

.product-icon-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.services-section {
  padding: 52px 0 48px;
}

.services-layout {
  gap: 40px;
}

.service-grid {
  gap: 26px 28px;
}

.service-icon {
  width: 42px;
  height: 42px;
  border-radius: 11px;
  box-shadow: 0 8px 20px rgba(31, 41, 51, 0.045);
}

.service-icon svg {
  width: 19px;
  height: 19px;
}

.service-icon svg {
  width: 23px;
  height: 23px;
}

.service-icon svg * {
  stroke-width: 2.6 !important;
}

.service-icon {
  width: 44px;
  height: 44px;
  color: var(--primary);
}

.approach-section {
  padding: 58px 0;
  border-bottom: 1px solid rgba(229, 231, 235, 0.72);
}

.approach-layout {
  display: grid;
  grid-template-columns: 0.85fr 1.75fr;
  gap: 48px;
  align-items: start;
}

.approach-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 18px;
}

.approach-step {
  position: relative;
  text-align: center;
}

.step-icon {
  width: 44px;
  height: 44px;
  margin: 0 auto 14px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--primary);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 800;
  box-shadow: 0 14px 30px rgba(63, 69, 75, 0.16);
}

.step-title {
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 800;
  margin-bottom: 6px;
}

.approach-step p {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .approach-layout {
    grid-template-columns: 1fr;
  }

  .approach-steps {
    grid-template-columns: 1fr;
    text-align: left;
  }

  .approach-step {
    text-align: left;
    display: grid;
    grid-template-columns: 54px 1fr;
    gap: 14px;
  }

  .step-icon {
    margin: 0;
  }
}

.quote-section {
  padding: 42px 0;
  border-bottom: 1px solid rgba(229, 231, 235, 0.72);
}

.quote-card {
  min-height: 96px;
  border: 1px solid rgba(229, 231, 235, 0.95);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 46px rgba(31, 41, 51, 0.08);
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  align-items: center;
  gap: 18px;
  padding: 24px 34px;
}

.quote-mark {
  color: var(--primary);
  font-size: 2.8rem;
  line-height: 1;
  font-weight: 900;
}

.quote-card p {
  margin: 0;
  color: var(--text);
  font-size: 1.02rem;
  line-height: 1.5;
  max-width: 74ch;
}

.quote-logo {
  color: var(--primary);
  font-size: 1.4rem;
  font-weight: 900;
  text-align: right;
  letter-spacing: 1px;
}

@media (max-width: 720px) {
  .quote-card {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 22px;
  }

  .quote-logo {
    text-align: left;
  }
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.45fr repeat(4, 1fr);
  gap: 34px;
  align-items: start;
}

.footer-brand p {
  margin: 14px 0 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  max-width: 28ch;
}

.footer-column {
  display: grid;
  gap: 9px;
}

.footer-heading {
  color: var(--faint);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.footer-column a {
  color: var(--muted);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 600;
}

.footer-column a:hover {
  color: var(--text);
  text-decoration: underline;
}

.footer-bottom {
  margin-top: 34px;
  padding-top: 18px;
  border-top: 1px solid rgba(229, 231, 235, 0.8);
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: var(--faint);
  font-size: 0.82rem;
}

@media (max-width: 840px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }

  .footer-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 520px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }

  .footer-bottom {
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .approach-section {
    padding: 52px 0;
  }

  .approach-layout {
    gap: 30px;
  }

  .approach-steps {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .approach-step {
    display: grid;
    grid-template-columns: 74px 1fr;
    gap: 18px;
    text-align: left;
    align-items: start;
  }

  .step-icon {
    width: 58px;
    height: 58px;
    margin: 0;
    font-size: 1rem;
  }

  .step-title {
    font-size: 1.15rem;
    margin-top: 4px;
    margin-bottom: 8px;
  }

  .approach-step p {
    grid-column: 2;
    font-size: 1rem;
    line-height: 1.55;
    max-width: 34ch;
  }
}

@media (max-width: 720px) {
  .home-page .hero {
    padding: 56px 0 76px;
    background-image:
      linear-gradient(
        180deg,
        rgba(247, 248, 250, 1) 0%,
        rgba(247, 248, 250, 0.92) 12%,
        rgba(247, 248, 250, 0.18) 42%,
        rgba(247, 248, 250, 0.22) 64%,
        rgba(247, 248, 250, 1) 100%
      ),
      linear-gradient(
        90deg,
        rgba(247, 248, 250, 1) 0%,
        rgba(247, 248, 250, 0.86) 38%,
        rgba(247, 248, 250, 0.24) 74%,
        rgba(247, 248, 250, 0) 100%
      ),
      radial-gradient(
        circle at 86% 48%,
        rgba(255, 255, 255, 0) 0%,
        rgba(255, 255, 255, 0.08) 52%,
        rgba(247, 248, 250, 0.58) 82%,
        rgba(247, 248, 250, 0.96) 100%
      ),
      url("./assets/highgate/hero-flow-bg.jpg");
    background-repeat: no-repeat;
    background-position:
      center center,
      left top,
      right center,
      70% 44%;
    background-size:
      auto,
      auto,
      auto,
      155% auto;
  }

  .home-page .hero::before {
    inset: -34% -30%;
    opacity: 0.72;
    filter: blur(24px);
    animation: heroMistDriftMobile 18s ease-in-out infinite alternate;
  }
}

@keyframes heroMistDriftMobile {
  from {
    transform: translate3d(-20px, -8px, 0) scale(1);
    opacity: 0.48;
  }

  to {
    transform: translate3d(18px, 10px, 0) scale(1.06);
    opacity: 0.82;
  }
}

@media (max-width: 720px) {
  .home-page .hero {
    background-image:
      linear-gradient(
        180deg,
        rgba(247, 248, 250, 1) 0%,
        rgba(247, 248, 250, 0.86) 14%,
        rgba(247, 248, 250, 0.38) 40%,
        rgba(247, 248, 250, 0.52) 70%,
        rgba(247, 248, 250, 1) 100%
      ),
      linear-gradient(
        90deg,
        rgba(247, 248, 250, 1) 0%,
        rgba(247, 248, 250, 0.68) 38%,
        rgba(247, 248, 250, 0.12) 74%,
        rgba(247, 248, 250, 0) 100%
      ),
      url("./assets/highgate/hero-flow-bg.jpg");
    background-repeat: no-repeat;
    background-position:
      center center,
      left top,
      72% 42%;
    background-size:
      auto,
      auto,
      165% auto;
  }

  .home-page .hero::before {
    animation: none;
    opacity: 0;
  }
}