:root {
  --black: #080808;
  --ink: #0a0f1f;
  --white: #fff;
  --blue: #2563eb;
  --blue-bright: #3b82f6;
  --blue-dark: #173ea5;
  --paper: #fff;
  --paper-2: #eff6ff;
  --muted: #9db4df;
  --muted-dark: #52627d;
  --line: rgba(255, 255, 255, .14);
  --line-dark: rgba(37, 99, 235, .2);
  --max: 1200px;
  --ease: cubic-bezier(.2, .8, .2, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 84px; }
body {
  margin: 0;
  min-width: 320px;
  background: var(--black);
  color: var(--white);
  font-family: "DM Sans", sans-serif;
  -webkit-font-smoothing: antialiased;
}
body.modal-open, body.menu-open { overflow: hidden; }
button, input, textarea, select { font: inherit; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
p { line-height: 1.7; }
.container { width: min(var(--max), calc(100% - 40px)); margin-inline: auto; }
.section { position: relative; padding: clamp(88px, 10vw, 150px) 0; overflow: hidden; }
.section-light { background: var(--paper); color: var(--ink); }
.hidden, .sr-only {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: fixed; z-index: 999; top: 8px; left: 8px; padding: 10px 15px;
  background: var(--white); color: var(--black); transform: translateY(-160%);
}
.skip-link:focus { transform: none; }

.site-header {
  position: fixed; z-index: 50; inset: 0 0 auto; height: 78px;
  border-bottom: 1px solid transparent; transition: background .3s ease, border-color .3s ease;
}
.site-header.scrolled { background: rgba(8, 8, 8, .86); border-color: var(--line); backdrop-filter: blur(18px); }
.nav-wrap { height: 100%; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; gap: 11px; font-size: 15px; letter-spacing: -.02em; }
.brand b { font-weight: 600; color: var(--blue-bright); }
.brand-mark {
  display: grid; width: 32px; height: 32px; place-items: center;
  border: 1px solid var(--blue-bright); color: var(--blue-bright); font-family: "Manrope", sans-serif; font-size: 13px;
}
.site-nav { display: flex; align-items: center; gap: 31px; font-size: 13px; }
.site-nav > a:not(.button) { color: #c8c8c6; transition: color .2s; }
.site-nav > a:not(.button):hover { color: var(--white); }
.menu-toggle { display: none; border: 0; background: none; color: white; width: 42px; height: 42px; padding: 12px 8px; }
.menu-toggle span:not(.sr-only) { display: block; height: 1px; margin: 7px 0; background: currentColor; transition: transform .25s; }

.button {
  display: inline-flex; min-height: 54px; align-items: center; justify-content: center; gap: 20px;
  padding: 0 24px; border: 1px solid transparent; border-radius: 0; font-size: 13px;
  font-weight: 600; letter-spacing: .01em; cursor: pointer; transition: transform .25s var(--ease), background .25s, color .25s, border .25s;
}
.button:hover { transform: translateY(-2px); }
.button-light { background: var(--blue); color: var(--white); }
.button-light:hover { background: var(--blue-dark); color: var(--white); border-color: var(--blue-bright); }
.button-dark { background: var(--black); color: var(--white); }
.button-dark:hover { background: transparent; color: var(--black); border-color: var(--black); }
.button-outline-dark { border-color: var(--black); background: transparent; color: var(--black); }
.button-outline-dark:hover { background: var(--black); color: var(--white); }
.button-outline-light { border-color: var(--blue-bright); background: transparent; color: var(--white); }
.button-outline-light:hover { background: var(--blue); color: var(--white); }
.button-small { min-height: 42px; padding-inline: 18px; }
.button-full { width: 100%; justify-content: space-between; }
.text-link { display: inline-flex; align-items: center; gap: 14px; padding-bottom: 5px; border-bottom: 1px solid rgba(255,255,255,.45); font-size: 13px; font-weight: 600; }
.text-link span { transition: transform .25s; }
.text-link:hover span { transform: translate(2px, -2px); }
.text-link-dark { border-color: rgba(0,0,0,.4); }

.eyebrow {
  display: flex; align-items: center; gap: 11px; margin: 0 0 24px;
  color: var(--muted); font-size: 11px; font-weight: 600; letter-spacing: .19em; text-transform: uppercase;
}
.eyebrow span { width: 25px; height: 1px; background: currentColor; }
.eyebrow-dark { color: var(--muted-dark); }
.section-heading { max-width: 790px; margin: 0 auto clamp(50px, 7vw, 84px); text-align: center; }
.section-heading .eyebrow { justify-content: center; }
.section-heading h2, .demo-heading h2, .trust-copy h2, .contact-copy h2 {
  margin: 0; font-family: "Manrope", sans-serif; font-size: clamp(38px, 5.5vw, 70px);
  font-weight: 400; letter-spacing: -.055em; line-height: 1.03;
}
.section-heading > p:last-child { max-width: 620px; margin: 24px auto 0; color: var(--muted-dark); font-size: 16px; }
.section-heading-left { margin: 0; text-align: left; }
.section-heading-left .eyebrow { justify-content: flex-start; }
.section-heading-left > p:last-of-type { margin-inline: 0; }

.hero { position: relative; overflow: hidden; padding: 170px 0 0; }
.hero-glow {
  position: absolute; width: 700px; height: 700px; left: 52%; top: -180px;
  border-radius: 50%; background: rgba(37,99,235,.22); filter: blur(110px); pointer-events: none;
}
.hero-grid { display: grid; grid-template-columns: 1.04fr .96fr; gap: clamp(40px, 8vw, 100px); align-items: center; min-height: 610px; }
.hero-copy h1 {
  max-width: 760px; margin: 0; font-family: "Manrope", sans-serif; font-size: clamp(54px, 7vw, 96px);
  font-weight: 400; letter-spacing: -.065em; line-height: .94;
}
.hero-copy h1 em { color: var(--blue-bright); font-style: normal; }
.hero-lead { max-width: 620px; margin: 30px 0 34px; color: #aeaeac; font-size: clamp(16px, 1.4vw, 19px); }
.hero-actions { display: flex; align-items: center; gap: 30px; }
.hero-trust { display: flex; flex-wrap: wrap; gap: 24px; margin: 37px 0 0; padding: 0; list-style: none; color: #9d9d9b; font-size: 12px; }
.hero-trust span { margin-right: 6px; color: var(--blue-bright); }
.hero-visual { position: relative; padding: 35px 0 50px; }
.browser-card { position: relative; border: 1px solid var(--line); background: #101010; box-shadow: 0 30px 90px rgba(0,0,0,.5); transform: perspective(1200px) rotateY(-3deg) rotateX(1deg); }
.browser-top { height: 45px; display: flex; align-items: center; border-bottom: 1px solid var(--line); padding: 0 16px; }
.browser-dots { display: flex; gap: 6px; }
.browser-dots i { width: 5px; height: 5px; border-radius: 50%; background: #656565; }
.browser-url { width: 45%; margin: auto; padding: 5px; background: #171717; color: #626262; font-size: 8px; text-align: center; }
.mock-page { height: 425px; padding: 22px; background: linear-gradient(135deg,#0d0d0d,#181818); }
.mock-nav { display: flex; justify-content: space-between; align-items: center; }
.mock-logo { width: 58px; height: 9px; background: #e6e6e3; }
.mock-links { display: flex; gap: 10px; }
.mock-links i { width: 22px; height: 3px; background: #5d5d5c; }
.mock-content { padding: 75px 16px 58px; }
.mock-content span { display: block; }
.mock-kicker { width: 65px; height: 5px; background: #858583; margin-bottom: 18px; }
.mock-title { width: 84%; height: 24px; margin-bottom: 8px; background: #f4f4f0; }
.mock-title.short { width: 56%; }
.mock-text { width: 70%; height: 5px; margin-top: 25px; background: #656564; }
.mock-text.shorter { width: 50%; margin-top: 8px; }
.mock-button { width: 92px; height: 28px; margin-top: 25px; background: var(--blue); }
.mock-proof { display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line); padding-top: 18px; }
.mock-proof div { display: grid; gap: 4px; padding-left: 15px; border-left: 1px solid var(--line); }
.mock-proof strong { font-size: 12px; }.mock-proof span { color: #696968; font-size: 7px; text-transform: uppercase; letter-spacing: .1em; }
.float-card {
  position: absolute; display: flex; align-items: center; gap: 11px; padding: 13px 15px;
  border: 1px solid rgba(255,255,255,.2); background: rgba(20,20,20,.92); box-shadow: 0 15px 40px rgba(0,0,0,.4); backdrop-filter: blur(10px);
}
.float-card div { display: grid; gap: 3px; }.float-card small { color: #7d7d7b; font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }.float-card strong { font-size: 10px; font-weight: 500; }
.float-lead { left: -34px; bottom: 100px; }.float-chat { right: -15px; top: 85px; }
.status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--blue-bright); box-shadow: 0 0 0 5px rgba(37,99,235,.16); }
.chat-icon { display: grid; width: 27px; height: 27px; place-items: center; border: 1px solid #555; }
.credibility-strip { display: flex; align-items: center; justify-content: space-between; gap: 25px; margin-top: 85px; padding: 30px 0; border-top: 1px solid var(--line); }
.credibility-strip p { margin: 0; color: #6f6f6e; font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.credibility-items { display: flex; gap: clamp(20px, 5vw, 62px); color: #aaa; font-size: 12px; }

.service-grid { display: grid; grid-template-columns: repeat(3,1fr); }
.service-card { position: relative; min-height: 510px; padding: 38px; border: 1px solid var(--line-dark); background: var(--paper); }
.service-card + .service-card { border-left: 0; }
.service-card-dark { background: linear-gradient(145deg,var(--black),#10245c); color: var(--white); border-color: var(--blue); transform: translateY(-18px); box-shadow: 0 25px 60px rgba(37,99,235,.18); }
.service-number { position: absolute; right: 28px; top: 28px; color: #92928f; font-size: 10px; }
.service-icon { display: grid; width: 58px; height: 58px; place-items: center; margin-bottom: 55px; border: 1px solid var(--line-dark); }
.service-card-dark .service-icon { border-color: var(--line); }
.service-icon svg { width: 23px; fill: none; stroke: currentColor; stroke-width: 1.2; }
.service-card h3 { max-width: 260px; margin: 0 0 18px; font-family: "Manrope"; font-size: 27px; font-weight: 500; letter-spacing: -.04em; }
.service-card > p { color: var(--muted-dark); font-size: 14px; }
.service-card-dark > p { color: var(--muted); }
.check-list { display: grid; gap: 12px; margin: 28px 0 0; padding: 25px 0 0; border-top: 1px solid var(--line-dark); list-style: none; font-size: 12px; }
.service-card-dark .check-list, .price-card-featured .check-list { border-color: var(--line); }
.check-list li::before { content: "✓"; margin-right: 10px; }

.industries-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(60px, 10vw, 145px); align-items: start; }
.industries .section-heading > p { color: var(--muted); }
.industries .section-heading .text-link { margin-top: 20px; color: var(--white); }
.industry-list { border-top: 1px solid var(--line); }
.industry-row { display: grid; grid-template-columns: 45px 1fr 1fr; align-items: center; gap: 20px; padding: 26px 0; border-bottom: 1px solid var(--line); transition: padding .3s var(--ease), background .3s; }
.industry-row:hover { padding-inline: 12px; background: rgba(255,255,255,.03); }
.industry-row > span { color: #666; font-size: 10px; }
.industry-row h3 { margin: 0; font-family: "Manrope"; font-size: 20px; font-weight: 500; letter-spacing: -.03em; }
.industry-row p { margin: 0; color: #777; font-size: 12px; }

.process-grid { display: grid; grid-template-columns: repeat(4,1fr); border-top: 1px solid var(--line-dark); }
.process-step { min-height: 255px; padding: 30px 28px 0 0; border-right: 1px solid var(--line-dark); }
.process-step + .process-step { padding-left: 28px; }
.process-step:last-child { border-right: 0; }
.process-step > span { display: inline-grid; width: 35px; height: 35px; margin-bottom: 50px; place-items: center; border: 1px solid var(--line-dark); font-size: 9px; }
.process-step h3 { margin: 0 0 12px; font-size: 17px; font-weight: 600; }.process-step p { margin: 0; color: var(--muted-dark); font-size: 13px; }

.demo-section { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.demo-orb { position: absolute; width: 650px; height: 300px; left: 25%; top: -180px; border-radius: 50%; background: rgba(37,99,235,.25); filter: blur(100px); }
.demo-heading { max-width: 850px; margin-bottom: 55px; }
.demo-heading > p:last-child { max-width: 550px; margin: 22px 0 0; color: var(--muted); }
.video-preview {
  position: relative; display: grid; width: 100%; aspect-ratio: 16/8; overflow: hidden;
  place-items: center; border: 1px solid var(--line); background: #0d0d0d; color: var(--white); cursor: pointer;
  transition: transform .45s var(--ease), border-color .3s;
}
.video-preview:hover { transform: translateY(-5px); border-color: rgba(255,255,255,.45); }
.preview-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .68; pointer-events: none; }
.preview-grid { position: absolute; inset: 0; background: linear-gradient(135deg,rgba(37,99,235,.25),transparent 45%), repeating-linear-gradient(90deg,transparent 0,transparent calc(25% - 1px),rgba(255,255,255,.035) 25%); }
.preview-grid::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at center,rgba(0,0,0,.08) 0,rgba(0,0,0,.68) 90%); }
.preview-content { position: relative; display: grid; justify-items: center; text-align: center; }
.play-button { display: grid; width: 88px; height: 88px; margin-bottom: 25px; place-items: center; border: 1px solid var(--blue-bright); border-radius: 50%; color: var(--blue-bright); transition: background .25s,color .25s,transform .3s; }
.play-button svg { width: 24px; margin-left: 5px; fill: currentColor; }
.video-preview:hover .play-button { background: var(--white); color: var(--black); transform: scale(1.06); }
.preview-content strong { font-size: 16px; font-weight: 500; }.preview-content small { margin-top: 9px; color: #717170; font-size: 9px; letter-spacing: .14em; text-transform: uppercase; }

.pricing-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; max-width: 1000px; margin-inline: auto; }
.price-card { position: relative; display: flex; flex-direction: column; min-height: 650px; padding: clamp(30px,4vw,50px); border: 1px solid var(--line-dark); background: var(--white); }
.price-card-featured { background: var(--black); color: var(--white); border-color: var(--black); }
.popular-label { position: absolute; right: 0; top: 0; padding: 10px 15px; background: var(--white); color: var(--black); font-size: 9px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.plan-label { margin: 0 0 15px; color: var(--muted-dark); font-size: 10px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.price-card-featured .plan-label { color: var(--muted); }
.price-top h3 { margin: 0; font-family: "Manrope"; font-size: 29px; font-weight: 500; letter-spacing: -.04em; }
.price { margin: 33px 0 27px; font-family: "Manrope"; font-size: clamp(50px,6vw,72px); letter-spacing: -.06em; line-height: 1; }
.price sup { font-size: 23px; vertical-align: top; line-height: 1.5; }.price span { color: var(--muted-dark); font: 400 11px "DM Sans"; letter-spacing: 0; }
.price-top > p:last-child { min-height: 70px; color: var(--muted-dark); font-size: 14px; }
.price-card-featured .price-top > p:last-child { color: var(--muted); }
.price-card .check-list { margin-bottom: 40px; }
.purchase-policy { margin: auto 0 18px; padding-top: 16px; border-top: 1px solid var(--line-dark); color: var(--muted-dark); font-size: 10px; line-height: 1.5; }
.price-card-featured .purchase-policy { border-color: var(--line); color: var(--muted); }
.price-card .button { margin-top: 0; }
.checkout-actions { display: grid; gap: 10px; margin-top: auto; }
.refund-note { max-width: 1000px; margin: 42px auto 0; padding: 17px 20px; border: 1px solid var(--line-dark); color: var(--muted-dark); font-size: 11px; line-height: 1.6; text-align: center; }
.refund-note strong { color: var(--ink); }
.care-plan-note { margin: 18px 0 0; padding: 16px; border: 1px solid var(--line-dark); background: var(--paper-2); color: var(--muted-dark); font-size: 11px; line-height: 1.6; }
.care-plan-note strong { color: var(--ink); }
.care-plan-note ul, .plan-upgrade-note ul { display: grid; gap: 7px; margin: 11px 0 0; padding: 0; list-style: none; }
.care-plan-note li, .plan-upgrade-note li { position: relative; padding-left: 15px; }
.care-plan-note li::before, .plan-upgrade-note li::before { position: absolute; left: 0; content: "✓"; font-size: 9px; }
.plan-upgrade-note { margin: 18px 0 0; padding: 16px; border: 1px solid var(--blue); background: rgba(37,99,235,.1); color: #dbeafe; font-size: 11px; line-height: 1.6; }
.plan-upgrade-note strong { color: #fff; }
.scope-note { display: grid; grid-template-columns: .7fr 1.3fr; gap: 40px; max-width: 1000px; margin: 42px auto 0; padding: 28px; border: 1px solid var(--line-dark); background: var(--paper-2); }
.scope-note h3 { margin: 0; font-family: "Manrope",sans-serif; font-size: 22px; font-weight: 500; letter-spacing: -.035em; }
.scope-note > p { margin: 0; color: var(--muted-dark); font-size: 12px; }
.scope-note .plan-label { margin-bottom: 9px; }
.pricing-note { margin: 40px 0 0; color: var(--muted-dark); text-align: center; font-size: 12px; }.pricing-note a { color: var(--ink); border-bottom: 1px solid; }

.trust-section { border-bottom: 1px solid var(--line); }
.trust-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(60px,10vw,150px); }
.trust-copy { position: sticky; top: 130px; align-self: start; }.trust-copy h2 { font-size: clamp(39px,5vw,62px); }
.trust-points { border-top: 1px solid var(--line); }
.trust-points article { display: grid; grid-template-columns: 50px 1fr; gap: 20px; padding: 37px 0; border-bottom: 1px solid var(--line); }
.trust-points article > span { color: #555; font-size: 10px; }.trust-points h3 { margin: 0 0 10px; font-family: "Manrope"; font-size: 21px; font-weight: 500; }.trust-points p { margin: 0; color: #858583; font-size: 13px; }

.faq-grid { display: grid; grid-template-columns: .75fr 1.25fr; gap: clamp(60px,10vw,140px); align-items: start; }
.faq .section-heading .button { margin-top: 30px; }
.accordion { border-top: 1px solid var(--line-dark); }
.accordion details { border-bottom: 1px solid var(--line-dark); }
.accordion summary { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 27px 0; font-size: 16px; font-weight: 600; list-style: none; cursor: pointer; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary span, .accordion summary span::after { width: 14px; height: 1px; background: var(--black); transition: transform .3s; }
.accordion summary span { position: relative; flex: 0 0 auto; }.accordion summary span::after { position: absolute; content: ""; transform: rotate(90deg); }
.accordion details[open] summary span::after { transform: rotate(0); }
.answer { overflow: hidden; }.answer p { max-width: 620px; margin: -3px 0 25px; color: var(--muted-dark); font-size: 13px; }

body:not(.legal-page) > main { display: flex; flex-direction: column; }
.reviews-section { order: 99; border-bottom: 1px solid var(--line); }
.reviews-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(60px,10vw,140px); align-items: start; }
.review-copy { position: sticky; top: 130px; }
.review-copy h2 { margin: 0; font-family: "Manrope",sans-serif; font-size: clamp(42px,5.5vw,70px); font-weight: 400; letter-spacing: -.055em; line-height: 1.03; }
.review-copy > p { max-width: 560px; color: var(--muted); }
.review-standards { display: grid; margin-top: 40px; border-top: 1px solid var(--line); }
.review-standards div { display: grid; grid-template-columns: 34px 1fr; padding: 15px 0; border-bottom: 1px solid var(--line); font-size: 12px; }
.review-standards strong { color: #555; font-size: 9px; }
.review-form select { appearance: none; }
.optional-label { color: #777; font-size: 9px; font-weight: 400; letter-spacing: .08em; text-transform: uppercase; }

.contact-section { border-bottom: 1px solid var(--line); }
.contact-glow { position: absolute; width: 700px; height: 500px; left: -250px; bottom: -250px; border-radius: 50%; background: rgba(37,99,235,.22); filter: blur(100px); }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(60px,10vw,140px); align-items: start; }
.contact-copy h2 { font-size: clamp(44px,6vw,76px); }.contact-copy > p { max-width: 570px; color: var(--muted); }
.direct-contact { display: grid; gap: 0; margin-top: 35px; border-top: 1px solid var(--line); }
.direct-contact a { display: grid; gap: 4px; padding: 17px 0; border-bottom: 1px solid var(--line); transition: padding .25s var(--ease), color .25s; }
.direct-contact a:hover { padding-left: 8px; color: var(--muted); }
.direct-contact small { color: #666; font-size: 9px; font-weight: 600; letter-spacing: .13em; text-transform: uppercase; }
.direct-contact strong { font-size: 14px; font-weight: 500; overflow-wrap: anywhere; }
.contact-expect { display: grid; gap: 0; margin-top: 45px; border-top: 1px solid var(--line); }
.contact-expect div { display: grid; grid-template-columns: 35px 1fr; padding: 17px 0; border-bottom: 1px solid var(--line); font-size: 12px; }.contact-expect strong { color: #555; font-size: 9px; }
.contact-form { display: grid; gap: 21px; padding: clamp(28px,4vw,48px); border: 1px solid var(--line); background: rgba(255,255,255,.025); }
.form-intro { padding-bottom: 22px; border-bottom: 1px solid var(--line); }
.form-intro .plan-label { margin: 0 0 10px; color: var(--blue-bright); }
.form-intro h3 { margin: 0; font-family: "Manrope",sans-serif; font-size: clamp(24px,3vw,34px); font-weight: 500; letter-spacing: -.04em; }
.form-intro > p:last-child { margin: 12px 0 0; color: #8fa0c0; font-size: 12px; }
.form-row { display: grid; grid-template-columns: repeat(2,1fr); gap: 17px; }
.contact-form label { display: grid; gap: 9px; color: #aaa; font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; }
.contact-form input, .contact-form textarea, .contact-form select {
  width: 100%; border: 1px solid var(--line); border-radius: 0; outline: 0; background: #0b0b0b; color: var(--white);
  padding: 15px; font-size: 14px; letter-spacing: 0; text-transform: none; transition: border-color .2s;
}
.contact-form input { height: 49px; }.contact-form textarea { resize: vertical; min-height: 120px; }.contact-form select { height: 49px; appearance: none; }
.contact-form .file-input { height: auto; padding: 10px; color: #c8d5ef; cursor: pointer; }
.contact-form .file-input::file-selector-button { margin-right: 12px; padding: 9px 12px; border: 0; background: var(--blue); color: var(--white); font: inherit; cursor: pointer; }
.upload-note { margin: -10px 0 0; color: #70809e; font-size: 10px; line-height: 1.6; }
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus { border-color: var(--blue-bright); box-shadow: 0 0 0 3px rgba(37,99,235,.12); }
.contact-form .terms-check { display: grid; grid-template-columns: 18px 1fr; align-items: start; gap: 11px; padding: 15px; border: 1px solid var(--line); color: #8c8c8a; font-size: 10px; font-weight: 400; letter-spacing: 0; line-height: 1.6; text-transform: none; cursor: pointer; }
.contact-form .terms-check[hidden] { display: none; }
.contact-form .terms-check input { width: 16px; height: 16px; margin: 1px 0 0; padding: 0; accent-color: var(--white); }
.contact-form .terms-check a { color: var(--white); border-bottom: 1px solid #777; }
.form-note { margin: -8px 0 0; color: #666; font-size: 10px; text-align: center; }

.site-footer { padding: 65px 0 25px; }
.footer-top { display: grid; grid-template-columns: 1fr 1fr auto; align-items: center; gap: 40px; padding-bottom: 55px; }
.footer-top > p { max-width: 410px; margin: 0; color: #777; font-size: 13px; }.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 25px; border-top: 1px solid var(--line); color: #555; font-size: 10px; }
.footer-bottom div { display: flex; gap: 24px; }.footer-bottom p { margin: 0; }

.legal-page { min-height: 100vh; background: var(--paper); color: var(--ink); }
.legal-header { padding: 28px 0; border-bottom: 1px solid var(--line-dark); }
.legal-header .brand-mark { border-color: rgba(0,0,0,.35); }
.legal-header .brand b { color: var(--muted-dark); }
.legal-main { width: min(820px, calc(100% - 40px)); margin: 0 auto; padding: clamp(70px,10vw,120px) 0; }
.legal-main .eyebrow { color: var(--muted-dark); }
.legal-main h1 { margin: 0; font-family: "Manrope",sans-serif; font-size: clamp(48px,8vw,78px); font-weight: 400; letter-spacing: -.06em; line-height: 1; }
.legal-updated { margin: 22px 0 55px; color: var(--muted-dark); font-size: 12px; }
.legal-intro { padding: 25px 0; border-top: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark); font-size: 16px; }
.legal-section { padding: 28px 0; border-bottom: 1px solid var(--line-dark); }
.legal-section h2 { margin: 0 0 14px; font-family: "Manrope",sans-serif; font-size: 23px; font-weight: 500; letter-spacing: -.03em; }
.legal-section h3 { margin: 22px 0 8px; font-size: 15px; }
.legal-section p,.legal-section li { color: #525250; font-size: 13px; line-height: 1.75; }
.legal-section ul { display: grid; gap: 8px; padding-left: 20px; }
.legal-section a { color: var(--ink); border-bottom: 1px solid; }
.legal-footer { padding: 28px 0; border-top: 1px solid var(--line-dark); color: var(--muted-dark); font-size: 11px; }
.legal-footer .container { display: flex; justify-content: space-between; gap: 25px; }
.legal-footer nav { display: flex; flex-wrap: wrap; gap: 20px; }

.support-chat { position: fixed; z-index: 70; right: 20px; bottom: 20px; }
.chat-launcher {
  display: flex; align-items: center; gap: 10px; min-height: 52px; padding: 7px 18px 7px 7px;
  border: 1px solid var(--blue-bright); border-radius: 30px; background: var(--blue); color: var(--white);
  box-shadow: 0 15px 45px rgba(0,0,0,.35); font-size: 12px; font-weight: 600; cursor: pointer;
  transition: transform .25s var(--ease), box-shadow .25s;
}
.chat-launcher:hover { transform: translateY(-3px); box-shadow: 0 20px 55px rgba(0,0,0,.45); }
.chat-launcher-icon { display: grid; width: 36px; height: 36px; place-items: center; border-radius: 50%; background: var(--black); color: var(--white); }
.chat-panel {
  position: absolute; right: 0; bottom: 68px; display: flex; visibility: hidden; width: min(380px, calc(100vw - 28px));
  height: min(590px, calc(100vh - 110px)); flex-direction: column; overflow: hidden;
  border: 1px solid rgba(255,255,255,.22); background: #111; box-shadow: 0 28px 90px rgba(0,0,0,.55);
  opacity: 0; transform: translateY(15px) scale(.98); transform-origin: bottom right;
  transition: opacity .25s, transform .3s var(--ease), visibility .25s;
}
.chat-panel.open { visibility: visible; opacity: 1; transform: none; }
.chat-header { display: flex; align-items: center; justify-content: space-between; padding: 18px; border-bottom: 1px solid var(--line); }
.chat-header > div { display: flex; align-items: center; gap: 11px; }
.chat-header > div > div { display: grid; gap: 2px; }
.chat-header strong { font-size: 13px; font-weight: 600; }.chat-header small { color: #777; font-size: 9px; text-transform: uppercase; letter-spacing: .12em; }
.chat-header > button { width: 32px; height: 32px; border: 0; background: transparent; color: #aaa; font-size: 22px; cursor: pointer; }
.chat-status-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--blue-bright); box-shadow: 0 0 0 5px rgba(37,99,235,.16); }
.chat-messages { flex: 1; display: flex; flex-direction: column; gap: 11px; overflow-y: auto; padding: 18px; scroll-behavior: smooth; }
.chat-message { max-width: 86%; padding: 12px 14px; font-size: 12px; line-height: 1.55; overflow-wrap: anywhere; }
.bot-message { align-self: flex-start; background: #10245c; color: #eaf2ff; }
.user-message { align-self: flex-end; background: var(--white); color: var(--black); }
.chat-message a { border-bottom: 1px solid currentColor; font-weight: 600; }
.quick-replies { display: flex; flex-wrap: wrap; gap: 7px; padding: 0 18px 13px; }
.quick-replies button { padding: 8px 10px; border: 1px solid var(--line); background: transparent; color: #aaa; font-size: 9px; cursor: pointer; transition: border-color .2s,color .2s; }
.quick-replies button:hover { border-color: var(--blue-bright); color: white; }
.chat-form { display: grid; grid-template-columns: 1fr 42px; gap: 8px; padding: 13px 18px; border-top: 1px solid var(--line); }
.chat-form input { min-width: 0; height: 42px; padding: 0 12px; border: 1px solid var(--line); outline: 0; background: #0a0a0a; color: white; font-size: 12px; }
.chat-form input:focus { border-color: var(--blue-bright); }
.chat-form button { border: 0; background: white; color: black; font-size: 18px; cursor: pointer; }
.chat-disclaimer { margin: 0; padding: 0 18px 13px; color: #555; font-size: 8px; line-height: 1.4; text-align: center; }

.video-modal { position: fixed; z-index: 100; inset: 0; display: grid; visibility: hidden; padding: clamp(18px,5vw,60px); place-items: center; background: rgba(0,0,0,.94); opacity: 0; transition: opacity .25s,visibility .25s; }
.video-modal.is-open { visibility: visible; opacity: 1; }.modal-dialog { position: relative; width: min(1150px,100%); transform: translateY(15px); transition: transform .4s var(--ease); }.video-modal.is-open .modal-dialog { transform: none; }
.modal-close { position: absolute; right: 0; bottom: calc(100% + 13px); border: 0; background: none; color: white; font-size: 10px; letter-spacing: .12em; text-transform: uppercase; cursor: pointer; }.modal-close span { margin-left: 5px; font-size: 17px; }
.video-frame { display: grid; width: 100%; aspect-ratio: 16/9; place-items: center; border: 1px solid var(--line); background: #0b0b0b; overflow: hidden; }
.video-frame iframe,.video-frame video { width: 100%; height: 100%; border: 0; object-fit: contain; }.modal-placeholder { padding: 30px; color: #8a8a88; text-align: center; font-size: 14px; line-height: 1.7; }
.video-fullscreen { display: flex; min-height: 46px; margin: 14px 0 0 auto; padding: 0 18px; align-items: center; gap: 12px; border: 1px solid rgba(255,255,255,.35); background: #111; color: white; font-size: 11px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; }
.video-fullscreen:hover { border-color: white; background: white; color: black; }
.rotate-note { display: none; margin: 10px 0 0; color: #777; font-size: 9px; letter-spacing: .14em; text-align: center; text-transform: uppercase; }
.notice { position: fixed; z-index: 80; right: 20px; bottom: 20px; width: min(370px,calc(100% - 40px)); padding: 22px 45px 20px 22px; border: 1px solid rgba(255,255,255,.28); background: #151515; box-shadow: 0 20px 50px rgba(0,0,0,.35); transform: translateY(140%); opacity: 0; transition: transform .4s var(--ease),opacity .4s; }
.notice.show { transform: none; opacity: 1; }.notice button { position: absolute; right: 13px; top: 10px; border: 0; background: none; color: #aaa; font-size: 20px; cursor: pointer; }.notice strong { font-size: 13px; }.notice p { margin: 7px 0 0; color: #888; font-size: 11px; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s var(--ease),transform .75s var(--ease); transition-delay: var(--delay,0ms); }
.reveal.visible { opacity: 1; transform: none; }

@media (max-width: 980px) {
  .site-nav {
    position: fixed; inset: 78px 0 auto; display: grid; visibility: hidden; gap: 0;
    padding: 20px; background: rgba(8,8,8,.98); border-bottom: 1px solid var(--line); opacity: 0; transform: translateY(-10px); transition: .25s;
  }
  .site-nav.open { visibility: visible; opacity: 1; transform: none; }
  .site-nav > a:not(.button) { padding: 17px 3px; border-bottom: 1px solid var(--line); font-size: 15px; }
  .site-nav .button { margin-top: 18px; }
  .menu-toggle { display: block; }.menu-toggle.active span:nth-of-type(2) { transform: translateY(4px) rotate(45deg); }.menu-toggle.active span:nth-of-type(3) { transform: translateY(-4px) rotate(-45deg); }
  .hero { padding-top: 140px; }.hero-grid { grid-template-columns: 1fr; }.hero-copy { max-width: 760px; }.hero-visual { width: min(670px,92%); margin-left: auto; }
  .service-grid { grid-template-columns: 1fr; gap: 12px; }.service-card + .service-card { border-left: 1px solid var(--line-dark); }.service-card { min-height: auto; }.service-card-dark { transform: none; }.service-icon { margin-bottom: 35px; }
  .industries-grid,.trust-grid,.faq-grid,.reviews-grid,.contact-grid { grid-template-columns: 1fr; }.trust-copy,.review-copy { position: static; }.section-heading-left { max-width: 700px; }
  .process-grid { grid-template-columns: repeat(2,1fr); }.process-step:nth-child(2) { border-right: 0; }.process-step:nth-child(n+3) { border-top: 1px solid var(--line-dark); }
}

@media (max-width: 700px) {
  .container { width: min(100% - 28px,var(--max)); }.section { padding: 78px 0; }
  .hero { padding-top: 125px; }.hero-grid { gap: 30px; }.hero-copy h1 { font-size: clamp(48px,14vw,69px); }.hero-lead { font-size: 15px; }.hero-actions { align-items: stretch; flex-direction: column; gap: 22px; }.hero-actions .button { width: 100%; justify-content: space-between; }.hero-actions .text-link { align-self: flex-start; }
  .hero-trust { display: grid; gap: 10px; }.hero-visual { width: 100%; padding-left: 10px; }.mock-page { height: 320px; }.mock-content { padding: 50px 5px 35px; }.float-lead { left: -5px; bottom: 70px; }.float-chat { right: -4px; top: 65px; }.credibility-strip { align-items: flex-start; flex-direction: column; margin-top: 55px; }.credibility-items { display: grid; grid-template-columns: 1fr 1fr; width: 100%; }
  .section-heading { text-align: left; }.section-heading .eyebrow { justify-content: flex-start; }.section-heading > p:last-child { margin-inline: 0; }.section-heading h2,.demo-heading h2,.trust-copy h2,.contact-copy h2 { font-size: 39px; }
  .service-card { padding: 30px 25px; }.industry-row { grid-template-columns: 30px 1fr; }.industry-row p { grid-column: 2; margin-top: -13px; }
  .process-grid { grid-template-columns: 1fr; }.process-step { min-height: auto; padding: 26px 0 32px !important; border-right: 0; border-top: 1px solid var(--line-dark); }.process-step:first-child { border-top: 0; }.process-step > span { margin-bottom: 28px; }
  .video-preview { min-height: 280px; aspect-ratio: 4/3; }.preview-video { object-position: center; opacity: .74; }.play-button { width: 70px; height: 70px; }.preview-content { padding: 20px; }.preview-content strong { font-size: 14px; }
  .video-modal { padding: 12px; place-items: center; }
  .modal-dialog { display: flex; width: min(100%, 420px); height: min(calc(100dvh - 24px), 760px); padding: 42px 0 0; flex-direction: column; justify-content: center; }
  .modal-close { top: 2px; right: 0; bottom: auto; padding: 8px 4px; }
  .video-frame { width: auto; height: min(calc(100dvh - 146px), 660px); max-width: 100%; margin-inline: auto; aspect-ratio: 9/16; border: 1px solid var(--line); }
  .video-frame video { width: 100%; height: 100%; max-height: none; object-fit: contain; background: #000; }
  .video-fullscreen { width: min(100%, 372px); margin: 10px auto 0; justify-content: center; }
  .pricing-grid { grid-template-columns: 1fr; }.price-card { min-height: auto; }.price-top > p:last-child { min-height: 0; }.scope-note { grid-template-columns: 1fr; gap: 18px; }
  .form-row { grid-template-columns: 1fr; }.contact-form { padding: 25px 20px; }.footer-top { grid-template-columns: 1fr; }.footer-bottom { align-items: flex-start; flex-direction: column; gap: 16px; }.footer-bottom div { flex-wrap: wrap; gap: 14px 22px; }
  .support-chat { right: 14px; bottom: 14px; }.chat-launcher-label { display: none; }.chat-launcher { width: 52px; padding: 7px; }.chat-panel { bottom: 62px; height: min(560px, calc(100vh - 90px)); }
}

@media (max-width: 700px) and (orientation: portrait) {
  .video-modal.is-open .modal-dialog { transform: none; }
  .rotate-note { display: block; }
}

@media (max-width: 700px) and (orientation: landscape) {
  .modal-dialog { width: min(94vw, 900px); height: calc(100dvh - 16px); padding-top: 36px; }
  .video-frame { width: min(84vw, 900px); height: auto; aspect-ratio: 16/9; }
  .video-fullscreen { width: min(84vw, 900px); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
