/* ============== TOKENS ============== */
/* Warm "precision instrument" palette — shared with the home page (index.html). */
:root {
  --ink: #241B12;
  --ink-2: #2E231A;
  --ink-soft: #3A2C1E;
  --paper: #F4EEE3;
  --cream: #ECE3D4;
  --cream-2: #E4D9C7;
  --border: #DAC9B2;
  --border-strong: #C2AA86;
  --muted: #6E5C49;
  --muted-2: #8A7660;

  /* dark sections become warm espresso panels (matching the home-page editor) */
  --dark-bg: #241B14;
  --dark-bg-2: #2E231A;
  --dark-border: #3B2E22;
  --dark-border-2: #4A3826;
  --dark-text: #F1E7DA;
  --dark-muted: #A99681;
  --dark-muted-2: #857056;

  --accent: #A35E27;
  --accent-soft: #C98B4E;
  --accent-deep: #774114;
  --accent-amber: #C0863F;
  --accent-blue: #9E6B36;

  --radius: 12px;
  --radius-sm: 8px;
  --radius-lg: 20px;

  --shadow-sm: 0 1px 3px rgba(58,34,12,.06), 0 1px 2px rgba(58,34,12,.04);
  --shadow: 0 8px 24px -8px rgba(58,34,12,.12), 0 2px 6px rgba(58,34,12,.05);

  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;
  --space-3xl: 64px;

  --container: 1200px;
  --space-section: clamp(80px, 10vw, 128px);

  --font-sans: "Switzer", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono: "Martian Mono", ui-monospace, "JetBrains Mono", Menlo, monospace;
  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-logo: "Lexend Exa", "Switzer", system-ui, sans-serif;
}

/* ============== RESET ============== */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; }
code { font-family: var(--font-mono); font-size: .94em; }

/* Serif display headings — consistent with the home page */
.hero__title,
.page-hero__title,
.section-head__title,
.vision-cta__title,
.hub-announcement__title,
.why__interop-title {
  font-family: var(--font-display);
  font-weight: 600;
}
::selection { background: var(--accent); color: var(--paper); }

.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}

/* ============== NAV ============== */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid transparent;
  transition: background .25s ease, border-color .25s ease, backdrop-filter .25s ease;
}
.nav--scrolled {
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom-color: var(--border);
}
.nav__inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 14px 28px;
  display: flex;
  align-items: center;
  gap: 32px;
}
.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-weight: 700;
  letter-spacing: -.01em;
}
.nav__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: currentColor;
}
.nav__logo svg { width: 100%; height: 100%; display: block; }
.nav__wordmark { font-family: var(--font-logo); font-weight: 600; font-size: 16px; letter-spacing: .02em; }
.nav__links {
  display: flex;
  align-items: center;
  gap: 26px;
  margin-left: 8px;
  font-size: 15px;
  color: var(--muted);
}
.nav__links a {
  position: relative;
  padding: 4px 0;
  transition: color .15s ease;
}
.nav__links a:hover { color: var(--ink); }
.nav__links a[aria-current="page"] { color: var(--ink); font-weight: 500; }
.nav__cta { margin-left: auto; display: flex; align-items: center; gap: 10px; }

/* ============== BUTTONS ============== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0 18px;
  border-radius: 10px;
  font-weight: 500;
  font-size: 14.5px;
  letter-spacing: -.005em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .12s ease, background .15s ease, border-color .15s ease, color .15s ease;
  white-space: nowrap;
}
.btn--sm { height: 34px; padding: 0 14px; font-size: 13.5px; border-radius: 8px; }
.btn--primary {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.btn--primary:hover { background: #000; transform: translateY(-1px); }
.btn--ghost {
  background: transparent;
  border-color: var(--border);
  color: var(--ink);
}
.btn--ghost:hover { background: var(--cream); border-color: var(--border-strong); }
.btn--ghost-dark {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.18);
  color: var(--dark-text);
}
.btn--ghost-dark:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.3); }
.btn--discord { background: #5865F2; color: #fff; border-color: #5865F2; }
.btn--discord:hover { background: #4752c4; border-color: #4752c4; color: #fff; transform: translateY(-1px); }
.btn--discord svg { width: 18px; height: 18px; }
.nav__links a.btn--discord { color: #fff; padding: 0 14px; }
.nav__links a.btn--discord:hover { color: #fff; }

/* ============== HERO ============== */
.hero {
  position: relative;
  background: var(--dark-bg);
  color: var(--dark-text);
  overflow: hidden;
  isolation: isolate;
  padding: clamp(72px, 11vw, 140px) 0 clamp(40px, 6vw, 80px);
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.hero__glow {
  position: absolute;
  left: 50%;
  top: -10%;
  width: 1100px;
  height: 700px;
  transform: translateX(-50%);
  background:
    radial-gradient(ellipse 60% 40% at 50% 40%, rgba(163,94,39, 0.12), transparent 65%),
    radial-gradient(ellipse 50% 30% at 30% 60%, rgba(150,98,46, 0.10), transparent 70%),
    radial-gradient(ellipse 40% 35% at 70% 50%, rgba(192,134,63, 0.06), transparent 60%);
  filter: blur(44px);
}
.hero__inner {
  position: relative;
  z-index: 1;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
  text-align: center;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 14px 6px 12px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  font-size: 13px;
  color: var(--dark-muted);
  background: rgba(255,255,255,0.03);
  margin-bottom: 28px;
  transition: border-color .15s ease, background .15s ease;
}
.pill:hover { border-color: rgba(255,255,255,0.28); background: rgba(255,255,255,0.05); }
.pill__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(163,94,39, 0.18);
}
.pill__arrow { color: var(--dark-muted-2); font-size: 12px; }
.hero__title {
  font-size: clamp(38px, 6vw, 80px);
  font-weight: 600;
  line-height: 0.98;
  letter-spacing: -0.04em;
  margin: 0 0 24px;
  color: var(--dark-text);
}
.hero__title-accent {
  display: inline-block;
  background: linear-gradient(180deg, #ffffff 0%, #9ca3af 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__subheading {
  font-size: clamp(18px, 1.6vw, 22px);
  color: var(--dark-text);
  max-width: 720px;
  margin: 0 auto 12px;
  line-height: 1.45;
  font-weight: 500;
}
.hero__subheading--accent {
  font-size: clamp(17px, 1.5vw, 21px);
  color: var(--accent);
  margin: 0 auto 28px;
  letter-spacing: -0.01em;
}
.hero__sub {
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--dark-muted);
  max-width: 820px;
  margin: 0 auto 36px;
  line-height: 1.55;
}
.hero__cta {
  display: flex;
  gap: 12px;
  justify-content: center;
  margin-bottom: 28px;
}
.hero .btn--primary {
  background: #fff;
  color: var(--ink);
  border-color: #fff;
}
.hero .btn--primary:hover { background: var(--cream); border-color: var(--cream); }
.hero__meta {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  font-size: 13px;
  color: var(--dark-muted);
  font-family: var(--font-mono);
}
.hero__meta-item { display: inline-flex; align-items: center; gap: 8px; }
.hero__meta-item code {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 12px;
  color: var(--dark-text);
}
.dot {
  display: inline-block;
  width: 8px; height: 8px; border-radius: 50%;
}
.dot--green {
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(163,94,39, 0.16);
}

/* ============== TRUST ============== */
.trust {
  background: var(--paper);
  border-bottom: 1px solid var(--border);
  padding: clamp(36px, 4vw, 56px) 0;
}
.trust__inner {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}
.trust__label {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--muted-2);
  letter-spacing: 0.03em;
  margin: 0 0 10px;
  font-weight: 500;
}
.trust__body {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}
.trust__body a {
  color: var(--accent-deep);
  text-decoration: underline;
  text-decoration-color: rgba(119,65,20, 0.3);
  text-underline-offset: 2px;
}
.trust__body a:hover {
  text-decoration-color: var(--accent-deep);
}

/* ============== PAGE HERO (subpages) ============== */
.page-hero {
  background: var(--dark-bg);
  color: var(--dark-text);
  padding: clamp(56px, 8vw, 100px) 0 clamp(40px, 5vw, 64px);
}
.page-hero__inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 28px;
}
.page-hero .section-head__label {
  color: var(--dark-muted-2);
  margin-bottom: 18px;
}
.page-hero__title {
  font-size: clamp(36px, 5.5vw, 64px);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: -0.035em;
  margin: 0 0 20px;
  color: var(--dark-text);
}
.page-hero__subheading {
  font-size: clamp(17px, 1.6vw, 22px);
  font-weight: 500;
  color: var(--accent);
  max-width: 640px;
  line-height: 1.4;
  letter-spacing: -0.01em;
  margin: 0 0 16px;
}
.page-hero__sub {
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--dark-muted);
  max-width: 640px;
  line-height: 1.55;
  margin: 0;
}

/* ============== CONTENT SECTIONS ============== */
.content-section {
  padding: var(--space-section) 0;
  background: var(--paper);
  border-bottom: 1px solid var(--border);
}
.content-section--alt {
  background: var(--cream);
}
.content-section--dark {
  background: var(--dark-bg);
  color: var(--dark-text);
  border-bottom-color: var(--dark-border);
}

/* ============== SECTION HEAD ============== */
.section-head { margin-bottom: var(--space-3xl); max-width: 880px; }
.section-head__label {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--muted-2);
  letter-spacing: 0.04em;
  margin-bottom: 22px;
}
.section-head__title {
  font-size: clamp(36px, 4.8vw, 64px);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin: 0 0 20px;
  text-wrap: balance;
}
.muted-title { color: var(--muted-2); font-weight: 500; }
.section-head__sub {
  font-size: 17px;
  color: var(--muted);
  max-width: 620px;
  margin: 0;
  line-height: 1.55;
}
.section-head--centered {
  text-align: center;
  max-width: 840px;
  margin: 0 auto var(--space-3xl);
}
.section-head--centered .section-head__sub {
  margin: 0 auto;
}
.section-head--dark .section-head__title { color: var(--dark-text); }
.section-head--dark .section-head__sub { color: var(--dark-muted); }
.section-head--dark .section-head__label { color: var(--dark-muted-2); }

.section-head--horizontal {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  max-width: 100%;
  margin-bottom: var(--space-3xl);
}
.section-head--horizontal .section-head__primary {
  flex: 1.2;
  min-width: 0;
}
.section-head--horizontal .section-head__sub {
  flex: 1;
  margin: 0;
  max-width: none;
  padding-top: 36px;
}

/* ============== CHIPS ============== */
.chip {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  transition: border-color .15s ease, color .15s ease;
  display: inline-block;
}
.chip:hover { border-color: var(--border-strong); color: var(--ink); }
.chip--dark {
  border-color: var(--dark-border-2);
  color: var(--dark-muted);
}
.chip--dark:hover { border-color: rgba(255,255,255,0.3); color: var(--dark-text); }

/* ============== PRODUCT MARKS ============== */
.product__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  border-radius: 10px;
  background: var(--ink);
  color: #fff;
}
.product__mark svg { width: 26px; height: 26px; }
.product__mark--cpp {
  background: transparent;
  padding: 0;
}
.product__mark--cpp img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
}
.product__mark--gdal {
  background: linear-gradient(135deg, #C98B4E 0%, #A35E27 100%);
}
.product__mark--celoce {
  background: linear-gradient(135deg, #3A2C1E 0%, #5A4126 100%);
}
.product__mark--enterprise-icon {
  background: linear-gradient(135deg, #B5793C 0%, #774114 100%);
}

/* ============== STATS ============== */
.stat__num {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  margin-bottom: 6px;
  font-feature-settings: "tnum";
}
.stat__lbl {
  font-size: 12px;
  color: var(--muted);
  font-family: var(--font-mono);
}

/* ============== THE PROBLEM ============== */
.problem__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.problem__card {
  background: rgba(240, 244, 250, 0.65);
  border: 1px solid rgba(203, 213, 232, 0.6);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color .2s ease, background .2s ease;
}
.problem__card:hover { border-color: var(--border-strong); background: rgba(240, 244, 250, 0.85); }
.problem__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 9px;
  background: rgba(150,98,46, 0.1);
  color: var(--accent-blue);
  margin-bottom: 18px;
  border: 1px solid rgba(150,98,46, 0.2);
}
.problem__icon svg { width: 20px; height: 20px; }
.problem__card h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.problem__card p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}
.problem__context {
  max-width: 680px;
  padding: 24px 28px;
  background: rgba(240, 244, 250, 0.6);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent-blue);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.problem__context p {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

/* ============== WORKAROUNDS ============== */
.workarounds__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.workaround {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: border-color .2s ease, background .2s ease;
}
.workaround:hover { border-color: var(--border-strong); background: rgba(255, 255, 255, 0.9); }
.workaround__num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted-2);
  letter-spacing: 0.04em;
  margin-bottom: 16px;
  display: block;
}
.workaround h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.workaround p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

/* ============== 3-LAYER ARCHITECTURE ============== */
.arch__stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 760px;
  margin: 0 auto;
  gap: 0;
}
.arch__layer {
  width: 100%;
  padding: 32px;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  transition: border-color .2s ease, background .2s ease;
}
.arch__layer--oss {
  background: rgba(240, 244, 250, 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.arch__layer--oss:hover {
  background: rgba(255, 255, 255, 0.9);
  border-color: var(--border-strong);
}
.arch__layer--oss:hover .arch__layer-desc,
.arch__layer--oss:hover .arch__layer-role {
  color: var(--ink);
}
.arch__layer--cloud {
  background: var(--ink);
  color: var(--dark-text);
  border-color: rgba(38, 66, 112, 0.6);
}
.arch__layer--cloud:hover {
  border-color: rgba(38, 66, 112, 0.9);
}
.arch__layer--cloud:hover .arch__layer-desc,
.arch__layer--cloud:hover .arch__layer-role {
  color: var(--dark-text);
}
.arch__layer--enterprise {
  background: rgba(240, 244, 250, 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.arch__layer--enterprise:hover {
  background: rgba(255, 255, 255, 0.9);
  border-color: var(--border-strong);
}
.arch__layer--enterprise:hover .arch__layer-desc,
.arch__layer--enterprise:hover .arch__layer-role {
  color: var(--ink);
}
.arch__layer-head {
  margin-bottom: 20px;
}
.arch__badge {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 5px 10px;
  border-radius: 5px;
  font-weight: 500;
  text-transform: uppercase;
}
.arch__badge--oss {
  background: rgba(163,94,39, 0.12);
  color: var(--accent-deep);
  border: 1px solid rgba(163,94,39, 0.3);
}
.arch__badge--cloud {
  background: rgba(150,98,46, 0.15);
  color: #C98B4E;
  border: 1px solid rgba(150,98,46, 0.35);
}
.arch__badge--enterprise {
  background: rgba(192,134,63, 0.12);
  color: #B5793C;
  border: 1px solid rgba(192,134,63, 0.3);
}
.arch__badge--planned {
  background: rgba(255, 255, 255, 0.06);
  color: var(--muted);
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 1px 6px;
  border-radius: 4px;
}
.arch__layer-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}
.arch__layer-name {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 500;
}
.arch__layer-role {
  font-size: 13px;
  color: var(--muted);
  margin-top: 2px;
}
.arch__layer--cloud .arch__layer-role {
  color: var(--dark-muted);
}
.arch__layer-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 20px;
}
.arch__layer--cloud .arch__layer-desc {
  color: var(--dark-muted);
}
.arch__features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 20px;
  padding: 20px;
  background: var(--paper);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.arch__features--dark {
  background: var(--dark-bg-2);
  border-color: var(--dark-border-2);
}
.arch__feature-col h4 {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin: 0 0 12px;
}
.arch__layer--cloud .arch__feature-col h4 {
  color: var(--dark-muted-2);
}
.arch__feature-col ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.arch__feature-col li {
  position: relative;
  padding-left: 18px;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.4;
}
.arch__layer--cloud .arch__feature-col li {
  color: var(--dark-text);
}
.arch__feature-col li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 12px;
}
.arch__layer--cloud .arch__feature-col li::before {
  color: var(--accent);
}
.arch__layer-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.arch__divider {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 0;
  color: var(--muted-2);
}
.arch__divider svg {
  width: 24px;
  height: 32px;
}
.arch__divider span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

/* ============== ARCH GRID (horizontal platform layout) ============== */
.arch__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
.arch__grid .arch__layer {
  display: flex;
  flex-direction: column;
}
.arch__grid .arch__layer-links,
.arch__grid > .arch__layer > a.chip {
  margin-top: auto;
}
.arch__compact-list {
  list-style: none;
  margin: 0 0 var(--space-lg);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.arch__compact-list li {
  position: relative;
  padding-left: 18px;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.4;
}
.arch__compact-list li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 12px;
}
.arch__layer--cloud .arch__compact-list li {
  color: var(--dark-text);
}
.arch__layer--cloud .arch__compact-list li::before {
  color: var(--accent);
}
.arch__compact-list li code {
  background: rgba(0,0,0,0.05);
  border: 1px solid var(--border);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 12px;
}
.arch__layer--cloud .arch__compact-list li code {
  background: rgba(255,255,255,0.06);
  border-color: var(--dark-border-2);
  color: var(--dark-text);
}

/* ============== WHY THIS EXISTS ============== */
.why__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  max-width: 960px;
  margin: 0 auto;
}
.why__lead {
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 500;
  color: var(--dark-text);
  line-height: 1.4;
  margin: 0 0 20px;
}
.why__body {
  font-size: 15px;
  color: var(--dark-muted);
  line-height: 1.6;
  margin: 0 0 16px;
}
.why__diagram {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  max-width: 560px;
  margin: 0 auto;
}
.why__diagram-row {
  width: 100%;
  text-align: center;
  padding: 20px 24px;
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.03);
}
.why__diagram-row--core {
  background: rgba(163,94,39,0.06);
  border-color: rgba(163,94,39,0.22);
}
.why__diagram-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dark-muted-2);
  margin-bottom: 10px;
}
.why__diagram-row--core .why__diagram-label {
  color: var(--accent);
}
.why__diagram-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}
.why__chip {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 5px 10px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--dark-border-2);
  border-radius: 5px;
  color: var(--dark-text);
}
.why__chip--accent {
  background: rgba(163,94,39,0.1);
  border-color: rgba(163,94,39,0.25);
  color: var(--accent-soft);
}
.why__chip--out {
  background: rgba(150,98,46,0.1);
  border-color: rgba(150,98,46,0.25);
  color: var(--accent-blue);
}
.why__diagram-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  color: var(--dark-muted-2);
}
.why__diagram-arrow svg {
  width: 24px;
  height: 32px;
}

.why__diagram--horizontal {
  flex-direction: row;
  align-items: stretch;
  max-width: 100%;
  gap: 0;
}
.why__diagram--horizontal .why__diagram-row {
  flex: 1;
  min-width: 0;
}
.why__diagram-arrow--horizontal {
  height: auto;
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.why__diagram-arrow--horizontal svg {
  width: 32px;
  height: 24px;
}

/* ============== PROOF AT SCALE ============== */
.proof__card {
  background: rgba(240, 244, 250, 0.65);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 40px;
  max-width: 800px;
  margin: 0 auto 48px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.proof__brand {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.proof__name {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 500;
}
.proof__role {
  font-size: 13px;
  color: var(--muted);
  margin-top: 2px;
}
.proof__desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0 0 28px;
}
.proof__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
  padding: 24px;
  background: rgba(228, 234, 244, 0.5);
  border: 1px solid rgba(203, 213, 232, 0.4);
  border-radius: 12px;
}
.proof__users {
  max-width: 800px;
  margin: 0 auto;
}
.proof__users-label {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: var(--muted-2);
  letter-spacing: 0.04em;
  text-align: center;
  margin-bottom: 20px;
}
.proof__users-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.logo-ph {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 56px;
  padding: 0 12px;
  font-family: var(--font-mono);
  font-size: 12.5px;
  letter-spacing: 0.01em;
  color: var(--muted);
  background: rgba(240, 244, 250, 0.5);
  border: 1px solid rgba(203, 213, 232, 0.4);
  border-radius: 8px;
  text-align: center;
  transition: color .2s ease, border-color .2s ease, background .2s ease;
}
.logo-ph:hover {
  color: var(--ink);
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.8);
}

/* ============== DELIVERY ============== */
.delivery__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
.delivery__card {
  background: var(--dark-bg-2);
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius-lg);
  padding: 28px;
  transition: border-color .2s ease;
}
.delivery__card:hover {
  border-color: rgba(255,255,255,0.15);
}
.delivery__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 9px;
  background: rgba(163,94,39, 0.1);
  color: var(--accent);
  margin-bottom: 18px;
  border: 1px solid rgba(163,94,39, 0.2);
}
.delivery__icon svg { width: 20px; height: 20px; }
.delivery__card h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
  color: var(--dark-text);
}
.delivery__card p {
  font-size: 14.5px;
  color: var(--dark-muted);
  line-height: 1.55;
  margin: 0;
}

/* ============== PROOF HIGHLIGHT ============== */
.proof__highlight {
  font-size: clamp(17px, 1.4vw, 20px);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.4;
  margin: 0 0 12px;
  padding: 16px 20px;
  background: rgba(163,94,39, 0.08);
  border: 1px solid rgba(163,94,39, 0.2);
  border-radius: var(--radius);
}

/* ============== WORKLOADS ============== */
.workloads__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.workload {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: border-color .2s ease, background .2s ease;
}
.workload:hover { border-color: var(--border-strong); background: rgba(255, 255, 255, 0.9); }
.workload__icon {
  width: 40px;
  height: 40px;
  border-radius: 9px;
  background: rgba(163,94,39, 0.1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent-deep);
  margin-bottom: 18px;
  border: 1px solid rgba(163,94,39, 0.2);
}
.workload__icon svg { width: 20px; height: 20px; }
.workload h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.workload p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 16px;
}
.workload__libs {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted-2);
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

/* ============== INFRASTRUCTURE EXTENSIONS ============== */
.extensions__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.extension {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: border-color .2s ease, background .2s ease;
}
.extension:hover { border-color: var(--border-strong); background: rgba(255, 255, 255, 0.9); }
.extension__head {
  margin-bottom: 16px;
}
.extension__badge {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 5px 10px;
  border-radius: 5px;
  font-weight: 500;
  text-transform: uppercase;
  background: rgba(163,94,39, 0.12);
  color: var(--accent-deep);
  border: 1px solid rgba(163,94,39, 0.3);
}
.extension__badge--blue {
  background: rgba(150,98,46, 0.12);
  color: var(--accent-blue);
  border-color: rgba(150,98,46, 0.3);
}
.extension__badge--amber {
  background: rgba(192,134,63, 0.12);
  color: #B5793C;
  border-color: rgba(192,134,63, 0.3);
}
.extension__badge--green {
  background: rgba(163,94,39, 0.12);
  color: var(--accent-deep);
  border-color: rgba(163,94,39, 0.3);
}
.extension h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
}
.extension p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 16px;
}
.extension__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.extension__list li {
  position: relative;
  padding-left: 18px;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.4;
}
.extension__list li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 12px;
}

/* ============== ARCHITECTURE DIAGRAMS ============== */
.diagrams {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 900px;
  margin: 0 auto;
}
.diagram {
  background: var(--dark-bg-2);
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius-lg);
  padding: 32px;
}
.diagram__title {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--dark-muted-2);
  margin-bottom: 24px;
}
.diagram__stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.diagram__row {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
  padding: 14px 16px;
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.03);
}
.diagram__row span {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--dark-border-2);
  border-radius: 4px;
  color: var(--dark-text);
  white-space: nowrap;
}
.diagram__row--top span {
  color: var(--dark-muted);
}
.diagram__row--api {
  border-color: rgba(150,98,46,0.3);
  background: rgba(150,98,46,0.06);
}
.diagram__row--api span {
  border-color: rgba(150,98,46,0.3);
  background: rgba(150,98,46,0.1);
  color: #C98B4E;
}
.diagram__row--orch {
  border-color: rgba(192,134,63,0.3);
  background: rgba(192,134,63,0.05);
}
.diagram__row--orch span {
  border-color: rgba(192,134,63,0.3);
  background: rgba(192,134,63,0.1);
  color: var(--accent-amber);
}
.diagram__row--core {
  border-color: rgba(163,94,39,0.3);
  background: rgba(163,94,39,0.05);
}
.diagram__row--core span {
  border-color: rgba(163,94,39,0.3);
  background: rgba(163,94,39,0.1);
  color: var(--accent-soft);
}
.diagram__row--targets span {
  color: var(--dark-muted);
  font-size: 10px;
}
.diagram__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  color: var(--dark-muted-2);
  font-size: 16px;
}
.diagram__modes {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.diagram__mode {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.03);
}
.diagram__mode-label {
  font-size: 13px;
  color: var(--dark-muted);
  flex: 1;
}
.diagram__mode-arrow {
  color: var(--dark-muted-2);
  font-family: var(--font-mono);
  font-size: 14px;
}
.diagram__mode-value {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 4px 10px;
  background: rgba(163,94,39,0.1);
  border: 1px solid rgba(163,94,39,0.3);
  border-radius: 5px;
  color: var(--accent-soft);
}
.diagram__mode-value--cloud {
  background: rgba(150,98,46,0.1);
  border-color: rgba(150,98,46,0.3);
  color: #C98B4E;
}
.diagram__mode-value--enterprise {
  background: rgba(192,134,63,0.1);
  border-color: rgba(192,134,63,0.3);
  color: var(--accent-amber);
}

/* ============== ECOSYSTEM ============== */
.ecosystem__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.ecosystem__tool {
  background: var(--cream);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px;
}
.ecosystem__tool h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
}
.ecosystem__tool p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

/* ============== EMSCRIPTEN COMPARISON ============== */
.comparison__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 32px;
}
.comparison__col {
  background: rgba(240, 244, 250, 0.6);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.comparison__col--celoce {
  background: var(--ink);
  color: var(--dark-text);
  border-color: rgba(38, 66, 112, 0.6);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.comparison__col-title {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.comparison__col--celoce .comparison__col-title {
  border-bottom-color: var(--dark-border-2);
}
.comparison__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.comparison__list li {
  position: relative;
  padding-left: 20px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--muted);
}
.comparison__col--celoce .comparison__list li {
  color: var(--dark-muted);
}
.comparison__list li::before {
  content: "\2022";
  position: absolute;
  left: 2px;
  color: var(--muted-2);
  font-size: 16px;
  line-height: 1.3;
}
.comparison__col--celoce .comparison__list li::before {
  content: "\2713";
  color: var(--accent);
  font-size: 13px;
  font-weight: 600;
}
.comparison__note {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.55;
  max-width: 680px;
  padding: 20px 24px;
  background: rgba(240, 244, 250, 0.6);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent-blue);
}
.comparison__note p {
  margin: 0;
}

/* ============== CLOUD CONTENT ============== */
.cloud__content {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 32px;
  align-items: start;
}
.cloud__why {
  padding: 28px;
  background: rgba(240, 244, 250, 0.6);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.cloud__why h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 12px;
}
.cloud__why p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 16px;
}
.cloud__why-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.cloud__why-list li {
  position: relative;
  padding-left: 20px;
  font-size: 14px;
  color: var(--ink);
  line-height: 1.45;
}
.cloud__why-list li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 12px;
}

/* ============== ENTERPRISE CONTENT ============== */
.enterprise__position {
  max-width: 760px;
  margin-top: 24px;
  padding: 20px 24px;
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent-amber);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.enterprise__position p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

/* ============== DEPLOYMENT MODES ============== */
.deployment__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 900px;
  margin: 0 auto;
}
.deployment__mode {
  background: var(--dark-bg-2);
  border: 1px solid var(--dark-border-2);
  border-radius: var(--radius-lg);
  padding: 28px;
  text-align: center;
  transition: border-color .2s ease;
}
.deployment__mode:hover { border-color: rgba(255,255,255,0.15); }
.deployment__mode--featured {
  border-color: rgba(150,98,46,0.35);
  background: rgba(150,98,46,0.06);
}
.deployment__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(255,255,255,0.06);
  color: var(--dark-text);
  margin-bottom: 18px;
  border: 1px solid var(--dark-border-2);
}
.deployment__icon svg { width: 22px; height: 22px; }
.deployment__mode h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 10px;
  color: var(--dark-text);
}
.deployment__mode p {
  font-size: 14px;
  color: var(--dark-muted);
  line-height: 1.55;
  margin: 0 0 20px;
}
.deployment__product {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 5px 10px;
  border-radius: 5px;
  background: rgba(163,94,39,0.12);
  color: var(--accent);
  border: 1px solid rgba(163,94,39,0.3);
}
.deployment__product--cloud {
  background: rgba(150,98,46,0.12);
  color: #C98B4E;
  border-color: rgba(150,98,46,0.3);
}
.deployment__product--enterprise {
  background: rgba(192,134,63,0.1);
  color: var(--accent-amber);
  border-color: rgba(192,134,63,0.3);
}

/* ============== LIMITATIONS ============== */
.limitations__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.limitations__grid .limitation:last-child {
  grid-column: span 1;
}
.limitation {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.limitation h3 {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 0 0 8px;
}
.limitation p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

/* ============== PRICING ============== */
.pricing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.pricing__tier {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 32px;
  display: flex;
  flex-direction: column;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: border-color .2s ease, background .2s ease;
}
.pricing__tier:hover { border-color: var(--border-strong); background: rgba(255, 255, 255, 0.9); }
.pricing__tier--featured:hover { background: var(--ink-2); border-color: rgba(38, 66, 112, 0.9); }
.pricing__tier--featured {
  background: var(--ink);
  color: var(--dark-text);
  border-color: rgba(38, 66, 112, 0.6);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.pricing__tier-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.pricing__tier-head h3 {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin: 0;
}
.pricing__tier-price {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--muted);
}
.pricing__tier--featured .pricing__tier-price {
  color: var(--dark-muted);
}
.pricing__tier-desc {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0 0 24px;
}
.pricing__tier--featured .pricing__tier-desc {
  color: var(--dark-muted);
}
.pricing__tier-features {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.pricing__tier-features li {
  position: relative;
  padding-left: 22px;
  font-size: 14px;
}
.pricing__tier-features li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
}
.pricing__tier--featured .pricing__tier-features li::before {
  color: var(--accent);
}
.pricing__tier .btn {
  width: 100%;
  justify-content: center;
}
.pricing__tier--featured .btn--primary {
  background: #fff;
  color: var(--ink);
  border-color: #fff;
}
.pricing__tier--featured .btn--primary:hover {
  background: var(--cream);
  border-color: var(--cream);
}

/* ============== FAQ ============== */
.faq__grid {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.faq__item {
  border-bottom: 1px solid var(--border);
}
.faq__item:first-child {
  border-top: 1px solid var(--border);
}
.faq__q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.01em;
  cursor: pointer;
  list-style: none;
  color: var(--ink);
  transition: color .15s ease;
}
.faq__q:hover { color: var(--accent-deep); }
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after {
  content: "+";
  font-family: var(--font-mono);
  font-size: 18px;
  color: var(--muted-2);
  flex-shrink: 0;
  margin-left: 16px;
  transition: transform .2s ease;
}
.faq__item[open] .faq__q::after {
  content: "\2212";
}
.faq__a {
  padding: 0 0 20px;
}
.faq__a p {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0 0 12px;
}
.faq__a p:last-child {
  margin-bottom: 0;
}
.faq__a a {
  color: var(--accent-blue);
  text-decoration: underline;
  text-decoration-color: rgba(150,98,46,0.3);
  text-underline-offset: 2px;
}
.faq__a a:hover {
  text-decoration-color: var(--accent-blue);
}
.faq__a code {
  font-size: 13px;
  padding: 2px 6px;
  background: var(--cream-2);
  border-radius: 4px;
  border: 1px solid var(--border);
}

/* ============== ROADMAP ============== */
.roadmap__track {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}
.rm-col {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.rm-col--done {
  background: rgba(240, 244, 250, 0.65);
}
.rm-col--now {
  background: var(--ink);
  color: var(--dark-text);
  border-color: rgba(38, 66, 112, 0.6);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.rm-col__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.rm-col__tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(228, 234, 244, 0.6);
  color: var(--muted);
}
.rm-col__tag--now {
  background: rgba(163,94,39,0.14);
  color: var(--accent);
  border: 1px solid rgba(163,94,39,0.3);
}
.rm-col--now .rm-col__tag--now { background: rgba(163,94,39,0.18); }
.rm-col__tag--soon {
  background: rgba(150,98,46,0.1);
  color: var(--accent-blue);
  border: 1px solid rgba(150,98,46,0.2);
}
.rm-col__date {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted-2);
}
.rm-col--now .rm-col__date { color: var(--dark-muted); }
.rm-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rm-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14.5px;
  line-height: 1.5;
}
.rm-check {
  color: var(--accent-deep);
  font-weight: 600;
  flex-shrink: 0;
  width: 16px;
  text-align: center;
}
.rm-col--now .rm-check { color: var(--accent); }
.rm-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  margin-top: 9px;
  flex-shrink: 0;
}
.rm-dot--soon { background: var(--muted-2); }

/* ============== VISION CTA ============== */
.vision-cta {
  background: var(--dark-bg);
  color: var(--dark-text);
  padding: clamp(80px, 10vw, 140px) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.vision-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 50%, rgba(163,94,39, 0.07), transparent 70%),
    radial-gradient(ellipse 40% 40% at 30% 60%, rgba(150,98,46, 0.05), transparent 60%);
  pointer-events: none;
}
.vision-cta > .container { position: relative; z-index: 1; }
.vision-cta__title {
  font-size: clamp(32px, 4.5vw, 56px);
  font-weight: 500;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 20px;
}
.vision-cta__sub {
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--dark-muted);
  max-width: 640px;
  margin: 0 auto 36px;
  line-height: 1.55;
}
.vision-cta__actions {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.vision-cta .btn--primary {
  background: #fff;
  color: var(--ink);
  border-color: #fff;
}
.vision-cta .btn--primary:hover {
  background: var(--cream);
  border-color: var(--cream);
}

/* ============== FOOTER ============== */
.footer {
  background: var(--paper);
  padding-top: 64px;
}
.footer__inner {
  display: grid;
  grid-template-columns: 1.3fr 2fr;
  gap: 60px;
  padding-bottom: 56px;
}
.footer__brand {
  display: flex;
  flex-direction: column;
}
.footer__brand .nav__logo { width: 28px; height: 28px; color: var(--ink); }
.footer__brand .nav__wordmark { font-size: 20px; }
.footer__brand .nav__logo, .footer__brand .nav__wordmark { margin-bottom: 4px; }
.footer__brand { gap: 0; }
.footer__brand > .nav__logo { display: inline-block; }
.footer__brand > .nav__wordmark { display: inline-block; }
.footer__tag {
  font-size: 14px;
  color: var(--muted);
  margin: 16px 0 0;
  max-width: 280px;
  line-height: 1.5;
}
.footer__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}
.footer__col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer__col-head {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--muted-2);
  margin-bottom: 8px;
}
.footer__col a {
  font-size: 14.5px;
  color: var(--ink);
  transition: color .15s ease;
}
.footer__col a:hover { color: var(--accent-deep); }
.footer__base {
  border-top: 1px solid var(--border);
  padding: 20px 0;
}
.footer__base-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 13px;
  color: var(--muted);
  font-family: var(--font-mono);
}
.footer__legal { color: var(--muted-2); }

/* ============== TEAM ============== */
.team__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 960px;
  margin: 0 auto;
}
.team__card {
  position: relative;
  background: linear-gradient(168deg, #FDFAF3 0%, #F5EEDF 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 30px 30px;
  text-align: center;
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 16px 40px -30px rgba(58,34,12,0.5);
  transition: transform .25s ease, border-color .2s ease, box-shadow .2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.team__card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), transparent 85%);
}
.team__card:hover {
  transform: translateY(-3px);
  border-color: var(--accent);
  box-shadow: 0 1px 0 rgba(255,255,255,0.8) inset, 0 22px 48px -26px var(--accent-glow, rgba(163,94,39,0.28));
}
.team__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(150,98,46, 0.08);
  border: 1px solid rgba(150,98,46, 0.18);
  color: var(--accent-blue);
  margin-bottom: 20px;
}
.team__avatar svg { width: 48px; height: 48px; }
.team__role-badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  padding: 5px 10px;
  border-radius: 5px;
  font-weight: 500;
  text-transform: uppercase;
  background: rgba(163,94,39, 0.12);
  color: var(--accent-deep);
  border: 1px solid rgba(163,94,39, 0.3);
  margin-bottom: 14px;
}
.team__role-badge--blue {
  background: rgba(150,98,46, 0.12);
  color: var(--accent-blue);
  border-color: rgba(150,98,46, 0.3);
}
.team__role-badge--amber {
  background: rgba(192,134,63, 0.12);
  color: #B5793C;
  border-color: rgba(192,134,63, 0.3);
}
.team__photo {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto 18px;
  border: 3px solid rgba(163,94,39,0.30);
  box-shadow: 0 0 0 6px rgba(163,94,39,0.06);
  flex-shrink: 0;
}
.team__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.team__card h3 {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 0 0 12px;
}
.team__bio {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.5;
  margin: 0 0 16px;
}
.team__bio-extended {
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.65;
  margin: 0 0 18px;
  text-align: left;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  width: 100%;
}
.team__card p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}
.team__university-logo {
  margin: 0 0 16px;
  padding: 12px 0;
  width: 100%;
  display: flex;
  justify-content: center;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.team__university-logo img {
  height: 44px;
  width: auto;
  object-fit: contain;
  opacity: 0.65;
  filter: saturate(0.85);
  transition: opacity .25s ease, filter .25s ease;
}
.team__card:hover .team__university-logo img {
  opacity: 1;
  filter: saturate(1);
}
.team__credentials {
  list-style: none;
  margin: 0 0 18px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  flex: 1;
  width: 100%;
}
.team__credentials li {
  position: relative;
  padding-left: 20px;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.45;
}
.team__credentials li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--accent-deep);
  font-weight: 600;
  font-size: 11px;
}
.team__credentials a {
  color: var(--accent-deep);
  text-decoration: underline;
  text-decoration-color: rgba(119,65,20, 0.3);
  text-underline-offset: 2px;
}
.team__credentials a:hover {
  text-decoration-color: var(--accent-deep);
}
.team__links {
  display: flex;
  gap: 12px;
  justify-content: center;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  margin-top: auto;
  width: 100%;
}
.team__links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  color: var(--muted);
  border: 1px solid var(--border);
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.team__links a:hover {
  color: var(--ink);
  border-color: var(--border-strong);
  background: var(--cream);
}
.team__links svg {
  width: 18px;
  height: 18px;
}

/* ============== RESPONSIVE ============== */
@media (max-width: 1024px) {
  .nav__cta { display: none; }
  .nav__links { gap: 16px; font-size: 14px; }
  .section-head--horizontal { flex-direction: column; gap: 16px; }
  .section-head--horizontal .section-head__sub { padding-top: 0; }
  .problem__grid { grid-template-columns: 1fr 1fr; }
  .workarounds__grid { grid-template-columns: 1fr 1fr; }
  .why__diagram--horizontal { flex-direction: column; max-width: 560px; margin: 0 auto; }
  .why__diagram-arrow--horizontal { width: auto; height: 36px; }
  .why__diagram-arrow--horizontal svg { width: 24px; height: 32px; transform: rotate(90deg); }
  .workloads__grid { grid-template-columns: 1fr 1fr; }
  .comparison__grid { grid-template-columns: 1fr; }
  .limitations__grid { grid-template-columns: 1fr; }
  .pricing__grid { grid-template-columns: 1fr; }
  .roadmap__track { grid-template-columns: 1fr; }
  .why__content { grid-template-columns: 1fr; gap: 32px; }
  .arch__features { grid-template-columns: 1fr; }
  .proof__stats { grid-template-columns: repeat(2, 1fr); }
  .proof__users-row { grid-template-columns: repeat(2, 1fr); }
  .footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .extensions__grid { grid-template-columns: 1fr; }
  .diagrams { grid-template-columns: 1fr; }
  .ecosystem__grid { grid-template-columns: 1fr; }
  .cloud__content { grid-template-columns: 1fr; }
  .deployment__grid { grid-template-columns: 1fr; }
  .delivery__grid { grid-template-columns: 1fr; }
  .arch__grid { grid-template-columns: 1fr; }
  .team__grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .nav__links { gap: 12px; font-size: 13px; }
  .workloads__grid { grid-template-columns: 1fr; }
  .problem__grid { grid-template-columns: 1fr; }
  .workarounds__grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .hero__meta { flex-direction: column; align-items: center; gap: 8px; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
  .nav__links { gap: 8px; font-size: 12px; flex-wrap: wrap; }
  .proof__users-row { grid-template-columns: 1fr 1fr; }
  .proof__stats { grid-template-columns: 1fr 1fr; }
  .arch__layer-links { flex-direction: column; }
}

/* ============== 23 May v2 patch ============== */

/* Hero legacy box */
.hero__legacy {
  max-width: 560px;
  margin: 0 auto 28px;
  padding: 12px 16px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--dark-muted);
  line-height: 1.55;
  text-align: center;
}
.hero__legacy strong {
  color: var(--dark-text);
}

/* Why interop block */
.why__interop {
  max-width: 760px;
  margin: 48px auto 0;
  text-align: center;
  color: var(--dark-text);
}
.why__interop-title {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}
.why__interop-sub {
  font-size: 15px;
  color: var(--dark-muted);
  line-height: 1.6;
  margin: 0 0 20px;
}
.why__interop-sub code {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 13px;
  color: var(--accent);
}
.why__interop-code {
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 16px 20px;
  font-family: var(--font-mono);
  font-size: 13px;
  overflow-x: auto;
  white-space: pre;
  text-align: left;
  margin: 0;
  color: var(--dark-muted);
  border: 1px solid rgba(255,255,255,0.08);
}
.why__interop-code code {
  font-family: inherit;
  font-size: inherit;
  color: inherit;
}

/* Proof side-by-side layout */
.proof__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 28px;
  align-items: stretch;
}
.proof__layout .proof__card { margin: 0; }
.proof__layout .proof__users {
  margin: 0;
  padding: 24px;
  background: var(--bg-alt, #f6f7f9);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 16px;
  display: flex;
  flex-direction: column;
}
.proof__layout .proof__users-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}
.proof__layout .proof__users-row .logo-ph {
  display: block;
  padding: 8px 12px;
}
@media (max-width: 1100px) {
  .proof__layout .proof__stats {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 900px) {
  .proof__layout { grid-template-columns: 1fr; }
  .proof__layout .proof__users-row { flex-direction: row; flex-wrap: wrap; }
}

/* ============== HUB PAGE ============== */

/* Metric cards */
.hub-metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.hub-metric {
  background: rgba(240, 244, 250, 0.65);
  border: 1px solid rgba(203, 213, 232, 0.6);
  border-radius: var(--radius-lg);
  padding: 28px;
  text-align: center;
  transition: border-color .2s ease, background .2s ease;
}
.hub-metric:hover {
  border-color: var(--border-strong);
  background: rgba(240, 244, 250, 0.85);
}
.hub-metric__num {
  font-size: 48px;
  font-weight: 600;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 6px;
  color: var(--ink);
  font-feature-settings: "tnum";
}
.hub-metric__label {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--accent-deep);
  letter-spacing: 0.02em;
  margin-bottom: 12px;
  font-weight: 500;
}
.hub-metric__desc {
  font-size: 13.5px;
  color: var(--muted);
  line-height: 1.5;
}

/* Hub tables */
.hub-table-wrap {
  max-width: 900px;
  margin: 0 auto;
  overflow-x: auto;
}
.hub-table-wrap--dark {
  max-width: 800px;
}
.hub-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14.5px;
}
.hub-table th {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
  text-align: left;
  padding: 12px 16px;
  border-bottom: 2px solid var(--border);
  font-weight: 500;
}
.hub-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
  line-height: 1.5;
  vertical-align: top;
}
.hub-table td strong {
  color: var(--ink);
  font-weight: 500;
}
.hub-table td:last-child {
  white-space: nowrap;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--accent-deep);
  font-weight: 500;
}
.hub-table--compact td:last-child {
  white-space: normal;
  font-family: var(--font-sans);
  font-size: 14.5px;
  color: var(--muted);
  font-weight: 400;
}
.hub-table td code {
  background: var(--cream-2);
  border: 1px solid var(--border);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 12px;
}
.hub-table tbody tr:hover {
  background: rgba(240, 244, 250, 0.5);
}

/* Dark table variant */
.hub-table--dark th {
  color: var(--dark-muted-2);
  border-bottom-color: var(--dark-border-2);
}
.hub-table--dark td {
  border-bottom-color: var(--dark-border);
  color: var(--dark-muted);
}
.hub-table--dark td strong {
  color: var(--dark-text);
}
.hub-table--dark td:last-child {
  color: var(--accent);
}
.hub-table--dark.hub-table--compact td:last-child {
  color: var(--dark-muted);
}
.hub-table--dark tbody tr:hover {
  background: rgba(255, 255, 255, 0.03);
}

/* Library catalog grid */
.hub-catalog {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  max-width: 960px;
  margin: 0 auto;
}
.hub-catalog__item {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius);
  padding: 18px 20px;
  transition: border-color .2s ease, background .2s ease;
}
.hub-catalog__item:hover {
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.9);
}
.hub-catalog__item--community {
  border-color: rgba(163,94,39, 0.35);
  background: rgba(163,94,39, 0.06);
}
.hub-catalog__item--community:hover {
  border-color: rgba(163,94,39, 0.5);
  background: rgba(163,94,39, 0.1);
}
.hub-catalog__name {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 4px;
}
.hub-catalog__cat {
  font-size: 12.5px;
  color: var(--muted);
}

/* Community growth cards */
.hub-growth {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}
.hub-growth__card {
  background: rgba(240, 244, 250, 0.65);
  border: 1px solid rgba(203, 213, 232, 0.6);
  border-radius: var(--radius-lg);
  padding: 28px;
  transition: border-color .2s ease, background .2s ease;
}
.hub-growth__card:hover {
  border-color: var(--border-strong);
  background: rgba(240, 244, 250, 0.85);
}
.hub-growth__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 9px;
  background: rgba(163,94,39, 0.1);
  color: var(--accent-deep);
  margin-bottom: 18px;
  border: 1px solid rgba(163,94,39, 0.2);
}
.hub-growth__icon svg { width: 20px; height: 20px; }
.hub-growth__card h3 {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.015em;
  margin: 0 0 8px;
}
.hub-growth__card p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.55;
  margin: 0;
}

/* Potential callout */
.hub-potential {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding: 28px 32px;
  background: rgba(163,94,39, 0.06);
  border: 1px solid rgba(163,94,39, 0.2);
  border-radius: var(--radius-lg);
}
.hub-potential p {
  font-size: clamp(16px, 1.3vw, 18px);
  color: var(--dark-muted);
  line-height: 1.6;
  margin: 0;
}
.hub-potential strong {
  color: var(--accent-soft);
}

/* Notice banner */
.hub-notice {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: rgba(192,134,63, 0.1);
  border: 1px solid rgba(192,134,63, 0.3);
  border-radius: 8px;
  font-size: 13px;
  color: #B5793C;
  margin: 0 auto var(--space-2xl);
  display: flex;
  justify-content: center;
  max-width: 400px;
}

/* Horizon grid */
.hub-horizon {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  max-width: 960px;
  margin: 0 auto;
}
.hub-horizon__item {
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(203, 213, 232, 0.5);
  border-radius: var(--radius);
  padding: 18px 20px;
  transition: border-color .2s ease, background .2s ease;
}
.hub-horizon__item:hover {
  border-color: var(--border-strong);
  background: rgba(255, 255, 255, 0.9);
}
.hub-horizon__name {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 4px;
}
.hub-horizon__use {
  font-size: 12.5px;
  color: var(--muted);
}

/* Hub announcement */
.hub-announcement {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  padding: 36px 40px;
  background: rgba(163,94,39, 0.06);
  border: 1px solid rgba(163,94,39, 0.2);
  border-radius: var(--radius-lg);
  position: relative;
}
.hub-announcement__badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 5px 14px;
  border-radius: 6px;
  background: rgba(255, 90, 60, 0.15);
  color: #FF6B4A;
  border: 1px solid rgba(255, 90, 60, 0.35);
  margin-bottom: 20px;
  text-transform: uppercase;
}
.hub-announcement__title {
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--dark-text);
  margin: 0 0 16px;
}
.hub-announcement__desc {
  font-size: 15px;
  color: var(--dark-muted);
  line-height: 1.6;
  margin: 0;
}
.hub-announcement__desc strong {
  color: var(--accent-soft);
}

/* Hub responsive */
@media (max-width: 1024px) {
  .hub-metrics { grid-template-columns: repeat(2, 1fr); }
  .hub-growth { grid-template-columns: repeat(2, 1fr); }
  .hub-horizon { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .hub-metrics { grid-template-columns: 1fr; }
  .hub-growth { grid-template-columns: 1fr; }
  .hub-horizon { grid-template-columns: repeat(2, 1fr); }
  .hub-catalog { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .hub-horizon { grid-template-columns: 1fr; }
  .hub-catalog { grid-template-columns: 1fr; }
}
