/* =====================================================================
   POSTARA AI — Light / Premium Editorial
   Warm paper, deep-navy ink (from the logo), electric-blue accent.
   Display: Fraunces (serif)  ·  Body: Schibsted Grotesk
   ===================================================================== */

:root{
	/* paper */
	--paper:#f6f4ef;
	--paper:#f3f0e9;
	--paper-2:#faf8f3;
	--paper-3:#ece8df;
	--line:rgba(10,14,28,.12);
	--line-2:rgba(10,14,28,.18);
	--line-soft:rgba(10,14,28,.06);

	/* ink */
	--ink:#0a0e1c;
	--ink-soft:#555a68;
	--ink-dim:#9a9ca6;

	/* accent (brand) */
	--blue:#1500ff;
	--blue-2:#4636ff;
	--blue-deep:#0d00a8;
	--blue-soft:rgba(21,0,255,.06);

	/* type */
	--serif:"Fraunces",Georgia,"Times New Roman",serif;
	--sans:"Schibsted Grotesk",-apple-system,system-ui,sans-serif;

	--shell:1180px;
	--r:16px;
	--r-lg:24px;
	--shadow:0 18px 50px -28px rgba(10,14,28,.30);
	--shadow-sm:0 6px 22px -14px rgba(10,14,28,.32);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
	margin:0;background:var(--paper);color:var(--ink);
	font-family:var(--sans);font-size:17px;line-height:1.6;font-weight:400;
	letter-spacing:0;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--serif);font-optical-sizing:auto;font-weight:600;line-height:1.06;letter-spacing:-.015em;margin:0}

.px-shell{width:100%;max-width:var(--shell);margin:0 auto;padding:0 26px}
.px-mono{font-family:var(--sans);font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:12px}
.px-grad{background:linear-gradient(100deg,var(--blue),var(--blue-2));-webkit-background-clip:text;background-clip:text;color:transparent}

/* subtle paper grain */
.px-grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
	background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.px-skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 10px 0}
.px-skip:focus{left:0}

/* --------------------------------------------------------- buttons */
.px-btn{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;
	font-family:var(--sans);font-weight:600;font-size:15px;padding:13px 25px;border-radius:100px;border:1px solid var(--ink);
	transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,background .25s;cursor:pointer;white-space:nowrap}
.px-btn:hover{transform:translateY(-2px);box-shadow:0 16px 34px -16px rgba(11,16,34,.55)}
.px-btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.px-btn--ghost:hover{background:rgba(11,16,34,.04);border-color:var(--ink)}
.px-btn--invert{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.px-btn--invert:hover{background:#fff}
.px-btn--sm{padding:9px 19px;font-size:14px}
.px-btn--lg{padding:16px 34px;font-size:16px}
.px-btn--block{display:flex;justify-content:center;width:100%;margin-top:8px}

/* --------------------------------------------------------- eyebrow */
.px-eyebrow{display:inline-flex;align-items:center;gap:9px;color:var(--blue);font-family:var(--sans);
	font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:12px;margin-bottom:24px}
.px-eyebrow i{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:px-pulse 2.6s infinite}
@keyframes px-pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* --------------------------------------------------------- header */
.px-header{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);
	background:rgba(243,240,233,.72);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.px-header.is-stuck{border-bottom-color:var(--line);background:rgba(243,240,233,.92)}
.px-header__inner{display:flex;align-items:center;gap:26px;height:74px}
.px-brand{display:flex;align-items:center}
.px-brand__logo{height:26px;width:auto}
.custom-logo{height:30px!important;width:auto!important}
.px-nav{margin-left:auto}
.px-nav__list{display:flex;gap:32px;list-style:none;margin:0;padding:0}
.px-nav__list a{color:var(--ink-soft);font-size:15px;font-weight:500;transition:color .2s;position:relative}
.px-nav__list a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--blue);transition:width .25s}
.px-nav__list a:hover{color:var(--ink)}
.px-nav__list a:hover::after{width:100%}
.px-header__cta{margin-left:4px}

.px-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.px-burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.px-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.px-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.px-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.px-mobile{display:none;flex-direction:column;gap:2px;padding:14px 26px 26px;border-bottom:1px solid var(--line);background:rgba(243,240,233,.98)}
.px-mobile a{padding:14px 4px;color:var(--ink-soft);font-weight:500;border-bottom:1px solid var(--line)}
.px-mobile a:last-of-type{border:0}

/* --------------------------------------------------------- hero */
.px-hero{position:relative;padding:92px 0 80px;overflow:hidden}
.px-hero__glow{position:absolute;inset:0;pointer-events:none;z-index:0;
	background:
		radial-gradient(680px 480px at 88% 10%,rgba(21,0,255,.07),transparent 68%),
		repeating-linear-gradient(90deg,transparent 0 calc(12.5% - 1px),var(--line-soft) calc(12.5% - 1px) 12.5%)}
.px-hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center}
.px-hero__title{font-size:clamp(46px,6.4vw,86px);font-weight:600;margin-bottom:24px;letter-spacing:-.018em}
.px-hero__title em{font-style:italic;font-weight:500;color:var(--blue)}
.px-hero__sub{font-size:19px;color:var(--ink-soft);max-width:29em;margin-bottom:36px}
.px-hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px}
.px-hero__meta{display:flex;gap:30px;flex-wrap:wrap;color:var(--ink-dim);font-family:var(--sans);
	text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:600}
.px-hero__meta b{color:var(--ink);font-family:var(--serif);font-weight:600;font-size:16px;letter-spacing:0;text-transform:none;margin-right:6px}

/* ---- ecosystem constellation (hero right) ---- */
.px-cstl{position:relative;width:100%;max-width:560px;aspect-ratio:1;margin:0 auto}
.px-cstl__rings{position:absolute;inset:0;z-index:0}
.px-cstl__rings span{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:1px solid var(--line-soft);border-radius:50%}
.px-cstl__rings span:nth-child(1){width:54%;height:54%}
.px-cstl__rings span:nth-child(2){width:84%;height:84%;border-style:dashed;border-color:rgba(10,14,28,.08)}
.px-cstl__lines{position:absolute;inset:0;width:100%;height:100%;z-index:1;overflow:visible}
.px-cstl__lines .px-cl{stroke:rgba(10,14,28,.12);stroke-width:.4;transition:stroke .5s,stroke-width .5s}
.px-cstl__lines .px-cl.is-active{stroke:var(--blue);stroke-width:.7}
.px-cstl__hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;
	width:26%;aspect-ratio:1;border-radius:50%;display:grid;place-items:center;
	background:radial-gradient(circle at 36% 28%,#1a2142,#0a0e1c);
	box-shadow:0 18px 44px -16px rgba(10,14,28,.55),inset 0 0 0 1px rgba(255,255,255,.07)}
.px-cstl__hub img{width:72%}
.px-cstl__hub::after{content:"";position:absolute;inset:-10px;border-radius:50%;border:1px solid var(--blue-soft);animation:px-pulse 2.8s infinite}
@keyframes px-pulse{0%,100%{opacity:1}50%{opacity:.3}}
.px-cstl__card{position:absolute;transform:translate(-50%,-50%) scale(.78);width:28%;min-width:146px;z-index:2;opacity:.6;
	display:flex;flex-direction:column;gap:2px;padding:14px;border-radius:18px;
	background:linear-gradient(180deg,#fff,var(--paper-2));border:1px solid var(--line);
	box-shadow:0 10px 26px -18px rgba(10,14,28,.4);
	transition:transform .6s cubic-bezier(.2,.8,.2,1),opacity .5s,box-shadow .5s,border-color .5s}
.px-cstl__card::before{content:"";position:absolute;left:0;top:18%;height:0;width:3px;background:var(--blue);border-radius:3px;transition:height .5s}
.px-cstl__card.is-active{transform:translate(-50%,-50%) scale(1.04);opacity:1;z-index:6;border-color:rgba(21,0,255,.25);
	box-shadow:0 28px 60px -24px rgba(10,14,28,.5)}
.px-cstl__card.is-active::before{height:64%}
.px-pos-0{top:12%;left:50%}.px-pos-1{top:38%;left:87%}.px-pos-2{top:81%;left:73%}.px-pos-3{top:81%;left:27%}.px-pos-4{top:38%;left:13%}
.px-cstl__ctop{display:flex;align-items:center;justify-content:space-between;gap:8px}
.px-cstl__num{font-family:var(--serif);font-weight:500;font-size:15px;color:var(--ink-dim)}
.px-cstl__card.is-active .px-cstl__num{color:var(--blue)}
.px-cstl__tag{font-family:var(--sans);font-weight:600;letter-spacing:.09em;text-transform:uppercase;font-size:9px;color:var(--ink-soft);border:1px solid var(--line);padding:4px 8px;border-radius:6px;white-space:nowrap}
.px-cstl__card.is-active .px-cstl__tag{border-color:var(--blue-soft);color:var(--blue)}
.px-cstl__name{font-family:var(--serif);font-size:19px;font-weight:600;margin-top:6px}
.px-cstl__desc{color:var(--ink-soft);font-size:12.5px;line-height:1.4;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s,opacity .4s,margin .5s}
.px-cstl__card.is-active .px-cstl__desc{max-height:80px;opacity:1;margin-top:4px}
.px-cstl__go{display:none;align-items:center;gap:5px;color:var(--blue);font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:10px;margin-top:8px}
.px-cstl__card.is-active .px-cstl__go{display:inline-flex}
.px-cstl__dots{display:none;justify-content:center;gap:9px;margin-top:26px}
.px-cstl__dot{width:8px;height:8px;border-radius:50%;border:0;background:rgba(10,14,28,.18);cursor:pointer;padding:0;transition:.3s}
.px-cstl__dot.is-active{background:var(--blue);transform:scale(1.25)}

/* --------------------------------------------------------- marquee */
.px-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;overflow:hidden;background:var(--paper-3)}
.px-strip__track{display:flex;width:max-content;animation:px-marq 44s linear infinite}
.px-strip__track span{color:var(--ink-dim);padding-right:20px;letter-spacing:.2em;font-weight:600;font-size:13px}
@keyframes px-marq{to{transform:translateX(-50%)}}

/* --------------------------------------------------------- sections */
.px-section{padding:108px 0;position:relative}
.px-section--alt{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.px-head{max-width:680px;margin-bottom:56px}
.px-h2{font-size:clamp(31px,4vw,48px);margin-bottom:18px;font-weight:600}
.px-lede{font-size:18px;color:var(--ink-soft)}

/* --------------------------------------------------------- product grid */
.px-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.px-card{position:relative;display:flex;flex-direction:column;gap:14px;background:var(--paper-2);
	border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px 26px;
	transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .3s,box-shadow .3s;overflow:hidden;min-height:236px}
.px-card::after{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--blue);transition:width .4s cubic-bezier(.2,.8,.2,1)}
.px-card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:var(--shadow)}
.px-card:hover::after{width:100%}
.px-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.px-chip{background:var(--paper-3);border:1px solid var(--line);padding:5px 12px;border-radius:8px;color:var(--ink-soft);
	font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:10.5px}
.px-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-dim);font-family:var(--sans);font-weight:600}
.px-status i{width:7px;height:7px;border-radius:50%;background:#16c172;box-shadow:0 0 0 3px rgba(22,193,114,.16)}
.px-card__name{font-size:25px;font-weight:600}
.px-card__tag{color:var(--ink-soft);font-size:15.5px;flex:1;line-height:1.55}
.px-card__link{display:inline-flex;align-items:center;gap:6px;color:var(--blue);font-family:var(--sans);
	font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:11px;transition:gap .25s}
.px-card:hover .px-card__link{gap:11px}

/* --------------------------------------------------------- feats */
.px-feats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.px-feat{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;transition:border-color .3s,transform .3s}
.px-feat:hover{border-color:var(--line-2);transform:translateY(-3px)}
.px-feat__num{color:var(--blue);font-family:var(--serif);font-weight:600;display:block;margin-bottom:16px;font-size:18px}
.px-feat h3{font-size:22px;margin-bottom:10px;font-weight:600}
.px-feat p{color:var(--ink-soft);font-size:15.5px;margin:0}

/* --------------------------------------------------------- about */
.px-about{display:grid;grid-template-columns:1.3fr .7fr;gap:56px;align-items:center}
.px-about__copy .px-btn{margin-top:26px}
.px-about__stats{display:flex;flex-direction:column;gap:16px}
.px-about__stats div{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:24px 28px}
.px-about__stats b{font-family:var(--serif);font-weight:600;font-size:42px;display:block;line-height:1;color:var(--ink)}
.px-about__stats span{color:var(--ink-dim);font-size:11px;text-transform:uppercase;letter-spacing:.12em;font-weight:600}

/* --------------------------------------------------------- cta band (dark) */
.px-cta{padding:104px 0;text-align:center;background:var(--ink);position:relative;overflow:hidden}
.px-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 340px at 50% -10%,rgba(70,54,255,.25),transparent 70%)}
.px-cta__inner{position:relative;z-index:1;max-width:620px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px}
.px-cta__logo{height:42px;width:auto;margin-bottom:14px}
.px-cta__title{color:#fff;font-size:clamp(28px,3.6vw,42px);font-weight:600}
.px-cta__sub{color:rgba(255,255,255,.7);font-size:18px;margin:0}
.px-cta .px-btn{margin-top:14px}

/* --------------------------------------------------------- footer */
.px-footer{border-top:1px solid var(--line);background:var(--paper);padding:74px 0 36px}
.px-footer__top{display:grid;grid-template-columns:1.15fr 1.5fr;gap:44px;padding-bottom:46px;border-bottom:1px solid var(--line)}
.px-footer__logo{height:28px;width:auto;margin-bottom:16px}
.px-footer__tag{color:var(--ink-soft);max-width:24em;margin:0 0 16px}
.px-footer__social{color:var(--blue);font-family:var(--sans);font-weight:600;font-size:14px}
.px-footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.px-footer__h{color:var(--ink-dim);margin:0 0 16px;font-family:var(--sans)}
.px-footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.px-footer__col a{color:var(--ink-soft);font-size:15px;transition:color .2s}
.px-footer__col a:hover{color:var(--ink)}
.px-footer__bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:24px;color:var(--ink-dim);font-size:13px}
.px-footer__bottom .px-mono{letter-spacing:.12em;font-size:11px}

/* --------------------------------------------------------- reveal */
.px-reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1)}
.px-reveal.is-in{opacity:1;transform:none}
.px-grid .px-reveal.is-in:nth-child(2){transition-delay:.06s}
.px-grid .px-reveal.is-in:nth-child(3){transition-delay:.12s}
.px-grid .px-reveal.is-in:nth-child(4){transition-delay:.18s}
.px-grid .px-reveal.is-in:nth-child(5){transition-delay:.24s}

/* --------------------------------------------------------- responsive */
/* large tablet / small laptop: keep two columns, tighten */
@media (max-width:1080px){
	.px-hero__inner{gap:40px}
	.px-grid{grid-template-columns:repeat(3,1fr)}
}
/* tablet portrait: stack hero, constellation centered below copy */
@media (max-width:900px){
	.px-hero__inner{grid-template-columns:1fr;gap:48px;max-width:560px}
	.px-cstl{max-width:460px}
	.px-grid{grid-template-columns:repeat(2,1fr)}
	.px-about{grid-template-columns:1fr;gap:34px}
	.px-about__stats{flex-direction:row}
	.px-footer__top{grid-template-columns:1fr;gap:34px}
}
/* phone: constellation collapses to logo + single active card + dots */
@media (max-width:640px){
	body{font-size:16px}
	.px-nav,.px-header__cta{display:none}
	.px-burger{display:flex}
	.px-mobile.is-open{display:flex}
	.px-section{padding:74px 0}
	.px-grid,.px-feats{grid-template-columns:1fr}
	.px-hero{padding:48px 0 56px}
	.px-hero__inner{gap:36px}
	.px-hero__meta{gap:18px}
	.px-cstl{max-width:340px;aspect-ratio:auto;display:flex;flex-direction:column;align-items:center;gap:24px}
	.px-cstl__rings,.px-cstl__lines{display:none}
	.px-cstl__hub{position:static;transform:none;width:118px}
	.px-cstl__card{position:relative;left:auto;top:auto;transform:none;opacity:1;width:100%;max-width:320px;display:none}
	.px-cstl__card.is-active{display:flex;transform:none;box-shadow:0 24px 50px -26px rgba(10,14,28,.5)}
	.px-cstl__card::before{top:16%;height:0}
	.px-cstl__card.is-active::before{height:68%}
	.px-cstl__name{font-size:21px}
	.px-cstl__desc{font-size:13.5px}
	.px-cstl__dots{display:flex}
	.px-about__stats{flex-direction:column}
	.px-footer__bottom{flex-direction:column;gap:8px}
}
@media (prefers-reduced-motion:reduce){
	*{animation:none!important;transition:none!important}
	.px-reveal{opacity:1;transform:none}
}

/* =====================================================================
   INNER PAGES — hero, legal, about, contact
   ===================================================================== */

/* ---- inner page hero ---- */
.px-phero{position:relative;padding:88px 0 44px;overflow:hidden}
.px-phero__glow{position:absolute;inset:0;z-index:0;pointer-events:none;
	background:radial-gradient(680px 460px at 86% 6%,rgba(21,0,255,.06),transparent 66%),
	repeating-linear-gradient(90deg,transparent 0 calc(12.5% - 1px),var(--line-soft) calc(12.5% - 1px) 12.5%)}
.px-phero__in{position:relative;z-index:2;max-width:760px}
.px-phero__title{font-size:clamp(38px,5.2vw,64px);font-weight:600;letter-spacing:-.018em;margin:0}
.px-phero__title em{font-style:italic;font-weight:500;color:var(--blue)}
.px-phero__lead{font-size:19px;color:var(--ink-soft);margin:20px 0 0;max-width:52ch}
.px-phero__meta{margin:16px 0 0;color:var(--ink-dim);font-family:var(--sans);font-weight:600;
	text-transform:uppercase;letter-spacing:.12em;font-size:11.5px}

/* ---- shared prose ---- */
.px-prose{color:var(--ink-soft);font-size:16.5px;line-height:1.75}
.px-prose p{margin:0 0 16px}
.px-prose h3{color:var(--ink);font-family:var(--serif);font-weight:600;font-size:19px;margin:26px 0 10px}
.px-prose ul{margin:0 0 18px;padding:0;list-style:none}
.px-prose li{position:relative;padding-left:22px;margin-bottom:9px}
.px-prose li::before{content:"";position:absolute;left:3px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--blue);opacity:.55}
.px-prose strong{color:var(--ink);font-weight:600}
.px-prose a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}

/* ---- legal layout ---- */
.px-legal{padding:34px 0 104px}
.px-legal__grid{display:grid;grid-template-columns:230px 1fr;gap:56px;align-items:start}
.px-legal__toc{position:sticky;top:96px}
.px-legal__toc-h{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:var(--ink-dim);margin:0 0 14px}
.px-legal__toc nav{display:flex;flex-direction:column;gap:10px;border-left:1px solid var(--line);padding-left:16px}
.px-legal__toc a{color:var(--ink-soft);font-size:13.5px;line-height:1.4;transition:color .2s,border-color .2s}
.px-legal__toc a:hover{color:var(--blue)}
.px-legal__body{max-width:760px}
.px-legal__body section{padding:28px 0;border-top:1px solid var(--line)}
.px-legal__body section:first-child{border-top:0;padding-top:4px}
.px-legal__body h2{font-family:var(--serif);font-weight:600;font-size:26px;color:var(--ink);margin:0 0 14px;scroll-margin-top:96px}

/* ---- about page ---- */
.px-twocol{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.px-panel{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 28px}
.px-panel h3{font-family:var(--serif);font-weight:600;font-size:22px;margin:0 0 12px}
.px-panel p{color:var(--ink-soft);font-size:16px;line-height:1.7;margin:0}
.px-panel .px-eyebrow{margin-bottom:14px}
.px-chips{display:flex;flex-wrap:wrap;gap:10px}
.px-chips span{background:var(--paper-2);border:1px solid var(--line);border-radius:100px;padding:9px 16px;font-size:14px;font-weight:500;color:var(--ink)}
.px-vals{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.px-val{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;transition:border-color .3s,transform .3s}
.px-val:hover{border-color:var(--line-2);transform:translateY(-3px)}
.px-val h4{font-family:var(--serif);font-weight:600;font-size:19px;margin:0 0 8px}
.px-val p{color:var(--ink-soft);font-size:15px;line-height:1.6;margin:0}
.px-founder{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center;background:var(--ink);color:#fff;border-radius:var(--r-lg);padding:38px 36px}
.px-founder__badge{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;font-family:var(--serif);font-size:34px;font-weight:600;
	background:radial-gradient(circle at 36% 28%,#2a3160,#0a0e1c);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}
.px-founder h3{font-family:var(--serif);font-weight:600;font-size:24px;margin:0 0 8px}
.px-founder p{color:rgba(255,255,255,.72);font-size:15.5px;line-height:1.7;margin:0}
.px-info{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.px-info div{background:var(--paper);padding:20px 24px}
.px-info dt{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:10.5px;color:var(--ink-dim);margin:0 0 6px}
.px-info dd{font-family:var(--serif);font-size:18px;color:var(--ink);margin:0}

/* ---- contact page ---- */
.px-contact{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:start}
.px-contact__info h3{font-family:var(--serif);font-weight:600;font-size:20px;margin:0 0 6px}
.px-contact__block{padding:22px 0;border-top:1px solid var(--line)}
.px-contact__block:first-child{border-top:0;padding-top:0}
.px-contact__label{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--ink-dim);margin:0 0 6px}
.px-contact__block p{margin:0;color:var(--ink-soft);font-size:15.5px;line-height:1.6}
.px-contact__block a{color:var(--blue)}
.px-form{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 30px;box-shadow:var(--shadow)}
.px-field{margin-bottom:18px}
.px-field label{display:block;font-family:var(--sans);font-weight:600;font-size:13px;color:var(--ink);margin-bottom:7px}
.px-field input,.px-field textarea{width:100%;font-family:var(--sans);font-size:15.5px;color:var(--ink);background:var(--paper);
	border:1px solid var(--line-2);border-radius:12px;padding:13px 15px;transition:border-color .2s,box-shadow .2s}
.px-field input:focus,.px-field textarea:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}
.px-field textarea{resize:vertical;min-height:140px}
.px-form .px-btn{width:100%;justify-content:center;margin-top:4px}
.px-formmsg{padding:14px 16px;border-radius:12px;font-size:14.5px;margin-bottom:20px}
.px-formmsg--ok{background:rgba(22,193,114,.1);border:1px solid rgba(22,193,114,.3);color:#0f7a47}
.px-formmsg--err{background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.28);color:#b91c1c}

/* ---- inner page responsive ---- */
@media (max-width:900px){
	.px-legal__grid{grid-template-columns:1fr;gap:0}
	.px-legal__toc{display:none}
	.px-twocol{grid-template-columns:1fr}
	.px-vals{grid-template-columns:repeat(2,1fr)}
	.px-contact{grid-template-columns:1fr;gap:34px}
	.px-info{grid-template-columns:1fr}
}
@media (max-width:640px){
	.px-phero{padding:54px 0 30px}
	.px-vals{grid-template-columns:1fr}
	.px-founder{grid-template-columns:1fr;text-align:center;justify-items:center;padding:32px 24px}
	.px-founder__badge{margin:0 auto}
	.px-footer__cols{grid-template-columns:1fr 1fr;gap:24px}
}

/* =====================================================================
   PRODUCT LOGO PANELS  (per-logo background: dark for white logos,
   light for dark logos — keeps every brand mark legible)
   ===================================================================== */
.px-logobox{display:flex;align-items:center;justify-content:center;border-radius:12px;overflow:hidden}
.px-logobox img{display:block;width:auto;max-width:100%;height:auto;object-fit:contain}
.px-logobox--dark{background:var(--ink)}
.px-logobox--light{background:#fff;border:1px solid var(--line)}

/* product grid cards */
.px-card .px-logobox{height:66px;padding:13px 18px;margin:2px 0 2px}
.px-card .px-logobox img{max-height:40px}

/* constellation: name on resting cards, logo on the active (spotlit) card */
.px-cstl__logo{display:none;height:38px;padding:7px 11px;margin-top:4px}
.px-cstl__logo img{max-height:24px}
.px-cstl__card.is-active .px-cstl__logo{display:flex}
.px-cstl__card.is-active .px-cstl__name{display:none}

/* =====================================================================
   FOOTER additions (address + email)
   ===================================================================== */
.px-footer__addr{font-style:normal;color:var(--ink-soft);font-size:14.5px;line-height:1.85;margin:0}
.px-footer__h--contact{margin:18px 0 8px}

/* =====================================================================
   ROADMAP — alternating launch timeline with scroll-driven beam
   ===================================================================== */
.px-rmap{position:relative;max-width:1000px;margin:0 auto;padding:8px 0}
/* central spine */
.px-rmap__spine{position:absolute;left:50%;top:0;bottom:0;width:2px;transform:translateX(-50%);
	background:repeating-linear-gradient(180deg,rgba(10,14,28,.14) 0 7px,transparent 7px 14px);z-index:0}
.px-rmap__beam{position:absolute;left:50%;top:0;width:3px;height:0;transform:translateX(-50%);border-radius:3px;
	background:linear-gradient(180deg,rgba(21,0,255,0),var(--blue) 24%,#5b4bff);
	box-shadow:0 0 14px 1px rgba(21,0,255,.55);transition:height .15s linear}
.px-rmap__beam::after{content:"";position:absolute;left:50%;bottom:-5px;width:11px;height:11px;border-radius:50%;
	transform:translateX(-50%);background:#6354ff;box-shadow:0 0 16px 4px rgba(21,0,255,.65)}

/* rows */
.px-rmap__row{position:relative;display:grid;grid-template-columns:1fr 1fr;column-gap:60px;margin-bottom:10px;z-index:1}
.px-rmap__row:last-child{margin-bottom:0}
.px-rmap__row.is-left .px-rmap__card{grid-column:1;transform:translateX(34px)}
.px-rmap__row.is-right .px-rmap__card{grid-column:2;transform:translateX(-34px)}

/* node on the spine */
.px-rmap__node{position:absolute;left:50%;top:34px;width:20px;height:20px;transform:translate(-50%,-50%);z-index:3}
.px-rmap__core{position:absolute;inset:4px;border-radius:50%;background:var(--paper);
	box-shadow:0 0 0 3px var(--ink-dim);transition:box-shadow .45s,background .45s}
.px-rmap__ring{position:absolute;inset:0;border-radius:50%;border:2px solid var(--blue);opacity:0}

/* card */
.px-rmap__card{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);
	padding:24px 26px;opacity:0;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1),border-color .3s,box-shadow .3s;overflow:hidden}
.px-rmap__card::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
	background:radial-gradient(120% 80% at 50% -10%,rgba(21,0,255,.06),transparent 60%);opacity:0;transition:opacity .5s}
.px-rmap__num{position:absolute;top:16px;right:20px;font-size:12px;color:var(--ink-dim);letter-spacing:.08em}
.px-rmap__top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:11px}
.px-rmap__date{font-size:12.5px;color:var(--ink-soft);font-weight:600;letter-spacing:.02em}
.px-rmap__status{position:relative;overflow:hidden;font-family:var(--sans);font-weight:600;font-size:11px;
	text-transform:uppercase;letter-spacing:.09em;color:var(--blue);background:var(--blue-soft);
	border:1px solid rgba(21,0,255,.18);padding:4px 12px;border-radius:100px;white-space:nowrap}
.px-rmap__status::after{content:"";position:absolute;top:0;left:-60%;width:45%;height:100%;
	background:linear-gradient(100deg,transparent,rgba(255,255,255,.85),transparent);transform:skewX(-18deg);
	animation:px-shimmer 3.4s ease-in-out infinite}
.px-rmap__name{font-family:var(--serif);font-weight:600;font-size:23px;color:var(--ink);margin:0 0 8px}
.px-rmap__desc{color:var(--ink-soft);font-size:15.5px;line-height:1.65;margin:0}

/* lit state (set by scroll JS) */
.px-rmap__row.is-lit .px-rmap__card{opacity:1;transform:translateX(0)}
.px-rmap__row.is-lit .px-rmap__card::before{opacity:1}
.px-rmap__row.is-lit .px-rmap__card{border-color:rgba(21,0,255,.22);box-shadow:0 18px 40px -26px rgba(21,0,255,.5)}
.px-rmap__row.is-lit .px-rmap__core{background:var(--blue);box-shadow:0 0 0 3px var(--blue),0 0 18px 3px rgba(21,0,255,.6)}
.px-rmap__row.is-lit .px-rmap__ring{animation:px-node-pulse 1.6s ease-out infinite}

@keyframes px-shimmer{0%,60%{left:-60%}100%{left:160%}}
@keyframes px-node-pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(2.4);opacity:0}}

/* more-to-come block */
.px-rmap__more{position:relative;margin:48px auto 0;max-width:1000px;background:var(--ink);color:#fff;
	border-radius:var(--r-lg);padding:38px 38px;overflow:hidden}
.px-rmap__more::before{content:"";position:absolute;inset:0;
	background:radial-gradient(620px 280px at 88% 0,rgba(21,0,255,.28),transparent 60%);pointer-events:none}
.px-rmap__more>*{position:relative}
.px-rmap__more .px-eyebrow{color:rgba(255,255,255,.85);margin-bottom:14px}
.px-rmap__more .px-eyebrow i{background:var(--blue)}
.px-rmap__more p{color:rgba(255,255,255,.74);font-size:16px;line-height:1.72;margin:0 0 12px;max-width:62ch}
.px-rmap__more p:last-child{margin-bottom:0}

/* tablet / mobile → single rail on the left */
@media (max-width:760px){
	.px-rmap__spine{left:9px}
	.px-rmap__beam{left:9px}
	.px-rmap__row{grid-template-columns:1fr;column-gap:0;padding-left:44px;margin-bottom:16px}
	.px-rmap__row.is-left .px-rmap__card,
	.px-rmap__row.is-right .px-rmap__card{grid-column:1;transform:translateX(22px)}
	.px-rmap__row.is-lit .px-rmap__card{transform:translateX(0)}
	.px-rmap__node{left:9px;top:30px}
	.px-rmap__name{font-size:20px}
	.px-rmap__more{padding:28px 24px}
}

@media (prefers-reduced-motion:reduce){
	.px-rmap__card{opacity:1!important;transform:none!important;transition:none}
	.px-rmap__beam{transition:none}
	.px-rmap__status::after,.px-rmap__row.is-lit .px-rmap__ring{animation:none}
}


/* =====================================================================
   FAQ ACCORDION
   ===================================================================== */
.px-acc{border-top:1px solid var(--line)}
.px-acc__item{border-bottom:1px solid var(--line)}
.px-acc__q{width:100%;display:flex;align-items:center;gap:16px;text-align:left;background:none;border:0;
	cursor:pointer;padding:22px 4px;font-family:var(--sans);color:var(--ink);transition:color .2s}
.px-acc__qn{color:var(--ink-dim);font-size:12px;flex:none;width:26px;letter-spacing:.04em}
.px-acc__qt{flex:1;font-size:17px;font-weight:600;line-height:1.4;transition:color .2s}
.px-acc__ico{position:relative;flex:none;width:18px;height:18px}
.px-acc__ico::before,.px-acc__ico::after{content:"";position:absolute;background:var(--ink-soft);transition:transform .35s,opacity .35s,background .2s}
.px-acc__ico::before{left:0;top:8px;width:18px;height:2px}
.px-acc__ico::after{left:8px;top:0;width:2px;height:18px}
.px-acc__q:hover .px-acc__qt{color:var(--blue)}
.px-acc__item.is-open .px-acc__ico::after{transform:scaleY(0);opacity:0}
.px-acc__item.is-open .px-acc__ico::before{background:var(--blue)}
.px-acc__item.is-open .px-acc__qt{color:var(--blue)}
.px-acc__panel{overflow:hidden;max-height:0;transition:max-height .42s cubic-bezier(.4,0,.2,1)}
.px-acc__body{padding:0 4px 24px 46px;color:var(--ink-soft);font-size:16px;line-height:1.72}
.px-acc__body p{margin:0 0 12px}.px-acc__body p:last-child{margin-bottom:0}
.px-acc__body ul{margin:8px 0 12px}
.px-acc__cta{margin-top:44px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
	background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px 30px}
.px-acc__cta p{margin:0;font-family:var(--serif);font-size:20px;color:var(--ink)}
@media (max-width:560px){.px-acc__body{padding-left:30px}.px-acc__qt{font-size:16px}}

/* =====================================================================
   ABOUT PAGE — premium sections + animation
   ===================================================================== */
/* animated accent word in hero */
.px-abhero .px-phero__title em{
	background:linear-gradient(100deg,var(--blue),#6354ff,var(--blue));
	background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
	animation:px-flow 5s ease-in-out infinite}
@keyframes px-flow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}

/* stats */
.px-abstats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.px-abstat{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:30px 26px;
	transition:border-color .3s,transform .3s}
.px-abstat:hover{border-color:var(--line-2);transform:translateY(-3px)}
.px-abstat__n{display:block;font-family:var(--serif);font-weight:600;font-size:46px;line-height:1;color:var(--ink);letter-spacing:-.02em}
.px-abstat__l{display:block;font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.1em;font-size:11px;color:var(--ink-dim);margin-top:12px}

/* founder feature (dark) */
.px-abfdr{position:relative;overflow:hidden;background:var(--ink);color:#fff;padding:88px 0}
.px-abfdr::before{content:"";position:absolute;inset:0;pointer-events:none;
	background:radial-gradient(640px 360px at 12% 0,rgba(21,0,255,.26),transparent 62%)}
.px-abfdr__grid{position:relative;display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:center}
.px-abfdr__media{position:relative;margin:0;border-radius:var(--r-lg);overflow:hidden;max-width:420px;
	box-shadow:0 30px 70px -30px rgba(0,0,0,.7)}
.px-abfdr__media::after{content:"";position:absolute;inset:0;border-radius:var(--r-lg);
	box-shadow:inset 0 0 0 1px rgba(255,255,255,.14);pointer-events:none}
.px-abfdr__media img{display:block;width:100%;height:auto;
	clip-path:inset(0 0 100% 0);transform:scale(1.06);
	transition:clip-path 1.15s cubic-bezier(.2,.7,.2,1),transform 1.3s cubic-bezier(.2,.7,.2,1)}
.px-abfdr__media.is-in img{clip-path:inset(0 0 0 0);transform:scale(1)}
.px-abfdr__tag{position:absolute;left:16px;bottom:16px;background:var(--blue);color:#fff;
	font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:7px 15px;border-radius:100px;
	box-shadow:0 8px 22px -8px rgba(21,0,255,.8)}
.px-abfdr__body .px-eyebrow{color:rgba(255,255,255,.85)}
.px-abfdr__body .px-eyebrow i{background:var(--blue)}
.px-abfdr__name{font-family:var(--serif);font-weight:600;font-size:clamp(28px,4vw,42px);letter-spacing:-.01em;margin:8px 0 6px}
.px-abfdr__role{color:#9b8bff;font-family:var(--sans);font-weight:600;font-size:14.5px;margin:0 0 20px}
.px-abfdr__body .px-prose{color:rgba(255,255,255,.74);font-size:16.5px}

/* commitment grid */
.px-commit{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 30px}
.px-commit__item{display:flex;align-items:center;gap:14px;background:var(--paper-2);border:1px solid var(--line);
	border-radius:var(--r);padding:18px 20px;font-size:15.5px;color:var(--ink);font-weight:500}
.px-commit__tick{position:relative;flex:none;width:22px;height:22px;border-radius:50%;background:var(--blue-soft);border:1px solid rgba(21,0,255,.25)}
.px-commit__tick::after{content:"";position:absolute;left:7px;top:4px;width:5px;height:10px;border:solid var(--blue);border-width:0 2px 2px 0;transform:rotate(45deg)}

@media (max-width:820px){
	.px-abstats{grid-template-columns:repeat(2,1fr)}
	.px-abfdr__grid{grid-template-columns:1fr;gap:34px}
	.px-abfdr__media{max-width:340px}
	.px-commit{grid-template-columns:1fr}
}
@media (max-width:560px){
	.px-abstat__n{font-size:38px}
}
@media (prefers-reduced-motion:reduce){
	.px-abhero .px-phero__title em{animation:none}
	.px-abfdr__media img{clip-path:none;transform:none}
}

/* =====================================================================
   ABOUT v2 — orb, stagger, mission/vision, values list
   ===================================================================== */
/* floating accent orb in hero */
.px-abhero__orb{position:absolute;z-index:0;top:-130px;right:-70px;width:440px;height:440px;border-radius:50%;
	background:radial-gradient(circle at 32% 30%,rgba(21,0,255,.20),rgba(21,0,255,0) 70%);
	pointer-events:none;animation:px-orb 15s ease-in-out infinite}
@keyframes px-orb{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-34px,32px) scale(1.14)}}

/* staggered children reveal */
.px-stagger.px-reveal{opacity:1;transform:none}
.px-stagger>*{opacity:0;transform:translateY(16px);transition:opacity .55s ease,transform .55s cubic-bezier(.2,.7,.2,1)}
.px-stagger.is-in>*{opacity:1;transform:none}
.px-stagger.is-in>*:nth-child(1){transition-delay:.04s}
.px-stagger.is-in>*:nth-child(2){transition-delay:.10s}
.px-stagger.is-in>*:nth-child(3){transition-delay:.16s}
.px-stagger.is-in>*:nth-child(4){transition-delay:.22s}
.px-stagger.is-in>*:nth-child(5){transition-delay:.28s}
.px-stagger.is-in>*:nth-child(6){transition-delay:.34s}
.px-stagger.is-in>*:nth-child(7){transition-delay:.40s}
.px-stagger.is-in>*:nth-child(8){transition-delay:.46s}
.px-stagger.is-in>*:nth-child(9){transition-delay:.52s}

/* mission / vision */
.px-mv{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.px-mv__item{position:relative;display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;
	background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:36px 34px;overflow:hidden;
	transition:border-color .3s,transform .3s,box-shadow .3s}
.px-mv__item:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:var(--shadow)}
.px-mv__item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--blue),#6354ff);
	transform:scaleY(0);transform-origin:top;transition:transform .9s cubic-bezier(.2,.7,.2,1) .15s}
.px-mv__item.is-in::before{transform:scaleY(1)}
.px-mv__idx{font-family:var(--serif);font-weight:600;font-size:42px;line-height:1;color:var(--blue);opacity:.9}
.px-mv__body .px-eyebrow{margin-bottom:12px}
.px-mv__body p{color:var(--ink-soft);font-size:16px;line-height:1.72;margin:0 0 12px}
.px-mv__body p:last-child{margin-bottom:0}

/* values — numbered editorial list */
.px-vlist{border-top:1px solid var(--line)}
.px-vrow{display:grid;grid-template-columns:58px 1fr;column-gap:24px;row-gap:4px;
	padding:24px 10px;border-bottom:1px solid var(--line);transition:background .3s,padding-left .3s}
.px-vrow:hover{background:var(--paper-2);padding-left:20px}
.px-vrow__n{grid-column:1;grid-row:1 / 3;color:var(--blue);font-size:14px;letter-spacing:.04em;padding-top:6px}
.px-vrow__t{grid-column:2;grid-row:1;font-family:var(--serif);font-weight:600;font-size:21px;color:var(--ink);margin:0}
.px-vrow__d{grid-column:2;grid-row:2;color:var(--ink-soft);font-size:15.5px;line-height:1.6;margin:2px 0 0}

@media (max-width:820px){
	.px-mv{grid-template-columns:1fr}
	.px-abhero__orb{width:300px;height:300px;top:-90px;right:-60px}
}
@media (max-width:560px){
	.px-vrow{grid-template-columns:40px 1fr;column-gap:16px}
	.px-mv__item{padding:28px 24px;gap:18px}
}
@media (prefers-reduced-motion:reduce){
	.px-abhero__orb{animation:none}
	.px-stagger>*{opacity:1;transform:none;transition:none}
	.px-mv__item::before{transform:scaleY(1)}
}
