/* ============================================================
   CnX Modular — module page grammar
   Dark-first, self-contained shared stylesheet.
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
:root{--ff:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--r-sm:8px;--r-md:14px;--r-lg:22px;--r-xl:32px;--t-fast:.15s;--t-base:.25s;--t-slow:.45s;--maxw:1240px}
:root[data-theme="dark"]{--bg:#0a0a14;--bg-elev:#12121e;--bg-card:rgba(255,255,255,.04);--fg:#ffffff;--fg-2:#c4c4d4;--fg-mute:#8a8aa0;--line:rgba(255,255,255,.08);--line-2:rgba(255,255,255,.14);--blue:#0052CC;--blue-deep:#003D99;--blue-glow:rgba(0,82,204,.40);--orange:#FF7D1F;--orange-deep:#CC6519;--orange-glow:rgba(255,125,31,.36);--green:#4ade80;--green-deep:#22c55e;--green-glow:rgba(74,222,128,.36);--grad-blob-1:rgba(0,82,204,.40);--grad-blob-2:rgba(0,82,204,.22);--grad-blob-3:rgba(255,125,31,.55);--grad-blob-4:rgba(255,125,31,.32)}
:root[data-theme="light"]{--bg:#ffffff;--bg-elev:#f7f8fc;--bg-card:#ffffff;--fg:#0a0a14;--fg-2:#3a4658;--fg-mute:#6b7689;--line:rgba(10,10,20,.08);--line-2:rgba(10,10,20,.14);--blue:#0052CC;--blue-deep:#003D99;--blue-glow:rgba(0,82,204,.22);--orange:#FF7D1F;--orange-deep:#CC6519;--orange-glow:rgba(255,125,31,.22);--green:#16a34a;--green-deep:#15803d;--green-glow:rgba(22,163,74,.22);--grad-blob-1:rgba(0,82,204,.18);--grad-blob-2:rgba(0,82,204,.10);--grad-blob-3:rgba(255,125,31,.28);--grad-blob-4:rgba(255,125,31,.16)}
body{margin:0;font-family:var(--ff);font-size:16px;line-height:1.55;color:var(--fg);background:var(--bg);font-feature-settings:'ss01','ss02';-webkit-font-smoothing:antialiased;transition:background .4s ease,color .4s ease}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}
.skip-link{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:14px;top:14px;width:auto;height:auto;padding:8px 14px;background:var(--fg);color:var(--bg);border-radius:var(--r-sm);font-weight:600;z-index:100}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:16px 0;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);background:rgba(10,10,20,.55);border-bottom:1px solid var(--line);transition:background .4s ease,border-color .4s ease}
:root[data-theme="light"] .nav{background:rgba(255,255,255,.72)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.05rem;letter-spacing:-.01em}
.brand-mark{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--blue) 0%,var(--orange) 100%);position:relative;box-shadow:0 0 24px var(--blue-glow)}
.brand-mark::after{content:"";position:absolute;inset:5px;border-radius:5px;background:var(--bg)}
.brand-mark::before{content:"";position:absolute;inset:9px;border-radius:3px;background:linear-gradient(135deg,var(--blue),var(--orange))}
.nav-links{display:flex;gap:30px;align-items:center}
@media (max-width:760px){.nav-links{display:none}}
.nav-links a{color:var(--fg-2);font-size:.92rem;font-weight:500;transition:color var(--t-fast) ease}
.nav-links a:hover{color:var(--fg)}
.nav-right{display:flex;align-items:center;gap:14px}
.theme-toggle{width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--line-2);color:var(--fg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--t-fast) ease,border-color var(--t-fast) ease}
.theme-toggle:hover{background:var(--bg-elev);border-color:var(--fg-mute)}
.theme-toggle svg{width:16px;height:16px}
:root[data-theme="dark"] .theme-icon-sun{display:none}
:root[data-theme="light"] .theme-icon-moon{display:none}
.nav-cta{background:var(--fg);color:var(--bg);padding:9px 18px;border-radius:999px;font-size:.88rem;font-weight:600;border:0;transition:transform var(--t-fast) ease,opacity var(--t-fast) ease}
.nav-cta:hover{transform:translateY(-1px);opacity:.92}
.brand-logo{height:30px;width:auto;display:block}
.footer-brand-logo{height:30px;width:auto;display:block;margin-bottom:14px}
.cs-brand-logo{height:24px;width:auto;display:block}
.nav-login{background:transparent;color:var(--fg);padding:9px 16px;border-radius:999px;font-size:.88rem;font-weight:600;border:1px solid var(--line-2);transition:border-color var(--t-fast) ease,background var(--t-fast) ease;text-decoration:none}
.nav-login:hover{border-color:var(--fg-mute);background:var(--bg-card)}
@media (max-width:760px){.nav-login{display:none}}

/* Eyebrow + grad helpers */
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;font-size:.78rem;font-weight:500;letter-spacing:.04em;background:var(--bg-card);border:1px solid var(--line-2);border-radius:999px;color:var(--fg-2);margin-bottom:20px}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 12px var(--orange-glow);animation:dot-pulse 2.5s ease-in-out infinite}
@keyframes dot-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}
.grad{background:linear-gradient(120deg,var(--blue) 0%,var(--blue) 38%,var(--orange) 62%,var(--orange) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;background-size:220% 100%;animation:gradient-shift 8s ease-in-out infinite}
@keyframes gradient-shift{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* Page hero */
.page-hero{position:relative;padding:148px 0 64px;overflow:hidden;isolation:isolate}
.page-hero-bg{position:absolute;inset:0;z-index:-1;pointer-events:none}
.page-hero-bg::before,.page-hero-bg::after{content:"";position:absolute;inset:-15%;filter:blur(120px)}
.page-hero-bg::before{background:radial-gradient(circle 480px at 18% 30%,var(--grad-blob-1) 0%,transparent 60%),radial-gradient(circle 460px at 82% 70%,var(--grad-blob-2) 0%,transparent 60%);animation:blob-drift-a 24s ease-in-out infinite alternate}
.page-hero-bg::after{background:radial-gradient(ellipse 760px 280px at 50% -10%,var(--grad-blob-3) 0%,transparent 70%),radial-gradient(circle 380px at 78% 30%,var(--grad-blob-4) 0%,transparent 60%);animation:blob-drift-b 30s ease-in-out infinite alternate}
@keyframes blob-drift-a{0%{transform:translate(0,0) scale(1)}50%{transform:translate(4%,-3%) scale(1.05)}100%{transform:translate(-3%,4%) scale(.98)}}
@keyframes blob-drift-b{0%{transform:translate(0,0) scale(1) rotate(0deg)}50%{transform:translate(-3%,4%) scale(1.04) rotate(2deg)}100%{transform:translate(4%,-3%) scale(.98) rotate(-1deg)}}
.page-hero-grid{position:absolute;inset:0;z-index:-1;pointer-events:none;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at 50% 40%,#000 25%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at 50% 40%,#000 25%,transparent 70%);opacity:.4}
.page-hero-inner{position:relative;z-index:1;text-align:center;max-width:880px;margin:0 auto}
.page-hero h1{font-size:clamp(2.2rem,5.4vw,4.4rem);font-weight:800;letter-spacing:-.035em;line-height:1.04;margin:0 0 22px;color:var(--fg)}
.page-hero-lede{font-size:clamp(1rem,1.45vw,1.18rem);color:var(--fg-2);max-width:680px;margin:0 auto;line-height:1.55}

/* Section head */
.section-head{text-align:center;max-width:780px;margin:0 auto 44px}
.section-head .eyebrow{margin-bottom:20px}
.section-head h2{font-size:clamp(1.8rem,4vw,3.2rem);font-weight:800;letter-spacing:-.03em;line-height:1.06;margin:0 0 16px;color:var(--fg)}
.section-head p{font-size:1.02rem;color:var(--fg-2);margin:0;line-height:1.65}

/* Feature strip */
.feature-strip{padding:clamp(28px,3.5vw,48px) 0;position:relative;overflow:hidden}
.strip-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;max-width:1180px;margin:0 auto}
@media (max-width:980px){.strip-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.strip-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:380px){.strip-grid{grid-template-columns:1fr}}
.strip-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-md);padding:20px 18px;display:flex;flex-direction:column;align-items:flex-start;gap:10px;transition:transform var(--t-base) ease,border-color var(--t-base) ease,background var(--t-base) ease}
.strip-card:hover{transform:translateY(-2px);border-color:var(--blue);background:var(--bg-elev)}
.strip-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.strip-name{font-family:var(--ff);font-size:.98rem;font-weight:700;color:var(--fg);letter-spacing:-.005em;line-height:1.2}
.strip-tag{font-family:'JetBrains Mono','Menlo','Consolas',monospace;font-size:.66rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute)}

/* Screenshot showcase */
.screenshot-showcase{padding:clamp(28px,3.5vw,48px) 0 clamp(40px,5vw,72px);position:relative;overflow:hidden}
.screenshot-showcase::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(ellipse 720px 280px at 50% 0%,var(--grad-blob-1) 0%,transparent 70%),radial-gradient(ellipse 620px 240px at 50% 100%,var(--grad-blob-3) 0%,transparent 70%);filter:blur(80px);opacity:.55}
.screenshot-frame{position:relative;max-width:1140px;margin:0 auto;border-radius:var(--r-lg);background:var(--bg-elev);border:1px solid var(--line-2);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.55),0 0 0 1px var(--line)}
.screenshot-frame::after{content:"";position:absolute;inset:-50px;z-index:-1;background:radial-gradient(ellipse 60% 60% at 50% 50%,var(--blue-glow) 0%,transparent 60%);filter:blur(80px)}
.screenshot-frame-bar{display:flex;align-items:center;gap:8px;padding:12px 18px;background:var(--bg-elev);border-bottom:1px solid var(--line)}
.screenshot-frame-bar .dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.screenshot-frame-bar .dot-red{background:#ff6b6b}
.screenshot-frame-bar .dot-amber{background:#ffd166}
.screenshot-frame-bar .dot-green{background:#51cf66}
.screenshot-frame-label{margin-left:14px;font-size:.78rem;color:var(--fg-mute);font-family:'JetBrains Mono','Menlo','Consolas',monospace;letter-spacing:.04em}
.screenshot-frame img{display:block;width:100%;height:auto}
:root[data-theme="dark"]  .theme-img-light{display:none}
:root[data-theme="light"] .theme-img-dark{display:none}

/* Capabilities */
.capabilities{padding:clamp(28px,3.5vw,48px) 0;position:relative;overflow:hidden}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1180px;margin:0 auto}
@media (max-width:980px){.cap-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cap-grid{grid-template-columns:1fr}}
.cap-card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-md);padding:24px;transition:transform var(--t-base) ease,border-color var(--t-base) ease,background var(--t-base) ease,box-shadow var(--t-base) ease}
.cap-card:hover{transform:translateY(-3px);background:var(--bg-elev);border-color:var(--blue);box-shadow:0 12px 32px var(--blue-glow)}
.cap-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--blue-deep));color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.cap-card h3{font-family:var(--ff);font-size:1.18rem;font-weight:700;letter-spacing:-.01em;margin:0 0 12px;color:var(--fg)}
.cap-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.cap-card li{font-size:.88rem;color:var(--fg-2);line-height:1.45;padding-left:16px;position:relative}
.cap-card li::before{content:"";position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--blue)}

/* Trust strip */
.trust-strip{padding:clamp(20px,3vw,36px) 0;position:relative}
.trust-list{list-style:none;padding:24px 28px;margin:0 auto;display:flex;flex-wrap:wrap;justify-content:center;gap:24px 40px;max-width:980px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--r-lg)}
.trust-list li{display:inline-flex;align-items:center;gap:10px;font-size:.92rem;color:var(--fg-2)}
.trust-list svg{color:var(--blue);flex-shrink:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 24px;border-radius:999px;font-size:.95rem;font-weight:600;cursor:pointer;border:0;transition:transform var(--t-fast) ease,background var(--t-fast) ease,box-shadow var(--t-fast) ease;text-decoration:none}
.btn-primary{background:var(--fg);color:var(--bg);box-shadow:0 0 0 1px var(--line-2),0 8px 24px rgba(0,0,0,.20)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px var(--fg-2),0 12px 28px rgba(0,0,0,.30)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 8px 24px var(--orange-glow)}
.btn-orange:hover{background:var(--orange-deep);box-shadow:0 12px 28px var(--orange-glow)}
.btn .arrow{transition:transform var(--t-fast) ease}
.btn:hover .arrow{transform:translateX(3px)}

/* Final CTA */
.final-cta-section{padding:clamp(56px,7vw,84px) 0;text-align:center;position:relative;overflow:hidden}
.final-cta-section::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(ellipse 600px 240px at 50% 0%,var(--grad-blob-3) 0%,transparent 70%),radial-gradient(ellipse 600px 240px at 50% 100%,var(--grad-blob-1) 0%,transparent 70%);filter:blur(80px);opacity:.7}
.final-cta-section h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:800;letter-spacing:-.03em;line-height:1.06;margin:0 0 16px;color:var(--fg)}
.final-cta-section p{font-size:1.02rem;color:var(--fg-2);max-width:600px;margin:0 auto 28px;line-height:1.6}

/* Reveals */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.is-revealed{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.reveal[data-delay="4"]{transition-delay:.32s}
.reveal[data-delay="5"]{transition-delay:.40s}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}.reveal{opacity:1;transform:none}}

/* Footer */
.footer{padding:64px 0 28px;border-top:1px solid var(--line)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:32px;margin-bottom:48px}
@media (max-width:1000px){.footer-grid{grid-template-columns:1fr 1fr 1fr;gap:32px}}
@media (max-width:680px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:460px){.footer-grid{grid-template-columns:1fr}}
.footer-brand-name{font-family:var(--ff);font-size:1.1rem;font-weight:800;margin:0 0 12px;color:var(--fg);letter-spacing:-.01em}
.footer-brand p{font-size:.9rem;color:var(--fg-2);line-height:1.6;margin:0 0 14px;max-width:340px}
.footer-brand .powered-by{font-size:.78rem;color:var(--fg-mute)}
.footer-brand .powered-by a{color:var(--blue)}
.footer-brand .powered-by a:hover{text-decoration:underline}
.footer-col h4{font-family:var(--ff);font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute);margin:0 0 14px}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{font-size:.9rem;color:var(--fg-2);transition:color var(--t-fast) ease}
.footer-col a:hover{color:var(--fg)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:22px;border-top:1px solid var(--line);font-size:.78rem;color:var(--fg-mute);flex-wrap:wrap;gap:14px}
.footer-bottom a{color:var(--fg-mute)}
.footer-bottom a:hover{color:var(--fg)}

/* Slim footer (for coming-soon home and standalone informational pages) */
.cs-footer{padding:36px 0 28px;border-top:1px solid var(--line)}
.cs-footer-inner{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;font-size:.82rem;color:var(--fg-mute)}
.cs-footer-inner .cs-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--fg)}
.cs-footer-inner a{color:var(--fg-mute);transition:color var(--t-fast) ease}
.cs-footer-inner a:hover{color:var(--fg)}
.cs-footer-legal{display:flex;gap:18px;flex-wrap:wrap}
</content>
</invoke>