/**
 * Home — Figma-exact section styles.
 *
 * Rebuilt directly from the Figma source of truth (file Qc0svJadX2mkcEk7D5wHUl,
 * frame home_new 7107:14377), NOT reverse-engineered from the Webflow export.
 * Loaded AFTER webflow.css so it corrects any drift from the design.
 * Each block cites its Figma node id + the named text styles it implements.
 *
 * Figma type system (canonical):
 *   Button/Regular  DM Mono 400 14/20 UPPER  (eyebrows -> purple #5D4AF5)
 *   H2/Medium       Archivo 500 40/48        (section titles)
 *   H5/Semi-bold    Archivo 600 24/32        (card titles)
 *   P md/Regular    Geist   400 16/24        (lead / summary)
 *   P lg/Regular    Geist   400 20/28        (card body)
 *   Button/Medium   DM Mono 500 14/14 UPPER  (CTA labels)
 * Colors: purple #5D4AF5, ink #1A1A1A, line #E6E9EE, paper #F7F7F7, card #FFF.
 *
 * @package Limestone
 */

/* ============================================================
 * hero-pp  (Figma node 7388:15501) — the small gradient sphere
 * on the AI-Velocity-Pod ("Ellipse 5": 11x11, radial gradient,
 * shadow + 1px blur) that the flat pod PNG was missing.
 * ============================================================ */
.hero-pp__col-right {
	position: relative;
}

/* Hero pod illustration: the connector dot is baked into the image export
 * (Figma node 7388:15516, "col") so it scales with the artwork — no separate
 * positioned element (the old .hero-pp__pod-ball mis-placed on mobile). */

/* Figma hero Section (7388:15501) padding is 240px 140px 80px; the carried
 * Webflow build left a 180px bottom pad. Trim to the Figma 80px. */
.hero-pp {
	padding-bottom: 80px;
}

/* In Figma the client logos live in a distinct "Logo Group" band
 * (7388:15526) with a 1px top border (#E6E9EE) and 40px vertical padding,
 * visually separating it from the hero content. The WP build merges that
 * band into the hero, so reproduce the divider + 40px breathing room. */
.hero-pp__logos {
	display: block;
	margin-top: 40px;
	padding-top: 40px;
	border-top: 1px solid #e6e9ee;
}
/* Animated client-logo marquee (Figma Logo Group 7388:15526: row gap 120, opacity .5,
   blur(10px) edge fade reproduced as a mask gradient). Two identical tracks scroll left
   for a seamless loop; respects prefers-reduced-motion. */
.hero-pp__marquee {
	display: flex;
	overflow: hidden;
	width: 100%;
	-webkit-mask-image: linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
	        mask-image: linear-gradient(to right, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.hero-pp__logo-track {
	display: flex;
	flex: 0 0 auto;
	align-items: center;
	gap: 120px;
	margin: 0;
	padding: 0 120px 0 0;
	list-style: none;
	animation: hero-logo-marquee 38s linear infinite;
}
.hero-pp__logo-item { flex: 0 0 auto; display: flex; align-items: center; }
.hero-pp__logo-item img { display: block; width: auto; opacity: 0.5; }
@keyframes hero-logo-marquee { from { transform: translateX(0); } to { transform: translateX(-100%); } }
@media (prefers-reduced-motion: reduce) { .hero-pp__logo-track { animation: none; } }

/* Figma H1/Medium declares no letter-spacing; the carried build tightened
 * the title by -0.01em. Reset to Figma-exact 0. */
.hero-pp__title {
	letter-spacing: 0;
}

/* Figma Button/Medium declares no letter-spacing; the carried build added
 * +0.02em on the CTA label. Reset to Figma-exact 0. */
.hero-pp__cta {
	letter-spacing: 0;
}

/* ============================================================
 * s1-problem  (Figma node 7388:15573)
 * ============================================================ */
.s1-problem__eyebrow {
	font-family: "DM Mono", monospace;
	font-weight: 400;
	font-size: 14px;
	line-height: 20px;
	text-transform: uppercase;
	color: #5d4af5;
}

.s1-problem__title {
	font-family: Archivo, sans-serif;
	font-weight: 500;
	font-size: 40px;
	line-height: 48px;
	color: #1a1a1a;
}

.s1-problem__lead,
.s1-problem__close {
	font-family: Geist, sans-serif;
	font-weight: 400;
	font-size: 16px;
	line-height: 24px;
	color: #1a1a1a;
}

/* card (layout_85JB1S): white, 1px #E6E9EE, radius 6, padding 40, gap 40 */
.s1-problem__card {
	background-color: #fff;
	border: 1px solid #e6e9ee;
	border-radius: 6px;
	padding: 40px;
	gap: 40px;
}

/* numeral: 40x30 purple SVG (replaces the flat text "01") */
.s1-problem__num {
	display: block;
	height: 30px;
	line-height: 0;
}

.s1-problem__num img {
	display: block;
	height: 30px;
	width: auto;
}

/* text container gap 16 (title -> body) */
.s1-problem__h3 {
	font-family: Archivo, sans-serif;
	font-weight: 600;
	font-size: 24px;
	line-height: 32px;
	color: #1a1a1a;
}

.s1-problem__body {
	font-family: Geist, sans-serif;
	font-weight: 400;
	font-size: 20px;
	line-height: 28px;
	color: #1a1a1a;
}

/* ============================================================
 * Per-section overrides — exact Figma values for each home
 * section node (eyebrow / title / cards / icons / spacing).
 * ============================================================ */

/* ===== s4-partner (Figma node 7388:15697) ===== */
.s4-partner { background-color:#f7f7f7; }
.s4-partner__head { gap:16px; }
.s4-partner__eyebrow { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; text-transform:uppercase; color:#5d4af5; text-align:center; }
.s4-partner__title { font-family:Archivo,sans-serif; font-weight:500; font-size:40px; line-height:48px; color:#1a1a1a; text-align:center; }
.s4-partner__cards { gap:40px; }
.s4-partner__col-right { gap:40px; }
.s4-partner__card { background-color:#fff; border:1px solid #e6e9ee; border-radius:6px; padding:44px; }
.s4-partner__card--dark { background-color:#1a1a1a; border:1px solid #e6e9ee; border-radius:6px; padding:44px; gap:32px; }
.s4-partner__card-body { gap:40px; }
.s4-partner__text { gap:16px; }
.s4-partner__h3 { font-family:Archivo,sans-serif; font-weight:500; font-size:28px; line-height:36px; color:#1a1a1a; }
.s4-partner__h3--light { color:#fdfdfc; }
.s4-partner__body { font-family:Geist,sans-serif; font-weight:400; font-size:16px; line-height:24px; color:#1a1a1a; }
.s4-partner__body--light { color:#fdfdfc; }
.s4-partner__cta-light { display:flex; justify-content:center; align-items:center; gap:16px; padding:16px 32px; border:1px solid #fdfdfc; border-radius:4px; }
.s4-partner__cta-light span { font-family:"DM Mono",monospace; font-weight:500; font-size:14px; line-height:14px; text-transform:uppercase; color:#1a1a1a; }
/* ===== s5-pod (Figma node 7388:15731) ===== */
.s5-pod__eyebrow { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; text-transform:uppercase; color:#5d4af5; }
.s5-pod__title { font-family:Archivo,sans-serif; font-weight:500; font-size:40px; line-height:48px; color:#1a1a1a; }
.s5-pod__card { background-color:#fff; border:1px solid #e6e9ee; border-radius:6px; padding:32px; gap:28px; }
.s5-pod__label { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; text-transform:uppercase; color:#5d4af5; }
.s5-pod__body { font-family:Geist,sans-serif; font-weight:400; font-size:16px; line-height:24px; color:#1a1a1a; }
.s5-pod__link,.s5-pod__link-arrow { font-family:"DM Mono",monospace; font-weight:500; font-size:14px; line-height:20px; text-transform:uppercase; color:#5d4af5; }
/* Long-arrow vector (Figma node 7388:15842, 31.69x12, #5D4AF5) replaces the short unicode glyph */
.s5-pod__link-arrow { display:inline-block; width:32px; height:12px; font-size:0; color:transparent; background:no-repeat center/contain url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='32'%20height='12'%20viewBox='0%200%2032%2012'%20fill='none'%3E%3Cpath%20d='M0%206h26.5M25%201l6%205-6%205'%20stroke='%235D4AF5'%20stroke-width='1.71'%3E%3C/path%3E%3C/svg%3E"); }
/* ===== s6-tl (Figma node 7388:15845) ===== */
.s6-tl__eyebrow { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; text-transform:uppercase; color:#5d4af5; }
.s6-tl__title { font-family:Archivo,sans-serif; font-weight:500; font-size:40px; line-height:48px; color:#1a1a1a; }
.s6-tl__h3 { font-family:Archivo,sans-serif; font-weight:500; font-size:28px; line-height:36px; color:#1a1a1a; }
.s6-tl__body { font-family:Geist,sans-serif; font-weight:400; font-size:16px; line-height:24px; color:#1a1a1a; }
.s6-tl__divider { background-color:#e6e9ee; height:1px; }
/* Figma: every step-number wrapper is a FIXED 50px box so the step text columns align;
   the carried build shrank --01/--03 to glyph width (40/48), misaligning the columns. */
.s6-tl__num { width: 50px; background-position: left center; }
.s6-tl__num--01, .s6-tl__num--03 { width: 50px; }
.s6-tl__roi { background-color:#fff; border:1px solid #e6e9ee; border-radius:6px; padding:52px 56px; gap:32px; }
.s6-tl__roi-title { font-family:"DM Mono",monospace; font-weight:500; font-size:28px; line-height:36px; color:#211753; }
.s6-tl__roi-item { font-family:"DM Mono",monospace; font-weight:400; font-size:28px; line-height:36px; color:#211753; }
.s6-tl__cta { background-color:#1a1a1a; border-radius:4px; padding:16px 32px; }
.s6-tl__cta span { font-family:"DM Mono",monospace; font-weight:500; font-size:14px; line-height:14px; text-transform:uppercase; color:#fff; }
/* ===== s7-sla (Figma node 7388:15880) ===== */
.s7-sla {
	gap:60px;
	padding:128px 140px;
}
.s7-sla__head {
	gap:16px;
}
.s7-sla__eyebrow {
	font-family:"DM Mono",monospace;
	font-weight:400;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	color:#5d4af5;
}
.s7-sla__title {
	font-family:Archivo,sans-serif;
	font-weight:500;
	font-size:40px;
	line-height:48px;
	color:#1a1a1a;
}
.s7-sla__cards {
	gap:40px;
}
.s7-sla__card {
	background-color:#fff;
	border:1px solid #e6e9ee;
	border-radius:6px;
	padding:44px;
	gap:40px;
}
.s7-sla__txt {
	gap:16px;
}
.s7-sla__label {
	font-family:"DM Mono",monospace;
	font-weight:400;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	color:#5d4af5;
}
.s7-sla__body {
	font-family:Geist,sans-serif;
	font-weight:400;
	font-size:16px;
	line-height:24px;
	color:#1a1a1a;
}
.s7-sla__cta {
	background-color:#1a1a1a;
	border-radius:4px;
	gap:16px;
	padding:16px 32px;
	font-family:"DM Mono",monospace;
	font-weight:500;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	color:#fff;
}
.s7-sla__cta-arrow {
	color:#fff;
}
/* ===== homeai (Figma node 7388:15673) ===== */
.homeai { background-color:#f7f7f7; border-top:1px solid #e6e9ee; padding:128px 140px; }
.homeai__card { background-color:#5d4af5; border-radius:6px; padding:60px 64px; gap:64px; align-items:flex-end; }
.homeai__col { gap:40px; }
.homeai__head { gap:16px; }
.homeai__eyebrow { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; text-transform:uppercase; color:#aa9fff; }
.homeai__title { font-family:Archivo,sans-serif; font-weight:500; font-size:40px; line-height:48px; color:#fdfdfc; }
.homeai__row { gap:24px; align-items:center; }
.homeai__input { width:340px; gap:8px; }
.homeai__label { font-family:"DM Mono",monospace; font-weight:500; font-size:12px; line-height:16px; text-transform:uppercase; color:#fdfdfc; }
.homeai__select { background-color:#fdfdfc; border-radius:4px; padding:10px 12px; gap:8px; }
.homeai__select-text { font-family:"DM Mono",monospace; font-weight:400; font-size:14px; line-height:20px; color:#686868; }
.homeai__select-arrow { color:#686868; }
.homeai__chips { gap:8px; }
.homeai__chip { width:40px; height:40px; border:1px solid rgba(230,233,238,0.5); border-radius:4px; padding:8px; }
/* ===== s8-proof (Figma node 7388:15913) ===== */
.s8-proof {
	border-top:1px solid #e6e9ee;
}
.s8-proof__wrap {
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:60px;
	/* The carried webflow.css section gives the section padding:128px 0 (vertical
	 * inset). Only supply the horizontal 140px here — declaring the full
	 * shorthand re-added 128px top/bottom on top of the section, doubling the
	 * vertical inset (984px tall vs Figma's 727px). */
	padding:0 140px;
}
.s8-proof__head {
	display:flex;
	flex-direction:column;
	gap:16px;
	text-align:center;
}
.s8-proof__eyebrow {
	font-family:"DM Mono",monospace;
	font-weight:400;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	color:#5d4af5;
}
.s8-proof__title {
	font-family:Archivo,sans-serif;
	font-weight:500;
	font-size:40px;
	line-height:48px;
	color:#1a1a1a;
}
.s8-proof__kpis {
	display:flex;
	flex-direction:row;
	align-items:center;
	gap:24px;
}
.s8-proof__kpi {
	display:flex;
	flex-direction:column;
	gap:16px;
	padding:32px;
	background-color:#fff;
	border:1px solid #e6e9ee;
	border-radius:6px;
}
.s8-proof__kpi-label {
	font-family:"DM Mono",monospace;
	font-weight:400;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	color:#5d4af5;
	opacity:0.8;
}
.s8-proof__kpi-row {
	display:flex;
	flex-direction:row;
	align-items:center;
	gap:8px;
}
.s8-proof__kpi-num {
	font-family:Archivo,sans-serif;
	font-weight:500;
	font-size:28px;
	line-height:36px;
	color:#1a1a1a;
}
.s8-proof__stories {
	display:flex;
	flex-direction:row;
	gap:24px;
}
.s8-proof__story {
	display:flex;
	flex-direction:column;
	gap:32px;
}
.s8-proof__story-divider {
	width:1px;
	background-color:#e6e9ee;
}
.s8-proof__story-txt {
	display:flex;
	flex-direction:column;
	gap:8px;
}
.s8-proof__story-title {
	font-family:Geist,sans-serif;
	font-weight:600;
	font-size:16px;
	line-height:24px;
	color:#1a1a1a;
}
.s8-proof__story-body {
	font-family:Geist,sans-serif;
	font-weight:400;
	font-size:16px;
	line-height:24px;
	color:#1a1a1a;
}
/* ============================================================
 * s9-why  (Figma node 7388:15977)
 * ============================================================ */
.s9-why {
	border-top:1px solid #e6e9ee;
	border-bottom:1px solid #e6e9ee;
	padding:128px 140px;
	gap:60px;
}
.s9-why__head {
	gap:24px;
	max-width:1160px;
}
.s9-why__eyebrow {
	font-family:"DM Mono",monospace;
	font-weight:400;
	font-size:14px;
	line-height:20px;
	text-transform:uppercase;
	text-align:center;
	color:#5d4af5;
}
.s9-why__title {
	font-family:Archivo,sans-serif;
	font-weight:500;
	font-size:40px;
	line-height:48px;
	text-align:center;
	color:#1a1a1a;
}
.s9-why__grid {
	gap:40px;
}
.s9-why__col {
	gap:40px;
}
.s9-why__row {
	gap:64px;
}
.s9-why__txt {
	gap:16px;
}
.s9-why__h3 {
	font-family:Archivo,sans-serif;
	font-weight:500;
	font-size:28px;
	line-height:36px;
	color:#1a1a1a;
}
.s9-why__body {
	font-family:Geist,sans-serif;
	font-weight:400;
	font-size:16px;
	line-height:24px;
	color:#1a1a1a;
}
.s9-why__divider-h {
	height:1px;
	background-color:#e6e9ee;
}
.s9-why__divider-v {
	width:1px;
	background-color:#e6e9ee;
}
.s9-why__close {
	font-family:Geist,sans-serif;
	font-weight:400;
	font-size:16px;
	line-height:24px;
	text-align:center;
	color:#1a1a1a;
}
/* ============================================================
 * home_testimonials  (Figma node 7388:15631) — "Hear from our
 * customers" carousel. Dependency-free; JS in main.js drives it.
 * ============================================================ */
.home-tm {
	box-sizing: border-box;
	background-color: #f7f7f7;
	border-top: 1px solid #e6e9ee;
	border-bottom: 1px solid #e6e9ee;
	padding: 128px 140px;
}
.home-tm__wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 60px;
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
}
.home-tm__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
	text-align: center;
}
.home-tm__eyebrow {
	margin: 0;
	font-family: "DM Mono", monospace;
	font-weight: 400;
	font-size: 14px;
	line-height: 20px;
	text-transform: uppercase;
	color: #5d4af5;
}
.home-tm__title {
	margin: 0;
	font-family: Archivo, sans-serif;
	font-weight: 500;
	font-size: 40px;
	line-height: 48px;
	color: #1a1a1a;
}
.home-tm__carousel {
	width: 100%;
	max-width: 1160px;
	display: flex;
	flex-direction: column;
	gap: 24px;
}
.home-tm__viewport {
	overflow: hidden;
	width: 100%;
}
.home-tm__track {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
	transition: transform 0.45s ease;
}
.home-tm__slide {
	box-sizing: border-box;
	flex: 0 0 100%;
	display: flex;
	flex-direction: row;
	gap: 40px;
	background-color: #fff;
	border: 1px solid #e6e9ee;
	border-radius: 6px;
	padding: 12px;
}
.home-tm__media {
	position: relative;
	flex: 0 0 345px;
	width: 345px;
	height: 480px;
	border-radius: 4px;
	overflow: hidden;
}
.home-tm__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.home-tm__media-overlay {
	position: absolute;
	inset: 0;
	background-color: rgba(0, 0, 0, 0.3);
}
.home-tm__play {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background-color: rgba(247, 247, 247, 0.8);
	display: flex;
	align-items: center;
	justify-content: center;
}
.home-tm__play img {
	width: 40px;
	height: 40px;
	display: block;
}
.home-tm__content {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 40px;
	padding: 44px 32px 44px 0;
}
.home-tm__quote {
	margin: 0;
	font-family: Archivo, sans-serif;
	font-weight: 500;
	font-size: 24px;
	line-height: 32px;
	color: #1a1a1a;
}
.home-tm__body {
	margin: 0;
	font-family: Geist, sans-serif;
	font-weight: 400;
	font-size: 16px;
	line-height: 24px;
	color: #686868;
}
.home-tm__footer-row {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	gap: 16px;
}
.home-tm__authors {
	display: flex;
	flex-direction: row;
	gap: 16px;
}
.home-tm__author {
	display: flex;
	flex-direction: column;
}
.home-tm__author-name {
	font-family: Geist, sans-serif;
	font-weight: 600;
	font-size: 16px;
	line-height: 24px;
	color: #1a1a1a;
}
.home-tm__author-role {
	font-family: Geist, sans-serif;
	font-weight: 400;
	font-size: 14px;
	line-height: 20px;
	color: #686868;
}
.home-tm__logo {
	height: 32px;
	width: auto;
	flex-shrink: 0;
}
.home-tm__ui {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}
.home-tm__fraction {
	margin: 0;
	padding-left: 16px;
	font-family: Archivo, sans-serif;
	font-weight: 500;
	color: #1a1a1a;
}
.home-tm__frac-current {
	font-size: 24px;
	line-height: 32px;
}
.home-tm__frac-sep,
.home-tm__frac-total {
	font-size: 20px;
	line-height: 28px;
}
.home-tm__arrows {
	display: flex;
	flex-direction: row;
	gap: 12px;
}
.home-tm__arrow {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	padding: 0;
	background: none;
	border: 1px solid #1a1a1a;
	border-radius: 4px;
	cursor: pointer;
}
.home-tm__arrow img {
	width: 14px;
	height: 14px;
}
/* Figma shows both nav arrows equally dark on slide 1/3 — keep the disabled
   (first-slide) prev visually identical, just non-interactive. */
.home-tm__arrow[disabled] {
	cursor: default;
}

/* video lightbox (testimonial play buttons) */
.ld-lightbox {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 24px;
	background-color: rgba(0, 0, 0, 0.82);
}
.ld-lightbox__inner {
	position: relative;
	width: 100%;
	max-width: 960px;
}
.ld-lightbox__frame {
	position: relative;
	height: 0;
	padding-bottom: 56.25%;
}
.ld-lightbox__frame iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: 8px;
}
.ld-lightbox__close {
	position: absolute;
	top: -42px;
	right: 0;
	padding: 0;
	background: none;
	border: 0;
	color: #fff;
	font-size: 34px;
	line-height: 1;
	cursor: pointer;
}

/* quote: no UA blockquote indent/border (Figma has none) */
.home-tm__quote { border: 0; padding: 0; }

/* ============================================================
 * Side vertical lines (Figma "Vertical lines" overlay, 1280-wide
 * content column at x80/x1360) — applied uniformly so they run
 * continuously down every home section, matching Figma.
 * ============================================================ */
.s1-problem, .home-tm, .s4-partner, .s5-pod, .s6-tl, .s7-sla, .s8-proof, .s9-why {
	position: relative;
}
.s1-problem::before, .home-tm::before, .s4-partner::before, .s5-pod::before,
.s6-tl::before, .s7-sla::before, .s8-proof::before, .s9-why::before {
	content: "";
	position: absolute;
	z-index: 0;
	top: 0;
	bottom: 0;
	left: calc(50% - 640px);
	right: calc(50% - 640px);
	border-left: 1px solid #e6e9ee;
	border-right: 1px solid #e6e9ee;
	pointer-events: none;
}
/* keep each section's actual content above the lines */
.s1-problem__wrap, .home-tm__wrap, .s4-partner__wrap, .s5-pod__wrap,
.s6-tl__wrap, .s7-sla__wrap, .s8-proof__wrap, .s9-why__wrap {
	position: relative;
	z-index: 1;
}

/* ============================================================
 * s1-problem — complete the Figma-exact LAYOUT (the first-pass
 * block only set type/card; gaps+padding were left to carried CSS
 * and drifted). Figma node 7388:15573.
 * ============================================================ */
.s1-problem {
	padding: 128px 140px;
}
.s1-problem__wrap {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 60px;
}
.s1-problem__head {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
	text-align: center;
}
.s1-problem__steps {
	display: flex;
	flex-direction: column;
	gap: 24px;
	width: 100%;
}
.s1-problem__row {
	display: flex;
	flex-direction: row;
	gap: 24px;
	width: 100%;
}
.s1-problem__row--3 > .s1-problem__card,
.s1-problem__row--2 > .s1-problem__card {
	flex: 1 1 0;
	min-width: 0;
}
.s1-problem__card {
	display: flex;
	flex-direction: column;
	gap: 40px;
	padding: 40px;
}

/* problem cards must FILL the row (carried CSS capped their max-width →
   narrow cards, wrapped titles, asymmetry). Figma cards fill the column. */
.s1-problem__card {
	max-width: none;
	width: auto;
}

/* force the problem content column to the full Figma 1160 (carried CSS capped
   the wrap → narrow row → wrapped titles). */
.s1-problem__wrap { max-width: 1160px; width: 100%; }
.s1-problem__steps, .s1-problem__row { max-width: none; width: 100%; }

/* carried CSS pins the problem row narrow (live layout) — force Figma's full
   width so the 3 cards fill 1160 and titles sit on one line. */
.s1-problem__steps { width: 100% !important; max-width: none !important; }
.s1-problem__row { width: 100% !important; max-width: none !important; }
.s1-problem__row--3 > .s1-problem__card,
.s1-problem__row--2 > .s1-problem__card {
	flex: 1 1 0 !important;
	max-width: none !important;
	width: auto !important;
}

/* carried .s1-problem__wrap adds its own 140px padding ON TOP of the section
   padding (double inset → 880px content). Zero it: the section owns padding. */
.s1-problem__wrap { padding: 0 !important; }

/* lead paragraph: Figma Description node (7388:15580) is horizontal:fill →
   spans the full head width (1160). Carried webflow.css caps it at 720px;
   match Figma's fill behavior (.s1-problem__close already uses 1160). */
.s1-problem__lead { max-width: 1160px; }

/* card titles: negative tracking (design uses it on headings; hero=-0.01em).
   Closes the ~12px overflow so "You hired more engineers." sits on ONE line
   like Figma → all card bodies align. */

/* Figma renders Archivo ~4.6% narrower than Chrome's self-hosted cut, so card
   titles overflow by ~12px and wrap. Match Figma's effective width with -0.025em
   tracking → titles sit on one line, card bodies align. (Root: self-hosted
   Archivo width vs Figma — revisit with the variable font later.) */

/* card title weight: Figma renders this MUCH lighter than our 600 cut (our
   self-hosted Archivo is heavier). Match Figma's visual = Medium 500. */

/* DOUBLE-PADDING FIX: these 3 sections set section-padding (128/140) AND their
   carried __wrap also has 140px → content squeezed to 880. Zero the wrap padding
   so the section owns it → content 1160 (like s1-problem). */
.s7-sla__wrap, .homeai__wrap, .s9-why__wrap { padding: 0 !important; }

/* ============================================================
 * HEADER — floating pill navbar (Figma 7218:14167 / 7388:16045)
 * 3-way layout: logo (left) | nav (centered) | actions (right).
 * Collapses to a hamburger dropdown below the medium breakpoint.
 * ============================================================ */
.ld-header { position: fixed; top: 32px; left: 50%; transform: translateX(-50%); z-index: 1000; width: calc(100% - 48px); max-width: 1212px; }
.ld-header__bar { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 14px 32px; background-color: #f7f7f7; border: 1px solid #e6e9ee; border-radius: 12px; box-shadow: 0 67px 80px rgba(0,0,0,.07), 0 8.39px 10.02px rgba(0,0,0,.04); }
.ld-header__logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.ld-header__logo img { display: block; width: 124px; height: 32px; }
.ld-header__nav { display: flex; align-items: center; gap: 28px; }
.ld-header__link { font-family: "DM Mono", monospace; font-weight: 400; font-size: 14px; line-height: 20px; text-transform: uppercase; color: #1a1a1a; text-decoration: none; white-space: nowrap; transition: color .15s ease; }
.ld-header__link.is-active { font-weight: 500; color: #5d4af5; }
.ld-header__link:hover, .ld-header__link:focus-visible { color: #5d4af5; }
.ld-header__actions { display: flex; align-items: center; gap: 24px; flex-shrink: 0; }
.ld-header__cta { display: inline-flex; align-items: center; gap: 12px; padding: 8px 24px; background-color: #5d4af5; border-radius: 4px; color: #fdfdfc; font-family: "DM Mono", monospace; font-weight: 500; font-size: 14px; line-height: 20px; text-transform: uppercase; text-decoration: none; white-space: nowrap; }
.ld-header__cta-arrow { display: inline-flex; align-items: center; }
.ld-header__cta-arrow svg { display: block; }
.ld-header__cta--mobile { display: none; }
.ld-header__burger { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 40px; height: 40px; padding: 0; background: none; border: 0; cursor: pointer; }
.ld-header__burger span { display: block; width: 22px; height: 2px; margin: 0 auto; background-color: #1a1a1a; transition: transform .2s ease, opacity .2s ease; }
.ld-header__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ld-header__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.ld-header__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 991px) {
	.ld-header__burger { display: flex; }
	.ld-header__cta--desktop { display: none; }
	.ld-header__cta--mobile { display: inline-flex; justify-content: center; }
	.ld-header__nav { position: absolute; top: calc(100% + 8px); left: 0; right: 0; flex-direction: column; align-items: stretch; gap: 18px; padding: 24px; background-color: #f7f7f7; border: 1px solid #e6e9ee; border-radius: 12px; box-shadow: 0 24px 48px rgba(0,0,0,.12); display: none; }
	.ld-header__nav.is-open { display: flex; }
}
@media (max-width: 479px) {
	.ld-header { top: 16px; width: calc(100% - 32px); }
	.ld-header__bar { padding: 12px 16px; }
}
body:not(.home) #main { padding-top: 120px; }

/* ============================================================
 * Font smoothing — Chrome's DEFAULT (subpixel) renders text HEAVIER
 * than Figma's grayscale antialiasing, making everything look bolder
 * than the design. Grayscale smoothing matches Figma → correct weight.
 * ============================================================ */
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }

/* ============================================================
 * MOBILE header → match the LIVE site: CTA stays inline as an
 * OUTLINED button (not hidden in the dropdown, not filled purple),
 * the dropdown nav is CENTERED, and a purple CUSTOMER HUB link sits
 * at the bottom of the menu.
 * ============================================================ */
.ld-header__hub { display: none; }
@media (max-width: 991px) {
	/* inline outlined CTA */
	.ld-header__cta { background-color: transparent; border: 1px solid #1a1a1a; color: #1a1a1a; padding: 8px 16px; }
	.ld-header__cta .ld-header__cta-arrow { display: none; }
	/* centered dropdown menu */
	.ld-header__nav { align-items: center; text-align: center; gap: 24px; padding: 28px 24px; }
	/* CUSTOMER HUB link */
	.ld-header__hub { display: inline-flex; align-items: center; gap: 8px; margin-top: 4px; font-family: "DM Mono", monospace; font-weight: 500; font-size: 14px; line-height: 20px; text-transform: uppercase; color: #5d4af5; text-decoration: none; }
	.ld-header__hub-arrow { display: inline-flex; align-items: center; }
}
@media (max-width: 479px) {
	.ld-header__cta { padding: 8px 12px; }
	.ld-header__bar { gap: 12px; }
}

/* ============================================================
 * FOOTER (Figma footer 7217:12580 / live section_footer)
 * Purple footer: link groups, contact, subscribe, AI links,
 * large wordmark, Clutch + copyright.
 * ============================================================ */
.ld-footer {
	box-sizing: border-box;
	position: relative;
	overflow: hidden;
	/* Figma footer bg = purple #614afc with a faint white dot grid, stretched 100%×100% */
	background-color: #614afc;
	background: #614afc url("../images/footer/footer-bg.png") center / 100% 100% no-repeat;
	background-image: image-set(
		url("../images/footer/footer-bg.webp") type("image/webp"),
		url("../images/footer/footer-bg.png") type("image/png")
	);
	color: #fdfdfc;
	padding: 80px 140px 48px;
	/* Figma footer sub-frame top stroke — faint full-width divider (white @20%)
	   separating the CTA band from the footer nav row. strokeWeight 1px 0 0. */
	border-top: 1px solid rgba(253, 253, 252, 0.2);
}
.ld-footer__inner {
	width: 100%;
	max-width: 1160px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	position: relative;
	z-index: 1;
}
/* Figma "Vertical lines" overlay — the site-wide pinstripes at x80/x1360 continue
   through the footer. White @20% (the footer bg is purple, not the light page). */
.ld-footer::before {
	content: "";
	position: absolute;
	z-index: 0;
	top: 0;
	bottom: 0;
	left: calc(50% - 640px);
	right: calc(50% - 640px);
	border-left: 1px solid rgba(253, 253, 252, 0.2);
	border-right: 1px solid rgba(253, 253, 252, 0.2);
	pointer-events: none;
}
.ld-footer__top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	gap: 24px;
	flex-wrap: wrap;
}
.ld-footer__links { display: flex; flex-wrap: wrap; gap: 24px; }
.ld-footer__link {
	font-family: "DM Mono", monospace;
	font-weight: 400;
	font-size: 14px;
	line-height: 20px;
	text-transform: uppercase;
	color: #fdfdfc;
	text-decoration: none;
	transition: opacity 0.15s ease;
}
.ld-footer__link:hover { opacity: 0.7; }
.ld-footer__contact {
	margin: 52px 0 0;
	display: flex;
	gap: 8px;
	font-family: "DM Mono", monospace;
	font-size: 14px;
	line-height: 20px;
	text-transform: uppercase;
}
.ld-footer__contact a { color: #fdfdfc; text-decoration: none; }
.ld-footer__contact-label { opacity: 0.7; }
.ld-footer__row {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	gap: 40px;
	margin-top: 52px;
	flex-wrap: wrap;
}
.ld-footer__subscribe { display: flex; flex-direction: column; gap: 8px; flex: 0 0 auto; }
/* Figma: Input Label/Medium — DM Mono 500 12/16, #FDFDFC */
.ld-footer__sub-label {
	font-family: "DM Mono", monospace;
	font-weight: 500;
	font-size: 12px;
	line-height: 16px;
	text-transform: uppercase;
}
.ld-footer__sub-row { display: flex; gap: 16px; }
/* Figma: Input Frame fill #FDFDFC (solid white), no border, h40, DM Mono 14, placeholder #686868.
   Figma Input instance is a fixed 340px column (layout_H5HG2C width:340); the Subscribe
   button (172px) sits to its right at the row gap. */
.ld-footer__sub-input {
	width: 340px;
	flex: 0 0 auto;
	min-width: 0;
	height: 40px;
	padding: 0 12px;
	border: 0;
	border-radius: 4px;
	background-color: #fdfdfc;
	color: #1a1a1a;
	font-family: "DM Mono", monospace;
	font-size: 14px;
	line-height: 20px;
}
.ld-footer__sub-input::placeholder { color: #686868; }
/* Figma: Button "White Outline" — transparent fill, 1px #E6E9EE border, white text, h40, w172 */
.ld-footer__sub-btn {
	height: 40px;
	min-width: 172px;
	padding: 0 24px;
	border: 1px solid #e6e9ee;
	border-radius: 4px;
	background-color: transparent;
	color: #fdfdfc;
	font-family: "DM Mono", monospace;
	font-weight: 500;
	font-size: 14px;
	text-transform: uppercase;
	cursor: pointer;
}
/* Figma: Input Label/Regular — DM Mono 400 12/16, #FDFDFC */
.ld-footer__sub-note {
	margin: 0;
	font-family: "DM Mono", monospace;
	font-size: 12px;
	line-height: 16px;
	color: #fdfdfc;
}
.ld-footer__ai { display: flex; flex-direction: column; gap: 12px; align-items: flex-end; text-align: right; }
.ld-footer__ai-links { display: flex; gap: 16px; }
/* Figma: AI buttons fill #FDFDFC (white chip), 1px #E6E9EE border, dark #1A1A1A icon */
.ld-footer__ai-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid #e6e9ee;
	border-radius: 4px;
	background-color: #fdfdfc;
}
.ld-footer__ai-btn img { width: 16px; height: 16px; object-fit: contain; }
/* "Ask AI…" caption — Figma DM Mono 12/16, #E6E9EE */
.ld-footer__ai-desc { margin: 0; font-family: "DM Mono", monospace; font-size: 12px; line-height: 16px; color: #e6e9ee; }
.ld-footer__wordmark { display: block; }
/* Figma wordmark frame is a fixed 775px (53.8% of 1440) and overflows its column;
   the SVG's right edge clears the graphic, so reproduce the natural size. */
.ld-footer__wordmark img { display: block; width: clamp(240px, 53.8vw, 775px); max-width: none; height: auto; }
.ld-footer__bottom {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
}
.ld-footer__clutch img { display: block; height: 40px; width: auto; }
.ld-footer__copyright { margin: 0; font-family: Geist, sans-serif; font-size: 14px; line-height: 20px; color: #fdfdfc; }

@media (max-width: 991px) {
	.ld-footer { padding: 64px 24px 40px; }
	.ld-footer__row { flex-direction: column; align-items: stretch; gap: 32px; }
	.ld-footer__ai { align-items: flex-start; text-align: left; }
	.ld-footer__subscribe { min-width: 0; flex: 1 1 auto; }
	.ld-footer__sub-input { width: auto; flex: 1 1 auto; }
}

/* footer brand row: wordmark + clutch + copyright (left) | two-square graphic (right).
   The row breaks out of the centered max-width inner so the graphic bleeds flush to
   the footer's right + bottom edges, exactly like Figma "Footer Graphic 1" (682×452). */
.ld-footer__brand {
	display: flex;
	align-items: flex-end;
	gap: 0;
	margin-top: 64px;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding-left: max(140px, calc(50vw - 580px));
}
.ld-footer__brand-col { flex: 1 1 auto; min-width: 0; display: flex; flex-direction: column; gap: 40px; }
.ld-footer__graphic {
	flex: 0 0 52.46%;            /* 682 of the 1300px content box (1440 − 140 left pad) */
	align-self: flex-end;
	position: relative;
	aspect-ratio: 682 / 452;
	margin-bottom: -48px;        /* bleed past the footer's bottom padding to the edge */
	background: none;
}
/* two white rectangles, anti-diagonal step (Figma): top-right 391×291 @ (291,0); bottom-left 291×161 @ (0,291) */
.ld-footer__graphic::before,
.ld-footer__graphic::after { content: ""; position: absolute; background-color: #fdfdfc; }
.ld-footer__graphic::before { top: 0;      left: 42.67%; width: 57.33%; height: 64.38%; } /* 291/682 · 391/682 · 291/452 */
.ld-footer__graphic::after  { top: 64.38%; left: 0;      width: 42.67%; height: 35.62%; } /* 291/452 · 291/682 · 161/452 */
@media (max-width: 991px) {
	.ld-footer__graphic { display: none; }
	/* graphic is hidden on mobile — undo the desktop full-bleed break-out so the
	   wordmark/clutch/copyright align to the footer's normal left edge */
	.ld-footer__brand { width: auto; margin-left: 0; margin-right: 0; padding-left: 0; }
}

/* ── Footer CTA band (.section_footer-cta) — Figma node I7388:16043;4086:466 ──
   The cta is the top band of the Figma footer INSTANCE (7388:16043), which carries a
   dark IMAGE background fill (imageRef 5c1747ff…). WP renders the band as a standalone
   section on the near-white #F7F7F7 paper body, so its #FDFDFC white text was invisible
   (~1.02:1 contrast). Restore legibility with a scoped dark ink surface + Figma-exact
   button/typography. All rules SCOPED to .section_footer-cta — no shared surfaces touched.
   FLAG-FOR-HUMAN: flat #1A1A1A ink is the minimum legibility autofix; the live design
   intends the footer's dark IMAGE bg (imageRef 5c1747ff…) — confirm with Sandro whether
   that asset should be exported + applied instead of the flat fill. */
.section_footer-cta {
	background-color: #1a1a1a;                       /* dark ink so #FDFDFC text reads */
	border-top: 1px solid rgba(253, 253, 252, 0.2);  /* Figma cta top stroke 1px 0 0 */
}
.section_footer-cta .heading-style-h1 {
	font-family: Archivo, sans-serif;                /* Figma H1/Medium (was Helvetica Now Display) */
}
.section_footer-cta .paragraph-6 {
	font-family: Geist, sans-serif;                  /* Figma P lg/Medium (was Helvetica Neue) */
	line-height: 28px;                               /* Figma 28px (was 30px) */
}
.section_footer-cta .link-block-4 {
	border: 1px solid #e6e9ee;                       /* Figma stroke fill_N3CZLV (was 1px #FDFDFC, invisible) */
	border-radius: 4px;                              /* Figma Button borderRadius (was 6px) */
	padding: 12px 32px;                              /* Figma button layout_7G57DC (was 16px 32px) */
}
.section_footer-cta .padding-vertical {
	padding-top: 124px;                              /* Figma cta frame padding 124px (was 128px) */
	padding-bottom: 124px;                           /* Figma cta frame padding 124px (was 128px) */
}
.section_footer-cta .text-block-29 {
	font-weight: 500;                                /* Figma Button/Medium DM Mono 500 (was 400) */
	line-height: 20px;                               /* Figma Button/Medium 14/20 (was 14px) */
}

/* ============================================================
 * Mobile parity — desktop-first sections need fluid widths +
 * reduced padding so nothing overflows the small viewport.
 * ============================================================ */
@media (max-width: 991px) {
	/* homeai purple card: fluid, no fixed 340 input, reduced padding */
	.homeai { padding: 64px 24px; }
	.homeai__card { padding: 32px; gap: 32px; align-items: stretch; }
	.homeai__title { font-size: 32px; line-height: 40px; }
	.homeai__row { flex-direction: column; align-items: stretch; gap: 24px; }
	.homeai__input { width: 100%; }
	.homeai__illus { width: 100%; }
}
@media (max-width: 479px) {
	.homeai { padding: 56px 20px; }
	.homeai__card { padding: 24px 20px; gap: 24px; }
	.homeai__title { font-size: 26px; line-height: 32px; }
}

/* Side vertical pinstripes are a 1280px-wide centred overlay (Figma x80/x1360);
   below 1280 the calc(50% - 640px) goes negative and the ::before spills past the
   viewport → horizontal scroll on tablet/mobile. They are a wide-desktop guide, so
   hide them under 1280 (the design width). */
@media (max-width: 1279px) {
	.s1-problem::before, .home-tm::before, .s4-partner::before, .s5-pod::before,
	.s6-tl::before, .s7-sla::before, .s8-proof::before, .s9-why::before,
	.ld-footer::before { display: none; }
}

/* Content sections carry the Figma desktop padding (128px 140px) unconditionally,
   which clobbers the Webflow mobile padding → 110px content at 390. Restore mobile
   padding so content has room (and nowrap rows like proof KPIs stop overflowing). */
@media (max-width: 991px) {
	.s1-problem, .home-tm, .s4-partner, .s5-pod, .s6-tl, .s7-sla, .s8-proof, .s9-why { padding: 64px 24px; }
}
@media (max-width: 479px) {
	.s1-problem, .home-tm, .s4-partner, .s5-pod, .s6-tl, .s7-sla, .s8-proof, .s9-why { padding: 48px 20px; }
}

/* proof: the content (KPIs + stories) and the KPI metric row are desktop side-by-side;
   stack + wrap them on mobile so the 3 metric cards don't overflow. */
@media (max-width: 991px) {
	.s8-proof__content { flex-direction: column; }
	.s8-proof__kpis { flex-wrap: wrap; }
}

/* Footer CTA = the top of the continuous purple footer panel (Figma): purple + the
   same dotted bg as the footer, instead of the carried dark #1A1A1A. */
.section_footer-cta {
	background-color: #614afc;
	background: #614afc url("../images/footer/footer-bg.png") center / 100% 100% no-repeat;
	background-image: image-set(
		url("../images/footer/footer-bg.webp") type("image/webp"),
		url("../images/footer/footer-bg.png") type("image/png")
	);
}
