/* ============================================================
   Position Imaging Patents — animated IP-licensing site
   3D scroll cinematic + bold editorial brand.
   ============================================================ */
:root{
  --paper:#f3f1ea;
  --paper2:#eae7dd;
  --ink:#14161c;
  --ink2:#565963;
  --ink3:#9498a1;
  --line:#ddd9cd;
  --blue:#2d5bff;
  --lime:#caff3c;
  --coral:#ff5a36;
  --teal:#10b890;
  --maxw:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --disp:"Geist",system-ui,sans-serif;
  --body:"Geist",system-ui,sans-serif;
  --mono:"Fragment Mono",ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--body);background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
sup{font-size:.5em;top:-.7em}
::selection{background:var(--lime);color:var(--ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
.mono{font-family:var(--mono)}
.disp{font-family:var(--disp);font-weight:700;letter-spacing:-.02em;line-height:1}
.hl{background:linear-gradient(180deg,transparent 58%,var(--lime) 58%);padding:0 .04em}
.lime{color:var(--lime)}
.grad{background:linear-gradient(96deg,var(--blue),var(--coral) 55%,var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

#webgl{position:fixed;inset:0;width:100vw;height:100vh;z-index:0;display:block}

/* boot */
.boot{position:fixed;inset:0;z-index:80;background:var(--paper);display:grid;place-items:center;transition:opacity .7s var(--ease),visibility .7s}
.boot.done{opacity:0;visibility:hidden}
.boot__logo{font-family:var(--disp);font-weight:700;font-size:18px;display:flex;align-items:center;gap:10px;margin-bottom:20px}
.boot__logo b{color:var(--blue)}
.boot__bar{width:min(280px,60vw);height:2px;background:var(--line);border-radius:2px;overflow:hidden}
.boot__bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--coral),var(--teal));transition:width .2s linear}
.boot__pct{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink3);margin-top:14px;text-transform:uppercase}

/* logomark */
.mark{width:18px;height:18px;border-radius:5px;background:var(--ink);position:relative;flex:0 0 auto}
.mark::after{content:"";position:absolute;inset:5px;border-radius:50%;background:var(--lime)}

/* nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,48px);transition:background .4s,backdrop-filter .4s,border-color .4s,padding .35s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(243,241,234,.78);backdrop-filter:blur(14px);border-color:var(--line);padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--disp);font-weight:700;font-size:16px}
.brand small{font-family:var(--mono);font-weight:500;font-size:10px;letter-spacing:.16em;color:var(--ink2);border:1px solid var(--line);padding:3px 7px;border-radius:5px;text-transform:uppercase}
.nav__r{display:flex;align-items:center;gap:22px}
.nav__r a{font-size:14px;color:var(--ink2);transition:color .2s}
.nav__r a:hover{color:var(--ink)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:100px;font-family:var(--disp);font-weight:600;font-size:15px;transition:transform .25s var(--ease),box-shadow .25s,background .25s}
.btn i{width:7px;height:7px;border-top:2px solid currentColor;border-right:2px solid currentColor;transform:rotate(45deg)}
.btn--p{background:var(--ink);color:var(--paper)}
.btn--p:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(20,22,28,.5)}
.btn--lime{background:var(--lime);color:var(--ink)}
.btn--lime:hover{transform:translateY(-2px);box-shadow:0 14px 36px -8px rgba(202,255,60,.7)}
.btn--ghost{background:transparent;color:var(--paper);border:1.5px solid rgba(255,255,255,.4)}
.btn--ghost:hover{background:rgba(255,255,255,.1)}

/* progress rail */
.rail{position:fixed;left:clamp(12px,3vw,28px);top:50%;transform:translateY(-50%);z-index:20;display:flex;flex-direction:column;gap:11px;opacity:0;transition:opacity .5s}
.rail.on{opacity:1}
.rail span{width:8px;height:8px;border-radius:50%;background:var(--line);transition:all .4s var(--ease)}
.rail span.on{background:var(--ink);transform:scale(1.35)}

/* cinematic */
.film{height:560vh;position:relative;z-index:2}
.film__sticky{position:sticky;top:0;height:100vh;overflow:hidden}
.chip{position:absolute;top:96px;left:50%;transform:translateX(-50%);z-index:6;display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:100px;background:rgba(255,255,255,.72);backdrop-filter:blur(8px);border:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink2);opacity:0;transition:opacity .5s}
.chip.on{opacity:1}
.chip__dot{width:7px;height:7px;border-radius:50%;background:var(--blue);box-shadow:0 0 0 0 rgba(45,91,255,.5);animation:ping 1.8s infinite}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(45,91,255,.5)}70%{box-shadow:0 0 0 8px rgba(45,91,255,0)}100%{box-shadow:0 0 0 0 rgba(45,91,255,0)}}
.chip em{color:var(--ink);font-style:normal}

.caps{position:absolute;inset:0;z-index:5;pointer-events:none}
.cap{position:absolute;max-width:min(640px,86vw);opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.cap.show{opacity:1;transform:none}
.cap.hide{opacity:0;transform:translateY(-22px);transition-duration:.45s}
.cap--hero{left:50%;top:50%;transform:translate(-50%,calc(-50% + 26px));text-align:center}
.cap--hero.show{transform:translate(-50%,-50%)}
.cap--hero.hide{transform:translate(-50%,calc(-50% - 22px))}
.cap--l{left:clamp(20px,7vw,90px);top:50%;transform:translateY(calc(-50% + 26px))}
.cap--l.show{transform:translateY(-50%)}
.cap--r{right:clamp(20px,7vw,90px);left:auto;top:50%;text-align:right;transform:translateY(calc(-50% + 26px))}
.cap--r.show{transform:translateY(-50%)}
.cap--c{left:50%;top:62%;transform:translate(-50%,26px);text-align:center}
.cap--c.show{transform:translate(-50%,0)}
.cap h1{font-family:var(--disp);font-weight:700;font-size:clamp(22px,2.9vw,42px);line-height:1.12;letter-spacing:-.025em;max-width:none;margin-inline:auto}
.cap h2{font-family:var(--disp);font-weight:700;font-size:clamp(26px,4.1vw,54px);line-height:1.06;letter-spacing:-.025em}
.cap p{margin-top:18px;font-size:clamp(15px,1.8vw,20px);line-height:1.55;color:var(--ink2);max-width:48ch}
.cap--hero p{margin-left:auto;margin-right:auto}
.cap--r p{margin-left:auto}

.eyebrow,.kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;color:var(--ink2);text-transform:uppercase;margin-bottom:18px}
.eyebrow i{width:7px;height:7px;border-radius:50%;background:var(--blue);box-shadow:0 0 10px var(--blue);animation:pulse 2s infinite}
.kicker::before{content:"";width:22px;height:1.5px;background:var(--ink)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.tech-bullets{list-style:none;margin-top:26px;display:flex;flex-direction:column;gap:14px}
.tech-bullets li{display:flex;align-items:center;gap:13px;font-size:clamp(16px,2vw,22px);color:var(--ink2);opacity:0;transform:translateX(-14px);transition:all .6s var(--ease)}
.cap.show .tech-bullets li{opacity:1;transform:none}
.cap.show .tech-bullets li:nth-child(1){transition-delay:.15s}
.cap.show .tech-bullets li:nth-child(2){transition-delay:.32s}
.cap.show .tech-bullets li:nth-child(3){transition-delay:.49s}
.tech-bullets b{color:var(--ink);font-weight:600}
.tech-bullets li::before{content:"";width:14px;height:14px;border-radius:50%;flex:0 0 auto}
.tech-bullets li[data-c="rf"]::before{background:var(--blue);box-shadow:0 0 14px var(--blue)}
.tech-bullets li[data-c="cv"]::before{background:var(--coral);box-shadow:0 0 14px var(--coral)}
.tech-bullets li[data-c="ai"]::before{background:var(--teal);box-shadow:0 0 14px var(--teal)}

.cue{display:inline-flex;align-items:center;gap:11px;margin-top:34px;font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--ink3);text-transform:uppercase}
.cue i{width:20px;height:32px;border:1.5px solid var(--line);border-radius:11px;position:relative}
.cue i::after{content:"";position:absolute;left:50%;top:6px;width:3px;height:7px;border-radius:3px;background:var(--ink);transform:translateX(-50%);animation:wheel 1.7s infinite}
@keyframes wheel{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}70%{opacity:1}100%{opacity:0;transform:translate(-50%,11px)}}

/* ===== page sections ===== */
section.sec{position:relative;z-index:2;background:var(--paper);padding:clamp(80px,13vh,150px) 0}
.sec.alt{background:var(--paper2)}
.sec.center{text-align:center}
.sec.ink-sec{background:var(--ink);color:var(--paper)}
.ink-sec .lead{color:#b7b9c1}.ink-sec .kicker{color:#9a9ca5}.ink-sec .kicker::before{background:var(--lime)}
.ink-sec .sec-head h2{color:var(--paper)}
.sec-head{max-width:760px;margin-bottom:50px}
.sec-head h2{font-family:var(--disp);font-weight:700;font-size:clamp(30px,5vw,64px);line-height:1.02;letter-spacing:-.025em;margin-top:18px}
.lead{font-size:clamp(17px,2vw,21px);line-height:1.55;color:var(--ink2)}
h1,h2,h3,.sec-head h2{text-wrap:balance}
.lead,.offer p,.win__p,.tm__bio,.path p,.cited__stmt,.pcard p{text-wrap:pretty}
.grid2{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:18px}
.grid3{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:16px}

/* marquee */
.marq{display:flex;overflow:hidden;white-space:nowrap;border-top:1px solid rgba(255,255,255,.14);border-bottom:1px solid rgba(255,255,255,.14);background:var(--ink)}
.marq__t{display:inline-flex;gap:42px;padding:16px 21px;color:var(--paper);font-family:var(--mono);font-size:13px;letter-spacing:.04em;animation:marq 40s linear infinite;will-change:transform}
.marq__t span b{color:var(--lime);font-weight:700;margin-right:8px}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* pains */
.pain{border-top:1px solid rgba(255,255,255,.16);padding-top:22px}
.pain b{font-family:var(--disp);font-weight:700;font-size:clamp(34px,5vw,58px);color:var(--lime);display:block;line-height:1}
.pain span{display:block;font-family:var(--disp);font-weight:600;font-size:19px;margin:8px 0 10px}
.pain p{color:#b7b9c1;font-size:14.5px;line-height:1.55}
.bigline{font-family:var(--disp);font-weight:700;font-size:clamp(20px,2.7vw,32px);margin-top:54px;max-width:26ch;line-height:1.2}

/* products */
.prod{background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 24px;height:100%}
.prod .tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:6px 12px;border-radius:100px;border:1px solid var(--line)}
.prod[data-c="rf"] .tag{color:var(--blue);border-color:var(--blue)}
.prod[data-c="cv"] .tag{color:var(--coral);border-color:var(--coral)}
.prod[data-c="ai"] .tag{color:var(--teal);border-color:var(--teal)}
.prod .tag::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.prod h3{font-family:var(--disp);font-weight:600;font-size:24px;margin:18px 0 10px}
.prod p{color:var(--ink2);font-size:14.5px;line-height:1.55}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:56px;border-top:1px solid var(--line);padding-top:40px}
.stat b{font-family:var(--disp);font-weight:700;font-size:clamp(32px,4.4vw,56px);line-height:1;display:block}
.stat span{display:block;font-size:13px;color:var(--ink2);margin-top:8px;max-width:20ch}

/* paths */
.path{background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px 30px;height:100%}
.path--dark{background:var(--ink);color:var(--paper)}
.path__tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;margin-bottom:18px}
.path__tag.blue{color:var(--blue)}.path__tag.lime{color:var(--lime)}
.path h3{font-family:var(--disp);font-weight:700;font-size:clamp(26px,3.4vw,40px);margin-bottom:14px}
.path p{font-size:15px;line-height:1.6;color:var(--ink2);margin-bottom:22px}
.path--dark p{color:#c4c6ce}
.path ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.path li{display:flex;align-items:center;gap:11px;font-size:14.5px}
.path li::before{content:"";width:7px;height:7px;border-radius:2px;background:var(--blue);flex:0 0 auto}
.path--dark li::before{background:var(--lime)}

/* industries */
.ind{display:grid;gap:14px}
.indrow{display:grid;grid-template-columns:.7fr 1.3fr;gap:24px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 30px}
.indrow__n{font-family:var(--disp);font-weight:700;font-size:clamp(24px,3vw,38px)}
.indrow__r{display:flex;align-items:baseline;gap:10px;font-size:16px;color:var(--ink2)}
.indrow__r+.indrow__r{margin-top:12px}
.indrow__r .pain-t,.indrow__r .pat-t{font-family:var(--mono);font-size:11px;letter-spacing:.1em;flex:0 0 auto;width:84px}
.pain-t{color:var(--coral)}.pat-t{color:var(--blue)}

/* portfolio */
.pillar{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 26px;height:100%;border-top:4px solid var(--c)}
.pillar[data-c="rf"]{--c:var(--blue)}.pillar[data-c="cv"]{--c:var(--coral)}.pillar[data-c="ai"]{--c:var(--teal)}
.pillar .pc{font-size:12px;color:var(--c);display:block;margin-bottom:16px}
.pillar h3{font-family:var(--disp);font-weight:600;font-size:23px;margin-bottom:10px}
.pillar p{color:var(--ink2);font-size:14.5px;line-height:1.55}
.note{font-size:13px;color:var(--ink2);margin-top:26px}

/* cta */
.cta-h{font-family:var(--disp);font-weight:700;font-size:clamp(34px,6.4vw,86px);line-height:1;margin:18px auto 0;max-width:16ch}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:36px}
.foot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;align-items:center;margin-top:clamp(70px,12vh,140px);padding-top:26px;border-top:1px solid rgba(255,255,255,.16);font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:#9a9ca5;text-transform:uppercase}
.foot .brand{font-size:13px;color:var(--paper)}
.foot .brand small{color:#9a9ca5;border-color:rgba(255,255,255,.2)}

/* interactive verticals */
.vert{border:2px solid var(--ink);border-radius:22px;overflow:hidden;background:#fff}
.vtabs{display:flex;flex-wrap:wrap;border-bottom:2px solid var(--ink)}
.vtab{flex:1 1 auto;padding:18px 20px;font-family:var(--disp);font-weight:700;font-size:15px;color:var(--ink);background:#fff;border-right:2px solid var(--ink);transition:all .25s;position:relative;cursor:pointer}
.vtab:last-child{border-right:none}
.vtab:hover{background:var(--paper2)}
.vtab.on{color:#fff}
.vtab.on[data-g="log"]{background:linear-gradient(135deg,#2d5bff,#23c7ff)}
.vtab.on[data-g="ret"]{background:linear-gradient(135deg,#ff5a36,#ff2e8a)}
.vtab.on[data-g="hc"]{background:linear-gradient(135deg,#0fb890,#62d96a)}
.vtab.on[data-g="rob"]{background:linear-gradient(135deg,#7b5cff,#c06bff)}
.vpanes{position:relative}
.vpane{display:none;grid-template-columns:1fr 1fr;gap:36px;padding:clamp(28px,4vw,52px)}
.vpane.on{display:grid;animation:vfade .5s var(--ease)}
@keyframes vfade{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.vp__l h3{font-family:var(--disp);font-weight:700;font-size:clamp(24px,3vw,36px);margin-bottom:14px}
.vp__l>p{color:var(--ink2);font-size:15.5px;line-height:1.6;margin-bottom:24px;max-width:44ch}
.vp__own{margin-bottom:26px}
.vp__k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);display:block;margin-bottom:12px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.chip2{font-family:var(--mono);font-size:12px;padding:7px 13px;border-radius:100px;border:1px solid var(--cc,var(--line));color:var(--cc,var(--ink2));background:color-mix(in srgb,var(--cc,#ffffff) 9%,#fff)}
.chip2.rf{--cc:var(--blue)}.chip2.cv{--cc:var(--coral)}.chip2.ai{--cc:var(--teal)}
.pn{font-family:var(--mono);font-size:12.5px;color:var(--ink2);letter-spacing:.02em}
.vp__uses{list-style:none;display:flex;flex-direction:column}
.vp__uses li{padding:18px 0 18px 22px;border-bottom:1px solid var(--line);position:relative;font-size:14px;color:var(--ink2);line-height:1.5}
.vp__uses li:last-child{border-bottom:none}
.vp__uses li::before{content:"";position:absolute;left:0;top:24px;width:8px;height:8px;border-radius:2px;background:var(--blue)}
.vp__uses b{display:block;font-family:var(--disp);font-weight:600;font-size:16px;color:var(--ink);margin-bottom:4px}

/* connect / photo CTA */
.connect{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(28px,5vw,64px);align-items:center}
.connect__photo{position:relative;border-radius:24px;border:1px solid rgba(255,255,255,.14);max-width:380px;box-shadow:0 30px 60px -30px rgba(0,0,0,.6),0 0 48px 2px rgba(202,255,60,.18);animation:connectGlow 5.5s var(--ease) infinite}
.connect__photo img{position:relative;z-index:1;width:100%;display:block;aspect-ratio:4/5;object-fit:cover;object-position:center top;border-radius:24px}
.connect__pulse{position:absolute;z-index:2;left:18px;bottom:18px;width:12px;height:12px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(202,255,60,.6);animation:pulseLime 1.8s infinite}
/* lime glow + twin pulse-rings behind the b&w photo (minimal radar, draws the eye) */
.connect__photo::before,.connect__photo::after{content:"";position:absolute;z-index:0;inset:0;border-radius:24px;border:1.5px solid var(--lime);opacity:0;transform-origin:center;pointer-events:none;animation:connectRing 3.6s var(--ease) infinite}
.connect__photo::after{animation-delay:1.8s}
@keyframes connectGlow{0%,100%{box-shadow:0 30px 60px -30px rgba(0,0,0,.6),0 0 46px 2px rgba(202,255,60,.16)}50%{box-shadow:0 30px 60px -30px rgba(0,0,0,.6),0 0 86px 10px rgba(202,255,60,.42)}}
@keyframes connectRing{0%{opacity:.6;transform:scale(1)}70%,100%{opacity:0;transform:scale(1.16)}}
@keyframes pulseLime{0%{box-shadow:0 0 0 0 rgba(202,255,60,.55)}70%{box-shadow:0 0 0 9px rgba(202,255,60,0)}100%{box-shadow:0 0 0 0 rgba(202,255,60,0)}}
@media (prefers-reduced-motion:reduce){.connect__photo,.connect__photo::before,.connect__photo::after{animation:none}.connect__photo{box-shadow:0 30px 60px -30px rgba(0,0,0,.6),0 0 60px 4px rgba(202,255,60,.26)}}
.connect__h{font-family:var(--disp);font-weight:700;font-size:clamp(34px,5.5vw,72px);line-height:1;margin:14px 0 0;color:var(--paper)}
.connect__who{margin:22px 0 24px;display:flex;flex-direction:column;gap:3px}
.connect__who b{font-family:var(--disp);font-weight:700;font-size:18px;color:var(--paper)}
.connect__who span{font-family:var(--mono);font-size:12px;letter-spacing:.06em;color:#9a9ca5}

/* problem big numbers */
.bignums{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid rgba(255,255,255,.18);border-bottom:1px solid rgba(255,255,255,.18)}
.bignum{padding:40px 26px 36px 0;border-right:1px solid rgba(255,255,255,.14)}
.bignum:last-child{border-right:none}
.bignum{display:flex;flex-direction:column}
.bignum b{font-family:var(--disp);font-weight:800;font-size:clamp(40px,5.4vw,80px);line-height:1;letter-spacing:-.04em;color:var(--lime);display:block;white-space:nowrap;min-height:1.6em;display:flex;align-items:flex-end}
.bignum b i{font-style:normal;font-size:.4em;color:var(--paper);margin-left:3px;margin-bottom:.18em}
.bignum span{display:block;margin-top:14px;font-size:14.5px;line-height:1.5;color:#b7b9c1;max-width:24ch}
.solveline{display:flex;align-items:center;gap:20px;margin-top:46px;flex-wrap:wrap}
.solveline__k{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);background:var(--lime);padding:8px 14px;border-radius:100px;flex:0 0 auto}
.solveline p{font-family:var(--disp);font-weight:600;font-size:clamp(18px,2.4vw,28px);line-height:1.25;color:var(--paper);max-width:40ch}

/* two ways (bigger) */
.path--big{padding:clamp(34px,4vw,52px)}
.path--big .path__tag{font-size:13px;letter-spacing:.18em}
.path--big h3{font-size:clamp(30px,4vw,52px);line-height:1.0;margin-bottom:18px}
.path--big p{font-size:16px}

/* results */
.result{background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px 30px;position:relative}
.result__n{font-family:var(--mono);font-size:13px;color:var(--blue)}
.result h3{font-family:var(--disp);font-weight:700;font-size:clamp(21px,2.6vw,30px);line-height:1.1;margin:12px 0 12px}
.result p{color:var(--ink2);font-size:15px;line-height:1.6}

/* portfolio ecosystem grid */
.pfolio{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 22px;border-top:4px solid var(--c);display:flex;flex-direction:column}
.pcard[data-c="rf"]{--c:var(--blue)}.pcard[data-c="cv"]{--c:var(--coral)}.pcard[data-c="ai"]{--c:var(--teal)}
.pcard__t{font-family:var(--disp);font-weight:700;font-size:17px;line-height:1.15;margin-bottom:10px}
.pcard p{font-size:13px;line-height:1.5;color:var(--ink2);flex:1}
.pcard__ex{font-family:var(--mono);font-size:11px;color:var(--ink3);margin-top:14px;letter-spacing:.02em}
.pcard--cta{--c:var(--ink);background:var(--ink);color:var(--paper)}
.pcard--cta .pcard__t{color:var(--lime)}
.pcard--cta p{color:#b7b9c1}
.pcard--cta a{margin-top:14px;font-family:var(--disp);font-weight:600;font-size:14px;color:var(--paper);display:inline-flex;align-items:center;gap:8px}
.pcard--cta a i{width:6px;height:6px;border-top:2px solid var(--lime);border-right:2px solid var(--lime);transform:rotate(45deg)}

/* footer */
.footer{background:var(--ink);color:var(--paper);padding:clamp(56px,8vh,90px) 0 30px;position:relative;z-index:2}
.footer__top{display:grid;grid-template-columns:1.2fr 2fr;gap:clamp(28px,5vw,70px);padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.14)}
.footer__brand .brand{color:var(--paper);font-size:16px;margin-bottom:16px}
.footer__brand .brand small{color:#9a9ca5;border-color:rgba(255,255,255,.2)}
.footer__brand p{color:#9a9ca5;font-size:14px;line-height:1.6;max-width:34ch;margin-bottom:22px}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.footer__col{display:flex;flex-direction:column;gap:11px}
.footer__col span{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);margin-bottom:5px}
.footer__col a{font-size:14px;color:#c4c6ce;transition:color .2s}
.footer__col a:hover{color:var(--lime)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:12px;color:#9a9ca5}
.footer__bottom .mono{font-size:11px;letter-spacing:.08em}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.grid3 .reveal:nth-child(2),.grid2 .reveal:nth-child(2){transition-delay:.08s}
.grid3 .reveal:nth-child(3){transition-delay:.16s}

/* responsive */
@media(max-width:860px){
  .nav__r a:not(.btn){display:none}
  .rail{display:none}
  .stats{grid-template-columns:repeat(2,1fr)}
  .indrow{grid-template-columns:1fr;gap:12px}
  .vpane{grid-template-columns:1fr;gap:22px}
  .vtab{flex:1 1 45%;font-size:13.5px;padding:14px 14px}
  .connect{grid-template-columns:1fr;text-align:center}
  .connect__photo{margin:0 auto}
  .connect__who{align-items:center}
  .connect .cta-btns{justify-content:center!important}
  .cap--l,.cap--r{left:50%;right:auto;top:50%;text-align:center;transform:translate(-50%,calc(-50% + 26px));max-width:88vw}
  .cap--l.show,.cap--r.show{transform:translate(-50%,-50%)}
  .cap--r p{margin:18px auto 0}
  .bignums{grid-template-columns:repeat(2,1fr)}
  .bignum{border-right:none;border-bottom:1px solid rgba(255,255,255,.14);padding:26px 0}
  .bignum:nth-child(odd){border-right:1px solid rgba(255,255,255,.14);padding-right:20px}
  .pfolio{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr}
}
@media(max-width:560px){
  .bignums,.pfolio,.footer__cols{grid-template-columns:1fr}
  .bignum:nth-child(odd){border-right:none}
}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.cap{transition:none}}

/* ===================== ICP pages + Choose industry ===================== */
body.icp{background:var(--paper)}
.icp main{position:relative;z-index:1}

/* choose industry grid (home) */
.ichoose{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ichoose__card{position:relative;display:flex;flex-direction:column;gap:8px;padding:30px 26px 24px;border-radius:20px;background:#fff;border:1px solid var(--line);overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s;min-height:200px}
.ichoose__card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -26px rgba(20,22,28,.3)}
.ichoose__bar{position:absolute;left:0;top:0;height:6px;width:100%;background:linear-gradient(90deg,var(--a1),var(--a2))}
.ichoose__name{font-family:var(--disp);font-weight:700;font-size:clamp(20px,2.3vw,26px);line-height:1.05;margin-top:10px}
.ichoose__sub{font-family:var(--mono);font-size:12px;color:var(--ink2);letter-spacing:.01em;line-height:1.5}
.ichoose__go{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-weight:600;font-size:14px;color:var(--ink)}
.ichoose__go i{width:7px;height:7px;border-top:2px solid var(--a1);border-right:2px solid var(--a1);transform:rotate(45deg)}

/* icp hero */
.ipchero{position:relative;padding:clamp(120px,16vh,190px) 0 clamp(54px,8vh,90px);color:#fff;background:linear-gradient(135deg,var(--a1),var(--a2))}
.ipchero__back{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:rgba(255,255,255,.85);display:inline-block;margin-bottom:24px;transition:color .2s}
.ipchero__back:hover{color:#fff}
.ipchero__ey{font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:rgba(255,255,255,.85);margin-bottom:18px}
.ipchero h1{font-family:var(--disp);font-weight:800;font-size:clamp(38px,6.4vw,82px);line-height:.98;letter-spacing:-.03em;max-width:20ch}
.ipchero p{margin-top:22px;font-size:clamp(16px,1.9vw,21px);line-height:1.55;max-width:56ch;color:rgba(255,255,255,.94)}
.ipchero__btns{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn--ink{background:var(--ink);color:#fff}.btn--ink:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(0,0,0,.4)}
.btn--line{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}.btn--line:hover{background:rgba(255,255,255,.14)}

/* this is you */
.icpyou{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,5vw,60px);align-items:start}
.icpyou .chips{margin-top:22px;gap:9px}
.icpyou__r{background:#fff;border:1px solid var(--line);border-radius:18px;padding:6px 26px}
.icpyou__row{padding:20px 0;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:5px}
.icpyou__row:last-child{border-bottom:none}
.icpyou__row span{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3)}
.icpyou__row b{font-family:var(--disp);font-weight:600;font-size:16.5px;line-height:1.35}

.chip2.a{border-color:var(--a1);color:var(--a1);background:color-mix(in srgb,var(--a1) 9%,#fff)}

/* icp pains marker */
.pain .painmark{display:block;width:38px;height:5px;border-radius:3px;background:linear-gradient(90deg,var(--a1),var(--a2));margin-bottom:16px}

/* offers */
.offer{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;height:100%;display:flex;flex-direction:column}
.offer__n{font-family:var(--mono);font-size:13px;color:var(--a1)}
.offer h3{font-family:var(--disp);font-weight:700;font-size:clamp(21px,2.5vw,28px);line-height:1.12;margin:12px 0 12px;min-height:2.24em}
.ink-sec .offer h3{color:var(--ink)}
.offer p{color:var(--ink2);font-size:15px;line-height:1.6}

/* patents block */
.ipcpat{background:#fff;border:1px solid var(--line);border-radius:20px;padding:clamp(26px,4vw,44px)}
.ipcpat .chips{margin-bottom:20px;gap:9px}
.ipcpat__nums{display:flex;flex-wrap:wrap;gap:6px 24px;font-family:var(--mono);font-size:15px;color:var(--ink)}
.ipcpat__nums span{padding:7px 0}
.ipcpat .note{margin-top:18px;color:var(--ink2);max-width:60ch}

/* outcomes */
.outgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.result__n.a{color:var(--a1)}

/* other industries */
.otherind{display:flex;flex-wrap:wrap;gap:12px}
.otherind a{font-family:var(--disp);font-weight:600;font-size:clamp(15px,1.8vw,20px);padding:13px 22px;border:1px solid var(--line);border-radius:100px;background:#fff;transition:border-color .25s,transform .25s}
.otherind a:hover{border-color:var(--ink);transform:translateY(-2px)}

@media(max-width:860px){
 .ichoose{grid-template-columns:1fr 1fr}
 .icpyou{grid-template-columns:1fr;gap:26px}
 .outgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){.ichoose,.outgrid{grid-template-columns:1fr}}

/* ===================== problem (universal, punchy) ===================== */
.problemx{max-width:1000px}
.problemx__h{font-family:var(--disp);font-weight:800;font-size:clamp(40px,7vw,94px);line-height:.98;letter-spacing:-.03em;margin:6px 0 22px}
.rot{display:inline-block;position:relative;color:var(--lime);min-width:7ch;transition:opacity .26s}
.rot::after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.08em;background:var(--lime);opacity:.45}
.problemx__pains{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin:48px 0 44px;border-top:1px solid rgba(255,255,255,.16);padding-top:36px}
.ppain>span{font-family:var(--mono);font-size:13px;color:var(--lime)}
.ppain b{display:block;font-family:var(--disp);font-weight:700;font-size:clamp(20px,2.4vw,28px);margin:10px 0 8px}
.ppain p{color:#b7b9c1;font-size:15px;line-height:1.55}
.problemx__cta{display:flex;align-items:center;gap:22px;flex-wrap:wrap}
.problemx__cta span{font-size:14px;color:#9a9ca5;max-width:36ch;line-height:1.5}

/* ===================== interactive industry picker ===================== */
.picker{display:grid;grid-template-columns:.95fr 1.05fr;gap:20px;align-items:stretch}
.picker__list{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.picker__row{display:flex;align-items:center;gap:16px;padding:22px 8px;border-bottom:1px solid var(--line);transition:opacity .3s;position:relative}
.picker__row .picker__num{font-family:var(--mono);font-size:12px;color:var(--ink3)}
.picker__row .picker__name{font-family:var(--disp);font-weight:700;font-size:clamp(19px,2.5vw,31px);transition:transform .3s var(--ease)}
.picker__row i{margin-left:auto;width:9px;height:9px;border-top:2px solid var(--ink);border-right:2px solid var(--ink);transform:rotate(45deg);opacity:0;transition:opacity .3s}
.picker__row.on .picker__name{transform:translateX(10px)}
.picker__row.on i{opacity:1}
.picker__row:not(.on){opacity:.42}
.picker__row:hover{opacity:1}
.picker__stage{position:relative;border-radius:24px;overflow:hidden;min-height:360px}
.pkpanel{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;gap:14px;padding:clamp(28px,4vw,46px);color:#fff;background:linear-gradient(140deg,var(--a1),var(--a2));opacity:0;transform:scale(1.04);transition:opacity .5s var(--ease),transform .6s var(--ease);pointer-events:none}
.pkpanel.on{opacity:1;transform:none;pointer-events:auto}
.pkpanel__tag{font-family:var(--mono);font-size:12px;letter-spacing:.2em;opacity:.85}
.pkpanel__h{font-family:var(--disp);font-weight:700;font-size:clamp(24px,3.2vw,40px);line-height:1.05;max-width:18ch}
.pkpanel__chips{font-family:var(--mono);font-size:13px;opacity:.92}
.pkpanel__go{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-weight:600;font-size:16px;margin-top:6px}
.pkpanel__go i{width:8px;height:8px;border-top:2px solid #fff;border-right:2px solid #fff;transform:rotate(45deg)}
@media(max-width:860px){
  .problemx__pains{grid-template-columns:1fr;gap:18px}
  .picker{grid-template-columns:1fr}
  .picker__row:not(.on){opacity:1}
  .picker__stage{min-height:240px;order:-1}
  .problemx__cta{gap:14px}
}

/* ===================== build vs license comparison ===================== */
.vs{border-top:2px solid var(--ink)}
.vsrow{display:grid;grid-template-columns:clamp(86px,12vw,140px) 1fr 1fr;gap:clamp(16px,3vw,40px);padding:24px 0;border-bottom:1px solid var(--line);align-items:start}
.vsrow--h{padding:14px 0;border-bottom:2px solid var(--ink)}
.vs__h{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.vs__h--a{color:var(--ink3)}
.vs__h--b{color:var(--ink);display:inline-flex;align-items:center;gap:8px}
.vs__h--b::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--lime)}
.vs__t{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);padding-top:2px}
.vs__a,.vs__b{position:relative;padding-left:24px;font-size:clamp(14px,1.5vw,16px);line-height:1.5}
.vs__a{color:var(--ink3)}
.vs__a::before{content:"";position:absolute;left:0;top:.55em;width:13px;height:2px;background:var(--coral)}
.vs__b{color:var(--ink);font-weight:500}
.vs__b::before{content:"";position:absolute;left:1px;top:.3em;width:11px;height:11px;border-radius:50%;border:3px solid var(--lime)}
@media(max-width:760px){
  .vsrow{grid-template-columns:1fr;gap:8px;padding:20px 0}
  .vsrow--h{display:none}
  .vs__t{font-size:13px;color:var(--ink);font-family:var(--disp);font-weight:700;letter-spacing:0;text-transform:none;margin-bottom:2px}
  .vs__a,.vs__b{padding-left:22px}
}

/* connect photo crop for landscape source */
.connect__photo img{object-position:48% 26%}

/* ===================== vsx — modern build/license compare ===================== */
.vsx{display:flex;flex-direction:column;gap:14px}
.vsx__row{display:grid;grid-template-columns:clamp(92px,12vw,150px) 1fr 1fr;gap:clamp(16px,2.6vw,40px);align-items:stretch;
  opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.vsx__row.in{opacity:1;transform:none}
.vsx__row:nth-child(3).in{transition-delay:.06s}.vsx__row:nth-child(4).in{transition-delay:.13s}
.vsx__row:nth-child(5).in{transition-delay:.2s}.vsx__row:nth-child(6).in{transition-delay:.27s}
.vsx__row--h{align-items:center}
.vsx__t{display:flex;flex-direction:column;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);padding-top:18px}
.vsx__t svg{width:22px;height:22px;fill:none;stroke:var(--ink2);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
/* left (build) — muted */
.vsx__a{position:relative;padding:18px 22px 18px 28px;color:var(--ink3);font-size:clamp(14px,1.5vw,16px);line-height:1.5}
.vsx__a::before{content:"";position:absolute;left:0;top:25px;width:14px;height:2px;background:var(--coral)}
.vsx__a.vsx__h{font-family:var(--mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700;padding:0}
.vsx__a.vsx__h::before{display:none}
/* right (license) — shiny card */
.vsx__b{position:relative;overflow:hidden;padding:18px 22px 18px 48px;border-radius:16px;color:var(--ink);font-weight:500;font-size:clamp(14px,1.5vw,16px);line-height:1.5;
  background:linear-gradient(150deg,#ffffff 0%,#f4ffda 58%,#e9ffbf 100%);
  border:1px solid rgba(150,190,40,.4);
  box-shadow:0 22px 50px -28px rgba(70,90,0,.45),0 0 0 1px rgba(202,255,60,.22),inset 0 1px 0 rgba(255,255,255,.75);
  transition:transform .4s var(--ease),box-shadow .4s}
.vsx__b:hover{transform:translateY(-3px);box-shadow:0 32px 64px -28px rgba(70,90,0,.55),0 0 0 1px rgba(202,255,60,.5),inset 0 1px 0 rgba(255,255,255,.9)}
.vsx__b::before{content:"";position:absolute;left:18px;top:21px;width:13px;height:13px;border-radius:50%;border:3px solid #93cc00;background:rgba(202,255,60,.3)}
.vsx__b::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.6) 48%,transparent 64%);transform:translateX(-130%)}
.vsx__row.in .vsx__b::after{animation:sheen 1.5s var(--ease) .25s 1}
@keyframes sheen{to{transform:translateX(130%)}}
.vsx__b.vsx__h{padding:15px 22px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#163000;font-weight:700;display:flex;align-items:center;gap:9px;background:linear-gradient(150deg,#a6dd2a 0%,#83b600 100%);border:1px solid rgba(105,140,15,.55);box-shadow:0 18px 40px -24px rgba(70,90,0,.5),inset 0 1px 0 rgba(255,255,255,.35)}
.vsx__b.vsx__h::before{display:none}
.vsx__b.vsx__h::after{display:none}
.vsx__bdot{width:9px;height:9px;border-radius:50%;background:#8fd400;box-shadow:0 0 10px #b6e92e;flex:0 0 auto}
@media(max-width:760px){
  .vsx__row{grid-template-columns:1fr;gap:6px;padding-bottom:6px}
  .vsx__row--h{display:none}
  .vsx__t{flex-direction:row;align-items:center;padding-top:16px;color:var(--ink);font-family:var(--disp);font-weight:700;font-size:15px;letter-spacing:0;text-transform:none}
  .vsx__t svg{stroke:var(--ink)}
  .vsx__a{padding:6px 0 8px 22px}.vsx__a::before{top:12px}
  .vsx__b{padding:14px 18px 14px 40px}.vsx__b::before{top:17px}
}


/* ===================== dot-logo branding ===================== */
.mark{width:34px;height:20px;border-radius:0;background:transparent center/contain no-repeat;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 88 52'%3E%3Ccircle cx='6' cy='6' r='5.7' fill='%23b9bfc7'/%3E%3Ccircle cx='26' cy='6' r='5.7' fill='%23a4aab2'/%3E%3Ccircle cx='46' cy='6' r='5.7' fill='%238f959d'/%3E%3Ccircle cx='66' cy='6' r='5.7' fill='%232db84d'/%3E%3Ccircle cx='16' cy='26' r='5.7' fill='%23aeb4bc'/%3E%3Ccircle cx='36' cy='26' r='5.7' fill='%23999fa7'/%3E%3Ccircle cx='56' cy='26' r='5.7' fill='%23848a92'/%3E%3Ccircle cx='76' cy='26' r='5.7' fill='%236f757d'/%3E%3Ccircle cx='6' cy='46' r='5.7' fill='%23b3b9c1'/%3E%3Ccircle cx='26' cy='46' r='5.7' fill='%239ea4ac'/%3E%3Ccircle cx='46' cy='46' r='5.7' fill='%23898f97'/%3E%3Ccircle cx='66' cy='46' r='5.7' fill='%235f656c'/%3E%3C/svg%3E");flex:0 0 auto}
.mark::after{content:none;display:none}
.ink-sec .mark,.footer .mark,.boot .mark{filter:brightness(1.45) saturate(1.1)}
.boot__logo .mark{width:40px;height:24px}
.footlogo{height:62px;width:auto;display:block;margin-bottom:18px}
.ink-sec .footlogo,.footer .footlogo{filter:brightness(1.5)}

/* animated tracked-dots motif */
.trackdots{position:absolute;width:clamp(140px,18vw,210px);height:auto;top:clamp(70px,9vh,110px);right:clamp(20px,5vw,60px);z-index:1;pointer-events:none;opacity:.85}
.trackdots .td{fill:var(--ink3);opacity:.35}
.ink-sec .trackdots .td{fill:#5a6068;opacity:.6}
.trackdots .td-hot{fill:#caff3c;filter:drop-shadow(0 0 5px #caff3c);animation:tdpulse 2.4s var(--ease) infinite}
.trackdots .td-ring{fill:none;stroke:#caff3c;stroke-width:2;transform-box:fill-box;transform-origin:center;animation:tdring 2.4s var(--ease) infinite}
@keyframes tdpulse{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes tdring{0%{transform:scale(.7);opacity:.7}70%{transform:scale(3.4);opacity:0}100%{opacity:0}}
@media(max-width:760px){.trackdots{display:none}}

/* ===== vsx refinements: topic-in-build, darker license heading ===== */
.vsx__row{grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,56px)}
.vsx__a{display:flex;flex-direction:column;gap:11px;padding:18px 26px 18px 0;color:var(--ink3)}
.vsx__a::before{display:none}
.vsx__a.vsx__h{flex-direction:row;padding:0}
.vsx__t{flex-direction:row;align-items:center;gap:9px;padding-top:0;color:var(--ink2)}
.vsx__txt{position:relative;margin:0;padding-left:28px;color:var(--ink3);font-size:clamp(14px,1.5vw,16px);line-height:1.5}
.vsx__txt::before{content:"";position:absolute;left:0;top:.55em;width:14px;height:2px;background:var(--coral)}
.vsx__b.vsx__h{color:#1f3d00}
@media(max-width:760px){
  .vsx__row{grid-template-columns:1fr}
  .vsx__a{padding:8px 0 4px}
}


/* ===== arrow dot-logo (recreated) ===== */
.mark{width:46px;height:24px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 88 52'%3E%3Ccircle cx='6' cy='6' r='5.7' fill='%23b9bfc7'/%3E%3Ccircle cx='26' cy='6' r='5.7' fill='%23a4aab2'/%3E%3Ccircle cx='46' cy='6' r='5.7' fill='%238f959d'/%3E%3Ccircle cx='66' cy='6' r='5.7' fill='%232db84d'/%3E%3Ccircle cx='16' cy='26' r='5.7' fill='%23aeb4bc'/%3E%3Ccircle cx='36' cy='26' r='5.7' fill='%23999fa7'/%3E%3Ccircle cx='56' cy='26' r='5.7' fill='%23848a92'/%3E%3Ccircle cx='76' cy='26' r='5.7' fill='%236f757d'/%3E%3Ccircle cx='6' cy='46' r='5.7' fill='%23b3b9c1'/%3E%3Ccircle cx='26' cy='46' r='5.7' fill='%239ea4ac'/%3E%3Ccircle cx='46' cy='46' r='5.7' fill='%23898f97'/%3E%3Ccircle cx='66' cy='46' r='5.7' fill='%235f656c'/%3E%3C/svg%3E")}
.boot__logo .mark{width:40px;height:24px}
.brand .mark{width:27px;height:16px}

/* ===== animated dot-mark (pilogo) ===== */
.pilogo{display:inline-block;vertical-align:middle;color:#9aa1ac;line-height:0}
.pilogo svg{display:block;height:1em;width:auto;overflow:visible}
.ink-sec .pilogo,.footer .pilogo,.path--dark .pilogo{color:#cdd1d8}
.pilogo .pd{transform-box:fill-box;transform-origin:center;animation:piwave 2.4s ease-in-out infinite;animation-delay:calc(var(--i,0)*.13s)}
.pilogo .pa{transform-box:fill-box;transform-origin:center;animation:papulse 2.4s ease-in-out .5s infinite}
.pilogo .pr{transform-box:fill-box;transform-origin:center;stroke-width:2.4;animation:pring 2.4s ease-out .5s infinite}
@keyframes piwave{0%,58%,100%{opacity:.3}22%{opacity:1}}
@keyframes papulse{0%,100%{transform:scale(1);filter:drop-shadow(0 0 1px rgba(45,184,77,.45))}45%{transform:scale(1.34);filter:drop-shadow(0 0 7px rgba(45,184,77,.95))}}
@keyframes pring{0%{transform:scale(.5);opacity:0}14%{opacity:.85}72%{transform:scale(3.4);opacity:0}100%{opacity:0}}
.pilogo--bullet{font-size:.74em;margin-right:.36em;margin-top:-.06em}
.kicker .pilogo{font-size:13px;margin-right:9px}
@media(prefers-reduced-motion:reduce){.pilogo .pd,.pilogo .pa,.pilogo .pr{animation:none}.pilogo .pd{opacity:.72}}

/* ===== high-end motion layer ===== */
/* masked char-split hero (descender-safe mask) */
.cap--hero h1 .w{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.13em;margin-bottom:-.13em}
.cap--hero h1 .ch{display:inline-block;will-change:transform}
/* nav hides on fast down-scroll, returns on up-scroll */
.nav{transition:background .4s,backdrop-filter .4s,border-color .4s,padding .35s,transform .5s var(--ease)}
.nav.hid{transform:translateY(-110%)}
/* scrub-linked captions are JS-driven; keep GPU hints */
.cap{backface-visibility:hidden}
