:root {
  --ink: #14241c;
  --forest: #123c2e;
  --green: #1f6a52;
  --sage: #6f7c74;
  --ivory: #f6f4ee;
  --paper: #fffefa;
  --line: #dcded7;
  --mint: #e3f0e9;
  --lavender: #ece9ff;
  --sand: #efe3d2;
  --violet: #705cff;
  --serif: Georgia, "Times New Roman", serif;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--ivory); font-family: var(--sans); font-size: 16px; line-height: 1.6; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, a { -webkit-tap-highlight-color: transparent; }
button { font: inherit; }
.shell { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.section { padding: 112px 0; }
.sr-only { position: absolute; 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: 1000; top: 12px; left: 12px; padding: 10px 14px; background: white; border-radius: 8px; transform: translateY(-150%); }
.skip-link:focus { transform: translateY(0); }
:focus-visible { outline: 3px solid var(--violet); outline-offset: 3px; }

.site-header { position: sticky; z-index: 100; top: 0; border-bottom: 1px solid transparent; background: rgba(246, 244, 238, .92); backdrop-filter: blur(18px); transition: border-color .2s, box-shadow .2s; }
.site-header.scrolled { border-color: var(--line); box-shadow: 0 10px 30px rgba(20, 36, 28, .06); }
.header-inner { min-height: 82px; display: flex; align-items: center; gap: 34px; }
.brand { display: inline-flex; align-items: center; gap: 12px; font: 700 25px/1 var(--serif); }
.brand-mark { display: inline-flex; align-items: end; gap: 3px; height: 23px; }
.brand-mark i { display: block; width: 4px; border-radius: 4px; background: var(--green); transform: rotate(-7deg); }
.brand-mark i:nth-child(1) { height: 13px; }
.brand-mark i:nth-child(2) { height: 21px; }
.brand-mark i:nth-child(3) { height: 17px; }
.site-nav { display: flex; gap: 28px; margin-left: auto; color: #415047; font-size: 14px; font-weight: 650; }
.site-nav a, .text-link { transition: color .2s; }
.site-nav a:hover, .text-link:hover { color: var(--green); }
.header-actions { display: flex; align-items: center; gap: 22px; font-size: 14px; font-weight: 700; }
.menu-toggle { display: none; border: 0; background: transparent; padding: 9px; }
.menu-toggle > span:not(.sr-only) { display: block; width: 22px; height: 2px; margin: 4px; background: var(--ink); }

.button { display: inline-flex; min-height: 52px; align-items: center; justify-content: center; gap: 9px; padding: 13px 23px; border: 1px solid var(--forest); border-radius: 9px; color: white; background: var(--forest); font-weight: 750; line-height: 1.2; box-shadow: 0 12px 24px rgba(18, 60, 46, .14); transition: transform .2s, background .2s, box-shadow .2s; }
.button:hover { transform: translateY(-2px); background: #18523e; box-shadow: 0 16px 28px rgba(18, 60, 46, .2); }
.button-small { min-height: 42px; padding: 10px 17px; border-radius: 8px; }
.button-ghost { color: var(--ink); background: transparent; border-color: #cfd3cc; box-shadow: none; }
.button-ghost:hover { background: white; }
.button-light { color: var(--forest); background: white; border-color: white; }
.play-mini { display: inline-grid; width: 25px; height: 25px; place-items: center; padding-left: 2px; border-radius: 50%; color: white; background: var(--forest); font-size: 9px; }

.hero { min-height: 720px; display: flex; align-items: center; overflow: hidden; padding: 64px 0 86px; }
.hero-grid { display: grid; grid-template-columns: .84fr 1.16fr; align-items: center; gap: 44px; }
.hero-copy { position: relative; z-index: 2; padding: 30px 0; }
.eyebrow, .kicker { margin: 0 0 17px; color: var(--green); font-size: 12px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow { display: flex; align-items: center; gap: 10px; }
.eyebrow span { width: 26px; height: 1px; background: var(--green); }
h1, h2, h3 { margin: 0; letter-spacing: -.035em; }
h1, h2 { font-family: var(--serif); font-weight: 700; line-height: .98; }
h1 { max-width: 620px; font-size: clamp(60px, 6.4vw, 94px); }
h2 { font-size: clamp(44px, 5.2vw, 72px); }
h3 { font-size: 29px; line-height: 1.14; }
.hero-lede { max-width: 560px; margin: 28px 0; color: #57645c; font-size: 20px; line-height: 1.55; }
.button-row { display: flex; flex-wrap: wrap; gap: 12px; }
.microcopy { margin: 14px 0 0; color: #78827c; font-size: 12px; }
.hero-visual { position: relative; min-height: 570px; }
.product-shot { position: absolute; overflow: hidden; margin: 0; border: 1px solid rgba(42, 61, 51, .14); border-radius: 14px; background: white; box-shadow: 0 28px 80px rgba(34, 48, 40, .17); }
.product-shot img { width: 100%; height: auto; }
.hero-builder { z-index: 2; top: 30px; right: -62px; width: 83%; transform: rotate(1.6deg); }
.hero-report { z-index: 3; bottom: 10px; left: -6px; width: 68%; transform: rotate(-1.4deg); }
.soft-orbit { position: absolute; border-radius: 50%; filter: blur(1px); }
.orbit-one { width: 440px; height: 440px; top: 5px; right: -95px; background: var(--mint); }
.orbit-two { width: 310px; height: 310px; bottom: -30px; left: 40px; background: var(--lavender); }
.hero-note { position: absolute; z-index: 5; display: grid; padding: 12px 16px; border: 1px solid rgba(42, 61, 51, .12); border-radius: 11px; background: rgba(255, 255, 255, .94); box-shadow: 0 14px 34px rgba(25, 40, 32, .12); font-size: 12px; }
.hero-note strong { font-size: 13px; }
.hero-note span { color: var(--sage); }
.note-one { top: 74px; left: -18px; }
.note-two { right: -30px; bottom: 88px; }

.section-heading { margin-bottom: 58px; }
.section-heading.centered { max-width: 780px; margin-right: auto; margin-left: auto; text-align: center; }
.section-heading.narrow { max-width: 750px; }
.section-heading > p:not(.kicker), .split-heading > p { color: var(--sage); font-size: 18px; }
.split-heading { display: grid; grid-template-columns: 1.15fr .75fr; align-items: end; gap: 80px; }
.split-heading > p { margin: 0 0 4px; }

.friction { border-top: 1px solid var(--line); background: var(--paper); }
.friction-grid { display: grid; grid-template-columns: 1.06fr .94fr; gap: 28px; align-items: stretch; }
.team-image { position: relative; min-height: 540px; overflow: hidden; margin: 0; border-radius: 18px; background: #d9ddd7; }
.team-image img { width: 100%; height: 100%; object-fit: cover; }
.team-image figcaption { position: absolute; right: 18px; bottom: 18px; left: 18px; padding: 15px 18px; border-radius: 10px; color: white; background: rgba(20, 36, 28, .9); font-weight: 650; }
.problem-list { border: 1px solid var(--line); border-radius: 18px; background: var(--ivory); }
.problem-list article { display: grid; grid-template-columns: 46px 1fr; gap: 18px; padding: 27px 30px; border-bottom: 1px solid var(--line); }
.problem-list article:last-child { border: 0; }
.problem-list article > span { display: grid; width: 40px; height: 40px; place-items: center; border-radius: 50%; color: var(--green); background: var(--mint); font-size: 12px; font-weight: 800; }
.problem-list h3 { font-size: 21px; }
.problem-list p { margin: 7px 0 0; color: var(--sage); line-height: 1.45; }

.product { background: var(--ivory); }
.feature-row { display: grid; grid-template-columns: .72fr 1.28fr; align-items: center; gap: 70px; margin: 0 0 112px; }
.feature-row.reverse { grid-template-columns: 1.28fr .72fr; }
.feature-row.reverse .feature-copy { order: 2; }
.feature-number { display: inline-grid; width: 36px; height: 36px; place-items: center; margin-bottom: 24px; border: 1px solid #ccd2cc; border-radius: 50%; color: var(--green); font-size: 12px; font-weight: 800; }
.feature-copy h3 { font-family: var(--serif); font-size: 43px; }
.feature-copy > p:not(.kicker) { margin: 21px 0; color: var(--sage); font-size: 17px; }
.check-list { display: grid; gap: 9px; padding: 0; list-style: none; font-size: 14px; font-weight: 700; }
.check-list li::before { content: "✓"; margin-right: 9px; color: var(--green); }
.feature-shot { overflow: hidden; margin: 0; padding: 36px 0 36px 36px; border-radius: 20px; box-shadow: inset 0 0 0 1px rgba(37, 58, 46, .08); }
.feature-shot img { width: 112%; max-width: none; border: 1px solid rgba(25, 45, 34, .13); border-radius: 12px 0 0 12px; box-shadow: 0 18px 42px rgba(28, 42, 34, .13); }
.feature-shot.mint { background: var(--mint); }
.feature-shot.lavender { background: var(--lavender); }
.feature-shot.sand { background: var(--sand); }
.feature-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.feature-card { overflow: hidden; border: 1px solid var(--line); border-radius: 19px; background: white; }
.feature-card-copy { padding: 36px 38px 30px; }
.feature-card-copy h3 { font-family: var(--serif); font-size: 37px; }
.feature-card-copy > p:not(.kicker) { color: var(--sage); }
.feature-card figure { height: 330px; overflow: hidden; margin: 0 0 0 38px; border: 1px solid var(--line); border-width: 1px 0 0 1px; border-radius: 12px 0 0; background: var(--ivory); }
.feature-card img { width: 110%; max-width: none; }

.industries { color: white; background: var(--forest); }
.industries .kicker { color: #a9d7c3; }
.industries .section-heading > p:not(.kicker) { color: #bdcbc4; }
.industry-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; overflow: hidden; border: 1px solid rgba(255, 255, 255, .16); border-radius: 18px; background: rgba(255, 255, 255, .16); }
.industry-grid article { min-height: 360px; padding: 34px 30px; background: #164634; }
.industry-grid article:nth-child(even) { background: #194d3a; }
.industry-icon { display: grid; width: 47px; height: 47px; place-items: center; margin-bottom: 64px; border: 1px solid rgba(255, 255, 255, .25); border-radius: 50%; color: #c8f0dc; font-size: 20px; }
.industry-grid h3 { font-family: var(--serif); font-size: 28px; }
.industry-grid p:last-child { color: #bdcbc4; font-size: 14px; }

.story { background: var(--paper); }
.story-grid { display: grid; grid-template-columns: .72fr 1.28fr; gap: 68px; align-items: center; }
.story-copy h2 { font-size: clamp(44px, 4.8vw, 66px); }
.story-copy > p:not(.kicker) { color: var(--sage); font-size: 17px; }
.story-steps { display: grid; margin-top: 35px; }
.story-steps button { display: grid; grid-template-columns: 38px 1fr; gap: 13px; width: 100%; padding: 16px 0; border: 0; border-top: 1px solid var(--line); color: var(--sage); background: transparent; text-align: left; cursor: pointer; }
.story-steps button > span { display: grid; width: 32px; height: 32px; place-items: center; border-radius: 50%; background: #edf0eb; font-size: 11px; font-weight: 800; }
.story-steps strong, .story-steps small { display: block; }
.story-steps strong { color: var(--ink); }
.story-steps button.active { color: var(--green); }
.story-steps button.active > span { color: white; background: var(--green); }
.story-player { position: relative; aspect-ratio: 16/10; overflow: hidden; border-radius: 20px; background: var(--ink); box-shadow: 0 28px 70px rgba(20, 36, 28, .2); }
.story-frame { position: absolute; inset: 0; opacity: 0; transition: opacity .7s ease; }
.story-frame.active { opacity: 1; }
.story-frame img { width: 100%; height: 100%; object-fit: cover; }
.story-frame:nth-child(2) img, .story-frame:nth-child(3) img { object-fit: contain; background: #efeee9; }
.story-frame::after { content: ""; position: absolute; inset: 45% 0 0; background: linear-gradient(transparent, rgba(10, 25, 18, .86)); }
.story-caption { position: absolute; z-index: 2; right: 40px; bottom: 38px; left: 40px; display: grid; color: white; }
.story-caption strong { font: 700 27px/1.2 var(--serif); }
.story-caption span { color: rgba(255, 255, 255, .78); }
.story-play { position: absolute; z-index: 4; top: 50%; left: 50%; display: grid; width: 76px; height: 76px; place-items: center; padding-left: 5px; border: 1px solid rgba(255, 255, 255, .5); border-radius: 50%; color: var(--forest); background: rgba(255, 255, 255, .94); font-size: 21px; transform: translate(-50%, -50%); cursor: pointer; box-shadow: 0 10px 34px rgba(0, 0, 0, .23); }
.story-player.playing .story-play { opacity: 0; pointer-events: none; }
.story-progress { position: absolute; z-index: 4; right: 0; bottom: 0; left: 0; height: 5px; background: rgba(255, 255, 255, .25); }
.story-progress i { display: block; width: 0; height: 100%; background: #83e0b9; }
.story-player.playing .story-progress i { animation: story-progress 15s linear forwards; }
@keyframes story-progress { to { width: 100%; } }

.compare { background: #ecebe6; }
.comparison-wrap { overflow-x: auto; border: 1px solid #d3d4ce; border-radius: 17px; background: white; }
table { width: 100%; min-width: 1000px; border-collapse: collapse; font-size: 13px; line-height: 1.45; }
th, td { padding: 19px 17px; border-right: 1px solid #e0e1dc; border-bottom: 1px solid #e0e1dc; text-align: left; vertical-align: top; }
tr:last-child th, tr:last-child td { border-bottom: 0; }
th:last-child, td:last-child { border-right: 0; }
thead th { padding-top: 22px; padding-bottom: 22px; font-size: 14px; }
tbody th { width: 145px; font-size: 13px; }
.signal-col { color: var(--forest); background: #edf6f1; font-weight: 700; }
thead .signal-col { color: white; background: var(--forest); }
.comparison-note { margin: 15px 0 0; color: var(--sage); font-size: 12px; }

.pricing { background: var(--paper); }
.pricing-grid { display: grid; grid-template-columns: repeat(4, 1fr); align-items: stretch; gap: 14px; }
.pricing-grid article { position: relative; display: flex; flex-direction: column; min-height: 390px; padding: 29px 25px; border: 1px solid var(--line); border-radius: 15px; background: var(--ivory); }
.pricing-grid h3 { margin-bottom: 17px; font-size: 14px; font-weight: 600; }
.pricing-grid h3 span { font: 700 43px/1 var(--serif); }
.pricing-grid article > p:not(.kicker) { min-height: 93px; color: var(--sage); font-size: 14px; }
.pricing-grid article > strong { margin: auto 0 23px; font-size: 13px; }
.pricing-grid .button { width: 100%; }
.featured-plan { border-color: var(--forest) !important; background: white !important; box-shadow: 0 20px 45px rgba(22, 54, 41, .12); transform: translateY(-12px); }
.plan-badge { position: absolute; top: -13px; right: 18px; padding: 6px 11px; border-radius: 20px; color: white; background: var(--violet); font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.pricing-note { margin: 24px 0 0; color: var(--sage); text-align: center; font-size: 12px; }

.faq { background: var(--ivory); }
.faq-grid { display: grid; grid-template-columns: .7fr 1.3fr; gap: 80px; align-items: start; }
.faq-intro { position: sticky; top: 120px; }
.faq-intro h2 { font-size: 56px; }
.faq-intro > p:not(.kicker) { color: var(--sage); }
.text-arrow { display: inline-flex; gap: 12px; align-items: center; margin-top: 15px; color: var(--green); font-weight: 800; }
.text-arrow span { font-size: 22px; }
.faq-list { border-top: 1px solid #ccd0ca; }
.faq-list details { border-bottom: 1px solid #ccd0ca; }
.faq-list summary { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 23px 2px; font-size: 17px; font-weight: 750; cursor: pointer; list-style: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary span { font-size: 24px; font-weight: 400; transition: transform .2s; }
.faq-list details[open] summary span { transform: rotate(45deg); }
.faq-list details p { max-width: 690px; margin: -4px 0 24px; color: var(--sage); }

.final-cta { padding: 106px 0; color: white; background: var(--forest); text-align: center; }
.final-cta .kicker { color: #a7dcc4; }
.final-cta h2 { font-size: clamp(46px, 5.5vw, 76px); }
.final-cta p:not(.kicker) { max-width: 600px; margin: 25px auto 30px; color: #bdd0c6; font-size: 18px; }
.site-footer { padding: 65px 0 25px; background: #0f2d23; color: white; }
.footer-grid { display: grid; grid-template-columns: 2fr repeat(3, 1fr); gap: 60px; }
.footer-grid > div { display: grid; align-content: start; gap: 8px; }
.footer-grid strong { margin-bottom: 9px; font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.footer-grid a:not(.brand), .footer-grid p { color: #a8bbb1; font-size: 13px; }
.footer-grid a:hover { color: white; }
.footer-link-button { width: fit-content; padding: 0; border: 0; color: #a8bbb1; background: transparent; font: inherit; font-size: 13px; text-align: left; cursor: pointer; }
.footer-link-button:hover { color: white; }
.footer-brand { margin-bottom: 7px; }
.footer-bottom { display: flex; justify-content: space-between; margin-top: 55px; padding-top: 22px; border-top: 1px solid rgba(255, 255, 255, .13); color: #82998d; font-size: 11px; }

.cookie-banner { position: fixed; z-index: 300; right: 24px; bottom: 24px; left: 24px; display: grid; grid-template-columns: 1fr auto; gap: 34px; max-width: 1120px; margin: auto; padding: 25px 27px; border: 1px solid #cbd1ca; border-radius: 16px; background: rgba(255, 254, 250, .98); box-shadow: 0 24px 70px rgba(20, 36, 28, .24); backdrop-filter: blur(18px); }
.cookie-banner[hidden] { display: none; }
.cookie-copy .kicker { margin-bottom: 6px; }
.cookie-copy h2 { font-family: var(--serif); font-size: 27px; line-height: 1.1; }
.cookie-copy p:last-child { max-width: 680px; margin: 8px 0 0; color: var(--sage); font-size: 13px; line-height: 1.45; }
.cookie-actions { display: grid; grid-template-columns: 1fr 1fr; align-content: center; gap: 9px; }
.cookie-actions .button { min-height: 44px; padding: 10px 15px; font-size: 13px; }
.cookie-customize { grid-column: 1 / -1; justify-content: center; margin: 0; padding: 3px; border: 0; background: transparent; cursor: pointer; font-size: 12px; }
.cookie-dialog { width: min(620px, calc(100% - 30px)); padding: 0; border: 0; border-radius: 18px; color: var(--ink); background: var(--paper); box-shadow: 0 30px 90px rgba(8, 24, 16, .35); }
.cookie-dialog::backdrop { background: rgba(12, 29, 21, .64); backdrop-filter: blur(5px); }
.cookie-dialog form { padding: 31px; }
.cookie-dialog-heading { display: flex; align-items: start; justify-content: space-between; gap: 20px; }
.cookie-dialog-heading .kicker { margin-bottom: 5px; }
.cookie-dialog h2 { font-size: 42px; }
.cookie-dialog form > p { color: var(--sage); }
.cookie-close { display: grid; width: 38px; height: 38px; place-items: center; padding: 0; border: 1px solid var(--line); border-radius: 50%; background: var(--ivory); cursor: pointer; font-size: 25px; }
.cookie-option { display: flex; align-items: center; justify-content: space-between; gap: 25px; padding: 18px 0; border-top: 1px solid var(--line); cursor: pointer; }
.cookie-option span { display: grid; }
.cookie-option small { color: var(--sage); }
.cookie-option input { width: 21px; height: 21px; accent-color: var(--green); }
.cookie-option.locked { cursor: default; }
.cookie-dialog-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }

.status-page { min-height: 100vh; background: var(--ivory); }
.status-shell { max-width: 900px; }
.status-header-actions { margin-left: auto; }
.status-hero { padding: 100px 0 55px; text-align: center; }
.status-hero h1 { font-size: clamp(62px, 8vw, 96px); }
.status-hero > .shell > p:not(.kicker) { max-width: 650px; margin: 25px auto 35px; color: var(--sage); font-size: 18px; }
.overall-status { display: flex; align-items: center; gap: 17px; max-width: 610px; margin: 0 auto; padding: 20px 23px; border: 1px solid var(--line); border-radius: 14px; background: white; text-align: left; }
.overall-status > div { display: grid; }
.overall-status small { color: var(--sage); }
.status-pulse { position: relative; display: block; width: 17px; height: 17px; flex: 0 0 auto; border-radius: 50%; background: #a6aea9; }
.status-pulse::after { content: ""; position: absolute; inset: -5px; border: 2px solid currentColor; border-radius: 50%; opacity: .22; }
.overall-status.operational { border-color: #a8d8c2; background: #eef8f3; }
.overall-status.operational .status-pulse { color: #168157; background: #168157; }
.overall-status.degraded { border-color: #e5bf83; background: #fff8e9; }
.overall-status.degraded .status-pulse { color: #b87511; background: #b87511; }
.status-content { padding: 0 0 100px; }
.status-panel { overflow: hidden; border: 1px solid var(--line); border-radius: 17px; background: var(--paper); box-shadow: 0 20px 55px rgba(20, 36, 28, .08); }
.status-panel-heading { display: flex; align-items: end; justify-content: space-between; gap: 24px; padding: 29px 31px 24px; border-bottom: 1px solid var(--line); }
.status-panel-heading .kicker { margin-bottom: 6px; }
.status-panel-heading h2 { font-size: 38px; }
.status-panel-heading > p { margin: 0; color: var(--sage); font-size: 12px; }
.service-row { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 21px 31px; border-bottom: 1px solid var(--line); }
.service-row:last-child { border: 0; }
.service-row > span { font-weight: 700; }
.service-row strong { display: inline-flex; align-items: center; gap: 8px; color: var(--sage); font-size: 13px; }
.service-row strong i { width: 9px; height: 9px; border-radius: 50%; background: #a6aea9; }
.service-row.operational strong { color: #168157; }
.service-row.operational strong i { background: #168157; }
.service-row.degraded strong { color: #b87511; }
.service-row.degraded strong i { background: #b87511; }
.status-notes { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 20px; }
.status-notes article { padding: 26px 28px; border: 1px solid var(--line); border-radius: 14px; background: white; }
.status-notes h3 { font-family: var(--serif); font-size: 28px; }
.status-notes article > p:last-of-type { color: var(--sage); font-size: 14px; }
.status-footer { margin-top: auto; padding-top: 1px; }
.status-footer .footer-bottom { padding-bottom: 8px; }
.status-footer a, .status-footer button { color: inherit; }

@media (max-width: 1050px) {
  .site-nav { gap: 17px; }
  .hero-grid { grid-template-columns: .9fr 1.1fr; }
  .hero-visual { min-height: 500px; }
  .industry-grid { grid-template-columns: 1fr 1fr; }
  .industry-grid article { min-height: 320px; }
  .pricing-grid { grid-template-columns: 1fr 1fr; }
  .featured-plan { transform: none; }
}

@media (max-width: 820px) {
  .section { padding: 82px 0; }
  .menu-toggle { display: block; margin-left: auto; }
  .header-actions .text-link { display: none; }
  .header-actions .button { min-height: 40px; padding: 9px 13px; }
  .site-nav { position: absolute; top: 74px; right: 20px; left: 20px; display: none; flex-direction: column; gap: 0; padding: 9px; border: 1px solid var(--line); border-radius: 13px; background: white; box-shadow: 0 20px 50px rgba(20, 36, 28, .16); }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 13px 14px; border-radius: 8px; }
  .site-nav a:hover { background: var(--mint); }
  .hero { padding-top: 40px; }
  .hero-grid, .friction-grid, .split-heading, .story-grid, .faq-grid { grid-template-columns: 1fr; }
  .hero-copy { text-align: center; }
  .eyebrow, .button-row { justify-content: center; }
  .hero-lede { margin-right: auto; margin-left: auto; }
  .hero-visual { min-height: 570px; margin-top: 20px; }
  .hero-builder { right: -7%; width: 84%; }
  .hero-report { left: 2%; width: 69%; }
  .note-one { left: 0; }
  .note-two { right: 0; }
  .split-heading { gap: 20px; }
  .feature-row, .feature-row.reverse { grid-template-columns: 1fr; gap: 35px; margin-bottom: 84px; }
  .feature-row.reverse .feature-copy { order: 0; }
  .feature-pair { grid-template-columns: 1fr; }
  .story-grid, .faq-grid { gap: 42px; }
  .faq-intro { position: static; }
  .footer-grid { grid-template-columns: 2fr 1fr 1fr; }
  .footer-grid > div:last-child { grid-column: 2; }
  .cookie-banner { grid-template-columns: 1fr; gap: 18px; }
  .cookie-actions { grid-template-columns: auto auto; justify-content: start; }
}

@media (max-width: 560px) {
  .shell { width: min(100% - 28px, 1180px); }
  .header-inner { min-height: 70px; gap: 12px; }
  .brand { font-size: 21px; }
  .brand-mark { transform: scale(.9); }
  .header-actions .button { font-size: 12px; }
  .hero { min-height: auto; padding-bottom: 55px; }
  h1 { font-size: clamp(49px, 15vw, 68px); }
  h2 { font-size: 45px; }
  .hero-lede { font-size: 17px; }
  .button-row { display: grid; }
  .hero-visual { min-height: 410px; }
  .hero-builder { top: 15px; right: -13%; width: 96%; }
  .hero-report { bottom: 18px; left: -3%; width: 80%; }
  .hero-note { display: none; }
  .orbit-one { width: 300px; height: 300px; right: -70px; }
  .orbit-two { width: 220px; height: 220px; left: -20px; }
  .section-heading { margin-bottom: 40px; }
  .team-image { min-height: 400px; }
  .problem-list article { grid-template-columns: 38px 1fr; padding: 22px 19px; }
  .feature-copy h3 { font-size: 37px; }
  .feature-shot { padding: 20px 0 20px 20px; }
  .feature-pair { gap: 16px; }
  .feature-card-copy { padding: 28px 25px 22px; }
  .feature-card figure { height: 240px; margin-left: 25px; }
  .industry-grid, .pricing-grid { grid-template-columns: 1fr; }
  .industry-grid article { min-height: 300px; }
  .industry-icon { margin-bottom: 45px; }
  .story-player { aspect-ratio: 4/3; }
  .story-caption { right: 22px; bottom: 22px; left: 22px; }
  .story-caption strong { font-size: 22px; }
  .story-play { width: 62px; height: 62px; }
  .pricing-grid article { min-height: 350px; }
  .faq-intro h2 { font-size: 45px; }
  .faq-list summary { font-size: 15px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 34px 25px; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
  .footer-grid > div:last-child { grid-column: auto; }
  .footer-bottom { display: grid; gap: 7px; }
  .cookie-banner { right: 12px; bottom: 12px; left: 12px; padding: 21px; }
  .cookie-actions { grid-template-columns: 1fr; }
  .cookie-customize { grid-column: auto; }
  .cookie-dialog form { padding: 24px 21px; }
  .cookie-dialog h2 { font-size: 35px; }
  .cookie-option { align-items: start; }
  .cookie-dialog-actions { display: grid; }
  .status-header-actions .text-link { display: none; }
  .status-hero { padding-top: 70px; }
  .status-panel-heading { display: grid; padding: 24px 21px 20px; }
  .service-row { padding: 19px 21px; }
  .status-notes { grid-template-columns: 1fr; }
}

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