:root{--fastn-blue:#6C5CE7;--fastn-blue-text:#8A7EED;--fastn-blue-hover:#8F85E8;--fastn-blue-pressed:#4029BA;--fastn-blue-tint:rgba(108,92,231,0.10);--bg:#0E0E10;--surface-1:#111113;--surface-2:#1A1A1D;--surface-3:#222226;--border:#2A2A2E;--border-high:#3E3E44;--text-1:#FFFFFF;--text-2:#D6D6D8;--text-3:#9A9AA2;--text-4:#6E6E76;--success:#10B981;--warning:#F59E0B;--error:#EF4444;--info:#6C5CE7;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-6:24px;--sp-8:32px;--sp-12:48px;--sp-16:64px;--sp-20:80px;--radius-1:4px;--radius-2:6px;--radius-3:8px;--radius-4:12px;--radius-5:16px;--radius-full:9999px;--dur-fast:100ms;--dur:180ms;--dur-slow:320ms;--surface:var(--surface-1);--border-soft:rgba(42,42,46,0.5);--text:var(--text-1);--text-dim:var(--text-2);--text-mute:var(--text-3);--primary:var(--fastn-blue);--primary-2:var(--fastn-blue-hover);--primary-soft:var(--fastn-blue-text);--primary-light:var(--fastn-blue-text);--on-primary:#FFFFFF;--danger:var(--error);--radius-sm:var(--radius-1);--radius:var(--radius-3);--radius-md:var(--radius-4);--radius-lg:var(--radius-5);--radius-xl:24px;--radius-pill:var(--radius-full);--gutter:24px;--container:1280px}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}}*{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden}html{background:var(--bg);color-scheme:dark}body{font-family:'Inter',system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.65;color:var(--text-2);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}:focus-visible{outline:3px solid rgba(108,92,231,0.18);outline-offset:2px}:focus:not(:focus-visible){outline:none}.nav a,.btn,button,.sidebar button{min-height:44px;min-width:44px}.h1{font-family:'Geist','Inter',system-ui,sans-serif;font-size:clamp(40px,5.4vw,58px);font-weight:500;line-height:1.05;letter-spacing:-0.03em;color:var(--text-1)}.h2{font-family:'Geist','Inter',system-ui,sans-serif;font-size:clamp(28px,3.6vw,38px);font-weight:500;line-height:1.1;letter-spacing:-0.02em;color:var(--text-1)}.h3{font-family:'Geist','Inter',system-ui,sans-serif;font-size:28px;font-weight:500;line-height:1.3;letter-spacing:-0.01em;color:var(--text-1)}.h4{font-family:'Inter',system-ui,sans-serif;font-size:20px;font-weight:600;line-height:1.35;color:var(--text-1)}.body-lg{font-size:18px;line-height:1.65;color:var(--text-2)}.body{font-size:16px;line-height:1.65;color:var(--text-2)}.body-sm{font-size:14px;line-height:1.6;color:var(--text-2)}.mono{font-family:'Geist Mono',ui-monospace,monospace;font-size:14px;line-height:1.6}.eyebrow{font-family:'Geist Mono',ui-monospace,monospace;font-size:12px;font-weight:600;line-height:1;letter-spacing:0.14em;text-transform:uppercase;color:var(--fastn-blue-text)}.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:var(--sp-3) var(--sp-6);font-family:'Inter',system-ui,sans-serif;font-size:16px;font-weight:600;border-radius:var(--radius-3);border:1px solid transparent;cursor:pointer;transition:background var(--dur),box-shadow var(--dur);text-decoration:none;white-space:nowrap;min-height:44px;min-width:44px}.btn:active{transform:scale(0.97)}.btn-primary{color:var(--on-primary);background:var(--fastn-blue)}.btn-primary:hover{background:var(--fastn-blue-hover)}.btn-primary:active{background:var(--fastn-blue-pressed)}.btn-secondary{color:var(--text-1);background:transparent;border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-2);border-color:var(--border-high)}.btn-ghost{color:var(--text-2);background:transparent}.btn-ghost:hover{background:var(--surface-2);color:var(--text-1)}.btn-white{background:#fff;color:#4A3AB8}.btn-white:hover{background:#ede8ff;color:#4A3AB8}.btn-outline-white{background:rgba(0,0,0,0.25);color:#fff;border-color:rgba(255,255,255,0.45)}.btn-outline-white:hover{background:rgba(255,255,255,0.08)}.card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md)}.card-padded{padding:24px}.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius-pill);font-size:13px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border-soft)}.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 4px rgba(16,185,129,0.12)}.header{position:sticky;top:0;z-index:50;background:rgba(0,0,0,0.72);backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--border-soft)}.header-inner{display:flex;justify-content:space-between;align-items:center;height:64px}.brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none}.brand-mark{width:26px;height:26px;border-radius:7px;background:var(--fastn-blue);display:flex;align-items:center;justify-content:center;color:var(--on-primary);font-weight:700;font-size:14px}.brand-name{font-weight:700;letter-spacing:-0.02em;font-size:18px}.brand-logo{height:22px;width:auto;display:block;filter:brightness(0) invert(1)}.brand-logo-footer{height:26px;width:auto;display:block;filter:brightness(0) invert(1)}.nav{display:flex;align-items:center;gap:6px;margin-left:32px}.nav a{color:var(--text-dim);text-decoration:none;padding:8px 14px;border-radius:8px;font-size:14px;transition:color 180ms,background 180ms}.nav a:hover{color:var(--text);background:var(--surface-1)}.nav a.active{color:var(--text)}.nav a.active::after{content:'';display:block;height:2px;margin-top:6px;background:var(--primary-light);border-radius:2px}.hero{position:relative;padding:96px 0 64px;overflow:hidden;text-align:center}.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0;background:transparent}.hero .grid-overlay{position:absolute;inset:0;z-index:0;background-image:linear-gradient(rgba(146,142,160,0.06) 1px,transparent 1px),linear-gradient(90deg,rgba(146,142,160,0.06) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 60% 50% at 50% 30%,#000 0%,transparent 80%)}.hero-inner{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:24px}.hero h1{max-width:920px;margin:0}.hero .lede{max-width:640px;color:var(--text-dim);font-size:18px}.hero .cta-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.status-row{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:8px}.status-row .pill{background:rgba(24,24,30,0.7);border-color:var(--border-soft)}.status-row .pill .check{width:16px;height:16px;color:var(--success)}.terminal{width:100%;max-width:1040px;margin:32px auto 0;background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-5);box-shadow:0 40px 120px -40px rgba(0,0,0,0.5);overflow:hidden}.terminal-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border);background:#0a0a0d}.terminal-bar .left{display:flex;align-items:center;gap:14px}.t-avatar{width:36px;height:36px;border-radius:10px;background:rgba(108,92,231,0.15);display:flex;align-items:center;justify-content:center;border:1px solid rgba(108,92,231,0.25)}.t-title{font-weight:600;font-size:15px;color:var(--text)}.t-id{display:none}.t-action{font-size:13px;color:var(--text-dim);padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;cursor:pointer;transition:background 180ms}.t-action:hover{background:var(--surface-1)}.terminal-body{padding:28px;min-height:360px;display:flex;flex-direction:column;gap:22px;text-align:left}.t-msg-user{align-self:flex-end;max-width:78%;background:var(--fastn-blue);color:var(--on-primary);padding:14px 18px;border-radius:16px 16px 4px 16px;font-weight:600;font-size:15px}.t-agent{align-self:flex-start;max-width:78%;background:var(--surface-2);border:1px solid var(--border);border-radius:16px 16px 16px 4px;padding:18px;display:flex;flex-direction:column;gap:14px}.t-agent .head{display:flex;align-items:center;gap:10px;color:var(--primary-soft);font-weight:600;font-size:14px}.t-agent .head .dot{width:8px;height:8px;border-radius:50%;background:var(--primary);box-shadow:0 0 12px rgba(108,92,231,0.4);animation:pulse-soft 1.6s ease-in-out infinite}@keyframes pulse-soft{0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(0.7);opacity:0.55}}.t-step{display:flex;align-items:center;gap:10px;color:var(--text-dim);font-size:14px}.t-step .ic{width:16px;height:16px;color:var(--success);flex:none}.t-step .spinner{width:14px;height:14px;border-radius:50%;border:2px solid rgba(108,92,231,0.25);border-top-color:var(--primary);animation:spin 0.8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.t-result{align-self:flex-start;max-width:78%;background:var(--surface-2);border:1px solid rgba(108,92,231,0.4);border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:14px;box-shadow:0 0 0 1px rgba(108,92,231,0.05) inset,0 18px 60px -20px rgba(0,0,0,0.45)}.t-result .head{display:flex;align-items:center;gap:12px}.t-result .head .badge{width:36px;height:36px;border-radius:50%;background:rgba(16,185,129,0.15);display:flex;align-items:center;justify-content:center;color:var(--success);border:1px solid rgba(16,185,129,0.3)}.t-result .head h4{margin:0;font-size:15px;font-weight:700}.t-result .head p{margin:0;font-size:13px;color:var(--text-mute)}.t-result .actions{display:flex;gap:10px}.t-mini-btn{font-size:13px;padding:8px 14px;border-radius:8px;cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--text);font-weight:600}.t-mini-btn.primary{background:var(--fastn-blue);border-color:transparent;color:var(--on-primary)}.t-mini-btn:hover{filter:brightness(1.08)}.terminal-input{border-top:1px solid var(--border);background:#0a0a0d;padding:14px 18px;display:flex;align-items:center;gap:12px}.terminal-input .field{flex:1;background:#0e0e13;border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-family:'Geist Mono',monospace;font-size:13px;color:var(--text);display:flex;align-items:center;gap:2px}.cursor{display:inline-block;width:8px;height:16px;background:var(--primary);margin-left:2px;animation:blink 1s steps(1) infinite;vertical-align:middle}@keyframes blink{50%{opacity:0}}.fade-up{opacity:0;transition:opacity var(--dur-slow) ease}.fade-up.in{opacity:1}@keyframes pageFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}main{animation:pageFadeIn 320ms ease forwards}@media (prefers-reduced-motion:reduce){main{animation:none}}.section{padding:96px 0;position:relative}.section.tight{padding:72px 0}.section-head{text-align:center;margin:0 auto 56px;max-width:720px}.section-head h2{margin:12px 0 14px}.section-head p{color:var(--text-dim);margin:0}.logo-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:40px 0;background:var(--bg)}.logo-strip .label{text-align:center;color:var(--text-mute);margin-bottom:24px;font-family:'Geist Mono',monospace;font-size:12px;letter-spacing:0.18em;text-transform:uppercase}.marquee{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}.marquee-track{display:flex;gap:64px;width:max-content;animation:scroll-left 32s linear infinite}.marquee-track:hover{animation-play-state:paused}@keyframes scroll-left{from{transform:translateX(0)} to{transform:translateX(-50%)}}.logo-item{display:flex;align-items:center;gap:10px;color:rgba(228,225,231,0.7);font-weight:600;font-size:18px;letter-spacing:-0.01em;padding:0 8px}.logo-item svg{width:22px;height:22px;opacity:0.85}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width:860px){.compare-grid{grid-template-columns:1fr}}.compare-grid .panel{padding:22px}.compare-grid .panel.after{border-color:rgba(108,92,231,0.35);position:relative;overflow:hidden}.compare-grid .panel.after::before{content:'';position:absolute;inset:auto -40px -40px auto;width:200px;height:200px;background:radial-gradient(circle,rgba(108,92,231,0.08),transparent 70%);filter:blur(10px);pointer-events:none}.row{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:10px;border:1px solid var(--border-soft);background:rgba(14,14,18,0.6)}.row + .row{margin-top:8px}.row.dim{opacity:0.55}.row.glow{border-color:rgba(108,92,231,0.35);background:rgba(108,92,231,0.06)}.row .name{font-weight:600;color:var(--text);font-size:14px}.row.dim .name{color:var(--text-mute);font-weight:500}.tag{font-size:12px;padding:4px 9px;border-radius:var(--radius-pill);letter-spacing:0.04em;font-family:'Geist Mono',monospace;font-weight:600}.tag.backlog{background:rgba(146,142,160,0.12);color:var(--text-mute)}.tag.ok{background:rgba(16,185,129,0.14);color:var(--success)}.benefit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media (max-width:980px){.benefit-grid{grid-template-columns:1fr}}.benefit{padding:22px;display:flex;flex-direction:column;gap:16px;transition:transform 220ms,border-color 220ms}.benefit:hover{transform:translateY(-2px);border-color:rgba(108,92,231,0.4)}.benefit .preview{height:200px;border-radius:10px;border:1px solid var(--border-soft);background:var(--bg);overflow:hidden;position:relative}.benefit h3{margin:4px 0 0}.benefit p{margin:0;color:var(--text-dim);font-size:14px}.step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative}@media (max-width:860px){.step-grid{grid-template-columns:1fr}}.step-grid::before{content:'';position:absolute;left:8%;right:8%;top:24px;height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent)}@media (max-width:860px){.step-grid::before{display:none}}.step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;position:relative}.step .num{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,rgba(108,92,231,0.25),rgba(108,92,231,0.1));border:1px solid rgba(108,92,231,0.5);color:var(--primary-soft);font-weight:700;font-size:17px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 8px var(--bg);position:relative;z-index:1}.step h4{margin:0}.step p{margin:0;color:var(--text-dim);font-size:14px;max-width:320px}.orbit-block{display:grid;grid-template-columns:1.05fr 0.95fr;gap:56px;align-items:center}@media (max-width:980px){.orbit-block{grid-template-columns:1fr;gap:32px}}.orbit{position:relative;aspect-ratio:1/1;max-width:520px;margin:0 auto;width:100%}.orbit .ring{position:absolute;inset:0;border:1px dashed rgba(146,142,160,0.18);border-radius:50%}.orbit .ring.inner{inset:18%;border-style:solid;border-color:rgba(146,142,160,0.12)}.orbit .ring.outer{inset:0}.orbit .core{position:absolute;inset:0;margin:auto;width:96px;height:96px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#0E1A26,#0e0e12 70%);border:1px solid rgba(108,92,231,0.45);display:flex;align-items:center;justify-content:center;color:var(--primary-soft);font-weight:700;letter-spacing:-0.02em;box-shadow:0 0 40px -10px rgba(108,92,231,0.25),inset 0 0 20px rgba(108,92,231,0.1)}.orbit .core .mark{width:38px;height:38px;border-radius:10px;background:var(--fastn-blue);display:flex;align-items:center;justify-content:center;color:var(--on-primary);font-weight:800;font-size:18px}.node{position:absolute;width:64px;height:64px;margin:-32px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--text);font-weight:600;font-size:12px;box-shadow:0 8px 24px -10px rgba(0,0,0,0.6);transition:transform 200ms,border-color 200ms;overflow:hidden;padding:8px}.node:hover{transform:scale(1.08);border-color:rgba(108,92,231,0.5)}.spin{animation:spin-cw 28s linear infinite}.spin.ccw{animation:spin-ccw 36s linear infinite}@keyframes spin-cw{to{transform:rotate(360deg)}}@keyframes spin-ccw{to{transform:rotate(-360deg)}}.counter{animation:spin-ccw 28s linear infinite}.counter.ccw{animation:spin-cw 36s linear infinite}.catalog{display:grid;grid-template-columns:1fr 1fr;gap:28px 40px}.catalog h4{margin:0 0 10px;color:var(--fastn-blue-text)}.catalog ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.catalog li{font-size:15px;color:var(--text);padding-left:14px;position:relative}.catalog li::before{content:'';position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--primary);opacity:0.7}.testimonial-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width:860px){.testimonial-grid{grid-template-columns:1fr}}.testimonial{padding:28px;display:flex;flex-direction:column;gap:18px}.testimonial .meta{display:flex;align-items:center;gap:14px}.testimonial .logo{width:48px;height:48px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text);font-weight:700;font-size:14px;letter-spacing:-0.02em}.testimonial .meta .stat{font-weight:700;font-size:16px;color:var(--text)}.testimonial .meta .org{font-size:12px;color:var(--text-mute);margin-top:2px}.testimonial blockquote{margin:0;font-style:italic;color:var(--text-dim);font-size:15px;line-height:1.6;border-left:2px solid var(--primary);padding-left:16px}.cta-band{border-radius:var(--radius-xl);padding:56px;background:radial-gradient(circle at 18% 20%,rgba(255,255,255,0.16),transparent 35%),radial-gradient(circle at 80% 80%,rgba(255,255,255,0.10),transparent 40%),linear-gradient(135deg,#6C5CE7 0%,#7B6DEA 100%);text-align:center;position:relative;overflow:hidden;box-shadow:0 60px 120px -60px rgba(0,0,0,0.6)}.cta-band::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.08) 1px,transparent 1px);background-size:28px 28px;opacity:0.6;pointer-events:none;mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,#000,transparent)}.cta-band > *{position:relative}.cta-band h2{color:#fff;margin:0 0 14px;max-width:800px;margin-left:auto;margin-right:auto}.cta-band .sub{color:#fff;max-width:640px;margin:0 auto 28px;font-size:16px}.cta-band .cta-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.cta-band .note{color:#fff;margin-top:18px;font-size:13px}.trust-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;max-width:920px;margin:0 auto}@media (max-width:820px){.trust-grid{grid-template-columns:1fr;gap:24px}}.trust-col{text-align:left;display:flex;flex-direction:column}.trust-col h3{margin:0 0 14px;color:var(--fastn-blue-text)}.trust-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.trust-col li{color:var(--text-2);font-size:14px;display:flex;align-items:center;gap:10px}.trust-col svg{color:var(--fastn-blue-text);flex:none}.footer{border-top:1px solid var(--border-soft);padding:56px 0 40px;background:#06060a}.footer-inner{display:grid;grid-template-columns:1.2fr 3fr;gap:56px}@media (max-width:800px){.footer-inner{grid-template-columns:1fr}}.footer .cols{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}@media (max-width:700px){.footer .cols{grid-template-columns:repeat(2,1fr)}}.footer .cols span.label{font-family:'Geist Mono',monospace;font-size:12px;letter-spacing:0.15em;text-transform:uppercase;color:var(--text)}.footer .cols a{display:block;color:var(--text-mute);font-size:13px;padding:6px 0;text-decoration:none}.footer .cols a:hover{color:var(--text)}.footer .copy{color:var(--text-mute);font-size:13px;margin-top:10px}.footer-bottom{border-top:1px solid var(--border-soft);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--text-mute);font-size:12px;font-family:'Geist Mono',monospace;letter-spacing:0.08em;text-transform:uppercase}.art{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(108,92,231,0.08),transparent 60%),#0a0a0e;overflow:hidden}.art .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(146,142,160,0.1) 1px,transparent 1px),linear-gradient(90deg,rgba(146,142,160,0.1) 1px,transparent 1px);background-size:18px 18px;mask-image:radial-gradient(ellipse 60% 60% at 50% 50%,#000,transparent)}.art .nodes{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.code-art{position:absolute;inset:14px;background:#0a0a0e;border:1px solid var(--border);border-radius:8px;padding:12px;font-family:'Geist Mono',monospace;font-size:12px;color:#D6D6D8;overflow:hidden;line-height:1.55}.code-art .k{color:#7B6DEA}.code-art .s{color:#ffb77d}.code-art .c{color:#908B9B}.modal-art{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:16px}.modal-art .modal{width:80%;max-width:220px;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:16px;display:flex;flex-direction:column;gap:10px}.modal-art .modal .ttl{font-size:12px;color:var(--text);font-weight:600}.modal-art .modal .sub{font-size:12px;color:var(--text-mute)}.modal-art .modal .field{height:28px;border-radius:6px;background:#0a0a0e;border:1px solid var(--border)}.modal-art .modal .btn-mini{height:28px;border-radius:6px;background:var(--fastn-blue);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--on-primary);font-weight:600}.shield-art{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.shield-art svg{width:60%;height:60%;color:var(--primary-soft);opacity:0.85;filter:drop-shadow(0 0 24px rgba(108,92,231,0.45))}.menu-toggle{display:none;width:44px;height:44px;border:none;background:transparent;cursor:pointer;padding:10px;color:var(--text-1);border-radius:var(--radius-3);transition:background var(--dur)}.menu-toggle:hover{background:var(--surface-1)}.menu-toggle svg{width:24px;height:24px}.mobile-nav{display:none;position:fixed;inset:0;z-index:100;background:rgba(0,0,0,0.85);backdrop-filter:blur(16px);flex-direction:column;align-items:center;justify-content:center;gap:8px}.mobile-nav.open{display:flex}.mobile-nav a{color:var(--text);text-decoration:none;font-size:20px;font-weight:600;padding:16px 32px;border-radius:12px;transition:background 180ms;width:80%;max-width:320px;text-align:center}.mobile-nav a:hover{background:var(--surface-1)}.mobile-nav .close-btn{position:absolute;top:16px;right:16px;width:40px;height:40px;border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:8px}.mobile-nav .close-btn:hover{background:var(--surface-1)}.mobile-nav .mobile-cta{margin-top:16px;display:flex;flex-direction:column;gap:8px;width:80%;max-width:320px}.mobile-nav .mobile-cta .btn{width:100%}@media (max-width:768px){:root{--gutter:16px}.menu-toggle{display:flex;align-items:center;justify-content:center}.nav{display:none !important}.header-inner .btn-ghost,.header-inner .btn-primary{display:none !important}.h1{font-size:clamp(28px,7vw,40px)}.h2{font-size:clamp(24px,5.5vw,32px)}.h3{font-size:20px}.body-lg,.hero .lede{font-size:16px}.hero{padding:80px 0 48px}.hero h1{max-width:100%}.hero .lede{max-width:100%}.hero .cta-row{flex-direction:column;width:100%;max-width:360px}.hero .cta-row .btn{width:100%}.status-row{flex-direction:column;align-items:center}.status-row .pill{width:100%;max-width:360px;justify-content:center}.terminal{margin-top:24px;border-radius:var(--radius-md)}.terminal-body{padding:16px;min-height:280px;gap:16px}.terminal-bar{padding:10px 14px}.t-msg-user{max-width:92%;font-size:14px;padding:12px 14px}.t-agent{max-width:92%;padding:14px}.t-result{max-width:92%;padding:16px}.t-result .actions{flex-wrap:wrap}.terminal-input{padding:10px 12px;gap:8px}.terminal-input .field{padding:10px 12px;font-size:12px}.t-id{display:none}.t-action{font-size:12px;padding:6px 10px}.section{padding:56px 0}.section.tight{padding:44px 0}.section-head{margin-bottom:32px}.logo-strip{padding:28px 0}.logo-item{font-size:15px;gap:6px}.marquee-track{gap:40px}.compare-grid .panel{padding:16px}.row{padding:10px 12px}.row .name{font-size:13px}.benefit .preview{height:160px}.step p{max-width:100%}.orbit{max-width:300px}.node{width:52px;height:52px;margin:-26px;font-size:12px;border-radius:10px}.orbit .core{width:72px;height:72px}.orbit .core .mark{width:28px;height:28px;font-size:14px}.testimonial{padding:20px}.testimonial blockquote{font-size:14px}.cta-band{padding:32px 20px;border-radius:var(--radius-lg)}.cta-band .cta-row{flex-direction:column;align-items:center}.cta-band .cta-row .btn{width:100%;max-width:320px}.footer{padding:40px 0 28px}.footer-inner{gap:32px}.footer-bottom{flex-direction:column;align-items:center;text-align:center;gap:8px;font-size:12px}}
/* ====== Styles from contact.html ====== */

@keyframes fadeUp { from { opacity:0; } to { opacity:1; } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes slideInRight { from { opacity:0; } to { opacity:1; } }

/* Contact page specifics */
.contact-layout {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
  grid-auto-rows: auto;
  align-items: start;
  padding: 40px 0 80px;
}
@media (max-width: 960px) { .contact-layout { grid-template-columns: 1fr; gap: 48px; } }

/* Hero left */
.contact-hero h1 { margin: 0 0 24px; animation: fadeUp 500ms ease both; }
.contact-hero .lede {
  font-size: 18px; line-height: 1.65; color: var(--text-dim); max-width: 520px;
  margin: 0 0 32px; animation: fadeUp 500ms 80ms ease both;
}

/* Stat cards */
.stat-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 36px; animation: fadeUp 500ms 160ms ease both; }
.stat-card {
  background: var(--surface-1); border: 1px solid var(--border); border-radius: var(--radius-md);
  padding: 18px 20px; transition: border-color 200ms, transform 200ms;
}
.stat-card:hover { border-color: rgba(108,92,231,0.45); transform: translateY(-2px); }
.stat-card .num { color: var(--primary-soft); font-weight: 700; font-size: 18px; margin-bottom: 4px; }
.stat-card .desc { font-size: 12px; color: var(--text-mute); line-height: 1.45; }

/* Feature list */
.feature-list { display: flex; flex-direction: column; gap: 8px; animation: fadeUp 500ms 240ms ease both; }
.feature-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 8px 12px; border-radius: var(--radius-md);
  transition: background 200ms, transform 200ms; margin: -8px -12px;
}
.feature-item:hover { background: rgba(108,92,231,0.04); transform: translateX(4px); }
.feature-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--primary);
  flex: none; margin-top: 8px; box-shadow: 0 0 0 4px rgba(108,92,231,0.12);
  transition: box-shadow 200ms;
}
.feature-item:hover .feature-dot { box-shadow: 0 0 0 6px rgba(108,92,231,0.2); }
.feature-item h2 { font-size: 16px; font-weight: 600; color: var(--text-1); margin: 0 0 2px; }
.feature-item p { margin: 0; font-size: 14px; color: var(--text-dim); line-height: 1.55; }

/* Right column */
.calendly-col {
  align-self: start !important;
  max-width: 480px;
  height: auto !important;
  min-height: 0 !important;
  flex-grow: 0 !important;
}

/* Trust badges */
.trust-strip {
  text-align: center; margin-bottom: 14px;
  font-family: 'Geist Mono', monospace;
  font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--text-mute); line-height: 1.6;
}
.trust-strip span { display: inline-flex; align-items: center; gap: 6px; margin: 0 6px; }

/* Calendly card — removed, using Cal.com popup */


/* What to expect */
.expect-card {
  margin-top: 0; padding: 22px; border: 1px solid var(--border);
  background: var(--surface-1); border-radius: var(--radius-md);
}

.expect-card p { color: var(--text-dim); font-size: 13px; line-height: 1.65; margin: 0; }

.tour-link {
  display: block; text-align: center;
  color: var(--primary-soft); font-size: 14px; font-weight: 500;
  text-decoration: none; transition: color 200ms;
}
.tour-link:hover { color: var(--primary-2); }

/* Mobile overrides for Contact page */
@media (max-width: 768px) {
  .contact-layout { grid-template-columns: 1fr; gap: 36px; padding: 24px 0 48px; }
  .contact-hero h1 { font-size: clamp(28px, 7vw, 40px); }
  .contact-hero .lede { font-size: 15px; max-width: 100%; }
  .stat-row { grid-template-columns: 1fr; gap: 10px; }
  .feature-item { margin: -8px -12px; padding: 8px 12px; }
  .feature-item h3 { font-size: 15px; }
  .feature-item p { font-size: 13px; }
  .calendly-col { max-width: 100%; }
  .cal-header { padding: 20px 16px 18px; }
  .cal-header h2 { font-size: 18px; }
  .cal-body { padding: 16px; }
  .cal-days { max-width: 100%; }
  .cal-nav { max-width: 100%; }
  .cal-weekdays { max-width: 100%; }
  .cal-meta { max-width: 100%; }
  .cal-note { max-width: 100%; }
  .time-slots { max-width: 100%; }
  .expect-card { padding: 18px; }
  .contact-footer .grid-4 { grid-template-columns: 1fr 1fr; gap: 28px; }
}

/* Contact footer (richer than homepage) */
.contact-footer { border-top: 1px solid var(--border-soft); padding: 64px 0 32px; background: #040408; }
.contact-footer .grid-4 { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1fr 1fr; gap: 40px; }
@media (max-width: 800px) { .contact-footer .grid-4 { grid-template-columns: 1fr 1fr; } }
.contact-footer h4 { color: var(--text); font-weight: 700; font-size: 15px; margin: 0 0 18px; }
.contact-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.contact-footer li a { color: var(--text-mute); font-size: 13px; text-decoration: none; display: flex; align-items: center; gap: 8px; transition: color 200ms; }
.contact-footer li a:hover { color: var(--text); }
.contact-footer li a.highlight { color: var(--primary-soft); font-weight: 600; }
.contact-footer .sub-label {
  font-family:'Geist Mono',monospace; font-size: 10px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-mute); margin-bottom: 6px;
}
.contact-footer .socials { display: flex; gap: 14px; margin-top: 20px; }
.contact-footer .socials a { color: var(--text-mute); transition: color 200ms; }
.contact-footer .socials a:hover { color: var(--text); }
.copyright-bar {
  border-top: 1px solid var(--border-soft); margin-top: 48px; padding-top: 20px;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: var(--text-mute);
}
.copyright-bar a { color: var(--text-mute); text-decoration: none; }
.copyright-bar a:hover { color: var(--text); }
.copyright-links { display: flex; gap: 20px; }


/* ====== Styles from integrations.html ====== */

/* ====== Integrations page overrides ====== */
@keyframes fadeUp { from { opacity:0; } to { opacity:1; } }
@keyframes cardIn { from { opacity:0; } to { opacity:1; } }

.int-hero { padding: 100px 0 56px; position:relative; overflow:hidden; }
.int-hero .hero-bg {
  position:absolute; inset:0; pointer-events:none;
  background: transparent;
}
.int-hero .hero-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center;
}
@media (max-width: 860px) { .int-hero .hero-grid { grid-template-columns: 1fr; } }
.int-hero h1 { max-width: 640px; margin: 0 0 14px; }
.int-hero .lede { max-width: 560px; color: var(--text-dim); font-size: 17px; margin: 0 0 28px; }
.int-hero .cta-row { display:flex; gap:12px; flex-wrap:wrap; }

/* Integration animation */
.int-anim {
  position: relative; width: 100%; aspect-ratio: 1.1/1; max-width: 480px;
  margin: 0 auto;
}
.int-anim .center-node {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 72px; height: 72px; border-radius: 18px;
  background: var(--fastn-blue);
  display: flex; align-items: center; justify-content: center;
  color: var(--on-primary); font-weight: 800; font-size: 24px;
  box-shadow: 0 0 60px rgba(108,92,231,0.4), 0 0 0 1px rgba(108,92,231,0.3);
  z-index: 10;
}
.int-anim .ring {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  border: 1px dashed rgba(146,142,160,0.18); border-radius: 50%;
}
.int-anim .ring-1 { width: 65%; height: 65%; }
.int-anim .ring-2 { width: 100%; height: 100%; border-style: solid; border-color: rgba(146,142,160,0.08); }
.int-anim .sat {
  position: absolute; width: 48px; height: 48px; margin: -24px;
  background: var(--surface-2); border: 1px solid var(--border); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Geist Mono',monospace;
  font-size: 9px; font-weight: 600; color: var(--text-dim); text-align: center;
  box-shadow: 0 8px 20px -8px rgba(0,0,0,0.5);
  transition: border-color 300ms, transform 300ms;
  overflow: hidden; padding: 6px;
}
.int-anim .sat:hover { border-color: rgba(108,92,231,0.5); transform: scale(1.1); }
.int-anim .pulse-line {
  position: absolute; top: 50%; left: 50%; width: 50%; height: 1px;
  transform-origin: 0 0; z-index: 1;
}
.int-anim .pulse-line .beam {
  position: absolute; left: 0; top: -1px; height: 3px; border-radius: 2px;
  background: linear-gradient(90deg, transparent, var(--primary), transparent);
  animation: beam-travel 3s ease-in-out infinite;
}
@keyframes beam-travel {
  0% { left: 0; width: 0; opacity: 0; }
  20% { width: 20%; opacity: 1; }
  80% { left: 80%; width: 20%; opacity: 1; }
  100% { left: 100%; width: 0; opacity: 0; }
}
@keyframes float-y {
  0%,100% { transform: translate(-50%,-50%) translateY(0); }
  50% { transform: translate(-50%,-50%) translateY(-8px); }
}
.int-anim .center-node { animation: float-y 4s ease-in-out infinite; }

/* Search bar */
.search-bar {
  display: flex; align-items: center; gap: 10px;
  background: var(--surface-1); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 10px 16px;
  max-width: 480px; margin-bottom: 40px;
  transition: border-color 200ms;
}
.search-bar:focus-within { border-color: var(--fastn-blue); box-shadow: 0 0 0 3px rgba(108,92,231,0.18); }
.search-bar svg { color: var(--text-mute); flex: none; }
.search-bar input {
  flex:1; background:transparent; border:none; outline:none;
  color: var(--text); font-family: 'Inter'; font-size: 14px;
}
.search-bar input::placeholder { color: var(--text-mute); }
.search-bar .count {
  font-family: 'Geist Mono',monospace; font-size: 11px;
  color: var(--text-mute); padding: 3px 8px; border-radius: var(--radius-pill);
  background: rgba(108,92,231,0.08); border: 1px solid rgba(108,92,231,0.15);
  white-space: nowrap;
}

/* Layout: sidebar + grid */
.catalog-layout { display: grid; grid-template-columns: 220px 1fr; gap: 40px; align-items: start; }
@media (max-width: 860px) { .catalog-layout { grid-template-columns: 1fr; } }

/* Sidebar */
.sidebar { position: sticky; top: 80px; }
.sidebar-title {
  font-family: 'Geist Mono',monospace;
  font-size: 11px; font-weight: 600; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-mute); margin-bottom: 12px;
}
.sidebar ul { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:2px; }
.sidebar li { display:flex; }
.sidebar button {
  display:flex; align-items:center; gap:10px; width:100%;
  padding: 9px 14px; border:none; background:transparent; cursor:pointer;
  border-radius: 8px; font-family:'Inter'; font-size:13px; color: var(--text-dim);
  transition: all 160ms; text-align:left; border-left: 2px solid transparent;
  border-radius: 0 8px 8px 0;
}
.sidebar button:hover { color: var(--text); background: var(--surface-1); }
.sidebar button.active {
  color: var(--primary-soft); background: rgba(108,92,231,0.06);
  border-left-color: var(--primary);
}
.sidebar button svg { width:16px; height:16px; flex:none; opacity:0.7; }
.sidebar button.active svg { opacity:1; color: var(--primary-soft); }
.sidebar .cat-count {
  margin-left:auto; font-family:'Geist Mono',monospace;
  font-size:12px; color: var(--text-mute); min-width:20px; text-align:right;
}

/* Integration grid */
.int-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 700px) { .int-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 440px) { .int-grid { grid-template-columns: 1fr; } }

.int-card {
  background: var(--surface-1); border: 1px solid var(--border);
  border-radius: var(--radius-md); padding: 28px 20px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  text-align: center; cursor: pointer;
  transition: all 200ms ease;
  animation: cardIn 380ms ease both;
}
.int-card:hover {
  border-color: rgba(108,92,231,0.5);
  background: linear-gradient(180deg, rgba(108,92,231,0.04), var(--surface-1));
  transform: translateY(-3px);
  box-shadow: 0 12px 32px -12px rgba(108,92,231,0.3);
}
.int-card .icon-wrap {
  width: 44px; height: 44px; border-radius: 10px;
  background: rgba(108,92,231,0.08); border: 1px solid rgba(108,92,231,0.15);
  display: flex; align-items: center; justify-content: center;
  color: var(--primary-soft); transition: all 200ms;
}
.int-card:hover .icon-wrap {
  background: rgba(108,92,231,0.14);
  border-color: rgba(108,92,231,0.35);
  box-shadow: 0 0 16px rgba(108,92,231,0.2);
}
.int-card .name { font-weight: 600; font-size: 14px; color: var(--text); }
.int-card .cat-tag {
  font-family:'Geist Mono',monospace; font-size:12px;
  color: var(--text-mute); letter-spacing: 0.06em; text-transform: uppercase;
}

/* Load more */
.load-more-wrap { display:flex; justify-content:center; margin-top:32px; }

/* Mobile overrides for Integrations page */
@media (max-width: 768px) {
  .int-hero { padding: 80px 0 40px; }
  .int-hero .hero-grid { grid-template-columns: 1fr; gap: 24px; }
  .int-hero h1 { font-size: clamp(28px, 7vw, 40px); }
  .int-hero .lede { font-size: 15px; }
  .int-hero .cta-row { flex-direction: column; }
  .int-hero .cta-row .btn { width: 100%; }
  .int-anim { max-width: 280px; }
  .int-anim .sat { width: 40px; height: 40px; margin: -20px; font-size: 8px; border-radius: 8px; }
  .int-anim .center-node { width: 52px; height: 52px; border-radius: 14px; font-size: 18px; }
  .catalog-layout { grid-template-columns: 1fr; gap: 24px; }
  .sidebar { position: static; display: flex; flex-direction: column; }
  .sidebar ul { flex-direction: row; flex-wrap: wrap; gap: 4px; }
  .sidebar button { padding: 7px 12px; font-size: 12px; border-radius: 8px !important; border-left: none !important; border: 1px solid var(--border); }
  .sidebar button.active { border-color: rgba(108,92,231,0.5); }
  .int-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .int-card { padding: 20px 14px; }
  .search-bar { max-width: 100%; }
}

/* Empty state */
.empty-state {
  grid-column: 1/-1; text-align:center; padding: 56px 20px;
  color: var(--text-mute); font-size:15px;
}
.empty-state svg { margin: 0 auto 16px; display:block; color: var(--primary); opacity:0.5; }


/* ====== Styles from compare.html ====== */

@keyframes fadeUp { from { opacity:0; } to { opacity:1; } }

/* Compare hero */
.compare-hero { padding: 100px 0 56px; position: relative; text-align: center; overflow: hidden; }
.compare-hero .hero-bg {
  position:absolute; inset:0; pointer-events:none;
  background: transparent;
}
.compare-hero h1 { margin: 0 0 18px; max-width: 800px; margin-left:auto; margin-right:auto; }
.compare-hero .lede { max-width: 680px; margin: 0 auto 32px; color: var(--text-dim); font-size: 18px; line-height: 1.65; }

/* Comparison table */
.comp-table-wrap { overflow-x: auto; margin: 0 auto; max-width: 100%; }
.comp-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  background: #1A1A1D; border: 1px solid var(--border);
  border-radius: 16px; overflow: hidden;
  min-width: 700px;
}
.comp-table th, .comp-table td {
  padding: 24px 24px; text-align: left; border-bottom: 1px solid var(--border);
  font-size: 14px; line-height: 1.55; vertical-align: top;
  width: 25%;
}
.comp-table th { font-weight: 700; color: var(--text); font-size: 16px; }
.comp-table thead th {
  background: var(--surface-2); border-bottom: 2px solid var(--border);
  padding: 20px 24px;
}
.comp-table thead th:first-child { color: var(--text-mute); font-weight: 600; font-size: 13px; }
.comp-table thead th.fastn-col {
  color: var(--fastn-blue); position: relative;
}
.comp-table thead th.fastn-col::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0; height: 2px;
  background: var(--fastn-blue);
}
.comp-table thead th.comp-col { color: var(--text-mute); font-weight: 500; }

.comp-table tbody tr:last-child td { border-bottom: none; }
.comp-table tbody tr:hover { background: rgba(108,92,231,0.03); }

.comp-table .dim-q { font-weight: 600; color: var(--text); font-size: 14px; }

/* Cell indicators */
.cell-good {
  color: var(--text); font-size: 14px; line-height: 1.55;
}
.cell-good .indicator {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 4px;
  color: #10B981; font-weight: 600; font-size: 13px;
}
.cell-good .indicator svg { flex: none; }
.cell-good .detail { color: var(--text-dim); font-size: 13px; }

.cell-weak {
  color: var(--text-dim); font-size: 14px; line-height: 1.55;
}
.cell-weak .indicator {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 4px;
  color: var(--text-mute); font-weight: 500; font-size: 13px;
}
.cell-weak .indicator svg { flex: none; color: #ef4444; opacity: 0.7; }
.cell-weak .detail { color: var(--text-mute); font-size: 13px; }

/* Fastn column highlight */
.comp-table td.fastn-cell {
  background: rgba(108,92,231,0.04);
  border-left: 1px solid rgba(108,92,231,0.12);
  border-right: 1px solid rgba(108,92,231,0.12);
}
.comp-table th.fastn-col {
  background: rgba(108,92,231,0.08);
  border-left: 1px solid rgba(108,92,231,0.12);
  border-right: 1px solid rgba(108,92,231,0.12);
}

/* Bottom CTA */
.compare-cta {
  text-align: center; padding: 80px 0 40px;
}
.compare-cta h2 { margin: 0 0 24px; }
.compare-cta .cta-row { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }

/* Mobile */
@media (max-width: 768px) {
  .compare-hero { padding: 80px 0 40px; }
  .compare-hero h1 { font-size: clamp(28px, 7vw, 40px); }
  .compare-hero .lede { font-size: 15px; }
  .comp-table th, .comp-table td { padding: 14px 12px; font-size: 13px; }
  .compare-cta { padding: 48px 0 32px; }
  .compare-cta .cta-row { flex-direction: column; align-items: center; }
  .compare-cta .cta-row .btn { width: 100%; max-width: 320px; }
}


/* ====== Styles from pricing.html ====== */

.pricing-hero {
  padding: var(--sp-20) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
  min-height: 60vh;
  display: flex;
  align-items: center;
}
.pricing-hero .hero-bg {
  position: absolute; inset: 0; pointer-events: none;
  background: transparent;
}
.pricing-inner {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-6);
}
.pricing-inner h1 {
  margin: 0;
}
.pricing-inner .subhead {
  font-size: 18px;
  line-height: 1.65;
  color: var(--text-2);
  max-width: 560px;
  margin: 0;
}
@media (max-width: 768px) {
  .pricing-hero { padding: var(--sp-16) 0; min-height: 50vh; }
  .pricing-inner .subhead { font-size: 16px; }
}
