:root {
  --ink: #101820;
  --navy: #0a0f3c;
  --blue: #1f7fff;
  --cyan: #00a6a6;
  --green: #17a673;
  --violet: #7a5cff;
  --amber: #f8c14a;
  --coral: #ff674d;
  --rose: #ff674d;
  --line: #dbe6f2;
  --muted: #64748b;
  --paper: #f7f9fc;
  --white: #fff;
  --shadow: 0 18px 46px rgba(16, 24, 32, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
a { color: inherit; }
img { max-width: 100%; }
h1, h2, h3, p { letter-spacing: 0; }
h1 { margin: 0; max-width: 900px; font-size: clamp(42px, 6.4vw, 76px); line-height: .98; }
h2 { margin: 0; max-width: 860px; font-size: clamp(30px, 4vw, 50px); line-height: 1.05; }
h3 { margin: 0; font-size: 20px; line-height: 1.2; }
p { margin: 0; color: var(--muted); line-height: 1.62; }
ul { margin: 0; padding-left: 20px; }
li { margin: 8px 0; color: var(--muted); line-height: 1.45; }
button, input, select, textarea { font: inherit; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  min-height: 72px;
  padding: 14px clamp(18px, 5vw, 72px);
  border-bottom: 1px solid rgba(219, 230, 242, .86);
  background: rgba(255, 255, 255, .94);
  backdrop-filter: blur(16px);
}
.brand img { display: block; width: 148px; }
nav { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 12px 18px; color: #526174; font-size: 14px; font-weight: 850; }
nav a { text-decoration: none; white-space: nowrap; }
.nav-portal {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border: 1px solid rgba(31, 127, 255, .22);
  border-radius: 8px;
  color: var(--navy);
  background: #eef7ff;
}
.nav-cta {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 13px;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}

.hero {
  position: relative;
  min-height: clamp(560px, 82svh, 760px);
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: clamp(44px, 7vw, 92px) clamp(18px, 5vw, 72px);
  color: var(--white);
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .86) 36%, rgba(5, 11, 31, .42) 68%, rgba(5, 11, 31, .1) 100%),
    url("/assets/vonics-ai-voice-routing.jpg");
  background-position: center;
  background-size: cover;
}
.hero::after, .vertical-hero::after {
  content: "";
  position: absolute;
  z-index: 0;
  right: clamp(22px, 5vw, 70px);
  bottom: clamp(22px, 5vw, 58px);
  width: clamp(76px, 8vw, 118px);
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .62);
  border-radius: 24px;
  background:
    rgba(255, 255, 255, .9)
    url("/brand/logos/vonics-mark.svg") center / 70% no-repeat;
  box-shadow: 0 22px 54px rgba(6, 19, 35, .26);
  backdrop-filter: blur(12px);
  pointer-events: none;
}
.hero-copy { position: relative; z-index: 1; width: min(820px, 100%); }
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  color: var(--cyan);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.hero .kicker { color: #72f0ec; }
.hero p:not(.kicker) { max-width: 710px; margin-top: 18px; color: #e7f2ff; font-size: 19px; }
.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.primary, .secondary, .plan-action {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 18px;
  border: 0;
  border-radius: 8px;
  font-weight: 950;
  text-decoration: none;
  cursor: pointer;
  text-align: center;
}
.primary, .plan-action { color: #041522; background: var(--amber); }
.secondary { color: var(--white); border: 1px solid rgba(255, 255, 255, .36); background: rgba(255, 255, 255, .1); }
.hero-points { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 24px; }
.hero-points span {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: 8px;
  color: #eef7ff;
  background: rgba(255, 255, 255, .08);
  font-weight: 850;
}

.proof-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  padding: 18px clamp(18px, 5vw, 72px);
  border-bottom: 1px solid var(--line);
  background: var(--white);
}
.proof-strip span {
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  font-weight: 900;
}

.section { padding: 76px clamp(18px, 5vw, 72px); }
.intro { max-width: 900px; margin-bottom: 28px; }
.intro p:not(.kicker) { max-width: 760px; margin-top: 14px; font-size: 17px; }
.intro.compact { margin-bottom: 22px; }

.platform { background: var(--white); }
.platform-grid, .offer-grid, .use-case-grid, .pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.platform-grid article, .offer-grid article, .use-case-grid article, .pricing-grid article, .panel, .lead-form, .legal-card, .legal-summary {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--white);
  box-shadow: var(--shadow);
}
.platform-grid article, .offer-grid article, .use-case-grid article, .pricing-grid article {
  display: grid;
  align-content: start;
  gap: 13px;
  min-height: 210px;
  padding: 20px;
}
.platform-grid img { width: 46px; height: 46px; }

.offer-band {
  color: #fff;
  background: linear-gradient(135deg, #061323, #0a0f3c);
}
.offer-band p { color: #d8e3ef; }
.offer-band .kicker { color: #72f0ec; }
.offer-grid article {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
  box-shadow: none;
}
.offer-grid b {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}
.offer-grid p { color: #d8e3ef; }

.vertical-sites { background: var(--white); }
.vertical-site-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
}
.vertical-site-grid a {
  position: relative;
  min-width: 0;
  display: grid;
  gap: 12px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  background: #fbfdff;
  box-shadow: var(--shadow);
  text-decoration: none;
}
.vertical-site-grid a::after {
  content: "";
  position: absolute;
  top: 14px;
  right: 14px;
  width: 56px;
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .66);
  border-radius: 16px;
  background:
    rgba(255, 255, 255, .9)
    url("/brand/logos/vonics-mark.svg") center / 72% no-repeat;
  box-shadow: 0 16px 34px rgba(6, 19, 35, .16);
  pointer-events: none;
}
.vertical-site-grid img {
  width: 100%;
  aspect-ratio: 16 / 7;
  object-fit: cover;
  object-position: center;
}
.vertical-site-grid span {
  width: fit-content;
  margin: 2px 16px 0;
  padding: 7px 10px;
  border-radius: 999px;
  color: #041522;
  background: var(--amber);
  font-size: 13px;
  font-weight: 950;
}
.vertical-site-grid strong {
  padding: 0 16px;
  color: var(--ink);
  font-size: 24px;
  line-height: 1.12;
}
.vertical-site-grid em {
  padding: 0 16px 18px;
  color: var(--muted);
  font-style: normal;
  line-height: 1.45;
}

.teams-routing { background: #f7f9fc; }
.teams-routing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, .8fr);
  gap: 20px;
  align-items: stretch;
}
.teams-brand-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: -12px 0 20px;
}
.teams-brand-row span {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  border: 1px solid #d8defa;
  border-radius: 999px;
  color: #333580;
  background: #fff;
  font-weight: 850;
  box-shadow: 0 12px 30px rgba(56, 62, 150, .09);
}
.teams-brand-row img, .teams-node-title img, .teams-visual-card figcaption img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}
.teams-routing-main {
  display: grid;
  gap: 16px;
}
.teams-routing-map, .teams-price-card, .teams-visual-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.teams-visual-card {
  position: relative;
  margin: 0;
  overflow: hidden;
  min-height: 330px;
  background: #f8fbff;
}
.teams-visual-card::after {
  content: "";
  position: absolute;
  top: 18px;
  right: 18px;
  width: 64px;
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .7);
  border-radius: 18px;
  background:
    rgba(255, 255, 255, .92)
    url("/brand/logos/vonics-mark.svg") center / 72% no-repeat;
  box-shadow: 0 16px 34px rgba(27, 42, 88, .16);
  pointer-events: none;
}
.teams-visual-card > img {
  width: 100%;
  height: 100%;
  min-height: 330px;
  object-fit: cover;
  display: block;
}
.teams-visual-card figcaption {
  position: absolute;
  left: 18px;
  bottom: 18px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  max-width: calc(100% - 36px);
  padding: 10px 14px;
  border: 1px solid rgba(98, 100, 167, .22);
  border-radius: 999px;
  color: #292a6c;
  background: rgba(255, 255, 255, .88);
  font-weight: 900;
  box-shadow: 0 16px 36px rgba(27, 42, 88, .13);
  backdrop-filter: blur(10px);
}
.teams-routing-map {
  display: grid;
  grid-template-columns: minmax(170px, 1fr) 54px minmax(190px, 1fr) 54px minmax(170px, 1fr);
  gap: 10px;
  align-items: center;
  padding: 22px;
  overflow: hidden;
}
.teams-node {
  min-height: 210px;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid #cbd9ea;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #edf6ff);
}
.teams-node-title {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.teams-node b { color: var(--ink); font-size: 20px; }
.teams-node span, .teams-outcomes span, .teams-price-card small { color: var(--muted); line-height: 1.45; }
.teams-node-title b { color: var(--ink); }
.teams-app { border-color: #bae6fd; }
.teams-edge { border-color: #bbf7d0; background: linear-gradient(180deg, #fff, #ecfdf5); animation: edgeGlow 3.4s ease-in-out infinite; }
.teams-carrier { border-color: #fed7aa; background: linear-gradient(180deg, #fff, #fff7ed); }
.teams-link { height: 6px; position: relative; border-radius: 999px; background: #dbe6f2; overflow: hidden; }
.teams-link span { position: absolute; inset: 0; width: 48%; border-radius: 999px; background: linear-gradient(90deg, transparent, var(--cyan), var(--green)); animation: dataFlow 1.9s linear infinite; }
.teams-outcomes {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.teams-outcomes article {
  display: grid;
  gap: 6px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fbfdff;
}
.teams-price-card {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 22px;
  border-color: rgba(31, 127, 255, .45);
}
.teams-price {
  font-size: clamp(46px, 7vw, 76px);
  font-weight: 950;
  line-height: .95;
  color: var(--ink);
}
.teams-price span { color: var(--muted); font-size: 18px; }
.teams-price-card .primary { margin-top: 4px; }
@keyframes edgeGlow { 0%,100% { border-color: #bbf7d0; transform: translateY(0); } 45% { border-color: var(--green); transform: translateY(-4px); } }

.playbooks { background: #eef4fb; }
.advisor {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: 20px;
  align-items: start;
}
.panel { padding: 22px; }
.selector-panel { display: grid; gap: 16px; }
.choices, .checks { display: grid; gap: 10px; }
.choices { grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); }
.checks { grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); }
.choice, .check {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  background: #fbfdff;
  cursor: pointer;
  text-align: left;
}
.choice { display: grid; gap: 7px; min-height: 124px; padding: 14px; }
.choice span { color: var(--muted); font-size: 13px; line-height: 1.38; }
.check { min-height: 44px; padding: 11px 12px; color: #526174; font-weight: 850; }
.choice.active, .check.active { border-color: var(--blue); background: #ecf5ff; box-shadow: inset 0 0 0 1px rgba(31, 127, 255, .22); }
.result-panel { position: sticky; top: 92px; display: grid; gap: 15px; }
.recommendations { display: grid; gap: 10px; margin: 4px 0; }
.recommendations div { display: grid; grid-template-columns: 22px minmax(0, 1fr); gap: 10px; }
.recommendations b {
  width: 10px;
  height: 10px;
  margin-top: 8px;
  border-radius: 50%;
  background: var(--green);
}

.connectors { background: var(--white); }
.connector-groups {
  display: grid;
  gap: 28px;
}
.connector-group {
  display: grid;
  gap: 14px;
}
.connector-group-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
}
.connector-group-head h3 { font-size: 24px; }
.connector-group-head span {
  max-width: 520px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.45;
}
.connector-logo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(245px, 1fr));
  gap: 16px;
}
.connector-logo-grid article {
  position: relative;
  min-height: 226px;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 48px 18px 18px;
  border: 1px solid #dce8f5;
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,255,.92)),
    radial-gradient(circle at 18% 8%, rgba(31,127,255,.08), transparent 38%);
  box-shadow: 0 12px 30px rgba(15, 35, 58, .06);
  overflow: hidden;
}
.connector-logo-grid article::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  opacity: .72;
}
.connector-logo-grid article::after {
  position: absolute;
  top: 16px;
  right: 16px;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .01em;
  box-shadow: 0 8px 18px rgba(15, 35, 58, .08);
}
.connector-logo-grid article.supported::after {
  content: "Ready";
  color: #064e3b;
  background: #dcfce7;
}
.connector-logo-grid article.supported::before {
  background: linear-gradient(90deg, #22c55e, #0ea5e9);
}
.connector-logo-grid article.beta::after {
  content: "Beta";
  color: #075985;
  background: #e0f2fe;
}
.connector-logo-grid article.beta::before {
  background: linear-gradient(90deg, #0ea5e9, #8b5cf6);
}
.connector-logo-grid article.priority::after {
  content: "Priority";
  color: #78350f;
  background: #fef3c7;
}
.connector-logo-grid article.priority::before,
.connector-logo-grid article.planned::before {
  background: linear-gradient(90deg, #f59e0b, #ff5a45);
}
.connector-logo-grid article.planned::after {
  content: "Roadmap";
  color: #7c2d12;
  background: #ffedd5;
}
.connector-logo-grid b {
  width: 100%;
  min-width: 0;
  height: 84px;
  display: grid;
  place-items: center;
  overflow: hidden;
  box-sizing: border-box;
  padding: 14px 18px;
  margin-bottom: 2px;
  border: 1px solid #dce8f5;
  border-radius: 8px;
  background:
    linear-gradient(180deg, #fff, #f8fbff);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.9),
    0 14px 26px rgba(15, 35, 58, .10);
}
.connector-logo-grid b img {
  display: block;
  width: auto;
  height: auto;
  max-width: min(100%, 152px);
  max-height: 50px;
  object-fit: contain;
  object-position: center;
}
.connector-logo-grid b:has(img[src$="twilio.svg"]) img,
.connector-logo-grid b:has(img[src$="whatsapp.svg"]) img,
.connector-logo-grid b:has(img[src$="xero.svg"]) img,
.connector-logo-grid b:has(img[src$="google-cloud.svg"]) img,
.connector-logo-grid b:has(img[src$="aws.svg"]) img,
.connector-logo-grid b:has(img[src$="microsoft-azure.svg"]) img,
.connector-logo-grid b:has(img[src$="smpp.svg"]) img,
.connector-logo-grid b:has(img[src$="smtp.svg"]) img,
.connector-logo-grid b:has(img[src$="siprec.svg"]) img,
.connector-logo-grid b:has(img[src$="knowledge-packs.svg"]) img,
.connector-logo-grid b:has(img[src$="vonics-pay-icon.svg"]) img,
.connector-logo-grid b:has(img[src$="tradie-m8.svg"]) img,
.connector-logo-grid b:has(img[src$="bp-premier.svg"]) img,
.connector-logo-grid b:has(img[src$="sharepoint-knowledge.svg"]) img,
.connector-logo-grid b:has(img[src$="google-drive-knowledge.svg"]) img {
  max-height: 42px;
}
.connector-logo-grid b:has(img[src$="fergus.svg"]),
.connector-logo-grid b:has(img[src$="nookal.svg"]),
.connector-logo-grid b:has(img[src$="actionstep.svg"]) {
  border-color: rgba(7, 23, 53, .42);
  background: linear-gradient(135deg, #071735, #162942);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 14px 26px rgba(15, 35, 58, .16);
}
.connector-logo-grid b:has(img[src$="microsoft.svg"]) img,
.connector-logo-grid b:has(img[src$="webhook-api.svg"]) img,
.connector-logo-grid b:has(img[src$="leap-legal.svg"]) img {
  max-width: 116px;
  max-height: 48px;
}
.connector-logo-grid b.connector-logo-compact img {
  max-width: 116px;
  max-height: 48px;
}
.connector-logo-grid b.connector-logo-dark {
  border-color: rgba(7, 23, 53, .42);
  background: linear-gradient(135deg, #071735, #162942);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 14px 26px rgba(15, 35, 58, .16);
}
.connector-logo-grid strong {
  max-width: 100%;
  color: #111827;
  font-size: 17px;
  line-height: 1.18;
}
.connector-logo-grid span {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.35;
}
.connector-disclaimer {
  margin-top: 14px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}
.connector-pathways {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
  margin-top: 28px;
}
.connector-pathways a {
  display: grid;
  gap: 8px;
  min-height: 142px;
  padding: 18px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  color: var(--ink);
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: var(--shadow);
  text-decoration: none;
}
.connector-pathways a:nth-child(2) { border-left-color: var(--violet); }
.connector-pathways a:nth-child(3) { border-left-color: var(--green); }
.connector-pathways a:nth-child(4) { border-left-color: var(--amber); }
.connector-pathways span {
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  color: #041522;
  background: var(--amber);
  font-size: 12px;
  font-weight: 950;
}
.connector-pathways strong { font-size: 20px; line-height: 1.15; }
.connector-pathways em {
  color: var(--muted);
  font-style: normal;
  line-height: 1.42;
}

.resource-hero {
  position: relative;
  min-height: 480px;
  display: grid;
  align-items: end;
  overflow: hidden;
  padding: clamp(72px, 10vw, 118px) clamp(18px, 5vw, 72px);
  color: #fff;
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)),
    url("/assets/vonics-teams-phone-routing.jpg");
  background-position: center;
  background-size: cover;
}
.resource-hero.ai-hero { background-image: linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)), url("/assets/vonics-ai-voice-routing.jpg"); }
.resource-hero.tradies-hero { background-image: linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)), url("/assets/vonics-tradies-ai-calls.jpg"); }
.resource-hero.clinic-hero { background-image: linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)), url("/assets/vonics-clinic-ai-reception.jpg"); }
.resource-hero.helpdesk-hero { background-image: linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)), url("/assets/vonics-helpdesk-rag-support.jpg"); }
.resource-hero.telco-hero { background-image: linear-gradient(90deg, rgba(5, 11, 31, .94), rgba(5, 11, 31, .78) 46%, rgba(5, 11, 31, .24)), url("/assets/vonics-teams-phone-routing.jpg"); }
.resource-hero-copy {
  position: relative;
  z-index: 1;
  width: min(860px, 100%);
}
.resource-hero p:not(.kicker) {
  max-width: 720px;
  margin-top: 18px;
  color: #e7f2ff;
  font-size: 19px;
}
.resource-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .68fr);
  gap: 24px;
  align-items: start;
  background: #fff;
}
.resource-main {
  display: grid;
  gap: 18px;
}
.resource-card, .faq-card, .resource-side-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.resource-card {
  display: grid;
  gap: 14px;
  padding: 24px;
}
.resource-card h2 { font-size: clamp(26px, 3vw, 38px); }
.resource-card ul {
  display: grid;
  gap: 8px;
}
.resource-aside {
  position: sticky;
  top: 92px;
  display: grid;
  gap: 14px;
}
.resource-side-card {
  display: grid;
  gap: 12px;
  padding: 20px;
}
.resource-side-card a {
  color: var(--navy);
  font-weight: 950;
  text-decoration: none;
}
.resource-hub-grid, .faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.resource-hub-grid a {
  display: grid;
  align-content: start;
  gap: 10px;
  min-height: 212px;
  padding: 20px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  color: var(--ink);
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: var(--shadow);
  text-decoration: none;
}
.resource-hub-grid a:nth-child(2n) { border-left-color: var(--blue); }
.resource-hub-grid a:nth-child(3n) { border-left-color: var(--green); }
.resource-hub-grid span {
  width: fit-content;
  padding: 6px 9px;
  border-radius: 999px;
  color: #041522;
  background: var(--amber);
  font-size: 12px;
  font-weight: 950;
}
.resource-hub-grid strong { font-size: 22px; line-height: 1.18; }
.resource-hub-grid em {
  color: var(--muted);
  font-style: normal;
  line-height: 1.45;
}
.faq-section { background: #eef4fb; }
.faq-card {
  display: grid;
  gap: 10px;
  min-height: 182px;
  padding: 20px;
}
.faq-card h3 { font-size: 19px; }
.faq-card p { font-size: 15px; }

.use-cases { background: #f7f9fc; }
.use-case-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.use-case-grid article { min-height: 190px; }

.pitch-reels {
  color: #fff;
  background: #061323;
}
.pitch-reels .kicker { color: #72f0ec; }
.pitch-reels .intro p:not(.kicker) { color: #d8e3ef; }
.pitch-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.pitch-card {
  display: grid;
  align-content: start;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
  box-shadow: 0 22px 54px rgba(0, 0, 0, .22);
}
.pitch-stage {
  position: relative;
  min-height: 230px;
  overflow: hidden;
  background:
    linear-gradient(135deg, #edf6ff, #ffffff 54%, #ecfdf5);
}
.pitch-stage-scene {
  min-height: 250px;
  background: #edf6ff;
}
.pitch-stage-scene::before {
  display: none;
}
.pitch-scene-image {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgba(237, 246, 255, .14), rgba(255, 255, 255, 0) 42%),
    var(--scene-image);
  background-size: cover;
  background-position: center;
  transform: scale(1.03);
  transition: transform 8s ease;
}
.pitch-card.playing .pitch-scene-image {
  transform: scale(1.1) translateX(-1.5%);
}
.pitch-scene-card {
  position: absolute;
  max-width: 190px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 127, 255, .16);
  border-radius: 8px;
  color: #041522;
  background: rgba(255, 255, 255, .94);
  box-shadow: 0 16px 32px rgba(15, 35, 58, .14);
  font-size: 13px;
  font-weight: 950;
  line-height: 1.18;
}
.pitch-scene-call {
  left: 16px;
  top: 22px;
  transform: translateY(8px);
  opacity: .92;
}
.pitch-scene-action {
  right: 16px;
  bottom: 42px;
  transform: translateY(12px);
  opacity: .9;
}
.pitch-card.playing .pitch-scene-call {
  animation: sceneCardIn 1.5s ease both;
}
.pitch-card.playing .pitch-scene-action {
  animation: sceneCardIn 1.5s ease .9s both;
}
.pitch-scene-wave {
  position: absolute;
  left: 22%;
  right: 22%;
  top: 50%;
  height: 5px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(0, 166, 166, .2);
  box-shadow: 0 0 22px rgba(0, 166, 166, .2);
}
.pitch-scene-wave span {
  position: absolute;
  inset: 0;
  width: 42%;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--amber));
  animation: dataFlow 1.55s linear infinite;
}
.pitch-scene-dot {
  position: absolute;
  width: 14px;
  height: 14px;
  border: 3px solid #fff;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 20px rgba(0, 166, 166, .4);
}
.dot-one {
  left: 28%;
  top: 48%;
  animation: dotTravelOne 4s ease-in-out infinite;
}
.dot-two {
  right: 29%;
  top: 48%;
  animation: dotTravelTwo 4.2s ease-in-out infinite;
}
.pitch-scene-progress {
  --progress: 0%;
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 12px;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(6, 19, 35, .16);
}
.pitch-scene-progress::before {
  content: "";
  display: block;
  width: var(--progress);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--amber), var(--cyan));
  transition: width .15s linear;
}
.pitch-stage::before {
  content: "";
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 32px;
  height: 18px;
  border-radius: 999px;
  background: rgba(31, 127, 255, .12);
}
.pitch-stage-movie::before {
  display: none;
}
.pitch-character {
  position: absolute;
  right: 30px;
  bottom: 34px;
  width: 72px;
  height: 92px;
  border-radius: 30px 30px 18px 18px;
  background: linear-gradient(180deg, #1f7fff, #0a0f3c);
  animation: pitchFloat 3.5s ease-in-out infinite;
}
.pitch-character::before {
  content: "";
  position: absolute;
  left: 18px;
  top: -34px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #ffd7b5;
  box-shadow:
    -12px -8px 0 #4b2d1f,
    12px -8px 0 #4b2d1f,
    inset 0 -3px 0 rgba(6, 19, 35, .08);
}
.pitch-character::after {
  content: "";
  position: absolute;
  left: -18px;
  top: -18px;
  width: 92px;
  height: 36px;
  border: 5px solid #0a0f3c;
  border-left-color: transparent;
  border-bottom-color: transparent;
  border-radius: 50%;
  transform: rotate(-12deg);
}
.pitch-desk {
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 18px;
  height: 36px;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 26px rgba(15, 35, 58, .16);
}
.pitch-phone {
  position: absolute;
  left: 32px;
  bottom: 56px;
  width: 64px;
  height: 42px;
  border-radius: 12px;
  background: #0a0f3c;
  box-shadow: 0 10px 24px rgba(15, 35, 58, .2);
  animation: phoneRing 2.8s ease-in-out infinite;
}
.pitch-phone::before {
  content: "";
  position: absolute;
  inset: 9px 13px auto;
  height: 9px;
  border-radius: 999px;
  background: #72f0ec;
}
.pitch-bubble {
  position: absolute;
  left: 22px;
  top: 22px;
  max-width: 178px;
  padding: 10px 12px;
  border: 1px solid rgba(31, 127, 255, .14);
  border-radius: 16px;
  color: #0f172a;
  background: rgba(255, 255, 255, .92);
  box-shadow: 0 14px 30px rgba(15, 35, 58, .12);
  font-weight: 950;
  line-height: 1.15;
  animation: bubblePop 4s ease-in-out infinite;
}
.pitch-bubble.secondary-bubble {
  left: auto;
  right: 20px;
  top: 26px;
  background: #fff7ed;
  animation-delay: .45s;
}
.pitch-wave {
  position: absolute;
  left: 112px;
  right: 110px;
  top: 112px;
  height: 4px;
  border-radius: 999px;
  background: rgba(0, 166, 166, .16);
  overflow: hidden;
}
.pitch-wave span {
  position: absolute;
  inset: 0;
  width: 46%;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--blue));
  animation: dataFlow 1.7s linear infinite;
}
.pitch-tile {
  position: absolute;
  left: 92px;
  bottom: 82px;
  display: grid;
  place-items: center;
  width: 72px;
  height: 54px;
  border: 1px solid #dbe6f2;
  border-radius: 12px;
  color: #041522;
  background: #fff;
  font-size: 13px;
  font-weight: 950;
  box-shadow: 0 12px 24px rgba(15, 35, 58, .12);
  animation: pitchFloat 3.8s ease-in-out infinite;
}
.pitch-copy {
  display: grid;
  gap: 12px;
  padding: 18px;
}
.pitch-copy h3 {
  color: #fff;
  font-size: 23px;
}
.pitch-copy p {
  color: #d8e3ef;
}
.pitch-subtitles {
  display: grid;
  gap: 7px;
  min-height: 98px;
}
.pitch-subtitles span {
  padding: 9px 10px;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 8px;
  color: #d8e3ef;
  background: rgba(255, 255, 255, .06);
  font-size: 14px;
  line-height: 1.32;
  transition: color .2s ease, background .2s ease, transform .2s ease;
}
.pitch-subtitles span.active,
.pitch-card.playing .pitch-subtitles span.active {
  color: #041522;
  background: var(--amber);
  transform: translateX(3px);
}
.pitch-play {
  width: fit-content;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 10px 14px;
  border: 0;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
  font-weight: 950;
  cursor: pointer;
}
.pitch-play::before {
  content: "";
  width: 0;
  height: 0;
  border-block: 7px solid transparent;
  border-left: 11px solid #041522;
}
.pitch-card.playing .pitch-play::before {
  width: 12px;
  height: 12px;
  border: 0;
  background: #041522;
}
.pitch-card.playing .pitch-stage {
  background:
    linear-gradient(135deg, #f0f9ff, #ffffff 48%, #fff7ed);
}
.pricing { background: var(--white); }
.pricing-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.pricing-grid article { min-height: 350px; }
.pricing-grid .enterprise-plan { border-color: rgba(31, 127, 255, .45); background: #f4f9ff; }
.price { margin: 4px 0; font-size: 42px; font-weight: 950; line-height: 1; }
.price span { color: var(--muted); font-size: 16px; }
.plan-action { margin-top: auto; background: var(--cyan); }
.plan-secondary { margin-top: -4px; color: var(--ink); border-color: var(--line); background: #fff; }

.contact {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(340px, 1.08fr);
  gap: 24px;
  align-items: start;
  color: #fff;
  background: #061323;
}
.contact p { color: #d8e3ef; }
.contact .kicker { color: #72f0ec; }
.signup-copy { display: grid; align-content: start; gap: 16px; }
.signup-copy > p:not(.kicker) { max-width: 720px; font-size: 18px; }
.signup-highlights { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 10px; }
.signup-highlights article { min-height: 142px; display: grid; align-content: start; gap: 8px; padding: 16px; border: 1px solid rgba(255,255,255,.18); border-radius: 8px; background: rgba(255,255,255,.08); }
.signup-highlights strong { color: #fff; font-size: 15px; line-height: 1.25; }
.signup-highlights span { color: #d8e3ef; font-size: 14px; line-height: 1.45; }
.contact-notes { display: grid; gap: 10px; margin-top: 8px; }
.contact-notes span {
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 8px;
  color: #edf6ff;
  background: rgba(255, 255, 255, .08);
  font-weight: 850;
}
.lead-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 22px;
  color: var(--ink);
}
.lead-form label { display: grid; gap: 6px; color: var(--muted); font-size: 13px; font-weight: 850; }
.lead-form .wide, .lead-form button, .form-status { grid-column: 1 / -1; }
.lead-form input, .lead-form select, .lead-form textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 11px;
  color: var(--ink);
  background: #fff;
}
.lead-form textarea { min-height: 120px; resize: vertical; }
.consent-check { grid-template-columns: 20px 1fr; align-items: start; }
.consent-check input { width: 18px; min-height: 18px; height: 18px; margin-top: 2px; padding: 0; }
.consent-check a { color: var(--navy); font-weight: 950; }
.form-status { margin: 0; color: var(--green); font-weight: 850; }
.form-status.error { color: #d92d20; }
.hidden-field { position: absolute; left: -10000px; width: 1px; height: 1px; opacity: 0; }

.site-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 24px clamp(18px, 5vw, 72px);
  border-top: 1px solid var(--line);
  background: #fff;
  color: var(--muted);
  font-size: 14px;
}
.site-footer a { color: var(--ink); font-weight: 850; text-decoration: none; }

.mega-footer {
  color: #fff;
  background: #071735;
}
.mega-footer-media {
  min-height: 118px;
  background-image:
    linear-gradient(90deg, rgba(0, 166, 166, .92), rgba(0, 166, 166, .66), rgba(31, 127, 255, .22)),
    url("/assets/vonics-ai-voice-routing.jpg");
  background-position: center 42%;
  background-size: cover;
}
.mega-footer-inner {
  display: grid;
  grid-template-columns: minmax(220px, .9fr) minmax(0, 1.7fr);
  gap: clamp(28px, 5vw, 72px);
  padding: 64px clamp(18px, 6vw, 78px) 52px;
}
.mega-footer-brand {
  display: grid;
  align-content: start;
  gap: 18px;
  max-width: 320px;
}
.mega-footer-brand img {
  width: 164px;
  height: auto;
  display: block;
}
.mega-footer-brand p {
  color: #d8e3ef;
  font-size: 15px;
}
.mega-footer-columns {
  display: grid;
  grid-template-columns: repeat(5, minmax(128px, 1fr));
  gap: clamp(18px, 3vw, 42px);
  align-items: start;
  justify-content: stretch;
  color: #fff;
  font-size: 15px;
  font-weight: 500;
}
.mega-footer-column {
  display: grid;
  align-content: start;
  gap: 14px;
}
.mega-footer-column h2 {
  margin: 0 0 2px;
  color: #fff;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.2;
}
.mega-footer-column a {
  color: #d8e3ef;
  text-decoration: none;
  white-space: normal;
  font-weight: 500;
  line-height: 1.35;
}
.mega-footer-column a:hover,
.mega-footer-column a:focus {
  color: #72f0ec;
}
.mega-footer-bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 clamp(18px, 6vw, 78px);
  padding: 18px 0 24px;
  border-top: 1px solid rgba(255, 255, 255, .34);
  color: #b8c7d8;
  font-size: 13px;
}
.mega-footer-bottom a {
  color: #d8e3ef;
  text-decoration: none;
  font-weight: 850;
}
.mega-footer-bottom-links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.chatbot-widget {
  position: fixed;
  right: clamp(14px, 3vw, 28px);
  bottom: clamp(14px, 3vw, 28px);
  z-index: 60;
  font-family: inherit;
}
.chatbot-launcher {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  border: 1px solid rgba(10, 15, 60, .2);
  border-radius: 999px;
  color: #041522;
  background: var(--amber);
  box-shadow: 0 18px 44px rgba(6, 19, 35, .22);
  font-weight: 950;
  cursor: pointer;
}
.chatbot-launcher-mark {
  width: 24px;
  height: 24px;
  display: inline-block;
  border-radius: 999px;
  background:
    radial-gradient(circle at 36% 36%, #fff 0 22%, transparent 23%),
    linear-gradient(135deg, var(--cyan), var(--blue));
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, .62);
}
.chatbot-panel {
  position: absolute;
  right: 0;
  bottom: 62px;
  width: min(390px, calc(100vw - 28px));
  overflow: hidden;
  border: 1px solid rgba(216, 227, 239, .9);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 26px 70px rgba(6, 19, 35, .28);
}
.chatbot-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  color: #fff;
  background: #071735;
}
.chatbot-head div {
  display: grid;
  gap: 2px;
}
.chatbot-head strong {
  font-size: 17px;
}
.chatbot-head span {
  color: #b8c7d8;
  font-size: 13px;
  font-weight: 800;
}
.chatbot-close {
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 8px;
  color: #fff;
  background: rgba(255, 255, 255, .08);
  font-weight: 950;
  cursor: pointer;
}
.chatbot-log {
  max-height: 300px;
  display: grid;
  gap: 12px;
  overflow-y: auto;
  padding: 16px;
  background: #f6f9fc;
}
.chatbot-message {
  display: grid;
  gap: 8px;
}
.chatbot-message.user {
  justify-items: end;
}
.chatbot-bubble {
  max-width: 92%;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  background: #fff;
  line-height: 1.45;
  font-size: 14px;
}
.chatbot-message.user .chatbot-bubble {
  color: #041522;
  border-color: rgba(248, 193, 74, .44);
  background: #fff7d6;
}
.chatbot-links {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.chatbot-message.user .chatbot-links {
  justify-content: flex-end;
}
.chatbot-links a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 7px 10px;
  border: 1px solid #cae0f8;
  border-radius: 999px;
  color: #0a3c6e;
  background: #edf6ff;
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
}
.chatbot-prompts {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  background: #fff;
}
.chatbot-prompts button {
  flex: 0 0 auto;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink);
  background: #fbfdff;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}
.chatbot-form {
  display: grid;
  gap: 8px;
  padding: 14px 16px 16px;
  border-top: 1px solid var(--line);
  background: #fff;
}
.chatbot-input-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}
.chatbot-input-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}
.chatbot-input-row input {
  min-width: 0;
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 11px;
  color: var(--ink);
}
.chatbot-input-row button {
  min-height: 42px;
  padding: 10px 13px;
  border: 0;
  border-radius: 8px;
  color: #041522;
  background: var(--cyan);
  font-weight: 950;
  cursor: pointer;
}

.subpage-hero {
  padding: 72px clamp(18px, 7vw, 96px) 42px;
  color: #fff;
  background: linear-gradient(135deg, #061323, #0a0f3c);
}
.subpage-hero .kicker { color: #72f0ec; }
.subpage-hero h1 { max-width: 980px; }
.subpage-hero p:not(.kicker) { max-width: 790px; margin-top: 16px; color: #d8e3ef; font-size: 18px; }
.subpage-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 24px; }

.about-hero {
  background-image:
    linear-gradient(90deg, rgba(6, 19, 35, .96), rgba(10, 15, 60, .84) 46%, rgba(6, 19, 35, .36)),
    url("/assets/vonics-ai-voice-routing.jpg");
  background-position: center;
  background-size: cover;
}
.about-story { background: #fff; }
.about-story-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .96fr);
  gap: 28px;
  align-items: center;
}
.about-copy {
  display: grid;
  gap: 14px;
}
.about-copy p:not(.kicker) {
  max-width: 820px;
  font-size: 17px;
}
.about-visual {
  position: relative;
  min-height: 520px;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #edf6ff;
  box-shadow: var(--shadow);
}
.about-visual::after {
  content: "";
  position: absolute;
  top: 18px;
  right: 18px;
  width: 64px;
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .7);
  border-radius: 18px;
  background:
    rgba(255, 255, 255, .92)
    url("/brand/logos/vonics-mark.svg") center / 72% no-repeat;
  box-shadow: 0 16px 34px rgba(27, 42, 88, .16);
  pointer-events: none;
}
.about-visual img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  display: block;
  object-fit: cover;
}
.about-visual figcaption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  display: grid;
  gap: 5px;
  padding: 14px 16px;
  border: 1px solid rgba(31, 127, 255, .16);
  border-radius: 8px;
  color: var(--ink);
  background: rgba(255, 255, 255, .9);
  box-shadow: 0 18px 38px rgba(15, 35, 58, .14);
  backdrop-filter: blur(10px);
}
.about-visual figcaption strong {
  font-size: 18px;
}
.about-visual figcaption span {
  color: var(--muted);
  line-height: 1.42;
}
.about-offers { background: #f7f9fc; }
.about-offers .platform-grid article {
  min-height: 245px;
}
.about-method { background: #fff; }
.about-method-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.about-method-grid article {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 230px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: var(--shadow);
}
.about-method-grid b {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}
.about-vision {
  color: #fff;
  background: linear-gradient(135deg, #061323, #0a0f3c);
}
.about-vision-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  gap: 28px;
  align-items: start;
}
.about-vision .kicker { color: #72f0ec; }
.about-vision p {
  max-width: 840px;
  margin-top: 14px;
  color: #d8e3ef;
  font-size: 17px;
}
.about-principles {
  display: grid;
  gap: 12px;
}
.about-principles article {
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
}
.about-principles article:nth-child(2) { border-left-color: var(--green); }
.about-principles article:nth-child(3) { border-left-color: var(--amber); }
.about-principles strong {
  color: #fff;
  font-size: 19px;
}
.about-principles span {
  color: #d8e3ef;
  line-height: 1.45;
}
.about-cta {
  background: #eef4fb;
}

.partner-hero {
  background-image:
    linear-gradient(90deg, rgba(6, 19, 35, .96), rgba(10, 15, 60, .82) 46%, rgba(6, 19, 35, .28)),
    url("/assets/vonics-teams-phone-routing.jpg");
  background-position: center;
  background-size: cover;
}
.partner-intro { background: #fff; }
.partner-audience-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.partner-audience-grid article {
  display: grid;
  align-content: start;
  gap: 13px;
  min-height: 280px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #f7fbff);
  box-shadow: var(--shadow);
}
.partner-audience-grid img {
  width: 46px;
  height: 46px;
}
.partner-offers {
  color: #fff;
  background: linear-gradient(135deg, #061323, #0a0f3c);
}
.partner-offers p { color: #d8e3ef; }
.partner-offers .kicker { color: #72f0ec; }
.partner-offers .offer-grid article {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
  box-shadow: none;
}
.partner-offers .offer-grid h3 { color: #fff; }
.partner-offers .offer-grid b {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}
.partner-offers .offer-grid p { color: #d8e3ef; }
.partner-motion { background: #f7f9fc; }
.partner-motion-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.partner-motion-grid article {
  display: grid;
  align-content: start;
  gap: 12px;
  min-height: 240px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.partner-motion-grid b {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}
.partner-principles {
  color: #fff;
  background: #061323;
}
.partner-principles-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, .96fr);
  gap: 28px;
  align-items: start;
}
.partner-principles .kicker { color: #72f0ec; }
.partner-principles p {
  max-width: 820px;
  margin-top: 14px;
  color: #d8e3ef;
  font-size: 17px;
}
.partner-principle-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.partner-principle-list article {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 176px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-top: 5px solid var(--cyan);
  border-radius: 8px;
  background: rgba(255, 255, 255, .08);
}
.partner-principle-list article:nth-child(2) { border-top-color: var(--green); }
.partner-principle-list article:nth-child(3) { border-top-color: var(--amber); }
.partner-principle-list article:nth-child(4) { border-top-color: var(--coral); }
.partner-principle-list strong {
  color: #fff;
  font-size: 18px;
  line-height: 1.24;
}
.partner-principle-list span {
  color: #d8e3ef;
  line-height: 1.45;
}

.vertical-hero {
  position: relative;
  min-height: clamp(560px, 82svh, 760px);
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: clamp(44px, 7vw, 92px) clamp(18px, 5vw, 72px);
  color: #fff;
  background-position: center;
  background-size: cover;
}
.tradies-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 38%, rgba(5, 11, 31, .35) 72%, rgba(5, 11, 31, .05) 100%),
    url("/assets/vonics-tradies-ai-calls.jpg");
}
.clinic-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .96) 0%, rgba(5, 11, 31, .86) 40%, rgba(5, 11, 31, .38) 72%, rgba(5, 11, 31, .08) 100%),
    url("/assets/vonics-clinic-ai-reception.jpg");
}
.helpdesk-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .96) 0%, rgba(5, 11, 31, .86) 40%, rgba(5, 11, 31, .38) 72%, rgba(5, 11, 31, .08) 100%),
    url("/assets/vonics-helpdesk-rag-support.jpg");
}
.pay-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .96) 0%, rgba(5, 11, 31, .86) 40%, rgba(5, 11, 31, .38) 72%, rgba(5, 11, 31, .08) 100%),
    url("/assets/pitch-scenes/main-payment-reminder.jpg");
}
.telco-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .96) 0%, rgba(5, 11, 31, .86) 39%, rgba(5, 11, 31, .38) 72%, rgba(5, 11, 31, .08) 100%),
    url("/assets/vonics-teams-phone-routing.jpg");
}
.law-hero {
  background-image:
    linear-gradient(90deg, rgba(5, 11, 31, .97) 0%, rgba(5, 11, 31, .88) 40%, rgba(5, 11, 31, .44) 72%, rgba(5, 11, 31, .08) 100%),
    url("/assets/vonics-law-teams-transcription.png");
}
.vertical-hero-copy { position: relative; z-index: 1; width: min(820px, 100%); }
.vertical-hero .kicker { color: #72f0ec; }
.vertical-hero p:not(.kicker) { max-width: 710px; margin-top: 18px; color: #e7f2ff; font-size: 19px; }
.vertical-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.vertical-card-grid article {
  min-height: 230px;
  display: grid;
  align-content: start;
  gap: 13px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.vertical-card-grid b {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #041522;
  background: var(--amber);
}
.vertical-workflows { background: #f7f9fc; }
.vertical-connectors article { position: relative; }
.vertical-pricing .price { font-size: 38px; }
.telco-product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.telco-product-grid article {
  min-height: 260px;
  display: grid;
  align-content: start;
  gap: 13px;
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.telco-product-grid b {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  padding: 9px;
  border-radius: 8px;
  background: #edf6ff;
  border: 1px solid #cfe0f2;
}
.telco-product-grid b img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.telco-network-band { background: #eef4fb; }
.telco-network-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(300px, .85fr);
  gap: 20px;
  align-items: stretch;
}
.telco-flow-map {
  display: grid;
  grid-template-columns: minmax(170px, 1fr) 58px minmax(190px, 1fr) 58px minmax(170px, 1fr);
  gap: 10px;
  align-items: center;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.telco-flow-node {
  min-height: 220px;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid #cbd9ea;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #edf6ff);
}
.telco-flow-node strong { color: var(--ink); font-size: 20px; line-height: 1.2; }
.telco-flow-node span, .telco-service-stack span, .telco-smallprint { color: var(--muted); line-height: 1.45; }
.telco-edge-node {
  border-color: #bbf7d0;
  background: linear-gradient(180deg, #fff, #ecfdf5);
  animation: edgeGlow 3.4s ease-in-out infinite;
}
.telco-mini-link {
  height: 6px;
  position: relative;
  border-radius: 999px;
  background: #dbe6f2;
  overflow: hidden;
}
.telco-mini-link span {
  position: absolute;
  inset: 0;
  width: 48%;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--green));
  animation: dataFlow 1.9s linear infinite;
}
.telco-service-stack {
  display: grid;
  gap: 12px;
}
.telco-service-stack article {
  min-height: 118px;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.telco-service-stack article:nth-child(2) { border-left-color: var(--violet); }
.telco-service-stack article:nth-child(3) { border-left-color: var(--green); }
.telco-receptionist {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(360px, 1.1fr);
  gap: 24px;
  align-items: center;
  background: #fff;
}
.telco-receptionist-copy {
  display: grid;
  gap: 16px;
  align-content: center;
}
.telco-receptionist-copy > p:not(.kicker) {
  max-width: 720px;
  font-size: 18px;
}
.telco-receptionist-points {
  display: grid;
  gap: 10px;
}
.telco-receptionist-points article {
  display: grid;
  gap: 6px;
  padding: 14px;
  border: 1px solid var(--line);
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  background: #fbfdff;
}
.telco-receptionist-points article:nth-child(2) { border-left-color: var(--green); }
.telco-receptionist-points article:nth-child(3) { border-left-color: var(--amber); }
.telco-receptionist-points span {
  color: var(--muted);
  line-height: 1.45;
}
.telco-receptionist-visual {
  position: relative;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #edf6ff;
  box-shadow: var(--shadow);
}
.telco-receptionist-visual::after {
  content: "";
  position: absolute;
  top: 18px;
  right: 18px;
  width: 64px;
  aspect-ratio: 1;
  border: 1px solid rgba(255, 255, 255, .7);
  border-radius: 18px;
  background:
    rgba(255, 255, 255, .92)
    url("/brand/logos/vonics-mark.svg") center / 72% no-repeat;
  box-shadow: 0 16px 34px rgba(27, 42, 88, .16);
  pointer-events: none;
}
.telco-receptionist-visual img {
  width: 100%;
  min-height: 360px;
  display: block;
  object-fit: cover;
  object-position: center;
}
.dark-secondary {
  color: var(--ink);
  border-color: var(--line);
  background: #fff;
}
.telco-flyover article { min-height: 205px; }
.telco-industries .use-case-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.telco-smallprint {
  max-width: 980px;
  margin-top: 18px;
  font-size: 14px;
}
.governance-band {
  color: #fff;
  background: linear-gradient(135deg, #061323, #0a0f3c);
}
.governance-band p { color: #d8e3ef; }
.governance-band .kicker { color: #72f0ec; }
.governance-band .vertical-card-grid article {
  border-color: rgba(255, 255, 255, .18);
  background: rgba(255, 255, 255, .08);
  box-shadow: none;
}
.governance-band .vertical-card-grid h3 { color: #fff; }
.governance-band .vertical-card-grid p { color: #d8e3ef; }
.law-teams-band, .law-transcript-band { background: #eef4fb; }
.law-call-map {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 58px minmax(220px, 1fr) 58px minmax(180px, 1fr);
  gap: 10px;
  align-items: center;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
  overflow: hidden;
}
.law-call-map article {
  min-height: 184px;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 18px;
  border: 1px solid #cbd9ea;
  border-left: 5px solid var(--cyan);
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #f0f9ff);
}
.law-call-map article:nth-of-type(2) { border-left-color: var(--violet); background: linear-gradient(180deg, #fff, #f5f3ff); }
.law-call-map article:nth-of-type(3) { border-left-color: var(--green); background: linear-gradient(180deg, #fff, #ecfdf5); }
.law-call-map strong {
  color: var(--ink);
  font-size: 20px;
  line-height: 1.2;
}
.law-call-map span {
  color: var(--muted);
  line-height: 1.45;
}
.law-call-map i {
  height: 6px;
  position: relative;
  border-radius: 999px;
  background: #dbe6f2;
  overflow: hidden;
}
.law-call-map i::before {
  content: "";
  position: absolute;
  inset: 0;
  width: 48%;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--cyan), var(--green));
  animation: dataFlow 1.9s linear infinite;
}
.law-transcript-layout {
  display: grid;
  grid-template-columns: minmax(320px, .95fr) minmax(0, 1.05fr);
  gap: 18px;
  align-items: stretch;
}
.law-transcript-card {
  display: grid;
  align-content: start;
  gap: 18px;
  min-height: 430px;
  padding: 22px;
  border: 1px solid rgba(114, 240, 236, .26);
  border-radius: 8px;
  color: #fff;
  background: #061323;
  box-shadow: 0 24px 70px rgba(6, 19, 35, .22);
}
.law-transcript-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}
.law-transcript-head span {
  color: #72f0ec;
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}
.law-transcript-head b {
  padding: 7px 10px;
  border-radius: 999px;
  color: #041522;
  background: var(--amber);
  font-size: 12px;
}
.law-transcript-card dl {
  display: grid;
  gap: 12px;
  margin: 0;
}
.law-transcript-card div:not(.law-transcript-head) {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, .12);
  border-left: 4px solid var(--cyan);
  border-radius: 8px;
  background: rgba(255, 255, 255, .07);
}
.law-transcript-card div:nth-child(3) { border-left-color: var(--violet); }
.law-transcript-card div:nth-child(4) { border-left-color: var(--amber); }
.law-transcript-card div:nth-child(5) { border-left-color: var(--green); }
.law-transcript-card dt {
  color: #72f0ec;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}
.law-transcript-card dd {
  margin: 0;
  color: #e7f2ff;
  line-height: 1.45;
}
.law-review-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.law-review-steps article {
  min-height: 205px;
  display: grid;
  align-content: start;
  gap: 9px;
  padding: 18px;
  border: 1px solid var(--line);
  border-top: 5px solid var(--cyan);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.law-review-steps article:nth-child(2) { border-top-color: var(--violet); }
.law-review-steps article:nth-child(3) { border-top-color: var(--amber); }
.law-review-steps article:nth-child(4) { border-top-color: var(--green); }
.law-review-steps strong {
  color: var(--ink);
  font-size: 20px;
}
.law-review-steps span {
  color: var(--muted);
  line-height: 1.45;
}
.law-governance .vertical-card-grid article {
  border-top: 5px solid var(--cyan);
}
.law-governance .vertical-card-grid article:nth-child(2) { border-top-color: var(--green); }
.law-governance .vertical-card-grid article:nth-child(3) { border-top-color: var(--amber); }
.law-reference-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}
.law-reference-list a {
  display: grid;
  align-content: center;
  min-height: 68px;
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: 8px;
  color: #fff;
  background: rgba(255, 255, 255, .08);
  font-weight: 900;
  line-height: 1.35;
}
.law-reference-list a:hover,
.law-reference-list a:focus {
  color: #061323;
  background: #72f0ec;
}

.voice-ai { background: linear-gradient(180deg, #061323, #0a0f3c); color: #fff; }
.voice-ai .intro p:not(.kicker), .voice-ai p { color: #d8e3ef; }
.voice-grid, .outbound-grid { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(300px, .8fr); gap: 24px; align-items: center; }
.voice-movie, .outbound-movie { position: relative; min-height: 430px; display: grid; grid-template-columns: minmax(210px, 1fr) 70px minmax(230px, 1fr) 70px minmax(190px, .9fr); gap: 10px; align-items: center; padding: 22px; border: 1px solid rgba(0,166,166,.28); border-radius: 8px; background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); box-shadow: 0 24px 70px rgba(0,0,0,.24); overflow: hidden; }
.voice-movie::before, .outbound-movie::before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255,255,255,.08); border-radius: 8px; pointer-events: none; }
.phone-card, .transcript-card, .outcome-stack div, .ledger-card, .tts-card { position: relative; z-index: 1; background: rgba(255,255,255,.96); color: var(--ink); border: 1px solid rgba(216,227,239,.9); border-radius: 8px; box-shadow: var(--shadow); }
.phone-card, .transcript-card, .ledger-card, .tts-card { display: grid; gap: 12px; padding: 18px; }
.phone-card p, .transcript-card p, .tts-card p { margin: 0; color: var(--muted); }
.live-dot { width: 12px; height: 12px; border-radius: 999px; background: #ef4444; box-shadow: 0 0 0 0 rgba(239,68,68,.6); animation: livePulse 1.5s infinite; }
.wave-bars, .mini-wave { display: flex; align-items: center; gap: 7px; height: 58px; }
.wave-bars i, .mini-wave i { display: block; width: 9px; border-radius: 999px; background: linear-gradient(180deg, var(--cyan), var(--blue)); animation: wave 1s ease-in-out infinite; }
.wave-bars i:nth-child(1), .mini-wave i:nth-child(1) { height: 18px; }
.wave-bars i:nth-child(2), .mini-wave i:nth-child(2) { height: 34px; animation-delay: .1s; }
.wave-bars i:nth-child(3), .mini-wave i:nth-child(3) { height: 48px; animation-delay: .2s; }
.wave-bars i:nth-child(4), .mini-wave i:nth-child(4) { height: 26px; animation-delay: .3s; }
.wave-bars i:nth-child(5), .mini-wave i:nth-child(5) { height: 42px; animation-delay: .4s; }
.wave-bars i:nth-child(6) { height: 30px; animation-delay: .5s; }
.wave-bars i:nth-child(7) { height: 42px; animation-delay: .6s; }
.flow-line, .agent-flow { height: 6px; position: relative; border-radius: 999px; background: rgba(255,255,255,.12); overflow: hidden; }
.outbound-flow, .agent-flow { background: rgba(6,19,35,.09); }
.flow-line span, .agent-flow span { position: absolute; inset: 0; width: 42%; border-radius: 999px; background: linear-gradient(90deg, transparent, var(--cyan), #fff); animation: dataFlow 1.8s linear infinite; }
.outbound-flow span { background: linear-gradient(90deg, transparent, var(--green), var(--cyan)); animation-duration: 2.1s; }
.flow-line.second span { animation-delay: .55s; }
.typing-line { position: relative; overflow: hidden; white-space: nowrap; border-right: 2px solid var(--cyan); animation: typeReveal 4.6s steps(58, end) infinite; }
.outcome-stack { display: grid; gap: 12px; }
.outcome-stack div { padding: 14px; font-weight: 900; animation: outcomePop 3.6s ease-in-out infinite; }
.outcome-stack div:nth-child(1) { --outcome-border: #bae6fd; --outcome-accent: var(--cyan); border-color: var(--outcome-border); background: #f0f9ff; }
.outcome-stack div:nth-child(2) { --outcome-border: #bbf7d0; --outcome-accent: var(--green); border-color: var(--outcome-border); background: #ecfdf5; animation-delay: .35s; }
.outcome-stack div:nth-child(3) { --outcome-border: #fed7aa; --outcome-accent: var(--amber); border-color: var(--outcome-border); background: #fff7ed; animation-delay: .7s; }
.voice-copy img { width: min(280px, 100%); height: 60px; object-fit: contain; object-position: left center; }
.voice-copy ul { padding-left: 20px; margin: 0; }
.voice-copy li { color: var(--muted); }

.agent-handler { background: #fff; }
.agent-grid { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr); gap: 24px; align-items: center; }
.agent-movie { min-height: 430px; display: grid; grid-template-columns: minmax(170px, 1fr) 52px minmax(170px, 1fr) 52px minmax(190px, 1fr) 52px minmax(170px, .9fr); gap: 8px; align-items: center; padding: 22px; border: 1px solid #cbd9ea; border-radius: 8px; background: linear-gradient(135deg, #fff, #edf6ff); box-shadow: var(--shadow); overflow: hidden; }
.agent-stage { --stage-accent: var(--cyan); --stage-tint: #f0f9ff; --stage-border: #bae6fd; position: relative; min-height: 230px; display: grid; align-content: start; gap: 10px; padding: 16px; border: 1px solid var(--stage-border); border-radius: 8px; background: linear-gradient(180deg, rgba(255,255,255,.98), var(--stage-tint)); box-shadow: var(--shadow); animation: agentLift 4.6s ease-in-out infinite; }
.agent-stage:nth-of-type(3) { animation-delay: .3s; }
.agent-stage:nth-of-type(5) { animation-delay: .6s; }
.agent-stage:nth-of-type(7) { animation-delay: .9s; }
.agent-stage b { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 999px; color: #041522; background: var(--stage-accent); }
.agent-stage strong { color: var(--ink); }
.agent-stage span { display: block; padding: 8px; border: 1px solid rgba(6,19,35,.06); border-radius: 8px; background: rgba(255,255,255,.68); color: var(--muted); font-size: 13px; line-height: 1.35; }
.context-stage { --stage-accent: var(--violet); --stage-tint: #f5f3ff; --stage-border: #ddd6fe; }
.context-stage b { color: #fff; }
.brain-stage { --stage-accent: var(--green); --stage-tint: #ecfdf5; --stage-border: #bbf7d0; }
.action-stage { --stage-accent: var(--amber); --stage-tint: #fff7ed; --stage-border: #fed7aa; }
.action-stage span { color: #7c2d12; font-weight: 850; }
.agent-copy img { width: min(250px, 100%); height: 58px; object-fit: contain; object-position: left center; }

.outbound-ai, .workflow-section { background: #f7fafc; }
.outbound-movie { grid-template-columns: minmax(230px, 1fr) 70px minmax(240px, 1.05fr) 70px minmax(190px, .9fr); background: linear-gradient(135deg, #fff, #edf6ff); }
.ledger-row { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; gap: 10px; align-items: center; padding: 10px; border: 1px solid #e6eef7; border-radius: 8px; color: var(--muted); font-size: 13px; }
.ledger-row b { color: var(--ink); }
.ledger-row em { font-style: normal; color: var(--green); font-weight: 900; }
.ledger-row.active { border-color: var(--cyan); background: #edf6ff; animation: ledgerPulse 2.4s ease-in-out infinite; }
.option-keys { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.option-keys span { min-height: 34px; display: grid; place-items: center; border-radius: 8px; color: #041522; background: #dff5ff; font-size: 13px; font-weight: 950; }

.workflow-demos { background: #fff; }
.demo-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.demo-card { --demo-accent: var(--cyan); --demo-accent-2: var(--blue); --demo-tint: #f0f9ff; --demo-soft: #e0f2fe; --demo-border: #bae6fd; display: grid; gap: 18px; align-content: start; padding: 20px; border: 1px solid var(--demo-border); border-radius: 8px; background: linear-gradient(180deg, #fff, var(--demo-tint)); box-shadow: var(--shadow); }
.demo-card:nth-child(2) { --demo-accent: var(--amber); --demo-accent-2: var(--rose); --demo-tint: #fff7ed; --demo-soft: #ffedd5; --demo-border: #fed7aa; }
.demo-card:nth-child(3) { --demo-accent: var(--violet); --demo-accent-2: var(--green); --demo-tint: #f5f3ff; --demo-soft: #ede9fe; --demo-border: #ddd6fe; }
.demo-copy { display: grid; gap: 8px; }
.demo-card .kicker { color: var(--demo-accent); }
.demo-flow { position: relative; display: grid; gap: 12px; padding: 14px; border: 1px solid var(--demo-border); border-radius: 8px; background: linear-gradient(135deg, #fff, var(--demo-soft)); overflow: hidden; }
.demo-flow::before { content: ""; position: absolute; left: 24px; top: 28px; bottom: 28px; width: 3px; border-radius: 999px; background: linear-gradient(180deg, var(--demo-accent), var(--demo-accent-2)); opacity: .72; }
.demo-node, .demo-stream, .choice-row, .slot-list { position: relative; z-index: 1; margin-left: 18px; }
.demo-node { display: grid; gap: 6px; padding: 12px; border: 1px solid var(--demo-border); border-left: 4px solid var(--demo-accent); border-radius: 8px; background: rgba(255,255,255,.94); animation: demoStep 4.8s ease-in-out infinite; }
.demo-node span, .demo-stream span, .slot-list span { color: var(--muted); font-size: 13px; line-height: 1.4; }
.demo-stream, .slot-list { display: grid; gap: 7px; padding: 12px; border: 1px solid var(--demo-border); border-radius: 8px; background: rgba(255,255,255,.58); }
.demo-stream span { animation: transcriptGlow 4s ease-in-out infinite; }
.demo-stream span:nth-child(2) { animation-delay: .35s; }
.demo-stream span:nth-child(3) { animation-delay: .7s; }
.demo-stream span:nth-child(4) { animation-delay: 1.05s; }
.choice-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.choice-row span { display: grid; place-items: center; min-height: 34px; padding: 8px; border: 1px solid var(--demo-border); border-radius: 8px; color: #041522; background: rgba(255,255,255,.72); font-size: 12px; font-weight: 950; text-align: center; animation: optionPulse 3.8s ease-in-out infinite; }
.choice-row span:nth-child(2) { animation-delay: .35s; }
.choice-row span:nth-child(3) { animation-delay: .7s; }
.slot-list span { padding: 8px; border-radius: 8px; background: #fff; }
.slot-list .active { color: var(--ink); border: 1px solid var(--demo-accent); font-weight: 950; animation: optionPulse 3.2s ease-in-out infinite; }
.ticket-node, .control-node, .sms-node { border-color: var(--demo-accent-2); border-left-color: var(--demo-accent-2); }
.flyover { display: grid; grid-template-columns: repeat(4, minmax(180px, 1fr)); gap: 14px; }
.flyover article { --flyover-accent: var(--cyan); --flyover-tint: #f0f9ff; --flyover-border: #bae6fd; min-height: 180px; display: grid; align-content: start; gap: 12px; padding: 18px; border-radius: 8px; background: linear-gradient(180deg, #fff, var(--flyover-tint)); border: 1px solid var(--flyover-border); box-shadow: var(--shadow); animation: pulseStep 3.2s ease-in-out infinite; }
.flyover article:nth-child(2) { --flyover-accent: var(--violet); --flyover-tint: #f5f3ff; --flyover-border: #ddd6fe; animation-delay: .25s; }
.flyover article:nth-child(3) { --flyover-accent: var(--green); --flyover-tint: #ecfdf5; --flyover-border: #bbf7d0; animation-delay: .5s; }
.flyover article:nth-child(4) { --flyover-accent: var(--amber); --flyover-tint: #fff7ed; --flyover-border: #fed7aa; animation-delay: .75s; }
.flyover b { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 999px; color: #041522; background: var(--flyover-accent); }
.flyover article:nth-child(2) b { color: #fff; }

@keyframes livePulse { 70% { box-shadow: 0 0 0 12px rgba(239,68,68,0); } }
@keyframes wave { 0%,100% { transform: scaleY(.62); } 50% { transform: scaleY(1.16); } }
@keyframes dataFlow { 0% { transform: translateX(-120%); } 100% { transform: translateX(260%); } }
@keyframes dataFlowDown { 0% { transform: translateY(-120%); } 100% { transform: translateY(260%); } }
@keyframes typeReveal { 0% { max-width: 0; } 48%,82% { max-width: 100%; } 100% { max-width: 0; } }
@keyframes outcomePop { 0%,100% { transform: translateY(0); border-color: var(--outcome-border, rgba(216,227,239,.9)); } 45% { transform: translateY(-7px); border-color: var(--outcome-accent, var(--cyan)); } }
@keyframes agentLift { 0%,100% { transform: translateY(0); } 45% { transform: translateY(-6px); } }
@keyframes ledgerPulse { 0%,100% { transform: translateY(0); } 45% { transform: translateY(-5px); } }
@keyframes demoStep { 0%,100% { transform: translateY(0); } 42% { transform: translateY(-4px); } }
@keyframes transcriptGlow { 0%,100% { color: var(--muted); } 45% { color: var(--ink); } }
@keyframes optionPulse { 0%,100% { transform: translateY(0); box-shadow: none; } 45% { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(0,166,166,.2); } }
@keyframes pulseStep { 0%,100% { transform: translateY(0); border-color: var(--flyover-border, var(--line)); } 45% { transform: translateY(-8px); border-color: var(--flyover-accent, var(--cyan)); } }
@keyframes pitchFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
@keyframes phoneRing { 0%,100% { transform: rotate(0); } 15% { transform: rotate(-4deg); } 30% { transform: rotate(4deg); } 45% { transform: rotate(0); } }
@keyframes bubblePop { 0%,100% { transform: translateY(0) scale(1); } 45% { transform: translateY(-6px) scale(1.02); } }
@keyframes sceneCardIn { from { opacity: 0; transform: translateY(16px) scale(.96); } to { opacity: 1; transform: translateY(0) scale(1); } }
@keyframes dotTravelOne { 0%,100% { transform: translate(0, 0); } 50% { transform: translate(100px, -16px); } }
@keyframes dotTravelTwo { 0%,100% { transform: translate(0, 0); } 50% { transform: translate(-110px, 14px); } }

.legal-page, .status-page { background: #f6f9fc; min-height: 100vh; }
.legal-hero, .status-hero { padding: 72px clamp(18px, 7vw, 96px) 34px; }
.legal-hero h1, .status-hero h1 { max-width: 920px; font-size: clamp(38px, 6vw, 72px); margin: 0; }
.legal-hero p:not(.kicker), .status-hero p:not(.kicker) { max-width: 820px; margin-top: 14px; font-size: 18px; }
.legal-layout {
  display: grid;
  grid-template-columns: minmax(220px, 320px) minmax(0, 1fr);
  gap: 18px;
  padding: 0 clamp(18px, 7vw, 96px) 72px;
}
.legal-summary { align-self: start; position: sticky; top: 92px; padding: 22px; }
.legal-summary strong { display: block; margin-bottom: 10px; color: var(--ink); font-size: 17px; }
.legal-summary p { margin-top: 10px; }
.legal-card { display: grid; gap: 10px; padding: 24px; }
.legal-card h2 { margin: 22px 0 0; font-size: 24px; }
.legal-card h2:first-child { margin-top: 0; }
.legal-card a { color: var(--navy); font-weight: 900; }

.status-overview {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  max-width: 920px;
  margin-top: 24px;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.status-overview strong { color: var(--ink); font-size: 18px; }
.status-good { color: var(--green) !important; }
.status-bad { color: #d92d20 !important; }
.status-section { padding: 28px clamp(18px, 7vw, 96px); }
.compact-intro { margin-bottom: 18px; }
.status-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.status-card, .uptime-row {
  display: grid;
  gap: 10px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  box-shadow: var(--shadow);
}
.status-card-head { display: flex; align-items: center; gap: 10px; }
.status-card-head strong { color: var(--ink); font-size: 20px; }
.status-card p { color: var(--ink); font-size: 16px; font-weight: 900; }
.status-card dl { display: grid; gap: 8px; margin: 0; }
.status-card dl div { display: grid; grid-template-columns: 110px 1fr; gap: 10px; }
.status-card dt { color: var(--muted); font-weight: 850; }
.status-card dd { margin: 0; color: var(--ink); overflow-wrap: anywhere; }
.status-empty { grid-column: 1 / -1; padding: 18px; border: 1px dashed var(--line); border-radius: 8px; background: #fff; color: var(--muted); font-weight: 850; }
.status-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: #94a3b8; flex: 0 0 auto; }
.status-dot.operational, .uptime-cell.operational { background: var(--green); }
.status-dot.degraded, .uptime-cell.degraded { background: #f59e0b; }
.status-dot.outage, .uptime-cell.outage { background: #d92d20; }
.status-dot.unknown, .uptime-cell.unknown { background: #d7e0ea; }
.uptime-panel { display: grid; gap: 14px; }
.uptime-row-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.uptime-row-head div { display: grid; gap: 4px; }
.uptime-row-head strong { color: var(--ink); font-size: 20px; }
.uptime-row-head b { color: var(--ink); font-size: 22px; white-space: nowrap; }
.uptime-cells { display: grid; grid-template-columns: repeat(61, minmax(3px, 1fr)); gap: 3px; }
.uptime-cell { display: block; height: 16px; border-radius: 3px; }
.uptime-legend { display: flex; flex-wrap: wrap; gap: 12px; color: var(--muted); font-size: 13px; font-weight: 850; }
.uptime-legend span { display: inline-flex; align-items: center; gap: 6px; }

@media (max-width: 1120px) {
  nav { gap: 12px; font-size: 13px; }
  .use-case-grid, .pricing-grid, .connector-logo-grid, .demo-grid, .flyover, .vertical-card-grid, .vertical-site-grid, .telco-product-grid, .telco-industries .use-case-grid, .pitch-grid, .about-method-grid, .partner-audience-grid, .partner-motion-grid, .resource-hub-grid, .faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mega-footer-inner { grid-template-columns: 1fr; }
  .mega-footer-columns { grid-template-columns: repeat(3, minmax(140px, 1fr)); }
}

@media (max-width: 900px) {
  .site-header { position: static; align-items: flex-start; flex-direction: column; }
  nav { width: 100%; overflow-x: auto; padding-bottom: 4px; }
  .hero {
    min-height: 620px;
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .86) 45%, rgba(5, 11, 31, .52) 100%),
      url("/assets/vonics-ai-voice-routing.jpg");
    background-position: center bottom;
  }
  .vertical-hero {
    min-height: 620px;
    background-position: center bottom;
  }
  .tradies-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/vonics-tradies-ai-calls.jpg");
  }
  .clinic-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/vonics-clinic-ai-reception.jpg");
  }
  .helpdesk-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/vonics-helpdesk-rag-support.jpg");
  }
  .pay-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/pitch-scenes/main-payment-reminder.jpg");
  }
  .telco-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/vonics-teams-phone-routing.jpg");
  }
  .law-hero {
    background-image:
      linear-gradient(180deg, rgba(5, 11, 31, .95) 0%, rgba(5, 11, 31, .84) 48%, rgba(5, 11, 31, .50) 100%),
      url("/assets/vonics-law-teams-transcription.png");
  }
  .advisor, .contact, .legal-layout, .voice-grid, .outbound-grid, .agent-grid, .teams-routing-layout, .teams-routing-map, .telco-network-layout, .telco-flow-map, .telco-receptionist, .about-story-layout, .about-vision-layout, .partner-principles-layout, .resource-layout, .law-call-map, .law-transcript-layout { grid-template-columns: 1fr; }
  .teams-brand-row { margin-top: -4px; }
  .teams-outcomes { grid-template-columns: 1fr; }
  .teams-link, .telco-mini-link, .law-call-map i { height: 44px; width: 6px; justify-self: center; }
  .teams-link span, .telco-mini-link span, .law-call-map i::before { width: 100%; height: 42%; animation: dataFlowDown 1.8s linear infinite; }
  .voice-movie, .outbound-movie, .agent-movie { grid-template-columns: 1fr; min-height: auto; }
  .flow-line, .agent-flow { height: 44px; width: 6px; justify-self: center; }
  .flow-line span, .agent-flow span { width: 100%; height: 42%; animation: dataFlowDown 1.8s linear infinite; }
  .result-panel, .legal-summary, .resource-aside { position: static; }
  .platform-grid, .offer-grid, .connector-pathways { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .section { padding: 54px 18px; }
  .hero, .vertical-hero, .resource-hero { min-height: 640px; padding: 42px 18px; }
  h1 { font-size: clamp(38px, 14vw, 56px); }
  h2 { font-size: clamp(28px, 10vw, 40px); }
  .actions, .hero-points { display: grid; }
  .primary, .secondary, .plan-action { width: 100%; }
  .proof-strip { justify-content: flex-start; }
  .choices, .checks, .use-case-grid, .pricing-grid, .connector-logo-grid, .lead-form, .status-grid, .demo-grid, .flyover, .signup-highlights, .option-keys, .choice-row, .vertical-card-grid, .vertical-site-grid, .telco-product-grid, .telco-industries .use-case-grid, .pitch-grid, .about-method-grid, .partner-audience-grid, .partner-motion-grid, .partner-principle-list, .resource-hub-grid, .faq-grid, .law-review-steps, .law-reference-list { grid-template-columns: 1fr; }
  .lead-form .wide, .lead-form button, .form-status { grid-column: auto; }
  .consent-check { grid-template-columns: 20px 1fr; }
  .teams-brand-row { display: grid; }
  .teams-brand-row span { justify-content: center; }
  .teams-visual-card, .teams-visual-card > img { min-height: 260px; }
  .telco-receptionist-visual img { min-height: 260px; }
  .teams-visual-card > img { object-position: 45% center; }
  .teams-visual-card figcaption {
    left: 12px;
    bottom: 12px;
    max-width: calc(100% - 24px);
    border-radius: 8px;
  }
  .teams-visual-card::after, .vertical-site-grid a::after { width: 50px; top: 12px; right: 12px; border-radius: 14px; }
  .about-visual, .about-visual img { min-height: 320px; }
  .about-visual::after { width: 50px; top: 12px; right: 12px; border-radius: 14px; }
  .about-visual figcaption { left: 12px; right: 12px; bottom: 12px; }
  .hero::after, .vertical-hero::after { width: 64px; right: 16px; bottom: 16px; border-radius: 18px; }
  .connector-group-head { display: grid; }
  .voice-movie, .outbound-movie, .agent-movie { padding: 14px; }
  .pitch-stage { min-height: 210px; }
  .pitch-bubble { max-width: 150px; font-size: 13px; }
  .pitch-wave { left: 92px; right: 84px; }
  .typing-line { white-space: normal; border-right: 0; animation: none; }
  .status-card dl div { grid-template-columns: 1fr; gap: 2px; }
  .uptime-row-head { display: grid; }
  .uptime-cells { grid-template-columns: repeat(31, minmax(4px, 1fr)); }
  .mega-footer-media { min-height: 86px; }
  .mega-footer-inner { padding: 44px 18px 34px; }
  .mega-footer-columns { grid-template-columns: 1fr; gap: 26px; }
  .mega-footer-bottom { display: grid; margin: 0 18px; }
  .chatbot-widget { right: 12px; bottom: 12px; }
  .chatbot-panel { bottom: 60px; width: calc(100vw - 24px); }
  .chatbot-log { max-height: min(48svh, 320px); }
  .chatbot-launcher { min-height: 46px; padding: 10px 14px; }
}
