section { padding: clamp(72px,9vw,130px) 0; }

/* --- Hero --- */
.hero {
  position: relative; overflow: hidden;
  padding: clamp(56px,8vw,120px) 0 clamp(72px,9vw,140px);
}
.hero__grid {
  display: grid; grid-template-columns: 1.15fr 1fr;
  gap: clamp(40px,6vw,90px); align-items: center;
}
.hero h1 span.serif { font-style: italic; color: var(--accent); font-weight: 400; }
.hero__lead { margin-top: 24px; max-width: 540px; font-size: 1.12rem; line-height: 1.6; color: var(--ink-soft); }
.hero__cta { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 32px; }
.hero__meta { display: flex; gap: 28px; flex-wrap: wrap; margin-top: 44px; padding-top: 28px; border-top: 1px solid var(--line); }
.hero__meta strong { font-family: var(--serif); font-size: 1.6rem; font-weight: 600; display: block; }
.hero__meta span { font-size: .78rem; color: var(--muted); letter-spacing: .06em; text-transform: uppercase; }
.hero__visual { position: relative; }
.hero__visual svg { width: 100%; height: auto; filter: drop-shadow(0 30px 60px -30px rgba(14,27,61,.3)); }
.hero::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(60% 50% at 75% 0%, rgba(26,161,226,.08), transparent 60%),
    radial-gradient(40% 40% at 0% 100%, rgba(79,179,184,.08), transparent 60%);
}
@media (max-width: 880px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual { max-width: 420px; margin: 0 auto; }
}

/* --- Trust bar --- */
.trust { background: var(--ink); color: var(--paper); padding: 36px 0; }

/* --- Platform overview --- */
.platform { background: #fff; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

/* --- AI Spotlight --- */
.spotlight { background: var(--ink); color: var(--paper); position: relative; overflow: hidden; }
.spotlight::after {
  content: ""; position: absolute; right: -200px; top: -150px; width: 500px; height: 500px;
  border-radius: 50%; background: radial-gradient(circle,rgba(26,161,226,.18),transparent 70%);
}
.spotlight h2 { color: var(--paper); }
.spotlight .sec-head p.lead { color: rgba(251,250,246,.75); }

/* --- Roadmap --- */
.roadmap { background: var(--paper-2); }

/* --- Cloud vs. On-Premises --- */
.cloudvs { background: var(--paper-2); }

.cvs-quote {
  margin: 0 0 clamp(40px,6vw,72px);
  padding: clamp(28px,4vw,44px) clamp(32px,5vw,64px);
  background: var(--ink);
  border-radius: var(--radius);
  color: var(--paper);
  font-family: var(--serif);
  font-size: clamp(1.1rem,2.5vw,1.5rem);
  font-style: italic;
  line-height: 1.55;
  position: relative;
  border: none;
}
.cvs-quote::before {
  content: "\201C";
  position: absolute;
  top: -8px; left: clamp(24px,4vw,52px);
  font-size: 7rem;
  color: var(--accent);
  font-family: var(--serif);
  line-height: 1;
  opacity: .85;
}

.cvs-table { display: flex; flex-direction: column; gap: 8px; }

.cvs-row {
  display: grid;
  grid-template-columns: 1.5fr 2fr 2fr;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--line);
  background: #fff;
}
.cvs-row--head {
  background: transparent;
  border: none;
  border-radius: 0;
  margin-bottom: 4px;
}
.cvs-label {
  padding: 20px 24px;
  background: var(--paper-2);
  font-weight: 700;
  font-size: .9rem;
  color: var(--ink);
  display: flex;
  align-items: center;
}
.cvs-col {
  padding: 20px 22px;
  font-size: .9rem;
  line-height: 1.55;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  border-left: 1px solid var(--line);
}
.cvs-col--onprem { color: var(--ink-soft); background: #fff; }
.cvs-col--cloud  { color: var(--ink); background: rgba(79,179,184,.06); }
.cvs-row--head .cvs-col {
  border: none;
  background: transparent;
  padding: 0 22px 10px;
  font-weight: 700;
  font-size: .74rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  align-items: center;
}
.cvs-row--head .cvs-col--onprem { color: var(--muted); }
.cvs-row--head .cvs-col--cloud  { color: var(--aqua); }

.cvs-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  border-radius: 50%;
  font-size: .7rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}
.cvs-badge--pos { background: rgba(95,188,46,.12); color: var(--good); }
.cvs-badge--neg { background: rgba(14,27,61,.08); color: var(--muted); }

@media (max-width: 720px) {
  .cvs-row { grid-template-columns: 1fr; }
  .cvs-row--head { display: none; }
  .cvs-col { border-left: none; border-top: 1px solid var(--line); }
}

/* --- Compliance --- */
.compliance { background: #fff; }

/* --- Testimonials --- */
.testimonial { background: var(--paper-2); }

/* --- CTA / Demo --- */
.cta { background: var(--ink); color: var(--paper); position: relative; overflow: hidden; }
.cta::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 100%, rgba(26,161,226,.25), transparent 50%),
    radial-gradient(circle at 80% 0%, rgba(79,179,184,.18), transparent 50%);
}

/* --- Footer --- */
.footer { background: var(--paper-2); color: var(--ink-soft); font-size: .88rem; padding: 60px 0 40px; }
