/* Novexis — Software Factory marketing site. Self-contained, no external assets. */
:root{
  --bg:#0a0f1c; --bg-alt:#0d1426; --surface:#121b30; --surface-2:#16213a;
  --border:#22304d; --border-soft:#1b2740;
  --text:#e8eef9; --muted:#9aa9c4; --muted-2:#7c8aa6;
  --brand:#818cf8; --brand-2:#22d3ee; --accent:#a78bfa;
  --grad:linear-gradient(100deg,#818cf8 0%,#22d3ee 100%);
  --radius:16px; --radius-sm:11px; --maxw:1140px;
  --shadow:0 18px 50px -20px rgba(0,0,0,.6);
  --ring:0 0 0 1px var(--border);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Inter,Helvetica,Arial,sans-serif;
  line-height:1.6; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.center{text-align:center}
.skip{position:absolute;left:-999px;top:0;background:var(--brand);color:#0a0f1c;padding:10px 16px;border-radius:8px;z-index:100}
.skip:focus{left:12px;top:12px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.97rem;
  padding:.74em 1.3em;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease;white-space:nowrap}
.btn-primary{background:var(--grad);color:#06122a;box-shadow:0 10px 30px -10px rgba(95,120,255,.6)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px -12px rgba(95,150,255,.75)}
.btn-ghost{background:rgba(255,255,255,.03);border-color:var(--border);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.07);border-color:#33456b;transform:translateY(-2px)}
.btn-lg{font-size:1.06rem;padding:.9em 1.7em}

/* header */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(12px);
  background:rgba(10,15,28,.72);border-bottom:1px solid var(--border-soft)}
.nav{display:flex;align-items:center;gap:24px;height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.18rem;letter-spacing:-.01em}
.brand-mark{width:28px;height:28px;flex:none}
.nav-links{display:flex;gap:26px;margin-left:auto;font-size:.95rem;color:var(--muted)}
.nav-links a{transition:color .15s}
.nav-links a:hover{color:var(--text)}
.nav-cta{margin-left:8px}

/* hero */
.hero{position:relative;padding:84px 0 72px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(900px 480px at 78% -8%,rgba(34,211,238,.16),transparent 60%),
  radial-gradient(760px 520px at 6% 4%,rgba(129,140,248,.18),transparent 58%);pointer-events:none}
.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.eyebrow{text-transform:uppercase;letter-spacing:.16em;font-size:.76rem;font-weight:700;color:var(--brand-2);margin:0 0 18px}
.eyebrow.center{margin-bottom:14px}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.5rem);line-height:1.08;letter-spacing:-.025em;margin:0 0 22px;font-weight:800}
.lede{font-size:1.16rem;color:var(--muted);max-width:38ch;margin:0 0 30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.hero-note{font-size:.95rem;color:var(--muted-2);margin:0}
.hero-note strong{color:var(--text);font-weight:600}

/* hero visual */
.hero-visual{position:relative;min-height:320px;display:flex;align-items:center;justify-content:center}
.orb{position:absolute;width:340px;height:340px;border-radius:50%;
  background:conic-gradient(from 200deg,#818cf8,#22d3ee,#a78bfa,#818cf8);filter:blur(46px);opacity:.32}
.pipe-card{position:relative;width:100%;max-width:360px;background:linear-gradient(180deg,var(--surface),var(--bg-alt));
  border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.pipe-label,.pipe-foot{display:block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.pipe-foot{margin-top:14px;line-height:1.5}
.pipe{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:9px;counter-reset:p}
.pipe li{display:flex;align-items:center;gap:12px;font-size:.97rem;font-weight:500;
  padding:10px 13px;border-radius:11px;background:rgba(255,255,255,.025);border:1px solid var(--border-soft)}
.pipe li i{display:grid;place-items:center;width:24px;height:24px;flex:none;border-radius:7px;
  font-style:normal;font-size:.78rem;font-weight:700;color:#06122a;background:var(--grad)}

/* sections */
.section{padding:84px 0}
.section-alt{background:var(--bg-alt);border-block:1px solid var(--border-soft)}
.section h2{font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.15;letter-spacing:-.02em;font-weight:800;margin:0 auto 44px;max-width:22ch}
.section h2.center{margin-inline:auto}

/* grids + cards */
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);
  padding:26px 24px;transition:transform .18s ease,border-color .18s ease,background .18s ease}
.card:hover{transform:translateY(-4px);border-color:#2c3d61;background:var(--surface-2)}
.card h3{margin:0 0 9px;font-size:1.12rem;font-weight:700;letter-spacing:-.01em}
.card p{margin:0;color:var(--muted);font-size:.97rem}
.card.sm{padding:22px 20px}
.card.sm h3{font-size:1.02rem}
.card code{background:rgba(129,140,248,.13);color:#c7cdff;padding:.1em .42em;border-radius:6px;font-size:.86em}
.feature{background:linear-gradient(180deg,var(--surface),var(--bg-alt));border:1px solid var(--border);
  border-radius:var(--radius);padding:34px 30px}
.feature h3{margin:0 0 12px;font-size:1.3rem;font-weight:700;letter-spacing:-.015em}
.feature p{margin:0;color:var(--muted);font-size:1.02rem}
.opportunity{text-align:center;font-size:clamp(1.15rem,2.2vw,1.5rem);font-weight:600;max-width:30ch;margin:46px auto 0;line-height:1.4}
.opportunity .grad{font-weight:800}

/* packs strip */
.packs-strip{margin-top:40px;background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);
  padding:24px 26px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;justify-content:center}
.packs-strip-label{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.chips{list-style:none;display:flex;gap:12px;flex-wrap:wrap;margin:0;padding:0;justify-content:center}
.chips li{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid var(--border);font-size:.93rem;font-weight:500}
.chips li b{color:var(--brand-2);font-weight:700}
.chip-total{background:var(--grad)!important;color:#06122a!important;font-weight:700;border-color:transparent!important}

/* pipeline flow */
.flow{list-style:none;counter-reset:f;display:flex;gap:14px;padding:0;margin:0 0 44px;flex-wrap:wrap;justify-content:center}
.flow li{position:relative;flex:1 1 170px;min-width:160px;background:var(--surface);border:1px solid var(--border-soft);
  border-radius:var(--radius-sm);padding:18px 18px 16px;counter-increment:f}
.flow li::before{content:counter(f);position:absolute;top:-12px;left:18px;width:26px;height:26px;display:grid;place-items:center;
  border-radius:8px;font-size:.8rem;font-weight:700;color:#06122a;background:var(--grad)}
.flow li:not(:last-child)::after{content:"→";position:absolute;right:-13px;top:50%;transform:translateY(-50%);color:var(--muted-2);font-size:1.1rem;z-index:1}
.flow-step{display:block;font-weight:700;margin-top:6px;font-size:1rem}
.flow-sub{display:block;color:var(--muted-2);font-size:.85rem;margin-top:3px}
.pipeline-notes{margin-top:8px}
.pipeline-notes em{color:var(--brand-2);font-style:normal;font-weight:600}

/* how-it-works diagram */
.diagram-wrap{margin:0 0 44px;background:linear-gradient(180deg,var(--surface),var(--bg-alt));
  border:1px solid var(--border);border-radius:var(--radius);padding:26px 22px 20px;box-shadow:var(--shadow);overflow:hidden}
.factory-diagram{width:100%;height:auto;display:block}
.diagram-wrap figcaption{text-align:center;color:var(--muted-2);font-size:.9rem;margin-top:16px}
@media (max-width:680px){
  .diagram-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .diagram-scroll .factory-diagram{min-width:640px}
}

/* cta */
.cta{padding:96px 0;background:
  radial-gradient(700px 360px at 50% 0%,rgba(129,140,248,.18),transparent 65%),var(--bg-alt);
  border-top:1px solid var(--border-soft)}
.cta-inner{text-align:center;max-width:680px}
.cta h2{font-size:clamp(1.7rem,3.2vw,2.4rem);letter-spacing:-.02em;font-weight:800;margin:0 0 16px;line-height:1.15}
.cta p{color:var(--muted);font-size:1.1rem;margin:0 0 30px}

/* footer */
.site-footer{border-top:1px solid var(--border-soft);background:var(--bg);padding:50px 0 30px}
.footer-grid{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:30px;border-bottom:1px solid var(--border-soft)}
.footer-tag{color:var(--muted-2);font-size:.93rem;margin:12px 0 0;max-width:30ch}
.footer-links{display:flex;gap:22px;align-items:flex-start;color:var(--muted);font-size:.95rem;flex-wrap:wrap}
.footer-links a:hover{color:var(--text)}
.footer-base{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:22px;font-size:.86rem;color:var(--muted-2)}
.footer-base .muted{color:var(--muted-2)}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}}

/* responsive */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-visual{order:-1;min-height:240px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr}
  .nav-links{display:none}
}
@media (max-width:560px){
  .section{padding:60px 0}
  .hero{padding:54px 0 48px}
  .grid-4,.grid-2{grid-template-columns:1fr}
  .nav-cta{display:none}
  .flow li:not(:last-child)::after{display:none}
}
