:root { --ink:#171717; --muted:#707070; --cream:#e7e5e0; --orange:#ff4d1c; --violet:#715cff; --line:#d6d3cd; --black:#050505; }
* { box-sizing:border-box; }
html { scroll-behavior:smooth; scroll-snap-type:y mandatory; background:var(--cream); }
body { margin:0; color:var(--ink); background:var(--cream); font-family:"Manrope",Arial,sans-serif; }
a { color:inherit; text-decoration:none; }
button { font:inherit; }
.landing-page { height:200vh; min-height:200vh; overflow:visible; background:var(--cream); position:relative; }
.landing-join-glow { position:absolute; z-index:3; left:-13vw; top:86vh; width:min(620px,52vw); height:min(500px,42vh); pointer-events:none; opacity:.62; background:radial-gradient(ellipse at 45% 50%,rgba(255,77,28,.18) 0%,rgba(255,77,28,.11) 26%,rgba(255,77,28,.048) 52%,transparent 76%); filter:blur(46px); transform:rotate(-10deg); }
.site-header { height:76px; padding:0 clamp(24px,4vw,64px); background:var(--black); color:#f5f4f1; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; position:sticky; top:0; z-index:70; scroll-snap-align:start; scroll-snap-stop:always; }
.brand { font-size:23px; letter-spacing:-1.4px; font-weight:800; width:fit-content; }.brand-mark { color:var(--orange); }
.nav-links { display:flex; align-items:center; gap:clamp(23px,3.2vw,52px); font-size:12px; font-weight:600; letter-spacing:.01em; }.nav-links a { color:#b6b6b4; transition:color .2s ease; }.nav-links a:hover { color:#fff; }
.header-cta { justify-self:end; color:#fff; background:transparent; border:0; border-bottom:1px solid #6d6b69; padding:0 0 5px; cursor:pointer; font-size:12px; font-weight:600; transition:border-color .2s ease; }.header-cta:hover { border-color:var(--orange); }.header-cta span { color:var(--orange); font-size:16px; margin-left:7px; vertical-align:-1px; }
.hero { min-height:calc(100vh - 76px); height:calc(100vh - 76px); background:var(--cream); position:relative; isolation:isolate; display:flex; flex-direction:column; padding:clamp(34px,5.8vh,68px) clamp(24px,7.1vw,114px) 16px; scroll-snap-align:none; scroll-snap-stop:normal; }
.background-visual,.grid,.flow-lines,.feature-path,.feature-network { position:absolute; inset:0; }.background-visual { overflow:hidden; z-index:0; }.grid { pointer-events:none; opacity:.7; background-image:linear-gradient(to right,transparent 0,transparent calc(25% - .5px),var(--line) calc(25% - .5px),var(--line) 25%,transparent 25%),linear-gradient(to bottom,transparent 0,transparent calc(33.3% - .5px),var(--line) calc(33.3% - .5px),var(--line) 33.3%,transparent 33.3%); background-size:100% 100%; }.flow-lines { pointer-events:none; width:100%; height:100%; }.flow-lines path { stroke:#bdbab4; stroke-width:1; stroke-dasharray:2 5; opacity:.48; }
.feature-path { width:100%; height:100%; overflow:visible; pointer-events:none; }.path-segment { stroke:#aaa7a1; stroke-width:1; stroke-dasharray:3 6; stroke-linecap:round; fill:none; opacity:0; transition:opacity .35s ease,stroke-width .2s ease; }.path-segment.is-visible { opacity:.34; }.path-segment.is-current { opacity:.74; stroke-width:1.3; }.path-segment.is-hovered { opacity:.65; stroke-width:1.4; }
.feature-network { pointer-events:none; }.feature-dot { --x:72%; --y:33%; position:absolute; left:var(--x); top:var(--y); width:11px; height:11px; padding:0; transform:translate(-50%,-50%) scale(0); border:2px solid var(--orange); background:var(--cream); border-radius:50%; box-shadow:0 0 0 7px rgba(255,77,28,.08),0 0 13px rgba(255,77,28,.24); opacity:0; cursor:pointer; pointer-events:none; transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .3s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease; }.feature-dot.is-visible { opacity:1; transform:translate(-50%,-50%) scale(1); pointer-events:auto; }.feature-dot.is-intro-card { border-color:transparent; background:transparent; box-shadow:none; }.feature-dot:hover,.feature-dot.is-open { box-shadow:0 0 0 8px rgba(255,77,28,.12),0 0 17px rgba(255,77,28,.52); }.feature-dot.is-intro-card.is-open { box-shadow:none; }.feature-dot--violet { --x:52%; --y:16%; border-color:var(--violet); box-shadow:0 0 0 7px rgba(113,92,255,.08),0 0 13px rgba(113,92,255,.26); }.feature-dot--violet:hover,.feature-dot--violet.is-open { box-shadow:0 0 0 8px rgba(113,92,255,.12),0 0 17px rgba(113,92,255,.48); }.feature-dot--violet.is-intro-card { border-color:transparent; background:transparent; box-shadow:none; }
.feature-dot:nth-child(2) { --x:78%; --y:34%; }.feature-dot:nth-child(3) { --x:23.1%; --y:41.2%; }.feature-dot:nth-child(4) { --x:48%; --y:65%; }.feature-dot:nth-child(5) { --x:75%; --y:72%; }
.feature-tooltip { position:absolute; left:calc(100% + 14px); bottom:50%; min-width:162px; transform:translate(6px,50%) scale(.96); padding:10px 11px; color:#5e5b57; background:rgba(243,241,236,.94); border:1px solid rgba(214,211,205,.95); font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.01em; white-space:normal; text-align:left; opacity:0; pointer-events:none; backdrop-filter:blur(4px); transition:opacity .22s ease,transform .22s ease; }.feature-tooltip strong,.feature-tooltip span { display:block; }.feature-tooltip strong { color:var(--ink); font-weight:500; margin-bottom:4px; }.feature-tooltip span { color:var(--muted); line-height:1.35; }.feature-dot.is-open .feature-tooltip { opacity:1; transform:translate(0,50%) scale(1); }.feature-dot--violet .feature-tooltip { border-color:rgba(113,92,255,.4); }.feature-dot--violet .feature-tooltip strong { color:#5545c6; }
.ambient-glow { position:absolute; pointer-events:none; width:580px; height:380px; right:-105px; top:7%; border-radius:50%; background:radial-gradient(ellipse,rgba(255,77,28,.12) 0%,rgba(255,77,28,.045) 35%,transparent 68%); filter:blur(12px); }.signal-card { position:absolute; z-index:1; display:flex; align-items:center; gap:8px; color:#686662; background:rgba(243,241,236,.72); border:1px solid rgba(214,211,205,.85); font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.01em; padding:9px 11px; backdrop-filter:blur(3px); }.signal-card-one { top:27%; right:10.6%; cursor:pointer; transition:background .2s ease,border-color .2s ease,color .2s ease; }.signal-card-one:hover { color:var(--ink); background:rgba(248,246,242,.95); border-color:rgba(255,77,28,.6); }.signal-card-two { bottom:19%; left:8.3%; pointer-events:none; }.mini-orbit { width:9px; height:9px; border:1px solid var(--orange); border-radius:50%; position:relative; }.mini-orbit::after { content:""; position:absolute; width:3px; height:3px; background:var(--orange); border-radius:50%; right:-2px; top:-2px; }
.hero-content { position:relative; z-index:2; max-width:1220px; width:100%; margin:0 auto; }.eyebrow { color:rgba(23,23,23,.68); text-transform:uppercase; font-family:"DM Mono",monospace; font-size:11px; line-height:1; letter-spacing:.22em; font-weight:600; display:inline-flex; align-items:center; gap:11px; margin:0 0 clamp(18px,2.2vh,28px) clamp(0px,6.4vw,124px); opacity:.74; }.eyebrow-dot { display:block; width:6px; height:6px; border-radius:999px; background:var(--violet); box-shadow:0 0 0 5px rgba(113,92,255,.07); flex:0 0 auto; }.hero-title { max-width:clamp(720px,54vw,980px); margin:clamp(18px,4vh,48px) 0 0 clamp(0px,6.4vw,124px); font-size:clamp(52px,5.9vw,94px); letter-spacing:-.065em; line-height:.86; font-weight:800; }.hero-title span { display:block; white-space:nowrap; }.hero-title span:nth-child(2) { transform:translateX(-.01em); }.hero-lower { width:min(810px,100%); display:grid; grid-template-columns:1.2fr .8fr; gap:clamp(35px,7vw,108px); margin:clamp(39px,7vh,78px) 0 0 clamp(0px,16.2vw,198px); }.hero-copy { color:var(--muted); font-size:14px; line-height:1.65; margin:0; max-width:430px; }.hero-action { position:relative; max-width:290px; }.prototype-hint { position:absolute; left:2vw; bottom:calc(100% - 115px - 6.5vh); font-family:"DM Mono",monospace; font-size:9px; line-height:1; letter-spacing:.15em; font-weight:400; text-transform:none; color:rgba(23,23,23,.42); pointer-events:none; transition:opacity .18s ease; }.prototype-hint.is-hidden { opacity:0; visibility:hidden; }.conversation-card { min-width:265px; padding:14px 15px 12px; background:var(--orange); color:#fff; box-shadow:0 14px 32px rgba(255,77,28,.15); }.conversation-label { display:block; font-family:"DM Mono",monospace; font-size:8px; letter-spacing:.04em; color:rgba(255,255,255,.72); text-transform:uppercase; }.conversation-name { display:flex; align-items:center; gap:7px; margin:6px 0 12px; font-size:12px; font-weight:700; }.conversation-name i { width:7px; height:7px; border-radius:50%; background:#fff; box-shadow:0 0 0 3px rgba(255,255,255,.2); }.conversation-input { display:flex; align-items:center; justify-content:space-between; padding:8px 9px; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.26); font-size:10px; color:rgba(255,255,255,.86); }.conversation-input b { font-size:14px; font-weight:400; color:#fff; }.hero-action p { margin:12px 0 0; color:var(--muted); font-size:10px; line-height:1.5; max-width:250px; }.hero-bottom-bar { position:relative; z-index:2; margin-top:auto; padding-top:18px; border-top:1px solid var(--line); display:grid; grid-template-columns:1fr auto 1fr; align-items:center; color:var(--muted); font-family:"DM Mono",monospace; font-size:10px; letter-spacing:.02em; }.hero-bottom-bar time { justify-self:start; }.hero-bottom-bar > a:last-child { justify-self:end; }.scroll-cue { justify-self:center; transition:color .2s ease; }.scroll-cue:hover { color:var(--orange); }.scroll-cue span { margin-left:4px; color:var(--ink); font-size:13px; }.anchor-target { display:block; height:0; }
@media (max-width:700px) { .site-header { height:65px; grid-template-columns:1fr auto; padding:0 20px; }.nav-links { display:none; }.header-cta { font-size:10px; }.hero { height:auto; min-height:calc(100svh - 65px); padding:48px 20px 22px; }.grid { background-size:100% 50%; opacity:.52; }.flow-lines { width:180%; left:-42%; opacity:.4; }.feature-dot:nth-child(1) { --x:77%; --y:18%; }.feature-dot:nth-child(2) { --x:80%; --y:36%; }.feature-dot:nth-child(3) { --x:16%; --y:53%; }.feature-dot:nth-child(4) { --x:54%; --y:67%; }.feature-dot:nth-child(5) { --x:79%; --y:76%; }.feature-tooltip { font-size:8px; padding:8px 9px; }.signal-card-one { right:5%; top:25%; }.signal-card-two { display:none; }.ambient-glow { width:370px; right:-150px; top:12%; }.eyebrow { max-width:100%; margin:0 0 32px; gap:9px; font-size:10px; letter-spacing:.16em; white-space:normal; }.eyebrow-dot { width:5px; height:5px; box-shadow:0 0 0 4px rgba(113,92,255,.07); }.hero-title { max-width:100%; margin:0; font-size:clamp(34px,10.4vw,58px); line-height:.88; letter-spacing:-.065em; }.hero-lower { display:block; margin:39px 0 0; }.hero-copy { max-width:330px; }.hero-action { margin-top:26px; }.prototype-hint { left:0; bottom:calc(100% + 7px); font-size:8.5px; letter-spacing:.08em; color:rgba(23,23,23,.42); }.primary-cta { width:100%; max-width:310px; }.hero-bottom-bar { padding-top:20px; font-size:9px; }.scroll-cue { display:none; } }
@media (max-width:385px) { .header-cta { font-size:0; border:0; }.header-cta span { font-size:19px; }.hero { min-height:600px; }.signal-card-one { transform:scale(.85); transform-origin:right top; } }
@media (prefers-reduced-motion:reduce) { *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; } }

/* Let the feature points receive hover events through the editorial text layer. */
.hero-content { pointer-events:none; }
.hero-action { pointer-events:auto; }
.hero-bottom-bar { pointer-events:none; }
.hero-bottom-bar a { pointer-events:auto; }

/* Final feature-dot route: center, across the right side, then down to the footer. */
.feature-dot { --x:78%; --y:39%; }
.feature-dot:nth-child(2) { --x:66%; --y:48%; }
.feature-dot:nth-child(3) { --x:44%; --y:82%; }
.feature-dot:nth-child(4) { --x:28%; --y:59%; }
.feature-dot:nth-child(5) { --x:15%; --y:69%; }
.feature-dot:nth-child(6) { --x:20%; --y:82%; }
.feature-dot:nth-child(7) { --x:34%; --y:94%; }
.feature-dot--violet { border-color:var(--violet); box-shadow:0 0 0 7px rgba(113,92,255,.08),0 0 13px rgba(113,92,255,.26); }
.hero-lower { width:min(910px,100%); grid-template-columns:minmax(540px,1fr) 265px; gap:clamp(35px,6vw,78px); }
.hero-copy { max-width:none; white-space:nowrap; font-size:12px; }
.hero-lower { width:100%; grid-template-columns:1fr 265px; margin-left:0; }.hero-copy { margin-left:clamp(0px,16.2vw,198px); }.hero-action { justify-self:end; }
.conversation-card { display:block; width:265px; border:0; text-align:left; cursor:pointer; font-family:inherit; transform:translate(2vw,calc(132px + 6.5vh)); transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease; }
.conversation-card:hover { transform:translate(2vw,calc(129px + 6.5vh)); box-shadow:0 18px 36px rgba(255,77,28,.25); }
.conversation-card.is-hidden { opacity:0; transform:translate(2vw,calc(142px + 6.5vh)); pointer-events:none; }
.chat-panel { position:fixed; z-index:80; top:76.5%; right:clamp(24px,7.1vw,114px); width:380px; height:360px; padding:7px; background:rgba(255,255,255,.86); border:1px solid rgba(255,77,28,.42); border-radius:22px; box-shadow:0 22px 60px rgba(23,23,23,.2),0 0 0 9px rgba(255,77,28,.055); backdrop-filter:blur(14px); transform:translateY(-44%) scale(.96); transform-origin:bottom right; opacity:0; pointer-events:none; transition:transform .45s cubic-bezier(.2,.8,.2,1),opacity .25s ease,box-shadow .25s ease; display:flex; flex-direction:column; overflow:hidden; }
.chat-panel.is-open { transform:translateY(0) scale(1); opacity:1; pointer-events:auto; }
.chat-panel.is-frozen { transform:translateY(-50%) scale(1); box-shadow:0 28px 80px rgba(23,23,23,.24),0 0 0 12px rgba(255,77,28,.065); }
.chat-panel.is-frozen::after { display:none; }
.chat-header { height:48px; flex:0 0 48px; display:flex; align-items:center; justify-content:space-between; padding:0 12px 0 14px; color:#3d3d3d; font-size:12px; font-weight:800; background:linear-gradient(135deg,#f7f6f3,#ededeb); border-radius:16px; }.chat-header span { display:flex; align-items:center; gap:8px; }.chat-header i { width:20px; height:20px; border-radius:50%; background:linear-gradient(135deg,#ff6a3b,#ff4d1c); position:relative; box-shadow:0 0 0 4px rgba(255,77,28,.12); }.chat-header i::before { content:""; position:absolute; inset:-7px; border:1px solid rgba(255,77,28,.34); border-radius:50%; animation:agentPulse 2.4s ease-in-out infinite; }.chat-header i::after { content:""; position:absolute; width:8px; height:8px; border-radius:50%; background:#fff; top:4px; left:6px; }.chat-header button { border:0; background:transparent; color:#777; font-size:20px; cursor:pointer; }.chat-messages { min-height:0; flex:1 1 auto; padding:16px 12px; display:flex; flex-direction:column; gap:10px; overflow-y:auto; overscroll-behavior:contain; scrollbar-width:thin; }.chat-bubble { max-width:78%; margin:0; padding:10px 12px; border-radius:14px; font-size:11px; line-height:1.35; flex:0 0 auto; }.chat-bubble--them { align-self:flex-start; color:#68645f; background:#eceae6; border-bottom-left-radius:4px; }.chat-bubble--you { align-self:flex-end; color:#fff; background:var(--orange); border-bottom-right-radius:4px; }.chat-bubble--short { max-width:45%; }.chat-compose { flex:0 0 auto; display:flex; align-items:center; justify-content:space-between; gap:8px; margin:3px; padding:8px 8px 8px 13px; border:1px solid rgba(23,23,23,.1); border-radius:16px; color:#b2b2b2; background:#fff; font-size:10px; }.chat-compose input { min-width:0; flex:1; border:0; outline:0; color:#555; background:transparent; font:inherit; }.chat-compose input::placeholder { color:#b2b2b2; }.chat-compose button { display:grid; place-items:center; width:22px; height:22px; border:0; border-radius:50%; background:var(--orange); color:#fff; cursor:pointer; }.chat-privacy-notice { position:relative; z-index:2; flex:0 0 auto; margin:5px 10px 4px; color:#8b8781; font:7px/1.35 "DM Mono",monospace; letter-spacing:.01em; }.chat-privacy-link { position:relative; z-index:3; color:#625f5a; text-decoration:underline; text-underline-offset:2px; cursor:pointer; pointer-events:auto; transition:opacity .18s ease; }.chat-privacy-link:hover { opacity:.72; }
@keyframes agentPulse { 0%,100% { opacity:.18; transform:scale(.92); } 50% { opacity:.55; transform:scale(1.06); } }
@media (max-width:700px) { .feature-dot { --x:78%; --y:38%; }.feature-dot:nth-child(2) { --x:63%; --y:48%; }.feature-dot:nth-child(3) { --x:82%; --y:69%; }.feature-dot:nth-child(4) { --x:28%; --y:59%; }.feature-dot:nth-child(5) { --x:15%; --y:69%; }.feature-dot:nth-child(6) { --x:31%; --y:79%; }.feature-dot:nth-child(7) { --x:76%; --y:92%; }.feature-tooltip { left:auto; right:calc(100% + 12px); transform:translate(-6px,50%) scale(.96); }.feature-dot.is-open .feature-tooltip { transform:translate(0,50%) scale(1); }.hero-copy { white-space:normal; font-size:14px; margin-left:0; }.hero-lower { width:100%; }.hero-action { justify-self:start; }.conversation-card { width:100%; max-width:310px; transform:none; }.conversation-card:hover { transform:translateY(-2px); }.conversation-card.is-hidden { transform:translateY(10px); }.chat-panel { position:fixed; top:auto; right:10px; bottom:10px; width:min(360px,calc(100vw - 20px)); height:min(420px,calc(100svh - 20px)); }.chat-panel.is-open { transform:translateY(0) scale(1); } }
.agent-memory { height:100vh; min-height:720px; padding:58px min(42vw,530px) 76px clamp(24px,7.1vw,114px); background:var(--cream); border-top:1px solid rgba(23,23,23,.12); display:grid; grid-template-columns:.78fr 1.22fr; grid-template-rows:auto 1fr auto; gap:24px clamp(42px,7vw,112px); align-items:start; position:relative; z-index:2; scroll-snap-align:start; scroll-snap-stop:always; overflow:hidden; }
.agent-memory::before { content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.42; background-image:linear-gradient(to right,transparent 0,transparent calc(25% - .5px),var(--line) calc(25% - .5px),var(--line) 25%,transparent 25%),linear-gradient(to bottom,transparent 0,transparent calc(25% - .5px),var(--line) calc(25% - .5px),var(--line) 25%,transparent 25%); }
.agent-memory > * { position:relative; z-index:1; }
.memory-route { position:absolute; inset:0; z-index:1; pointer-events:none; }
.memory-route-line { position:absolute; inset:0; width:100%; height:100%; overflow:visible; pointer-events:none; }
.memory-route-line path { fill:none; stroke:rgba(23,23,23,.22); stroke-width:.42; stroke-dasharray:1.3 1.6; stroke-linecap:round; vector-effect:non-scaling-stroke; }
.memory-route-dot { --x:73%; --y:21%; position:absolute; left:var(--x); top:var(--y); z-index:3; width:13px; height:13px; padding:0; transform:translate(-50%,-50%); border:2px solid var(--orange); border-radius:50%; background:var(--cream); box-shadow:0 0 0 8px rgba(255,77,28,.1),0 0 16px rgba(255,77,28,.24); pointer-events:auto; cursor:pointer; }
.memory-route-dot:nth-of-type(1) { --x:73%; --y:21%; }
.memory-route-dot:nth-of-type(2) { --x:76%; --y:38%; }
.memory-route-dot:nth-of-type(3) { --x:69%; --y:63%; }
.memory-route-dot:nth-of-type(4) { --x:59%; --y:82%; }
.memory-route-dot:nth-of-type(5) { --x:50%; --y:93%; }
.memory-route-dot span { position:absolute; right:calc(100% + 14px); top:50%; min-width:190px; padding:10px 11px; transform:translate(-6px,-50%) scale(.96); opacity:0; pointer-events:none; color:#5e5b57; background:rgba(248,247,244,.98); border:1px solid rgba(214,211,205,.95); font-family:"DM Mono",monospace; font-size:9px; text-align:left; transition:opacity .2s ease,transform .2s ease; box-shadow:0 12px 32px rgba(23,23,23,.08); }
.memory-route-dot:nth-of-type(3) span { min-width:190px; }
.memory-route-dot:hover span,.memory-route-dot:focus-visible span { opacity:1; transform:translate(0,-50%) scale(1); }
.memory-route-dot strong,.memory-route-dot small { display:block; }
.memory-route-dot strong { color:var(--ink); font-weight:500; margin-bottom:4px; }
.memory-route-dot small { color:var(--muted); line-height:1.35; }
.agent-memory-copy { grid-column:1; grid-row:1 / 3; align-self:center; }
.agent-memory-copy h2 { max-width:360px; margin:0; font-size:clamp(40px,4.2vw,68px); line-height:.88; letter-spacing:-.074em; }
.agent-tasks { grid-column:2; grid-row:1 / 3; align-self:center; max-width:460px; padding-top:8px; }
.task-step { display:grid; grid-template-columns:52px 1fr; align-items:baseline; gap:22px; padding:4px 0; }
.task-step span { color:var(--orange); font:10px "DM Mono",monospace; letter-spacing:.04em; }
.task-step h3 { margin:0; font-size:clamp(18px,1.55vw,24px); line-height:1.05; letter-spacing:-.035em; font-weight:800; text-transform:none; }
.task-step--split { grid-template-columns:54px minmax(180px,1fr) minmax(130px,.55fr); column-gap:22px; }
.task-step--split p { margin:0; color:#6d6963; font:12px "DM Mono",monospace; letter-spacing:.02em; }
.task-wave { height:20px; margin:16px 0 18px 74px; opacity:.42; background:radial-gradient(ellipse at center,transparent 0 41%,rgba(23,23,23,.28) 43% 48%,transparent 50%) 0 50%/17px 8px repeat-x; }
.empty-chat-note { position:absolute!important; right:calc(clamp(24px,7.1vw,114px) - 4vw - 16px); top:79.5%; width:340px; margin:0; transform:translateY(-50%); font-family:"IBM Plex Mono",monospace; font-size:12px; line-height:1.6; letter-spacing:0.03em; color:rgba(23,23,23,0.55); text-transform:lowercase; z-index:1; }
.data-title { grid-column:1; grid-row:3; align-self:end; justify-self:center; width:max-content; max-width:calc(100vw - 48px); white-space:nowrap; margin:0 0 178px; font-size:clamp(22px,2.25vw,34px); line-height:1.02; letter-spacing:-.055em; text-align:center; }
.table-cluster { grid-column:1 / 2; grid-row:3; align-self:end; justify-self:center; width:min(360px,100%); position:relative; min-height:132px; padding:0; border:0; background:transparent; display:grid; gap:0; overflow:visible; }
.memory-tab { display:flex; align-items:center; justify-content:center; min-height:44px; padding:0; border:0; border-top:1px solid rgba(23,23,23,.22); color:var(--ink); background:transparent; cursor:pointer; text-align:center; text-transform:lowercase; font:12px "DM Mono",monospace; letter-spacing:.02em; transition:color .2s ease,border-color .2s ease; }
.memory-tab:nth-of-type(3) { border-bottom:1px solid rgba(23,23,23,.22); }
.memory-tab:hover,.memory-tab.is-active { color:var(--orange); }
.table-sheet { position:absolute; left:50%; bottom:-10px; width:min(620px,calc(100vw - 56px)); height:318px; z-index:4; padding:8px; background:rgba(248,247,244,.97); border:1px solid rgba(23,23,23,.12); box-shadow:0 18px 48px rgba(23,23,23,.12); transform:translate(-50%,10px); opacity:0; pointer-events:none; transition:opacity .2s ease,transform .22s ease; }
.table-sheet.is-open { opacity:1; pointer-events:auto; transform:translate(-50%,0); }
.data-window-header { height:36px; display:flex; align-items:center; justify-content:space-between; padding:0 9px 0 11px; color:#46423d; background:#ebe9e4; font-size:11px; font-weight:800; }
.data-window-header button { border:0; background:transparent; color:#777; font-size:18px; cursor:pointer; }
.data-window-body { height:calc(100% - 36px); max-height:none; padding:9px 5px 2px; overflow:auto; }
.data-window-note { max-width:560px; margin:0 0 10px; color:#77726c; font:9px "DM Mono",monospace; line-height:1.45; letter-spacing:.01em; }
.table-sheet table { width:100%; min-width:var(--table-min-width,560px); border-collapse:collapse; font-size:10px; }
.table-sheet th { color:#8b8781; font:8px "DM Mono",monospace; text-transform:uppercase; letter-spacing:.06em; text-align:left; padding:0 5px 7px; }
.table-sheet td { padding:8px 5px; border-top:1px solid rgba(23,23,23,.08); color:#4f4b46; }
.table-sheet td:last-child { color:var(--orange); font-family:"DM Mono",monospace; font-size:9px; }
.table-sheet--calendar { background:rgba(248,247,244,.985); }
.calendar-preview { min-width:560px; }
.calendar-preview-meta { margin:0 0 12px; color:#77726c; font:9px "DM Mono",monospace; letter-spacing:.04em; text-transform:lowercase; }
.calendar-people { display:grid; grid-template-columns:repeat(3,minmax(160px,1fr)); gap:0; border-top:1px solid rgba(23,23,23,.14); border-bottom:1px solid rgba(23,23,23,.14); }
.calendar-person { min-width:0; padding:13px 14px 14px; border-right:1px solid rgba(23,23,23,.12); }
.calendar-person:last-child { border-right:0; }
.calendar-person h3 { margin:0 0 12px; color:var(--ink); font-size:15px; line-height:1.1; letter-spacing:-.035em; }
.calendar-group { padding-top:10px; border-top:1px solid rgba(23,23,23,.1); }
.calendar-group + .calendar-group { margin-top:12px; }
.calendar-group p { margin:0 0 7px; color:#68645f; font:8px "DM Mono",monospace; letter-spacing:.08em; text-transform:uppercase; }
.calendar-group ul { list-style:none; margin:0; padding:0; display:grid; gap:6px; }
.calendar-group li { display:grid; grid-template-columns:74px 1fr; gap:9px; align-items:baseline; color:#514d48; font-size:10px; line-height:1.25; }
.calendar-group li span { color:#77726c; font-family:"DM Mono",monospace; font-size:9px; white-space:nowrap; }
.calendar-group li strong { font-weight:600; }
.calendar-group--free li { display:block; color:var(--orange); font-family:"DM Mono",monospace; font-size:9px; }
.calendar-group--free li span { color:var(--orange); }
.calendar-preview .data-window-note { margin:12px 0 0; max-width:none; }
.gift-modal { position:fixed; inset:0; z-index:100; display:grid; place-items:center; padding:24px; background:rgba(5,5,5,.18); opacity:0; pointer-events:none; transition:opacity .2s ease; }
.gift-modal.is-open { opacity:1; pointer-events:auto; }
.gift-card { width:min(470px,100%); position:relative; padding:34px; background:rgba(247,246,242,.96); border:1px solid rgba(23,23,23,.14); box-shadow:0 28px 90px rgba(23,23,23,.22); }
.gift-close { position:absolute; right:16px; top:12px; border:0; background:transparent; color:#777; font-size:22px; cursor:pointer; }
.gift-card .eyebrow { margin-bottom:24px; }
.gift-card h2 { margin:0 0 26px; font-size:clamp(30px,4vw,48px); line-height:.96; letter-spacing:-.065em; }
.gift-card label { display:block; margin-top:14px; color:#67635d; font:10px "DM Mono",monospace; letter-spacing:.03em; }
.gift-card input { width:100%; margin-top:8px; padding:13px 0; border:0; border-bottom:1px solid rgba(23,23,23,.22); outline:0; background:transparent; color:var(--ink); font:15px "Manrope",Arial,sans-serif; }
.gift-card input:focus { border-color:var(--orange); }
.gift-email-row { display:none!important; }
.gift-modal.is-email-step .gift-email-row { display:block!important; }
.gift-card button[type="submit"] { margin-top:24px; padding:13px 16px; border:0; color:#fff; background:var(--orange); cursor:pointer; font-size:12px; font-weight:700; }
.gift-card button[type="submit"] span { margin-left:8px; }

.features-page { min-height:100vh; padding:clamp(86px,10vh,118px) clamp(24px,4vw,64px) clamp(72px,8vh,98px); color:#f5f4f1; background:var(--black); display:flex; align-items:center; scroll-snap-align:start; scroll-snap-stop:always; position:relative; overflow:hidden; }
.features-page::before { content:""; position:absolute; inset:0; pointer-events:none; opacity:.13; background-image:linear-gradient(to right,transparent 0,transparent calc(25% - .5px),#fff calc(25% - .5px),#fff 25%,transparent 25%); }
.features-content { width:min(1220px,100%); margin:0 auto; position:relative; z-index:1; }
.function-list { display:grid; grid-template-columns:repeat(2,minmax(260px,1fr)); gap:clamp(26px,4.6vw,72px) clamp(48px,8vw,128px); }
.function-row { display:grid; grid-template-columns:44px 1fr; gap:clamp(18px,2.4vw,34px); padding:25px 0 24px; border-top:1px solid rgba(255,255,255,.22); position:relative; }
.function-row:nth-child(2),.function-row:nth-child(5) { transform:translateY(34px); }
.function-row:nth-child(3) { transform:translateY(10px); }
.function-row:nth-child(6) { transform:translateY(-12px); }
.function-row::after { display:none; }
.function-row span { padding-top:4px; color:var(--orange); font:10px "DM Mono",monospace; letter-spacing:.04em; }
.function-row h3 { margin:0; color:#f5f4f1; font-size:22px; line-height:1.05; letter-spacing:-.045em; font-weight:800; }
.function-row p { width:min(580px,100%); margin:8px 0 0; color:#aaa6a0; font-size:13px; line-height:1.58; }

.demo-page { height:100vh; min-height:680px; padding:0 clamp(24px,4vw,64px) 34px; color:var(--ink); background:var(--cream); display:grid; grid-template-columns:.8fr 1.2fr; align-items:center; position:relative; scroll-snap-align:start; scroll-snap-stop:always; overflow:hidden; }
.demo-page::before { content:""; position:absolute; width:42vw; height:42vw; min-width:420px; min-height:420px; right:-14vw; top:12vh; border-radius:50%; border:1px solid rgba(23,23,23,.08); box-shadow:0 0 0 90px rgba(255,77,28,.035); pointer-events:none; }
.demo-left { align-self:end; padding-bottom:72px; position:relative; z-index:1; color:#6b6761; font:17px "DM Mono",monospace; }
.demo-left a { border-bottom:0; padding-bottom:0; }
.demo-form { width:min(520px,100%); justify-self:center; transform:translateX(12%); position:relative; z-index:1; }
.demo-form h2 { margin:0; font-size:clamp(38px,5vw,74px); line-height:.92; letter-spacing:-.07em; }
.demo-form > p:not(.eyebrow) { width:min(390px,100%); margin:18px 0 30px; color:var(--muted); font-size:13px; line-height:1.65; }
.demo-form label { display:block; margin-top:13px; color:#67635d; font:10px "DM Mono",monospace; letter-spacing:.03em; }
.demo-form input,.demo-form textarea { width:100%; margin-top:8px; padding:13px 0; border:0; border-bottom:1px solid rgba(23,23,23,.22); outline:0; resize:none; color:var(--ink); background:transparent; font:15px "Manrope",Arial,sans-serif; }
.demo-form input:focus,.demo-form textarea:focus { border-color:var(--orange); }
.demo-faq { margin-top:34px; border-top:1px solid rgba(23,23,23,.16); }
.demo-faq-row { padding:17px 0 18px; border-bottom:1px solid rgba(23,23,23,.16); }
.demo-faq-row h3 { margin:0; color:var(--ink); font-size:16px; line-height:1.12; letter-spacing:-.035em; font-weight:800; }
.demo-faq-row p { margin:8px 0 0; color:var(--muted); font-size:13px; line-height:1.55; }
.demo-form button { margin-top:24px; padding:13px 16px; border:0; color:#fff; background:var(--orange); cursor:pointer; font-size:12px; font-weight:700; }
.demo-form .demo-faq + button { margin-top:34px; }
.demo-form button span { margin-left:8px; }
.demo-footer { position:absolute; left:50%; bottom:31px; transform:translateX(-50%); z-index:10; pointer-events:auto; font:10px "DM Mono",monospace; color:#67635d; }
.demo-footer a { position:relative; z-index:10; pointer-events:auto; text-decoration:underline; text-underline-offset:4px; }

html.privacy-document { scroll-snap-type:none; }
.privacy-body { min-height:100vh; background:var(--cream); color:var(--ink); }
.privacy-header { min-height:76px; padding:0 clamp(24px,4vw,64px); display:flex; align-items:center; justify-content:space-between; background:var(--black); color:#f5f4f1; }
.privacy-back { color:#b6b6b4; border-bottom:1px solid #6d6b69; padding-bottom:5px; font-size:12px; font-weight:600; }
.privacy-back span { color:var(--orange); margin-left:7px; font-size:16px; vertical-align:-1px; }
.privacy-main { padding:clamp(56px,8vw,112px) clamp(22px,6vw,96px) clamp(72px,10vw,128px); }
.privacy-article { width:min(860px,100%); margin:0 auto; }
.privacy-kicker { margin:0 0 24px; color:#67635d; font:10px "DM Mono",monospace; letter-spacing:.1em; text-transform:uppercase; }
.privacy-article h1 { margin:0; max-width:820px; font-size:clamp(44px,7vw,92px); line-height:.94; letter-spacing:-.072em; }
.privacy-subtitle { width:min(680px,100%); margin:22px 0 0; color:#4d4944; font-size:clamp(17px,2vw,24px); line-height:1.35; letter-spacing:-.035em; font-weight:700; }
.privacy-updated { margin:18px 0 clamp(52px,7vw,86px); color:#77726c; font:11px "DM Mono",monospace; letter-spacing:.02em; }
.privacy-content { border-top:1px solid rgba(23,23,23,.18); }
.privacy-content h2 { margin:0; padding:34px 0 14px; color:var(--ink); border-top:1px solid rgba(23,23,23,.12); font-size:clamp(24px,3vw,38px); line-height:1.05; letter-spacing:-.055em; }
.privacy-content h2:first-child { border-top:0; }
.privacy-content h3 { margin:0; padding:22px 0 8px; color:#252321; font-size:clamp(18px,2vw,24px); line-height:1.18; letter-spacing:-.035em; }
.privacy-content p { margin:0 0 15px; color:#4f4b46; font-size:15px; line-height:1.72; }
.privacy-content p:last-child { margin-bottom:0; }
.privacy-content a { text-decoration:underline; text-underline-offset:3px; }

@media (max-width:700px) {
  .landing-page { height:auto; min-height:200svh; }
  .agent-memory { height:auto; min-height:100svh; grid-template-columns:1fr; grid-template-rows:auto; padding:44px 20px 42px; }
  .agent-memory-copy,.agent-tasks,.data-title,.table-cluster { grid-column:1; grid-row:auto; }
  .agent-memory-copy { align-self:start; }
  .agent-tasks { max-width:none; }
  .empty-chat-note { position:relative!important; right:auto; top:auto; transform:none; width:auto; margin:8px 0 22px; }
  .data-title { margin:26px 0 8px; }
  .task-step,.task-step--split { grid-template-columns:38px 1fr; gap:16px; }
  .task-step--split p { grid-column:2; margin-top:7px; }
  .task-wave { margin-left:54px; }
  .table-cluster { grid-column:1; min-height:195px; }
  .table-sheet { left:0; right:0; bottom:0; width:auto; height:300px; transform:translateY(10px); }
  .table-sheet.is-open { transform:translateY(0); }
  .features-page,.demo-page { min-height:100svh; height:auto; padding-left:20px; padding-right:20px; }
  .features-page { display:block; }
  .function-list { grid-template-columns:1fr; gap:0; }
  .function-row:nth-child(n) { transform:none; }
  .function-row { grid-template-columns:42px 1fr; gap:18px; padding:22px 0; }
  .function-row h3 { font-size:19px; }
  .demo-page { grid-template-columns:1fr; align-items:center; padding-top:48px; }
  .demo-form { justify-self:start; transform:none; }
  .demo-left { order:2; align-self:end; padding-bottom:58px; }
  .privacy-header { min-height:65px; padding:0 20px; }
  .privacy-back { font-size:10px; }
  .privacy-main { padding:46px 20px 72px; }
  .privacy-article h1 { font-size:clamp(40px,13vw,62px); }
  .privacy-content p { font-size:14px; line-height:1.68; }
}

.feature-dot:nth-child(3) {
  border-color: #171717;
  background: #d6d3cd;
  box-shadow: 0 0 0 7px rgba(23, 23, 23, 0.08), 0 0 13px rgba(23, 23, 23, 0.24);
}

.feature-dot:nth-child(3):hover,
.feature-dot:nth-child(3).is-open {
  box-shadow: 0 0 0 8px rgba(23, 23, 23, 0.12), 0 0 17px rgba(23, 23, 23, 0.45);
}

.feature-dot:nth-child(3) .feature-tooltip {
  border-color: rgba(23, 23, 23, 0.35);
}

.feature-dot:nth-child(3) .feature-tooltip strong {
  color: #171717;
}
